PREFS
The PREFS object contains a list of system-wide properties that control the look and feel of Logo. If you SAVE your workspace, the current settings are stored in the saved file. If you load a workspace that has been saved before, the settings are restored.
APPNAME
Contains the name of your Logo app.
Description
APPNAME contains the name of your Logo app if Logo runs in app mode. If Logo does not run in app mode, APPNAME outputs an empty word.
Example
GPROP “PREFS “APPNAME Result:
ARRAYBASE
Controls the lowest array or grid index.
Description
The ARRAYBASE property controls the lowest value that you can use as an array or grid index. You may want to set the value to 1 if you prefer to index arrays and grids with a starting value of 1; actually, any starting value is legal as long as you are comfortable with that value.
Example
GPROP “PREFS “ARRAYBASE Result: 0
AUTOSAVE
Controls the amount of data that Logo saves and restores automatically.
Description
Logo can be configured to save your workspace, your turtles and everything else in frequent intervals. The AUTOSAVE property can be set to one of four values to tell Logo what to save:
OFF : |
Nothing will be saved. |
WORKSPACE : |
Logo saves all procedures, names and property lists. This is the default. |
TURTLES : |
As with WORKSPACE , plus all turtles and the contents of the Graphics panel. |
ALL : |
As with TURTLES , plus the Listener, all controls and bitmaps, and all global built-in names. |
In the Web version, you can also set the AUTOSAVE property with an addition of an “autosave” argument to the link, as in this example:
https://weblogo.terrapinlogo.com?autosave=ALL
This is especially handy for classroom computers where you have a link for students to click.
If Logo is running a Logo app, the setting of this property is ignored. A Logo app never saves any autosave data.
Example
GPROP “PREFS “AUTOSAVE Result: WORKSPACE
CASE
Makes Logo convert its input to upper case or not.
Description
The CASE
property causes Logo to convert all input to upper case if set to TRUE
,
except for words that are enclosed in vertical bars or back quotes. If CASE
is FALSE
,
Logo does not convert any input to upper case. When Logo starts, it sets
CASE
to TRUE. Instead of setting the property CASE
, you can also set
the the global :CASE
variable.
Important: If you set CASE
to FALSE
, all commands must be entered in UPPER CASE!
Also, the case of all names and properties must remain in UPPER CASE!
Example
PPROP “PREFS “CASE FALSE PARSE “lower Result: [lower] make “a 5 Error: make is not a procedure name PPROP “PREFS “CASE TRUE PARSE “lower Result: [LOWER]
COLORED.TURTLES
Displays turtles with their pen color.
Description
Setting the COLORED.TURTLES property to TRUE causes turtles to draw themselves using the current pen color if it is anything else but black.
Example
SETPC “RED ; turtle 0 displays in red
DEBUGGER
Controls the use of the Logo debugger.
Description
The DEBUGGER property controls whether the Logo debugger should be activated in case of a runtime error. If this property is set to TRUE (which is the default), the debugger activates so you can debug the problem. If set to FALSE, Logo prints the runtime error along with a stack trace and returns to toplevel.
FONT
Controls the Listener font.
Description
The FONT property gets or sets the font that the Listener panel uses for output. For the font format, please see the SETFONT command.
Example
GPROP “PREFS “FONT Result: [MONOSPACE 12 0]
CONTROLS.FONT
Controls the font used when creating a control.
Description
The CONTROLS.FONT property gets or sets the font that Logo uses when creating a control. Set this property before creating a control so Logo can pick it up. For the font format, please see the SETFONT command.
Example
GPROP “PREFS “CONTROLS.FONT Result: [HELVETICA 12 0]
TURTLE.FONT
Controls the font used when creating a control.
Description
The TURTLE.FONT property gets or sets the font that turtles use when drawing text. For the font format, please see the SETFONT command.
Example
GPROP “PREFS “TURTLE.FONT Result: [HELVETICA 12 0]
LISTENER.LINES
Controls the maximum number of lines in the Listener panel.
Description
LISTENER.LINES controls the number of lines that the Listener panel’s output field will display. If Logo displays more than the given value, the oldest lines will be lost.
Example
GPROP “PREFS “LISTENER.LINES Result: 100
LISTENER.READONLY
Controls whether all output in the Listener panel is read-only.
Description
LISTENER.READONLY controls whether all output in the Listener panel is read only or not. If output is read only, it cannot be erased; only user input can be edited or erased. Since this is a good setting for students, the property is set to TRUE for all classroom logins with a student password.
Example
GPROP “PREFS “LISTENER.READONLY Result: TRUE
LOCALE
Alters Logo’s language.
Description
This property contains the current language that Logo uses to talk to
you as a three or five-letter ISO code. The actual setting depends on
your browser and system settings. For U.S. computers, the value is, for
example, EN
. Logo speaks a few different languages; you can see if
Logo speaks a specific language by setting the appropriate language
code. If Logo does not speak that language, it falls back to U.S.
English.
Please note that currently only messages are changed. We are working on providing translations for all of Logo including dialogs, menus, and more.
Example
GPROP “PREFS “LOCALE Result: EN
PICTURE.FORMAT
Controls the file extension used for images if none was supplied.
Description
This is the default file extension for graphics images. Logo uses this extension if you access an image file without a specific extension.
Example
GPROP “PREFS “PICTURE.FORMAT Result: PNG
PRECISION
Controls the number of decimals that Logo prints.
Description
PRECISION controls the number of decimal points that Logo outputs when printing a number. The value can be anything between 0 and 15; the value -1 instructs Logo to always print an appropriate number of decimals depending on the value.
Example
GPROP “PREFS “PRECISION Result: 2
PRINT.BITMAPS
Controls the printing of bitmaps and turtles.
Description
PRINT.BITMAPS controls whether the saving or printing of the Graphics panel includes all visible bitmaps and turtles. If set to TRUE (which is the default), all visible bitmaps and turtles are saved or printed as well. Setting this property also changes the setting of the checkbox in the Save Picture and Print Picture dialogs.
Example
GPROP “PREFS “PRINT.BITMAPS Result: TRUE
RELAXED.SYNTAX
Relaxes the syntax requirements of Logo.
Description
If set to TRUE, you do not need to use the colon to read the value of a
name (as in :VALUE
). Logo first checks if a name is a procedure; if
not, and RELAXED.SYNTAX
is set to true, Logo checks if a name has a
value.
Example
GPROP “PREFS “RELAXED.SYNTAX Result: FALSE
STACKSIZE
Controls the maximum number of nested procedure calls.
Description
STACKSIZE controls the maximum number of nested procedure calls. If an executing Logo program calls more than this number of nested procedures, the program terminates with a runtime error.
Example
GPROP “PREFS “STACKSIZE Result: 1000
TAB
Controls the tab stop size used in the Listener’s output field.
Description
TAB controls the tab stop size used in the Listener’s output field. This is the approximate number of spaces that Logo would use when printing the Tab character (which is CHAR 9); see also the PRINT command for a list of special printing characters.
Example
GPROP “PREFS “TAB Result: 4
USERNAME
Reports the user’s name.
Description
This is the name that your Logo license is registered with.
Example
GPROP “PREFS “USERNAME Result: John Doe
LOGO.ENV
This variable contains a property list of global program and system settings. Almost all of its properties are read-only.
BROWSER
Reports the browser name.
Description
BROWSER contains the name of the browser that Logo is executing in. For
the desktop version, BROWSER reports the word DESKTOP
.
Example
GPROP “LOGO.ENV “BROWSER Result: CHROME
ENVIRONMENT
Reports the device that Logo is executing upon.
Description
ENVIRONMENT contains a word describing the browser environment;
currently one of ANDROID
, IOS
, SILK
, MOBILE
or DESKTOP
.
Example
GPROP “LOGO.ENV “ENVIRONMENT Result: DESKTOP
FULLSCREEN
Controls whether to have Terrapin Logo occupy the entire screen or display in normal size.
Description
FULLSCREEN sets Terrapin Logo to fullscreen if its value is set to TRUE, or to normal size if its value is set to FALSE. It reports the current fullscreen setting.
Not all browsers allow a program to occupy the entire screen. In that case, setting the FULLSCREEN property to TRUE does not have any effect.
Also, do not expect any Logo panel to properly report its size immediately after setting the property. The change to fullscreen and back is independent from the execution of a Logo program, and resizing all panels takes some time before Logo is made aware of the changes.
Example
GPROP “LOGO.ENV “FULLSCREEN Result: FALSE
SCREENSIZE
Reports the size of the browser window (Web) or the desktop (Desktop version).
Description
SCREENSIZE reports the size of the browser window (Web) or the desktop (Desktop version) in pixels.
Example
GPROP “LOGO.ENV “SCREENSIZE Result: [1400 700]
VERSION
Reports the Logo version number.
Description
VERSION reports the Logo version number as a numeric value.
Example
GPROP “LOGO.ENV “VERSION Result: 5