The Cuis Cookbook: Difference between revisions
| No edit summary | Ssmith2112 (talk | contribs)  m (Fix typos) | ||
| (19 intermediate revisions by 2 users not shown) | |||
| Line 1: | Line 1: | ||
| A programming language cookbook is something like ''StackOverflow'', without the digging part and the try&pray experience. For a gentle and structured introduction to Cuis-Smalltalk, you should start with the '''The Cuis Book''' and '''Learning-Cuis''' more about this  | A programming language cookbook is something like ''[https://stackoverflow.com/ StackOverflow]'', without the digging part and the try&pray experience. For a gentle and structured introduction to Cuis-Smalltalk, you should start with the '''The Cuis Book''' and '''Learning-Cuis''' more about this in [[CuisCoookBook-References|References]]. This is intended to be a <u>resource for programmers</u>, in the sense that it answers questions that will naturally come up to programmers while exploring Smalltalk.  | ||
| '''Reliability'''. I am writing  | '''Reliability'''. I am writing these notes while learning Cuis. Some of what I write may not be the best way to solve the problem, it may not even be correct. Be patient, double check. Since I use these recipes myself I am going to improve them in time. | ||
| '''Sorting principles'''.  | '''Sorting principles'''. Topic order is intended to go from easy to difficult. From frequently necessary to rarely used. From needed at the beginning of the programming experience to needed by black belts. These three forces, as with the 3 laws of robotics, regulate what chapter goes toward the top of the document. They hold also for sub-chapters and articles. | ||
| '''Contributions'''. I am trying to figure out ways to make contributions possible and fruitful, see [[contributions motivated guidelines]]. As a write I see that [[format guidelines|format guidelines are also important]].   | |||
| '''Contribution'''. If you wish to contribute send me a pull request. | |||
| '''Copyright'''. You have the right to read, print for your own use and contribute to the document. You can make external links to this document. You can not copy the document and make it available somewhere else on the Internet. You can't claim ownership. You can't bring the document to an editor and publish it. I, as the author of more than 99% of the words | '''Copyright'''. You have the right to read, print for your own use, and contribute to the document. You can make external links to this document. You can not copy the document and make it available somewhere else on the Internet. You can't claim ownership. You can't bring the document to an editor and publish it. I, as the author of more than 99% of the words displayed here, retain all rights as well as the right to change these rules. | ||
| * [[Introduction]]. What you should expect from this book and the reason why I am writing it. STARTED. | * [[Introduction]]. What you should expect from this book and the reason why I am writing it. STARTED. | ||
| * [[Why Smalltalk?]]. For what reason should you learn another programming language which is also not so popular | * [[Why Smalltalk?]]. For what reason should you learn another programming language which is also not so popular? Read on, there are very good reasons. STARTED. | ||
| * [[Why Cuis Smalltalk?]] . TODO | |||
| * [[MetaCookbook]]. Collection of things about this document.   | |||
| == Installation and start up == | == Installation and start up == | ||
| * Install and run Cuis in Windows | * Install and run Cuis in Windows | ||
| * Install and run Cuis in  | * Install and run Cuis in MacOS | ||
| * [[Install and run Cuis in Linux]] | * [[Install and run Cuis in Linux]] | ||
| * [[Run Cuis in the Web Browser. (SqueakJS)]] | * [[Run Cuis in the Web Browser. (SqueakJS)]] | ||
| * [[Run Cuis in a ARM platform, RPi, BeagleBone and similar. (Linux)]] | * [[Run Cuis in a ARM platform, RPi, BeagleBone and similar. (Linux)|Run Cuis in an ARM platform, RPi, BeagleBone and similar. (Linux)]] | ||
| * Run Cuis  | * Run Cuis on a remote server. (Linux) | ||
| * Run Cuis on the metal: without Operating System | * Run Cuis on the metal: without an Operating System | ||
| * How to keep Cuis updated | * How to keep Cuis updated | ||
| * [[How to load the most recent changes Juan made to Cuis-Smalltalk-Dev]] | * [[How to load the most recent changes Juan made to Cuis-Smalltalk-Dev]] | ||
| Line 34: | Line 36: | ||
| == Things unique to Cuis and/or Smalltalk == | == Things unique to Cuis and/or Smalltalk == | ||
| Here are all the things that are totally unknown for anybody who never programmed in any Smalltalk. | Here are all the things that are totally unknown for anybody who has never programmed in any Smalltalk. | ||
| * [[How can I make X? Learn to fish in Smalltalk|How can I make X ? Learn to fish in Smalltalk]] | * [[How can I make X? Learn to fish in Smalltalk|How can I make X ? Learn to fish in Smalltalk]] | ||
| Line 45: | Line 47: | ||
| * [[My project needs to add a method to somebody else Class, how do I do it?|My project needs to add a method to somebody else Class, how do I do it ?]] | * [[My project needs to add a method to somebody else Class, how do I do it?|My project needs to add a method to somebody else Class, how do I do it ?]] | ||
| * [[How to use Class variables]]. STARTED | * [[How to use Class variables]]. STARTED | ||
| * [[Learn how to use the Transcript]] . This is really important, | * [[Learn how to use the Transcript]] . This is really important, you should take a peek. | ||
| * [[Tips & tricks]] . Those little keyboard/mouse  | * [[Tips & tricks]] . Those little keyboard/mouse shortcuts or little code snippets that may improve your programmer life. | ||
| * [[Traps and pitfalls for polyglot developers]] . If you know more programming languages this page is for you. | * [[Traps and pitfalls for polyglot developers]] . If you know more programming languages this page is for you. | ||
| * [["It didn't understand" can't happen]]. The end of most of your programmer anxiety. You can understand it all. | * [["It didn't understand" can't happen]]. The end of most of your programmer anxiety. You can understand it all. | ||
| Line 130: | Line 132: | ||
| == Error Handling and the Debugger == | == Error Handling and the Debugger == | ||
| * Call the debugger from a code location | * [[Call the debugger from a code location]] | ||
| * Quick exception handling, equivalent of Python <code>try ... except</code> | * [[Quick exception handling]], equivalent of Python <code>try ... except</code> | ||
| * Assertions | * [[Assertions]] | ||
| * Errors, raise and catch signals | * [[Errors, raise and catch signals]] | ||
| * Case-study-1. '''TODO'''. When the debugger pops up send me an email | * Case-study-1. '''TODO'''. When the debugger pops up send me an email | ||
| * b | * b | ||
| Line 139: | Line 141: | ||
| == Processes == | == Processes == | ||
| * Smalltalk processes are not Unix processes | * [[Smalltalk processes are not Unix processes]] | ||
| * See the list of running processes | * [[See the list of running processes]] | ||
| * Processes 101. Shows how to create a process, name it, start it, stop it and destroy it. | * [[Processes 101]]. Shows how to create a process, name it, start it, stop it and destroy it. | ||
| * Run a new process | * [[Run a new process]] | ||
| * Kill a process | * [[Kill a process]] | ||
| == Uncategorized useful features == | == Uncategorized useful features == | ||
| * Run a method every 2 hours or every day at 15:00, equivalent to Unix cron | * [[Run a method every 2 hours or every day at 15:00]], equivalent to Unix cron | ||
| * Zip and unZip files and directories --- TODO, miss zipping | * [[Zip and unZip files and directories]] --- TODO, miss zipping | ||
| * Convert a file to/from Base64 | * [[Convert a file to/from Base64]] | ||
| * Deal with XML files -- STARTED | * [[Deal with XML files]] -- STARTED | ||
| * About Random | * [[About Random]] | ||
| * How to invoke the garbage collector | * [[How to invoke the garbage collector]] | ||
| * Adapt newline characters to Cuis standard | * [[Adapt newline characters to Cuis standard]] | ||
| * Where to get information about the hardware . Screen size, free memory, cpu speed ... | * [[Where to get information about the hardware]] . Screen size, free memory, cpu speed ... | ||
| * The Dependency Mechanism - part 1. Here we talk about the Smalltalk classic '''Parent''' - '''Dependent''' model. | * [[The Dependency Mechanism - part 1]]. Here we talk about the Smalltalk classic '''Parent''' - '''Dependent''' model. | ||
| * The Dependency Mechanism - part 2. Here we explain the why of a '''Model''' class. | * [[The Dependency Mechanism - part 2]]. Here we explain the why of a '''Model''' class. | ||
| * The Dependency Mechanism - part 3. Here we talk about the '''Observer Pattern'''. (preferred current method in Cuis) | * [[The Dependency Mechanism - part 3]]. Here we talk about the '''Observer Pattern'''. (preferred current method in Cuis) | ||
| * How to use the '''serial port'''. See SerialPort package, it has documentation. | * How to use the '''serial port'''. See [https://github.com/nmingotti/Cuis-Smalltalk-SerialPort SerialPort] package, it has documentation. | ||
| == Run external programs == | == Run external programs == | ||
| If you run Cuis in Linux/Unix,  | If you run Cuis in Linux/Unix, and to some extent also in the Mac, you can use thousands of already written shell programs that solve the most diverse issues. Examples: | ||
| * Do you want to know how much free space is available on the disk? | |||
| ⚫ | |||
| * Run an R script to make a fantastic plot? | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| == Networking and the Web == | == Networking and the Web == | ||
| Line 180: | Line 181: | ||
| * How to ping a computer | * How to ping a computer | ||
| * How to discover the IP of a given host name | * How to discover the IP of a given host name | ||
| * How to get a webpage content | * How to get a webpage's content | ||
| == Databases == | == Databases == | ||
| Line 191: | Line 192: | ||
| This section is about setting Cuis to start up in the way you like it, on any image you may want to boot. | This section is about setting Cuis to start up in the way you like it, on any image you may want to boot. | ||
| * Author name and  | * Author name and initials programmatically | ||
| * Set your preferred font size | * Set your preferred font size | ||
| * Set your user name | * Set your user name | ||
| * Stop the system from asking to save the image on pressing Cuis World->Quit | * Stop the system from asking to save the image on pressing Cuis World->Quit | ||
| * An example of customized Cuis startup Requires only one executable script file ! | * An example of customized Cuis startup Requires only one executable script file ! | ||
| * Do ENV variables  | * Do ENV variables affect Cuis ? | ||
| * How do I pass a string to be executed by Cuis when it boots ? | * How do I pass a string to be executed by Cuis when it boots ? | ||
| * How do I pass a file to be executed by Cuis when it boots ? | * How do I pass a file to be executed by Cuis when it boots ? | ||
| * How to quit Cuis immediately. No  | * How to quit Cuis immediately. No questions asked. | ||
| == Scripting with Cuis == | == Scripting with Cuis == | ||
| Is it possible to make Unix scripts with Cuis? Does it make any sense? This section explores these  | Is it possible to make Unix scripts with Cuis? Does it make any sense? This section explores these subjects. | ||
| * Initial considerations. here | * Initial considerations. here | ||
| = Delivering an application written in Cuis = | = Delivering an application written in Cuis = | ||
| This  | This section explores ways in which you can have other people, non programmers, use your coolest applications. To run the application it may be necessary to: [1] Run VM and an Image [2] Run VM + Image + some code snippet passed as a String [3] Run VM + Image + a script file. | ||
| * Deploy a Cuis application in Linux | * Deploy a Cuis application in Linux | ||
| Line 216: | Line 217: | ||
| * Basic operations with Morphs | * Basic operations with Morphs | ||
| * Kill a Morph . A few ways to | * Kill a Morph . A few ways to destroy a Morph. | ||
| * Place Morphs in World as you wish, automatically | * Place Morphs in World as you wish, automatically | ||
| * Drawing and pictures with the ImageMorph | * Drawing and pictures with the ImageMorph | ||
| Line 223: | Line 224: | ||
| * How to layout the Morphs . This is the basic step to know prodromic to make your own GUI in Cuis. | * How to layout the Morphs . This is the basic step to know prodromic to make your own GUI in Cuis. | ||
| * Fonts - 1. First interactions with Fonts | * Fonts - 1. First interactions with Fonts | ||
| * Basic  | * Basic event handling in Morphic . Here we see how to do something when a mouse button or a key on the keyboard get pressed. | ||
| = The Sound system = | |||
| To some people doing programming is manipulating sounds. As for some other people it is building a nice graphical user interface or some one else does networks services. For this reason the sound system chapter is placed after Morphic.  | |||
| All this chapter requires you to load the sound module.  <syntaxhighlight lang="smalltalk"> | |||
| Feature require: 'Sound'. | |||
| </syntaxhighlight> | |||
| * [[First experiments with sound]] . Collecting knowledge here, when ready will be split into topics | |||
| * [[Play a melody writing a list of note names and their duration]] . Ok for note in the format C,D,E... TODO for notes with Italian names: Do, Re, Mi... | |||
| * TODO. Realtime sound playing. On event play immediately a sound, simulate and instrument typing on your computer keyboard | |||
| * [[Create and play *.wav files]].  | |||
| * [[References to the Sound system]] . for further study | |||
| = Introspection and The compiler = | = Introspection and The compiler = | ||
| These notes are taken reading the wonderful document "The HitchHiker's guide to the Smalltalk Compiler" by Vassili Bykov, here . | |||
| * get the current World object. | * get the current World object. | ||
| Line 238: | Line 251: | ||
| * Building the Virtual Machine | * Building the Virtual Machine | ||
| * Building the  | * Building the VectorGraphics plugin | ||
| * Choosing between FFI and plugin | * Choosing between FFI and plugin | ||
| * Run a script with a proper window title | * Run a script with a proper window title | ||
| Line 244: | Line 257: | ||
| = Applications built on Cuis = | = Applications built on Cuis = | ||
| * DrGeo | * DrGeo.  | ||
| * Borghi DataStreamer.  | |||
| == TODO == | == TODO == | ||
Latest revision as of 14:00, 3 June 2025
A programming language cookbook is something like StackOverflow, without the digging part and the try&pray experience. For a gentle and structured introduction to Cuis-Smalltalk, you should start with the The Cuis Book and Learning-Cuis more about this in References. This is intended to be a resource for programmers, in the sense that it answers questions that will naturally come up to programmers while exploring Smalltalk.
Reliability. I am writing these notes while learning Cuis. Some of what I write may not be the best way to solve the problem, it may not even be correct. Be patient, double check. Since I use these recipes myself I am going to improve them in time.
Sorting principles. Topic order is intended to go from easy to difficult. From frequently necessary to rarely used. From needed at the beginning of the programming experience to needed by black belts. These three forces, as with the 3 laws of robotics, regulate what chapter goes toward the top of the document. They hold also for sub-chapters and articles.
Contributions. I am trying to figure out ways to make contributions possible and fruitful, see contributions motivated guidelines. As a write I see that format guidelines are also important.
Copyright. You have the right to read, print for your own use, and contribute to the document. You can make external links to this document. You can not copy the document and make it available somewhere else on the Internet. You can't claim ownership. You can't bring the document to an editor and publish it. I, as the author of more than 99% of the words displayed here, retain all rights as well as the right to change these rules.
- Introduction. What you should expect from this book and the reason why I am writing it. STARTED.
- Why Smalltalk?. For what reason should you learn another programming language which is also not so popular? Read on, there are very good reasons. STARTED.
- Why Cuis Smalltalk? . TODO
- MetaCookbook. Collection of things about this document.
Installation and start up
- Install and run Cuis in Windows
- Install and run Cuis in MacOS
- Install and run Cuis in Linux
- Run Cuis in the Web Browser. (SqueakJS)
- Run Cuis in an ARM platform, RPi, BeagleBone and similar. (Linux)
- Run Cuis on a remote server. (Linux)
- Run Cuis on the metal: without an Operating System
- How to keep Cuis updated
- How to load the most recent changes Juan made to Cuis-Smalltalk-Dev
Cuis in its environment
- What is a .image file?
- What is a .changes file?
- What is a .user.changes file?
- What is a .log file?
- What is release of the image and VM I am running?
Things unique to Cuis and/or Smalltalk
Here are all the things that are totally unknown for anybody who has never programmed in any Smalltalk.
- How can I make X ? Learn to fish in Smalltalk
- First things first: 1+1 and "Hello World"
- How can I type in a basic object ? Know the literals !
- You want something to get done? Ask an object to do it!
- How do I define a function?
- How do I create my own Class with some methods inside it?
- What is a package? How do I create, load and unload one?
- My project needs to add a method to somebody else Class, how do I do it ?
- How to use Class variables. STARTED
- Learn how to use the Transcript . This is really important, you should take a peek.
- Tips & tricks . Those little keyboard/mouse shortcuts or little code snippets that may improve your programmer life.
- Traps and pitfalls for polyglot developers . If you know more programming languages this page is for you.
- "It didn't understand" can't happen. The end of most of your programmer anxiety. You can understand it all.
About a general Class and Object
- Create automatically all accessors for a Class instance variables
- Change the way an Object is printed
- Find all objects referencing anObject
- Make your own object initialization. All you need to know about new,basicNew,initializeetc. STARTED
- How to dump and restore an Object -- STARTED
- How to manage a Class who should have only one instance
- Discover in what package a Class lives
- Follow step bye how a method call gets resolved. Example-1
Data Structures
- Fundamentals: numbers, strings and symbols
Strings (before default UTF)
- What Strings are made of and how
- String escape
- Automatically escape a complex string
- String formatting with format:
- String formatting with printf:
- A thousand ways to say new line . Newline, to text find it fast
- Trim white chars
- String joining
- String splitting
- String search
- String replace
- Show me the string, but max N. characters
- Dump and restore JSON data strings
- How to hash a string
- Convert to Base64
- Convert strings from/to Utf8
- Remove accents with, 'sarà' asUnaccented . => " 'sara' "
- Convert UTF16 to Latin1. This is quite useful, in Windows-10 UTF16 is called Unicode.
- Jump to the next level of power, use Regex . Last in the list for complexity, but should be first for power, don't overlook this.
Collections
Streams
- Make a stream from a string, for reading.
- Write a long String with a Stream
- Write to stdout in any system. Not only Unix like. Useful for shell programs.
Date and time
- Get the current date and time
- Format date and time as you like most
- Date and time algebra
- Get the current time with the highest precision
- Get date and time as Unix epoch
- Get date and time in a different country
- Measure how much time it takes to run a code block
Files and directories
You should keep in mind that Smalltalk uses files but it is not based on files. I copy here
part of a Juan mail to mailing list: "... The essential idea you need to be aware of when learning about all this is that Smalltalk uses files, but it is not file-based. What this means is that all the tools in the Smalltalk image (with the only exception of FileList and FileContentsBrowser) are NOT showing files, but live objects. The way them relate to files is usually not really important ...".
- How to Read or Write a text file . without Streams, only Strings.
- How to Read or Write a text file with a Stream
- Read a file line by line . Or any general delimiter.
- Find the current directory, list it and move in the directory tree
- Filename extensions: .txt, .csv, .json ...
- Check things on a pathname. Is there anything? Is it a file? Is it writable? ...
- Delete files and directories
- Read/Write a binary file
- Create a new non-existing file name
- Using file locks -- TODO
- Get the list of open files
- Get the directory where a Class (its Package) is stored
- Where is the image file? Where is the VM?
Error Handling and the Debugger
- Call the debugger from a code location
- Quick exception handling, equivalent of Python try ... except
- Assertions
- Errors, raise and catch signals
- Case-study-1. TODO. When the debugger pops up send me an email
- b
Processes
- Smalltalk processes are not Unix processes
- See the list of running processes
- Processes 101. Shows how to create a process, name it, start it, stop it and destroy it.
- Run a new process
- Kill a process
Uncategorized useful features
- Run a method every 2 hours or every day at 15:00, equivalent to Unix cron
- Zip and unZip files and directories --- TODO, miss zipping
- Convert a file to/from Base64
- Deal with XML files -- STARTED
- About Random
- How to invoke the garbage collector
- Adapt newline characters to Cuis standard
- Where to get information about the hardware . Screen size, free memory, cpu speed ...
- The Dependency Mechanism - part 1. Here we talk about the Smalltalk classic Parent - Dependent model.
- The Dependency Mechanism - part 2. Here we explain the why of a Model class.
- The Dependency Mechanism - part 3. Here we talk about the Observer Pattern. (preferred current method in Cuis)
- How to use the serial port. See SerialPort package, it has documentation.
Run external programs
If you run Cuis in Linux/Unix, and to some extent also in the Mac, you can use thousands of already written shell programs that solve the most diverse issues. Examples:
- Do you want to know how much free space is available on the disk?
- How many wireless networks your computer can see?
- Run an R script to make a fantastic plot?
- ... these and thousands of other things are possible once you are able to leverage the power of Unix from Cuis.
You can perform these kind of operations with the module OSProcess included in Cuis or with the external package CommandShell. The second is easier, the first is lower level => more difficult but more flexible.  
- Traps and pitfalls specific to running external programs
- The basics of interacting with Unix . Find this process pid,ARGV,ENV,stdin,stdout,stderr... and all those fundamental things.
- Run a program with OSProcess
- Run a program with CommandShell
Networking and the Web
- How to ping a computer
- How to discover the IP of a given host name
- How to get a webpage's content
Databases
- Talk to PostgreSQL. See the PostgreSQL package, it has documentation.
- Talk to MongoDB
- Talk to SQlite
Scripting Cuis
This section is about setting Cuis to start up in the way you like it, on any image you may want to boot.
- Author name and initials programmatically
- Set your preferred font size
- Set your user name
- Stop the system from asking to save the image on pressing Cuis World->Quit
- An example of customized Cuis startup Requires only one executable script file !
- Do ENV variables affect Cuis ?
- How do I pass a string to be executed by Cuis when it boots ?
- How do I pass a file to be executed by Cuis when it boots ?
- How to quit Cuis immediately. No questions asked.
Scripting with Cuis
Is it possible to make Unix scripts with Cuis? Does it make any sense? This section explores these subjects.
- Initial considerations. here
Delivering an application written in Cuis
This section explores ways in which you can have other people, non programmers, use your coolest applications. To run the application it may be necessary to: [1] Run VM and an Image [2] Run VM + Image + some code snippet passed as a String [3] Run VM + Image + a script file.
- Deploy a Cuis application in Linux
- Deploy a Cuis application in Windows-10
- Deploy a Cuis application in MacOS
Morphic Cookbook
- Basic operations with Morphs
- Kill a Morph . A few ways to destroy a Morph.
- Place Morphs in World as you wish, automatically
- Drawing and pictures with the ImageMorph
- Application. Convert a color image to black and white
- Application. Show contours in an image
- How to layout the Morphs . This is the basic step to know prodromic to make your own GUI in Cuis.
- Fonts - 1. First interactions with Fonts
- Basic event handling in Morphic . Here we see how to do something when a mouse button or a key on the keyboard get pressed.
The Sound system
To some people doing programming is manipulating sounds. As for some other people it is building a nice graphical user interface or some one else does networks services. For this reason the sound system chapter is placed after Morphic.
All this chapter requires you to load the sound module.
Feature require: 'Sound'.
- First experiments with sound . Collecting knowledge here, when ready will be split into topics
- Play a melody writing a list of note names and their duration . Ok for note in the format C,D,E... TODO for notes with Italian names: Do, Re, Mi...
- TODO. Realtime sound playing. On event play immediately a sound, simulate and instrument typing on your computer keyboard
- Create and play *.wav files.
- References to the Sound system . for further study
Introspection and The compiler
These notes are taken reading the wonderful document "The HitchHiker's guide to the Smalltalk Compiler" by Vassili Bykov, here .
- get the current World object.
- what happens when Cuis start up.
- the main loop.
- The Cuis scanner.
- The Cuis parser.
- See the compiled code.
The Virtual Machine
- Building the Virtual Machine
- Building the VectorGraphics plugin
- Choosing between FFI and plugin
- Run a script with a proper window title
Applications built on Cuis
- DrGeo.
- Borghi DataStreamer.
TODO
These are reminders for me about things to do in the Cookbook or in Cuis
- DEV. SpellChecker, for text panes in Cuis. It would be useful to be able to spellcheck comments in code. I like to put comments, without spell checker they are so full of bugs they appear really untrustworthy.
- Video about class variables.
- Page about ';' -- '::' -- 'yourself'.
- Video about installation of Cuis, not so easy the first time
- Video about updating Cuis, not obvious
- Video about using the Transcript efficiently
- Video about creation of a minimal GUI
- Video about creation of a minimal application, runnable from Linux command line
- Video about creation of a minimal application, runnable from Windows GUI
- Video about making Tests, and discovering how to use existing classes with them
- Video-or-page about variables, especially class variables