DDDDD AAAAA EEEEEEE DDDDD AAAAA L U U SSSSS
D D A A E D D A A L U U S S
D D A A E D D A A L U U S
D D AAAAAAA EEEEEE D D AAAAAAA L U U SSSSS
D D A A E D D A A L U U S
D D A A E D D A A L U U S S
DDDDD A A EEEEEEE DDDDD A A LLLLLLL UUUUU SSSSS
** VERSION 3.5 **
This describes the Daedalus scripting language. Daedalus contains its own programming language, which can be used to automate actions, and even design whole games or other programs using Daedalus as a platform. The Macros submenu on the Edit menu allows access to these features. The file is divided into seven sections:
· 1) Glossary of Terms: Definitions of the main terms used in Daedalus scripting.
· 2) Commands: A list of each command and its shortcut, that runs a menu option.
· 3) Operations: A list of each operation, and documentation for it.
· 4) Variables: A list of each variable, and documentation for it.
· 5) Functions: A list of each function, and documentation for it.
· 6) Events: A list of each event, and how it behaves.
· 7) Texture mapping: Documentation of how texture bitmaps display in the perspective inside view.
Command Line: A string of text containing a sequence of actions. Command lines can be stored in macros and script files, and are automatically executed when the macro or script is run. They can also be manually executed by entering one in the Enter Command Line dialog, or specified on the operating system command line when initially launching the program.
Action: An individual instruction that tells Daedalus to run a menu command, set a dialog variable, or even access an extra feature which isn’t available through the standard user interface. An action is one of three things: A command, an operation, or a variable assignment.
Macro: A command line stored in a special place which can be executed at any time. Macros can be manually defined in the Enter Command Line dialog, or automatically defined by command lines. Macros can be manually run by selecting commands on the Run Macro submenus, or automatically run by command lines. Macros can call other macros and run script files. Macros can go 100 nested levels deep before the program will halt them with an error message.
Script: A file containing a sequence of command lines. Running the script executes each command line in sequence. Often a script will define a bunch of macros to act as functions or subroutines in a program. The first line of any script file needs to be the two characters “DS” for Daedalus to consider it as such.
Event: An occurrence in the program which can be made to automatically trigger a macro execution. Events can be manually defined in the Events dialog on the Macro submenu, or automatically defined by command lines.
Command: An action that runs a menu command, and is equivalent to selecting that menu option in the program. Every menu command in the program has a corresponding command action. Commands never take any parameters.
Operation: An action that does some other operation. Operations either duplicate the functionality behind dialogs, or access special “hidden” features only accessible through the scripting language. Operations take zero or more parameters. Note most every dialog has an operation that allows access to its functionality without bringing up the dialog itself. For example, the DlgSize command just brings up the Bitmap Size dialog and does nothing else. The Size operation however takes parameters to specify the new size of the bitmap, and automatically resizes the bitmap without bringing up the dialog.
Variable: A number or string stored somewhere. Each variable may have its value changed by an action. Variable assignments always take one parameter, which is the new value for the variable to have. Variables come in three types: Dialog settings, custom variables, and hidden scripting only variables. Most every dialog setting in the program has a corresponding variable.
Custom Variable: One of a set of generic numeric or string variables, which don’t correspond to any specific program setting, but can be used by scripts and such to store whatever they want. An example is storing your score in a game. Some of the numeric variables are automatically set by the program when it fires an event, and can be considered as parameters to that event macro. Some are automatically queried by the program after an event macro returns, and can be considered as return values from that event. The custom number and string slots start at index #0. Custom numeric variables can be referenced with the @ prefix (e.g. @0 or @999), while custom strings can be referenced with the $ prefix (e.g. $0 or $999). Custom numeric variables #1 through #26 can also be referenced with @a through @z. The strings $a through $z refer to the custom string variables indexed by the corresponding numeric variable, e.g. if @b contains 5, then $b refers to custom string #5.
Parameter: A piece of data passed to an operation or variable assignment. Parameters are one of the following three things: Constants, variables, or functions. Numeric constants are simply numbers, or may have a “#” prefix to indicate hexadecimal format, or a “##” prefix to indicate binary format. String constants are always surrounded by double quotes, single quotes, curly braces, or parentheses. Anything that’s not a constant is considered a variable or function to be queried or evaluated.
Function: A type of parameter, which evaluates to a number. Functions in turn are followed by zero or more parameters. An example is “Add”, which takes two numeric parameters and returns their sum. A function that takes zero parameters and always evaluates to the same thing can be considered a named constant, such as “True” or a specific color like “Red”. Because functions always precede their parameters, expressions in Daedalus are in prefix format, e.g. “Mul Add 1 2 Sub 4 3” expresses “Multiply(Add(1, 2), Subtract(4, 3))” or “(1 + 2) x (4 - 3)”.
Type: The type of data contained in a parameter or variable. All parameters or variables contain either numbers or strings. Numbers are signed 32 bit integers. Boolean values are no different from numbers, where False is represented by 0, and True is represented by 1 or any non-zero number. Colors are simply 24 bit numbers that represent the RGB parts of the color, where the high 8 bits contain the red part, the middle 8 bits contain the green part, and the low 8 bits contain the blue part. File handles are stored in numbers as well. There are no floating point numbers, where dialog variables that take floating point numbers are covered by integers with an assumed decimal point, where the low digits represent the fractional part, e.g. “1.25” in the dialog translates to 125, “2.5” in the dialog translates to 250, and so on.
Most commands which display a single numeric result will set custom variable @z to the value displayed. For example Fill Dead Ends sets @z to the number of dead ends filled. Count Pixels sets @z to the number of on pixels when the main bitmap is active, and to the number of white pixels when the color bitmap is active. Although it doesn’t display anything, Recursive Fractal sets @z to the minimum possible maximum depth for a solution path to the end at any depth.
In the table below, each command has a standard name, which may be referenced case insensitively. Some commands also have a shortcut, which must be referenced case sensitively. A command shortcut name is the only place where case matters in scripting. A command has a shortcut only if it has a keyboard shortcut on the menu. The command shortcut is basically the key you press, where “s” is a prefix for shift, “c” means control, and “a” means alt.
Menu command Command name Shortcut
******************** File Menu ********************
File / Open... DlgOpen o
File / Run Script / Demos Script1 a1
File / Run Script / Word Mazes Script2 a2
File / Run Script / World's Largest Maze Script3 a3
File / Run Script / 4D Mazes Script4 a4
File / Run Script / 5D Mazes Script5 a5
File / Run Script / Dragonslayer Game Script6 a6
File / Run Script / Pac-Man Game Script7 a7
File / Run Script / Sokoban Game Script8 a8
File / Run Script / The Hunger Games Script9 a9
File / Run Script / Survivor Maze #1 Script11 a!
File / Run Script / Survivor Maze #2 Script12 a@
File / Run Script / Survivor Maze #3 Script13 a#
File / Run Script / Survivor Maze #4 Script14 a$
File / Run Script / Survivor Maze #5 Script15 a%
File / Run Script / Survivor Maze #6 Script16 a^
File / Run Script / Survivor Maze #7 Script17 a&
File / Run Script / Survivor Maze #8 Script18 a*
File / Run Script / Survivor Maze #9 Script19 a(
File / Run Script / Survivor Maze #10 Script10 a)
File / Run Script / Carleton Farm Maze #1 Script21 ac1
File / Run Script / Carleton Farm Maze #2 Script22 ac2
File / Run Script / Stocker Farms Maze Script23 ac3
File / Run Script / Glacier Maze Script24 ac4
File / Run Script / Safari Maze Script25 ac5
File / Run Script / Mouse Maze Script26 ac6
File / Run Script / Survivor Squares Game Script27 ac7
File / Run Script / Mandelbrot Set Fractal Script28 ac8
File / Run Script / Pentris Script29 ac9
File / Run Script / Grippy Socks Script30 ac0
File / Run Script / Jareth's Labyrinth Script31 ac!
File / Open Bitmap... DlgOpenBitmap ao
File / Save Bitmap... DlgSaveBitmap w
File / Open Text... DlgOpenText
File / Save Text... DlgSaveText
File / DOS Text / Save Blocks... DlgSaveDOSBlock
File / DOS Text / Save Lines... DlgSaveDOSLine
File / DOS Text / Save Double Lines... DlgSaveDOSLine2
File / X11 Bitmap / Open... DlgOpenX11
File / X11 Bitmap / Save Normal... DlgSaveX11
File / X11 Bitmap / Save Compressed... DlgSaveX11Comp
File / X11 Bitmap / Save Supercompressed... DlgSaveX11Super
File / 3D Bitmap / Open... DlgOpen3D
File / 3D Bitmap / Save Normal... DlgSave3D
File / 3D Bitmap / Save Supercompressed... DlgSave3DSuper
File / Save As Wallpaper / Center Bitmap SaveWallCenter
File / Save As Wallpaper / Tile Bitmap SaveWallTile
File / Save As Wallpaper / Stretch Bitmap SaveWallStretch
File / Save As Wallpaper / Fit Bitmap SaveWallFit
File / Save As Wallpaper / Fill Bitmap SaveWallFill
File / Print... Print
File / Print Setup... PrintSetup
File / File Settings... DlgFile af
File / Open Documentation Documentation )
File / More Help / Open Documentation Documentation )
File / More Help / Open Scripting HelpScript
File / More Help / Open Changes HelpChange
File / More Help / Open License HelpLicense
File / More Help / Open Website Web
File / More Help / Open Website Mirror Web2
File / Setup / Create Program Group (User) SetupUser
File / Setup / Create Program Group (All) SetupAll
File / Setup / Create Desktop Icon SetupDesktop
File / Setup / Install File Extensions SetupExtension
File / Setup / Uninstall File Extensions UnsetupExtension
File / About Daedalus... About a0
File / Exit Exit Esc
******************** Edit Menu ********************
Edit / Repeat Command Repeat ;
Edit / Autorepeat Autorepeat N
Edit / Macros / Enter Command Line... DlgCommand Ent
Edit / Macros / Open Script... DlgOpenScript co
Edit / Macros / Run Macro / Macro 1 Macro1 F1
Edit / Macros / Run Macro / Macro 2 Macro2 F2
Edit / Macros / Run Macro / Macro 3 Macro3 F3
Edit / Macros / Run Macro / Macro 4 Macro4 F4
Edit / Macros / Run Macro / Macro 5 Macro5 F5
Edit / Macros / Run Macro / Macro 6 Macro6 F6
Edit / Macros / Run Macro / Macro 7 Macro7 F7
Edit / Macros / Run Macro / Macro 8 Macro8 F8
Edit / Macros / Run Macro / Macro 9 Macro9 F9
Edit / Macros / Run Macro / Macro 10 Macro10 F10
Edit / Macros / Run Macro / Macro 11 Macro11 F11
Edit / Macros / Run Macro / Macro 12 Macro12 F12
Edit / Macros / Run Macro / Macro 13 Macro13 sF1
Edit / Macros / Run Macro / Macro 14 Macro14 sF2
Edit / Macros / Run Macro / Macro 15 Macro15 sF3
Edit / Macros / Run Macro / Macro 16 Macro16 sF4
Edit / Macros / Run Macro / Macro 17 Macro17 sF5
Edit / Macros / Run Macro / Macro 18 Macro18 sF6
Edit / Macros / Run Macro / Macro 19 Macro19 sF7
Edit / Macros / Run Macro / Macro 20 Macro20 sF8
Edit / Macros / Run Macro / Macro 21 Macro21 sF9
Edit / Macros / Run Macro / Macro 22 Macro22 sF10
Edit / Macros / Run Macro / Macro 23 Macro23 sF11
Edit / Macros / Run Macro / Macro 24 Macro24 sF12
Edit / Macros / Run Macro / Macro 25 Macro25 cF1
Edit / Macros / Run Macro / Macro 26 Macro26 cF2
Edit / Macros / Run Macro / Macro 27 Macro27 cF3
Edit / Macros / Run Macro / Macro 28 Macro28 cF4
Edit / Macros / Run Macro / Macro 29 Macro29 cF5
Edit / Macros / Run Macro / Macro 30 Macro30 cF6
Edit / Macros / Run Macro / Macro 31 Macro31 cF7
Edit / Macros / Run Macro / Macro 32 Macro32 cF8
Edit / Macros / Run Macro / Macro 33 Macro33 cF9
Edit / Macros / Run Macro / Macro 34 Macro34 cF10
Edit / Macros / Run Macro / Macro 35 Macro35 cF11
Edit / Macros / Run Macro / Macro 36 Macro36 cF12
Edit / Macros / Run Macro / Macro 37 Macro37 aF1
Edit / Macros / Run Macro / Macro 38 Macro38 aF2
Edit / Macros / Run Macro / Macro 39 Macro39 aF3
Edit / Macros / Run Macro / Macro 40 Macro40 aF4
Edit / Macros / Run Macro / Macro 41 Macro41 aF5
Edit / Macros / Run Macro / Macro 42 Macro42 aF6
Edit / Macros / Run Macro / Macro 43 Macro43 aF7
Edit / Macros / Run Macro / Macro 44 Macro44 aF8
Edit / Macros / Run Macro / Macro 45 Macro45 aF9
Edit / Macros / Run Macro / Macro 46 Macro46 aF10
Edit / Macros / Run Macro / Macro 47 Macro47 aF11
Edit / Macros / Run Macro / Macro 48 Macro48 aF12
Edit / Macros / Macro Events... DlgEvent
Edit / Copy Bitmap CopyBitmap cc
Edit / Copy Text CopyText
Edit / Paste Paste cv
Edit / Display Settings... DlgDisplay Tab
Edit / Cell Viewport Span / Decrease By 1 Viewport-1 {
Edit / Cell Viewport Span / Increase By 1 Viewport+1 }
Edit / Cell Viewport Span / Decrease By 10 Viewport-10 [
Edit / Cell Viewport Span / Increase By 10 Viewport+10 ]
Edit / Window / Size Window Full Screen WindowFull sTab
Edit / Window / Size Window To Bitmap WindowBitmap
Edit / Window / Size Bitmap To Window SizeWindow
Edit / Window / Update Window Update n
Edit / Window / Redraw Window Redraw Spc
Edit / Window / Scroll Page Up ScrollUp aPgUp
Edit / Window / Scroll Page Down ScrollDown aPgDn
Edit / Window / Scroll To Beginning ScrollHome aHome
Edit / Window / Scroll To End ScrollEnd aEnd
Edit / Set Colors... DlgColors ck
Edit / Ignore Messages IgnoreMessage ?
Edit / Query Timer TimerQuery t
Edit / Reset Timer TimerReset ct
Edit / Pause Timer TimerPause p
Edit / Random Settings... DlgRandom ar
Edit / Randomize Seed Randomize cr
******************** Dot Menu ********************
Dot / Dot Settings... DlgDot v
Dot / Move Dot / Down Left MoveDL 1
Dot / Move Dot / Down MoveD 2
Dot / Move Dot / Down Right MoveDR 3
Dot / Move Dot / Left MoveL 4
Dot / Move Dot / Right MoveR 6
Dot / Move Dot / Up Left MoveUL 7
Dot / Move Dot / Up MoveU 8
Dot / Move Dot / Up Right MoveUR 9
Dot / Move Dot / Raise MoveRaise u
Dot / Move Dot / Lower MoveLower d
Dot / Move Relative / Forward MoveForward cf
Dot / Move Relative / Back MoveBack cb
Dot / Move Relative / Turn Around Around ca
Dot / Move Relative / Left Left l
Dot / Move Relative / Right Right r
Dot / Move Relative / Random MoveRandom 0
Dot / Move Relative / North MoveNorth cn
Dot / Move Relative / South MoveSouth cs
Dot / Move Relative / West MoveWest cw
Dot / Move Relative / East MoveEast ce
Dot / Jump Dot / Down Left JumpDL !
Dot / Jump Dot / Down JumpD @
Dot / Jump Dot / Down Right JumpDR #
Dot / Jump Dot / Left JumpL $
Dot / Jump Dot / Right JumpR ^
Dot / Jump Dot / Up Left JumpUL &
Dot / Jump Dot / Up JumpU *
Dot / Jump Dot / Up Right JumpUR (
Dot / Teleport Dot / UL Corner GoUL c7
Dot / Teleport Dot / UR Corner GoUR c9
Dot / Teleport Dot / LL Corner GoLL c1
Dot / Teleport Dot / LR Corner GoLR c3
Dot / Teleport Dot / Entrance GoEntrance c8
Dot / Teleport Dot / Exit GoExit c2
Dot / Teleport Dot / Left Entrance GoEntrance2 c4
Dot / Teleport Dot / Right Exit GoExit2 c6
Dot / Teleport Dot / Middle GoMiddle c5
Dot / Teleport Dot / Random GoRandom c0
Dot / Teleport Dot / 2nd Dot Go2nd cg
Dot / Show Dot DotShow .
Dot / Walls Impassable DotWall ,
Dot / Move By Two DotTwo e
Dot / Drag Move Dot DotDrag a
Dot / Drag Is Erase DotErase c
Dot / Drag Big Dot DotBig b
Dot / Drag By Two DotDragTwo f
Dot / Set At Dot DotSet h
Dot / Zap Dot / Destroy Wall ZapWall cz
Dot / Zap Dot / Make Wall Semitransparent ZapTrans cx
Dot / Zap Dot / Make Unsemitransparent ZapUntrans cy
Dot / 2nd Dot / Set To Dot 2ndSet g
Dot / 2nd Dot / Draw Line 2ndLine
Dot / 2nd Dot / Draw Block 2ndBlock
Dot / 2nd Dot / Draw Box 2ndBox
Dot / 2nd Dot / Draw Disk 2ndDisk
Dot / 2nd Dot / Draw Circle 2ndCircle
Dot / 2nd Dot / Get Section 2ndGet ag
Dot / 2nd Dot / Put At Dot 2ndPut aG
Dot / 2nd Dot / Put With Or 2ndOr
Dot / 2nd Dot / Put With And 2ndAnd
Dot / 2nd Dot / Put With Xor 2ndXor
Dot / View Inside Inside i
Dot / Map Inside InsideMap :
Dot / Mark 'X' At Dot MarkX x
Dot / Erase 'X' At Dot EraseX y
Dot / Inside Settings... DlgInside q
******************** Bitmap Menu ********************
Bitmap / Size... DlgSize s
Bitmap / Common Sizes / 32 x 16 SizeA cA
Bitmap / Common Sizes / 32 x 32 SizeB cB
Bitmap / Common Sizes / 64 x 32 SizeD cD
Bitmap / Common Sizes / 64 x 48 SizeE cE
Bitmap / Common Sizes / 64 x 64 SizeF cF
Bitmap / Common Sizes / 128 x 64 SizeH cH
Bitmap / Common Sizes / 128 x 96 SizeI cI
Bitmap / Common Sizes / 128 x 128 SizeJ cJ
Bitmap / Common Sizes / 128 x 192 SizeS cS
Bitmap / Common Sizes / 192 x 192 SizeT cT
Bitmap / Common Sizes / 256 x 192 SizeX cX
Bitmap / Common Sizes / 256 x 384 SizeY cY
Bitmap / Common Sizes / 512 x 384 SizeZ cZ
Bitmap / Common Sizes / 512 x 768 Size\ c\
Bitmap / Common Sizes / 1024 x 384 Size] c]
Bitmap / Common Sizes / 1024 x 768 Size! c!
Bitmap / Common Sizes / 1024 x 1024 Size^ c^
Bitmap / Common Sizes / 1024 x 2048 Size# c#
Bitmap / Common Sizes / 2048 x 4096 Size% c%
Bitmap / All / Clear All AllClear Del
Bitmap / All / Set All AllSet sDel
Bitmap / All / Invert All AllInvert cDel
Bitmap / All / Random All AllRandom
Bitmap / Zoom... DlgZoom z
Bitmap / Flip And Rotate / Flip Horizontal FlipHorizontal
Bitmap / Flip And Rotate / Flip Vertical FlipVertical
Bitmap / Flip And Rotate / Transpose Transpose
Bitmap / Flip And Rotate / Rotate Left RotateLeft
Bitmap / Flip And Rotate / Rotate Right RotateRight
Bitmap / Flip And Rotate / Rotate Across RotateAcross
Bitmap / Flip And Rotate / 3D Bitmap... DlgFlip3D
Bitmap / Temp Bitmap / Get TempGet =
Bitmap / Temp Bitmap / Put TempPut +
Bitmap / Temp Bitmap / Swap TempSwap _
Bitmap / Temp Bitmap / Or TempOr
Bitmap / Temp Bitmap / And TempAnd
Bitmap / Temp Bitmap / Xor TempXor
Bitmap / Temp Bitmap / Blend Blend
Bitmap / Temp Bitmap / Tessellate Tessellate
Bitmap / Temp Bitmap / Delete TempDelete
Bitmap / Extra Bitmap / Get ExtraGet \
Bitmap / Extra Bitmap / Put ExtraPut |
Bitmap / Extra Bitmap / Swap ExtraSwap -
Bitmap / Extra Bitmap / Delete ExtraDelete
Bitmap / Collapse To Set CollapseToSet
Bitmap / Smooth Zoomed SmoothZoom
Bitmap / Smooth Corners SmoothCorner
Bitmap / Thicken Thicken
Bitmap / Make Thinner Thinner
Bitmap / Accent Boundaries Accent
Bitmap / Fill At Dot Fill `
Bitmap / Flood At Dot Flood ~
Bitmap / Slide To Dot Slide
Bitmap / Row Column Edits / Insert Column At Dot InsCol
Bitmap / Row Column Edits / Delete Column At Dot DelCol
Bitmap / Row Column Edits / Insert Row At Dot InsRow
Bitmap / Row Column Edits / Delete Row At Dot DelRow
Bitmap / Row Column Edits / Insert Columns At Dots InsCols
Bitmap / Row Column Edits / Delete Columns At Dots DelCols
Bitmap / Row Column Edits / Insert Rows At Dots InsRows
Bitmap / Row Column Edits / Delete Rows At Dots DelRows
Bitmap / Bitmap Is 3D 3DBitmap j
Bitmap / Count Pixels CountPixels ac
******************** Color Menu ********************
Color / Show Color Bitmap ShowColor k
Color / Color Bitmap File / Open Targa... DlgOpenTarga
Color / Color Bitmap File / Save Targa... DlgSaveTarga
Color / Bitmap / Get From Bitmap ColorGet Quo
Color / Bitmap / Put To Bitmap ColorPut
Color / Bitmap / Put To Bitmap (Nearest) ColorNearest
Color / Bitmap / Put To Bitmap (Dither) ColorDither
Color / Bitmap / Or From Bitmap ColorOr
Color / Bitmap / And From Bitmap ColorAnd
Color / Bitmap / Xor From Bitmap ColorXor
Color / Blend From 2 Bitmaps Blend2
Color / Blend From 3 Bitmaps Blend3
Color / Graph Distance GraphDistance
Color / Graph Walls GraphWalls
Color / Antialias From Bitmap / 2x2 Antialias2
Color / Antialias From Bitmap / 3x3 Antialias3
Color / Antialias From Bitmap / 4x4 Antialias4
Color / Antialias From Bitmap / 5x5 Antialias5
Color / Antialias From Bitmap / 6x6 Antialias6
Color / Antialias From Bitmap / 7x7 Antialias7
Color / Antialias From Bitmap / 8x8 Antialias8
Color / Dot Color / Set To Color ColorDotSet
Color / Dot Color / Or With Color ColorDotOr
Color / Dot Color / And With Color ColorDotAnd
Color / Dot Color / Xor With Color ColorDotXor
Color / Dot Color / Add With Color ColorDotAdd
Color / Dot Color / Subtract With Color ColorDotSub
Color / Dot Color / Multiply With Color ColorDotMul
Color / Dot Color / Min With Color ColorDotMin
Color / Dot Color / Max With Color ColorDotMax
Color / Dot Color / Blend With Color ColorDotBlend
Color / Color Bitmap / Add With Temp ColorTempAdd
Color / Color Bitmap / Subtract With Temp ColorTempSub
Color / Color Bitmap / Alpha With Temp ColorTempAlpha
Color / Color Bitmap / Delete ColorDelete
Color / Make Grayscale ColorGrayscale
Color / Apply Texture / Background TextureBack
Color / Apply Texture / Color Walls TextureColor
Color / Apply Texture / Overlay Walls TextureOverlay
Color / Apply Texture / Color Overlay Walls TextureWall
Color / Apply Texture / Color Ground TextureColorG
Color / Apply Texture / Overlay Ground TextureOverlayG
Color / Apply Texture / Color Overlay Ground TextureGround
Color / Apply Texture / Color Blocks TextureColorB
Color / Apply Texture / Overlay Blocks TextureOverlayB
Color / Apply Texture / Color Overlay Blocks TextureBlock
Color / Apply Texture / Ceiling TextureCeiling
Color / Apply Texture / Variable Height Wall WallVariable
Color / Apply Texture / Ground Elevation GroundVariable
Color / Apply Texture / Delete TextureDelete
Color / Brightness... DlgBrightness aK
Color / Replace Color... DlgReplace ak
******************** Maze Menu ********************
Maze / Maze Size... DlgMazeSize m
Maze / Zoom Bias... DlgBias az
Maze / Add / Add Entrance AddEntrance
Maze / Add / Add Exit AddExit
Maze / Add / Add Passage AddPassage <
Maze / Add / Add Wall AddWall >
Maze / Remove / Crack Isolations NoIsolation
Maze / Remove / Connect Detachments NoDetachment
Maze / Remove / Crack Dead Ends NoDeadEnd
Maze / Remove / Seal Entrances NoEntrance
Maze / Remove / Connect Poles ConnectPole
Maze / Remove / Remove Poles NoPole
Maze / Remove / Crack Cells NoCell
Maze / Remove / Crack Blind Alley Cells NoBlindAlley
Maze / Remove / Fill Passages NoPassage
Maze / Remove / Fill Open Cells NoRoom
Maze / Remove / Remove Boundary NoBoundary
Maze / Remove / Remove Tubes NoTube
Maze / Normalize / Add Passages NormalizePassage
Maze / Normalize / Add Walls NormalizeWall
Maze / Normalize / Erase Bottom Right NoBottomRight '
Maze / Make Symmetric Symmetric
Maze / Expand Set ExpandSet
Maze / Room Thinned RoomThinned
Maze / Tweak Endpoints TweakEndpoint E
Maze / Tweak Passages TweakPassage H
Maze / Weave To 3D Weave3D
Maze / Weave To Inside WeaveInside
Maze / Clarify Weave ClarifyWeave
Maze / Clarify 3D Clarify3D
Maze / Clarify 4D Clarify4D
Maze / Count Possible CountPossible
Maze / Analyze Passages AnalyzePassage ap
Maze / Analyze Walls AnalyzeWall aP
Maze / Maze Settings... DlgMaze cm
******************** Create Menu ********************
Create / Perfect Perfect P
Create / Braid Braid B
Create / Unicursal Unicursal U
Create / More Perfect / Recursive Backtrack Recursive ab
Create / More Perfect / Prim's Algorithm Prim am
Create / More Perfect / True Prim's Prim2 aM
Create / More Perfect / Kruskal's Algorithm Kruskal al
Create / More Perfect / Aldous-Broder AldousBroder aa
Create / More Perfect / Wilson's Algorithm Wilson aw
Create / More Perfect / Eller's Algorithm Eller ae
Create / More Perfect / Growing Tree Tree T
Create / More Perfect / Growing Forest Forest aT
Create / More Perfect / Recursive Division Division aj
Create / More Perfect / Binary Tree Binary ay
Create / More Perfect / Sidewinder Sidewinder as
Create / More Perfect / Hunt And Kill Perfect P
Create / More Perfect / Random Perfect Random an
Create / Pattern / Spiral Spiral S
Create / Pattern / Diagonal Diagonal D
Create / Pattern / Segment Segment L
Create / Pattern / Nested Fractal Fractal O
Create / Pattern / Hilbert Curve Hilbert aH
Create / 3D / Weave Weave V
Create / 3D / 3D 3D Q
Create / 3D / 4D 4D R
Create / 3D / Planair Planair J
Create / 3D / Hyper Hyper ah
Create / Crack Crack K
Create / Cavern Cavern av
Create / Arrow Arrow A
Create / Tilt Tilt at
Create / Recursive Fractal Fractal2 ax
Create / Infinite / Start InfiniteStart ai
Create / Infinite / Continue Infinite I
Create / Infinite / End InfiniteEnd aI
Create / Infinite / Restart InfiniteRestart
Create / Omega (Shapes) / Gamma (Square) Gamma aq
Create / Omega (Shapes) / Theta (Circle) Theta W
Create / Omega (Shapes) / Delta (Triangle) Delta Y
Create / Omega (Shapes) / Sigma (Hexagon) Sigma X
Create / Omega (Shapes) / Upsilon (Octagon) Upsilon au
Create / Omega (Shapes) / Omicron (Sphere) Omicron
Create / Omega (Shapes) / Zeta (8 Way) Zeta Z
Create / Labyrinth / Current Labyrinth Labyrinth C
Create / Labyrinth / Labyrinth Settings... DlgLabyrinth cl
Create / Labyrinth / Classical Classical
Create / Labyrinth / Chartres Chartres
Create / Labyrinth / Cretan Cretan
Create / Labyrinth / Man In The Maze ManInTheMaze
Create / Labyrinth / Flat Classical FlatClassical
Create / Labyrinth / Flat Chartres FlatChartres
Create / Labyrinth / Chartres Replica ChartresReplica
Create / Labyrinth / Custom Custom
Create / Partial Create / Perfect At Dot PartialPerfect cP
Create / Partial Create / Braid Add Walls PartialBraid aB
Create / Partial Create / Unicursal Thinned PartialUnicursal cU
Create / Partial Create / Recursive At Dot PartialRecursive
Create / Partial Create / Prim's At Dot PartialPrim
Create / Partial Create / Kruskal Passages PartialKruskal
Create / Partial Create / Tree At Dot PartialTree
Create / Partial Create / Weave At Dot PartialWeave cV
Create / Partial Create / Crack Add Walls PartialCrack cK
Create / Partial Create / Cavern At Dot PartialCavern
Create / Partial Create / Zeta At Dot PartialZeta
Create / Polished Mazes Polish /
Create / Create Settings... DlgCreate M
******************** Solve Menu ********************
Solve / Fill Dead Ends DeadEnd F
Solve / Fill Cul-De-Sacs CulDeSac
Solve / Fill Blind Alleys BlindAlley
Solve / Fill Collisions Collision
Solve / Find A Path SolveRecursive
Solve / Find Shortest Path Shortest
Solve / Find Shortest Paths Shortests
Solve / Wall Follow / Follow Wall Left FollowLeft
Solve / Wall Follow / Follow Wall Right FollowRight
Solve / Wall Follow / Pledge Algorithm Left PledgeLeft
Solve / Wall Follow / Pledge Algorithm Right PledgeRight
Solve / Wall Follow / Chain Algorithm Chain
Solve / 3D / Fill Weave Dead Ends DeadEndWeave
Solve / 3D / Fill 4D Dead Ends DeadEnd4D
Solve / 3D / Fill Hyper Dead Ends SolveHyper
Solve / 3D / Find Recursive Fractal SolveFractal2
Solve / Tremaux's Algorithm Tremaux
Solve / Mark Dead Ends MarkDeadEnd G
Solve / Mark Cul-De-Sacs MarkCulDeSac
Solve / Mark Blind Alleys MarkBlindAlley
Solve / Mark Collisions MarkCollision
Solve / Fill Single Dead Ends FillDeadEnd
Solve / Show Bottlenecks Bottleneck
Solve / Flood Passages FloodPassage
Solve / Flood Walls Left FloodWallLeft
Solve / Flood Walls Right FloodWallRight
******************** Draw Menu ********************
Draw / Draw Settings... DlgDraw ad
Draw / Obscure Draw Settings... DlgDraw2 aD
Draw / Render Bitmap Overview Overview
Draw / Render Pyramid Pyramid
Draw / Life Generate Life aL
Draw / Open Wireframe... DlgOpenWire
Draw / Save Wireframe... DlgSaveWire
Draw / Wireframe File / Save Picture... DlgSavePicture
Draw / Wireframe File / Copy Picture CopyPicture
Draw / Wireframe File / Save Vector... DlgSaveVector
Draw / Make Wireframe Bitmap Overview MakeWire
Draw / Render Wireframe Perspective WirePerspective
Draw / Render Wireframe Aerial Aerial
Draw / Open Patches... DlgOpenPatch
Draw / Save Patches... DlgSavePatch
Draw / Make Patch Bitmap Overview MakePatch
Draw / Render Patch Perspective PatchPerspective
Draw / Convert Patches To Wireframe PatchToWire
Some operations take string parameters that are considered formatted strings. A formatted string is first evaluated before being used, where certain character sequences in it get translated to other things. When a string is formatted, “\n” becomes a line break, “\r” becomes a carriage return, “\t” becomes a tab, and “\s” becomes a space. The sequence “@x” where “x” is a letter from a-z or a number expands to the number contained in that custom variable. The sequence “$#” where “#” is a number expands to the string contained in that custom variable, while the sequence “$x” where “x” is a letter from a-z expands to the custom string indexed by custom variable @x. Finally, “\\” reduces to a single “\”, “@@” reduces to a single “@”, and “$$” reduces to a single “$”.
******************** Dialog and file operations ********************
Open <file>: Opens the file in the string <file>, regardless of its type. This accesses the functionality of the “Open...” command without bringing up a dialog.
OpenBitmap <file>: Opens the Windows bitmap file in the string <file>. This accesses the functionality of the “Open Bitmap...” command without bringing up a dialog.
OpenText <file>: Opens the text file in the string <file> into the main monochrome bitmap. This accesses the functionality of the “Open Text...” command without bringing up a dialog.
OpenX11 <file>: Opens the X11 bitmap in the string <file> into the main monochrome bitmap. This accesses the functionality of the “X11 Bitmap / Open...” command without bringing up a dialog.
Open3D <file>: Opens the Daedalus 3D bitmap in the string <file> into the main monochrome bitmap. This accesses the functionality of the “3D Bitmap / Open...” command without bringing up a dialog.
OpenDB <file>: Opens the Daedalus bitmap in the string <file>. Daedalus bitmaps are created with the SaveDB operation.
OpenScript <file>: Opens and runs the Daedalus script in the string <file>. This accesses the functionality of the “Open Script...” command without bringing up a dialog.
OpenScript2 <file>: Opens and runs the Daedalus script in the string <file>, and stops executing any command lines in progress. This accesses the functionality of the “Open Script...” command without bringing up a dialog, but allows opening a new script that may replace macros within an existing script, in a way that prevents the state of the old script interfering.
OpenTarga <file>: Opens the Targa bitmap in the string <file> into the color bitmap. This accesses the functionality of the “Color Targa File / Open...” command without bringing up a dialog.
OpenPaint <file>: Opens the Paint bitmap file in the string <file> into the color bitmap. This accesses the functionality of the DlgOpenPaint operation command without bringing up a dialog.
OpenWire <file>: Opens the Daedalus wireframe file in the string <file>. This accesses the functionality of the “Open Wireframe...” command without bringing up a dialog.
OpenPatch <file>: Opens the Daedalus patch file in the string <file>. This accesses the functionality of the “Open Patches...” command without bringing up a dialog.
DlgOpenDB: Brings up a dialog allowing one to select a file, and then loads that file as a Daedalus bitmap.
DlgOpenPaint: Brings up a dialog allowing one to select a file, and then loads that file as a 256 color Paint bitmap file (.PCX extension) into the color bitmap. This can be used to import the PCX format screenshots generated by certain games into the program.
EmbedX11: This is like OpenX11 except the X11 bitmap is embedded in the current Daedalus script file instead of in a separate file. This allows loading a monochrome bitmap within a script without having to have it in a separate file. Starting with the next line following this operation in the script file, should be the text of an X11 bitmap, which will be loaded as if it were in a separate file. Afterward the script file will continue executing at the line following the bitmap text. This should only be run inside a script. If this is run outside a script, it will behave like the DlgOpenX11 command and the user will be prompted for a file.
Embed3D: This is like EmbedX11 except a Daedalus 3D file embedded in the current script will be loaded.
EmbedDW: This is like EmbedX11 except a Daedalus wireframe file embedded in the current script will be loaded.
EmbedDP: This is like EmbedX11 except a Daedalus patch file embedded in the current script will be loaded.
EmbedDB: This is like EmbedX11 except a Daedalus bitmap file embedded in the current script will be loaded.
SaveBitmap <file>: Saves the active bitmap to a Windows bitmap file in the string <file>. This accesses the functionality of the “Save Bitmap...” command without bringing up a dialog.
SaveText <file>: Saves the main monochrome bitmap to a text file in the string <file>. This accesses the functionality of the “Save Text...” command without bringing up a dialog.
SaveDOSBlock <file>: Saves the main monochrome bitmap to a DOS block character text file in the string <file>. This accesses the functionality of the “DOS Text / Save Blocks...” command without bringing up a dialog.
SaveDOSLine <file>: Saves the main monochrome bitmap to a DOS line character text file in the string <file>. This accesses the functionality of the “DOS Text / Save Lines...” command without bringing up a dialog.
SaveDOSLine2 <file>: Saves the main monochrome bitmap to a DOS double line character text file in the string <file>. This accesses the functionality of the “DOS Text / Save Double Lines...” command without bringing up a dialog.
SaveX11 <file>: Saves the main monochrome bitmap to an X11 bitmap in the string <file>. This accesses the functionality of the “X11 Bitmap / Save Normal...” command without bringing up a dialog.
SaveX11Comp <file>: Saves the main monochrome bitmap to a compressed X11 bitmap in the string <file>. This accesses the functionality of the “X11 Bitmap / Save Compressed...” command without bringing up a dialog.
SaveX11Super <file>: Saves the main monochrome bitmap to a supercompressed X11 bitmap in the string <file>. This accesses the functionality of the “X11 Bitmap / Save Supercompressed...” command without bringing up a dialog.
Save3D <file>: Saves the 3D bitmap in the main bitmap to a Daedalus 3D bitmap in the string <file>. This accesses the functionality of the “3D Bitmap / Save Normal...” command without bringing up a dialog.
Save3DComp <file>: Saves the 3D bitmap in the main bitmap to a compressed Daedalus 3D bitmap in the string <file>, where each character in the file covers four pixels.
Save3DSuper <file>: Saves the 3D bitmap in the main bitmap to a supercompressed Daedalus 3D bitmap in the string <file>. This accesses the functionality of the “3D Bitmap / Save Supercompressed...” command without bringing up a dialog.
SaveDB <file>: Saves the active bitmap to a Daedalus bitmap in the string <file>. Daedalus bitmaps are a custom format which stores bitmaps using only ASCII characters, and have some compression too.
SaveTarga <file>: Saves the color bitmap to a Targa bitmap in the string <file>. This accesses the functionality of the “Color Targa File / Save...” command without bringing up a dialog.
SaveWire <file>: Saves the wireframe data in memory to a Daedalus wireframe file in the string <file>. This accesses the functionality of the “Save Wireframe...” command without bringing up a dialog.
SavePatch <file>: Saves the patch data in memory to a Daedalus patch file in the string <file>. This accesses the functionality of the “Save Patches...” command without bringing up a dialog.
SavePicture <file>: Saves the wireframe image in memory to a Windows metafile in the string <file>. This accesses the functionality of the “Draw / Wireframe File / Save Metafile...” command without bringing up a dialog.
SaveVector <file>: Saves the wireframe data in memory to a Scalable Vector Graphics (SVG) format file in the string <file>. This accesses the functionality of the “Draw / Wireframe File / Save Vector...” command without bringing up a dialog.
SaveSolids <file>: Generates the “solids.dp” file that’s part of the Daedalus distribution, and saves it to a file. This doesn’t ever need to be run in a standard install, because that file has already been generated.
Size <x> <y> <flag1> <flag2>: Resizes the main monochrome bitmap. This accesses the functionality of the “Size...” command when operating on a monochrome bitmap without bringing up the dialog. If <flag1> is false, this does “Set Lower Right Bound”, if true this does “Shift Down And Right By”. If <flag2> is true, the bitmap is cleared after being resized.
SizeC <x> <y> <flag1> <flag2>: Like the Size operation but resizes the main color bitmap. This accesses the functionality of the “Size...” command when operating on a color bitmap without bringing up the dialog. If <flag1> is false this does “Set Lower Right Bound”, and if true this does “Shift Down And Right By”. If <flag2> is true, the bitmap is set to black after being resized.
Zoom <x> <y> <flag> <num>: Zooms the active bitmap. This accesses the functionality of the “Zoom...” command without bringing up the dialog. If <flag> is false, this does “Zoom By Factor”, if true this does “Zoom To Size”. If <num> is 0 this does “Drop Lines When Shrinking”, if 1 this does “Preserve On When Shrinking”, if 2 this does “Tessellate Instead Of Zoom”.
Flip3D <num1> <num2>: Flips or rotates the 3D bitmap in the active bitmap. This accesses the functionality of the “Flip And Rotate / 3D Bitmap...” command without bringing up the dialog. If <num1> is 0 this affects the X axis, if 1 this affects the Y axis, if 2 this affects the Z axis. If <num2> is 0 this does “Flip”, if 1 this does “Rotate Left Or Forward”, if 2 this does “Rotate Right Or Forward”, if 3 this does “Rotate Across”.
MazeSize <x> <y> <flags>: Resizes the Maze in the main monochrome bitmap. This accesses the functionality of the “Maze Size...” command without bringing up the dialog. If <flags> is 2 or more, the bitmap will have odd dimensions and not have a blank row and column of pixels at the right and bottom edges. If <flags> is odd, the Maze bitmap is cleared after being resized.
MazeSizeC <x> <y> <flags>: Like the MazeSize operation but resizes the Maze in the main color bitmap. This accesses the functionality of the “Maze Size...” command when operating on a color bitmap without bringing up the dialog. If <flags> is 2 or more, the bitmap will have odd dimensions and not have a blank row and column of pixels at the right and bottom edges. If <flags> is odd, the Maze bitmap is cleared after being resized.
Bias <x0> <x1> <y0> <y1>: Zooms the main monochrome or color bitmap with different magnifications applied to even and odd coordinate pixels. This accesses the functionality of the “Zoom Bias...” command without bringing up the dialog.
Replace <color1> <color2> <flag>: Replaces all instances of <color1> with <color2> in the color bitmap. This accesses the functionality of the “Replace Color...” command without bringing up the dialog. The colors in <color1> and <color2> may be 24 bit color numbers or strings, where <color2> may be a pattern string. If <flag> is true, the colors are swapped instead of one replaced with the other.
Brightness <num1> <num2>: Changes the brightness of the pixels in the color bitmap, or does some other bitmap transformation. This accesses the functionality of the “Brightness...” command without bringing up the dialog. The brightness number is in <num1>. If <num2> is 0 this does “Brighten All By Factor”, if 1 this does “Brighten All By Offset”, if 2 this does “Brighten All By Multiplier”, if 3 this does “Limit Brightness To Value”, if 4 this does “Rotate All By Degree”, and if 5 this does “Twist Middle By Degree”.
******************** Control flow operations ********************
If <flag> <string>: If <flag> is true, <string> gets executed as a command line. Like the “if” statement in C.
IfElse <flag> <string1> <string2>: If <flag> is true, <string1> gets executed as a command line, otherwise <string2> gets executed as a command line. Like the “if / else” statement in C.
SwitchSgn <num> <string1> <string2> <string3>: If <num> is negative, <string1> gets executed as a command line. If <num> is 0, <string2> gets executed as a command line. If <num> is positive, <string3> gets executed as a command line.
DoCount <num> <string>: Executes <string> as a command line <num> times.
While <string1> <string2>: Evaluates <string1> as an expression. If true, executes <string2> as a command line, then repeats. Keeps reevaluating and executing until the expression is no longer true. Warning: Operations like “While True {}” will run forever and hang the program! Like the “while” statement in C.
DoWhile <string1> <string2>: Executes <string2> as a command line, then evaluates <string1> as an expression. If true, then executes and evaluates again, where this repeats until the expression is no longer true. Like the “do / while” statement in C.
For <var> <num1> <num2> <string>: Sets the custom variable indicated by <var> to <num1>. While the variable less than or equal to <num2>, execute <string> as a command line, then increment the variable. If <var> is a number it indicates the index of the custom variable, else if <var> is a string (e.g. “a”) it indicates the custom variable directly. In most cases one wants to specify the variable as a string like “a” instead of a number like @a. The former makes @a itself loop, while the latter makes the custom variable pointed to by the value of @a loop. Similar to the “for” loop in various languages.
ForStep <var> <num1> <num2> <num3> <string>: Like the For operation except the variable gets <num3> added to it each iteration, instead of just being incremented. The loop exits when the variable is no longer between <num1> and <num2>.
//: Comment. Stops executing the current command line. Since the rest of the command line always gets skipped, this causes the rest of the command line to act as a comment. Like the “//” comment token in C.
Continue: Stops executing the current command line, and also stops executing the surrounding command line. If the surrounding command line is part of a loop, the loop’s next iteration will begin. Like the “continue” statement in C.
Break: Stops executing the current command line, and also stops executing the surrounding command line. If the surrounding command line is part of a loop, the loop operation will immediately terminate. If this operation appears at the top level in a script file, the remaining lines in the script will be skipped. This is most often used to break out of one of the above looping operations. Like the “break” statement in C.
Return: Stops executing the current command line, and also stops executing any number of surrounding command lines within the current macro, returning control to the macro’s caller. Behaves like Halt if not within a macro. Like the “return” statement in C.
Halt: Stops executing the current command line, and also completely stops executing any number of surrounding command lines or loops, including remaining lines in a script file. Like the “end” command in BASIC.
Restart: Stops executing the current command line, then starts executing it from the beginning again. This will cause an infinite loop unless some other operation breaks out of the command line.
Do <string>: Simply executes <string> as a command line once. Useful if a command line is stored in a custom string instead of a macro.
DoWait <string>: Like the Do operation except the mouse pointer will be set to the wait or hourglass icon until the command line finishes. Useful for indicating slow operations within a script.
******************** Daedalus specific operations ********************
DefineMacro <num> <string1> <string2>: Sets macro number <num> to be <string1>. If <num> is between 1 and 48, the appropriate command on the Run Macro submenu will have its menu text set to <string2>. This accesses the functionality of the Define Macro button in the “Enter Command Line...” command without bringing up the dialog.
Macro <num>: Runs macro number <num>. Note the first 48 macros, since they exist on menus, also have commands which can run them directly.
EmbedMacro <num> <string>: Similar to DefineMacro, this sets macro number <num>. If <num> is between 1 and 48, the appropriate command on the Run Macro submenu will have its menu text set to <string>. The actual macro text will be embedded in the current Daedalus script file in the following lines, up until the next blank line. That allows a long macro to be spread across multiple lines, which is more readable. Within each line, leading spaces will be removed, so indenting can be applied without making the macro itself any longer. You can also embed comments, in which lines whose first non-whitespace is “//” will be ignored. This should only be run inside a script, and will do nothing outside that context.
Embed: Similar to EmbedMacro, this allows a command line to be spread over multiple lines. The actual command line will be embedded in the current Daedalus script file in the following lines, up until the next blank line. That allows a long command line be spread across multiple lines, which is more readable. Within each line, leading spaces will be removed, so indenting can be applied without making the macro itself any longer. This should only be run inside a script, and will do nothing outside that context.
DefineConst <string>: Defines a sequence of named numeric constants. Parameter <string> is a space separated list of names. Each name will be assigned to the next number in sequence, starting with 0. For example, “DefineConst ‘Cat Dog Horse’” will set Cat to 0, Dog to 1, and Horse to 2. If a token is a number, it will instead set the constant to assign to the next name. If a number is prefixed with “+” or “-”, the number instead of being incremented by one will be adjusted by the specified offset. For example, “DefineConst ‘Cat 10 Dog +5 Horse’” will set Cat to 0, Dog to 10, and Horse to 15.
Afterward macros can reference these constants by name with the “%” prefix. For example, after the above the parameter “%Dog” will be the constant value 10. Similarly, “@Dog” will contain the value within custom variable number 10, and “$Dog” will contain the value within custom string 10, which allows named numeric and string variables. Finally “*Dog” as an action will call macro 10, which allows named functions. Having “*Dog” in a parameter context will call the function and return whatever’s in @z. After DefineConst is invoked, @z will contain whether the operation failed for any reason, such as having duplicate names anywhere in the list. A script can call DefineConst at the beginning to name macros and variables, and then halt if there were any errors.
ClearEvents: Resets all macro events to 0. This means all fields in the Macro Events dialog and includes all hidden scripting only macro events.
SetVar <var> <num>: Sets custom variable <var> to value <num>. If <var> is a number it indicates the index of the custom variable, else if <var> is a string (e.g. “a”) it indicates the custom variable directly.
SetVars <var> <num> <string>: Sets a range of custom variables to a set of constants. This sets <num> variables starting with custom variable <var>. There should be <num> values contained in <string>, separated with spaces. Each value may be a numeric or color constant, or a custom variable reference like “@a”.
SwapVar <var1> <var2>: Swaps custom variables <var1> and <var2>.
Local <string>: Stores a copy of the custom numeric variables listed in <string>. The characters in <string> should range from a-z. When the current command line is finished, the saved values will be restored to the variables in question. This operation works properly when nested, and allows complicated scripts to have what amounts to local variables which can be changed within a context but don’t affect the values of those variables used in outer contexts.
SetString <var> <format>: Sets custom string <var> to formatted string <format>. If <var> is a number it indicates the index of the custom string, else if <var> is a string (e.g. “a”) it corresponds to a custom string directly.
SetStrings <var> <num> <string>: Sets a range of custom strings to a set of constant strings. The first character in <string> indicates a separator character, where there should be <num> strings contained in <string>, separated by this character.
SwapString <var1> <var2>: Swaps custom strings <var1> and <var2>.
AppendString <var> <string>: Appends <string> to custom string <var>. If <var> is a number it indicates the index of the custom string, else if <var> is a string (e.g. “a”) it indicates the custom string directly.
SetChar <var> <num> <char>: Sets character number <num> in custom string <var> to value <char>. Strings start at character 0. This does nothing if the custom string is empty or <num> is beyond the end of the string. If <char> is a number it indicates the ASCII value of the new character, else if <char> is a string (e.g. “!”) it indicates the character directly.
SetStringNum <var> <num> <digits>: Sets custom string <var> to a string containing the number <num>. If <num> contains fewer than <digits> digits, it will be prefixed with “0” characters. If you don’t want leading zeros, it’s easier to use SetString and let it expand custom numeric variables in the formatted string. If <var> is a number it indicates the index of the custom string, else if <var> is a string (e.g. “a”) it corresponds to a custom string directly.
SetStringReal <var> <num> <digits>: Sets custom string <var> to a string containing a floating point number represented by <num>. There will be <digits> digits to the right of the decimal point, or in other words this outputs <num> with a decimal point <digits> places from the right end. If <var> is a number it indicates the index of the custom string, else if <var> is a string (e.g. “a”) it corresponds to a custom string directly.
CopyMask <num1> <num2>: Copies monochrome bitmap <num1> to bitmap <num2>. Bitmaps 0 and beyond indicate custom texture mask bitmaps. Also bitmap -1 is the main bitmap, bitmap -2 is the temporary bitmap, and bitmap -3 is the extra bitmap.
SwapMask <num1> <num2>: Swaps monochrome bitmaps <num1> and <num2>. Note the main bitmap always exists, so it’s not allowed to be swapped with a bitmap that’s empty.
DeleteMask <num>: Deletes monochrome bitmap <num>. Note the main bitmap always exists, so it’s not allowed to be deleted.
CopyTexture <num1> <num2>: Copies color bitmap <num1> to bitmap <num2>. Bitmaps 0 and beyond indicate custom texture bitmaps. Also bitmap -1 is the main color bitmap, bitmap -2 is the temporary color bitmap, and bitmap -3 is the extra color bitmap. Bitmap -4 contains the scene most recently displayed as the perspective inside view, and bitmap -5 contains the rainbow sprite most recently displayed over the perspective inside view.
SwapTexture <num1> <num2>: Swaps color bitmaps <num1> and <num2>.
DeleteTexture <num>: Deletes color bitmap <num>.
MoveCloud <cloud> <distance>: Moves one or more clouds horizontally in the perspective inside view. The <cloud> parameter is the index of the cloud to move, where if invalid (e.g. negative) all clouds will be moved. The <distance> parameter is the offset to move the cloud(s) to the right. Clouds can have 16384 different positions, where the offset may range from -16383 to 16383. If the distance is invalid (i.e. a large positive or negative number) then the cloud(s) will be moved proportionally based on their index, with farther or lower index clouds moving slower.
Message <format>: Displays a message box containing formatted string <format>, and pauses until the user clicks OK.
MessageAsk <format> <num>: Displays a message box of type <num> containing formatted sting <format>, and pauses until the user clicks a button in it. Parameter <num> should contain a number from 0-5, where message box type 0 contains the button OK, type 1 contains OK and Cancel buttons, type 2 contains Retry and Cancel, type 3 contains Yes and No, type 4 contains Yes and No and Cancel, and type 5 contains Abort and Retry and Ignore. Afterward @z contains the button clicked, where 1 means OK or Yes or Retry was clicked, 0 means No or Ignore, and -1 means Cancel or Abort.
MessageInside <format> <num>: Displays formatted string <format> as a line of text in the perspective inside view, in the same font used for the Compass and Cell Location. The text is horizontally centered at row <num>. Row 0 is considered the top of the window, where negative rows start from the bottom of the window. Note cell location is displayed at row -2, and the compass at -3, so if you display at these rows your text can get overlapped, in which case you may want to turn on fNoLocation and fNoCompass to suppress normal output. This operation should only be run during the After Redraw Inside macro event, where this does nothing outside that context.
GetString <format> <var>: Brings up a dialog which prompts the user to enter a string. The formatted string <format> gets displayed as a caption in the dialog. If the user clicks OK instead of canceling the dialog, the string entered will be stored in custom string <var>. Afterward @z will contain 1 if the dialog was cancelled, 0 otherwise.
GetString2 <format1> <format2> <var>: Like GetString except prompts the user to enter two strings. The formatted strings <format1> and <format2> get displayed as captions in the dialog. If the user clicks OK instead of canceling the dialog, the strings entered will be stored in custom string slots <var> and <var+1>.
GetString3 <format1> <format2> <format3> <var>: Like GetString except prompts the user to enter three strings. The formatted strings <format1>, <format2>, and <format3> get displayed as captions in the dialog. If the user clicks OK instead of canceling the dialog, then the strings entered will be stored in custom string slots <var>, <var+1>, and <var+2>.
DisableAll: Disables all commands. Trying to run a disabled command by selecting it from a menu or keyboard shortcut will display a warning. Disabled commands may still be run through scripting.
EnableAll: Enables all commands disabled through the DisableAll or Disable operations. This only enables disabled commands, and won’t affect triggers set through OnCommandAll or OnCommand operations.
Disable <command>: Disables the command indicated by <command>. If <command> is a number it indicates the index of the command as returned by the Command function, else if <command> is a string (e.g. “DlgOpen” or “o”) it corresponds to the command directly. Note the About Daedalus command can never be disabled, where attempting to disable it does nothing.
Enable <command>: Enables the command indicated by <command>.
OnCommandAll <num>: Defines a trigger for all commands, such that when any command is selected from a menu or keyboard shortcut, macro <num> will run first. When this macro is run, @x contains the ASCII value of the key pressed to invoke the command, if any, otherwise @x is zero. @y contains the index of the command about to be run, where this index is the same as returned by the Command function. After the macro returns, if @z is non-zero, the command won’t run. Note a disabled command is considered a special type of trigger, where a command can’t be both disabled and have a macro trigger at the same time. Note the About Daedalus command can never have a trigger, where attempting to define one for it does nothing.
OnCommand <command> <num>: Defines a trigger for the command indicated by <command>, such that when that command is selected from a menu or keyboard shortcut, macro <num> will run first.
DoCommand <command>: Run the command indicated by <command>.
ResetProgram: Resets or deletes various custom data in the program. This does the following things: Resets all macro event variables to 0 (making this a superset of the ClearEvents operation), enables all commands and removes all triggers, deletes all custom texture bitmaps, initializes internal variables used by the Turtle operation, and finally turns off fAutorepeatLastCommand, fCreateMazesPolished, fShowDot2, fSky3D, fNoCompass, fNoLocation, fNoSubmerge, fFogGround, fMarkColor, fMarkAll, fTextureDual, fTextureDual2, and fTextureBlend. It also deactivates nStepHeight, nMessageTitle, kWall2, kSky2, kGround2, k3DCeiling2, kMountain2, kCloud2, nSkyMark, nWallVariable, nFogLit, and restores the Passage and Wall colors to black and white. This is useful to run at the start of a script, to ensure program state that might have been set by previously run scripts doesn’t interfere.
ResetInside: Randomly regenerates the positions of stars, mountains, and clouds in the perspective inside view.
WindowTitle <format> <flag>: Sets the formatted string <format> to be the title of the Daedalus window. If <flag> is true, the window title will have the default title “Daedalus 3.5” prepended to it.
Beep: Sounds a simple system beep.
Beep2 <num1> <num2>: Like Beep except sounds a tone of frequency <num1> for <num2> milliseconds. The parameter <num1> can range from 37 to 32767. Note this operation uses the PC speaker, and therefore will do nothing on certain operating systems, such as 64 bit Windows XP and Vista.
Sound <file>: Plays a Windows wave format sound file (which usually has a .wav extension). The nSoundDelay variable controls how sounds are played.
Delay <num>: Pauses or sleeps the program for at least <num> milliseconds. Does nothing if <num> is negative. Useful to ensure animation happens at a certain minimum speed on fast computers.
Set <x> <y> <flag>: Set pixel. Turns the pixel at the given coordinates in the main monochrome bitmap on or off.
SetT <x> <y> <flag>: Set temporary pixel. Turns the pixel at the given coordinates in the temporary monochrome bitmap on or off.
SetE <x> <y> <flag>: Set extra pixel. Turns the pixel at the given coordinates in the extra monochrome bitmap on or off.
SetA <num> <x> <y> <flag>: Set custom pixel. Turns the pixel at the given coordinates in custom monochrome bitmap <num> on or off.
SetC <x> <y> <num>: Set color pixel. Sets the color value of the pixel at the given coordinates on the color bitmap to <num>.
SetCT <x> <y> <num>: Set temporary color pixel. Sets the color value of the pixel at the given coordinates on the temporary color bitmap to <num>.
SetCE <x> <y> <num>: Set extra color pixel. Sets the color value of the pixel at the given coordinates on the extra color bitmap to <num>.
SetCA <num1> <x> <y> <num2>: Set custom color pixel. Sets the color value of the pixel at the given coordinates in custom color bitmap <num1> to <num2>.
SetX <x> <y> <dir> <num>: Set texture. Sets the texture on the block at the given coordinates facing the given direction. This means setting the appropriate bits of a pixel on custom color bitmap indicated by nTextureWall to <num>. If <dir> is -1, all four sides are set to the texture number. If <dir> is -2, both side pairs are set to the texture number, in a manner that assumes fTextureDual is set.
SetY <x> <y> <dir> <num>: Set texture. Sets the texture on the block at the given coordinates facing the given direction, in a manner that assumes fTextureDual is set. This means setting the appropriate bits of a pixel on the custom color bitmap indicated by nTextureWall to <num>. If <dir> is -1, both texture pairs (i.e. all four sides) are set to the texture number. If <dir> is -2, all four sides are set to the texture number, in a manner that assumes fTextureDual is off.
Set3 <x> <y> <z> <flag>: Set 3D pixel. Turns the pixel at the given coordinates in the 3D bitmap within the main bitmap on or off.
Set3T <x> <y> <z> <flag>: Set temporary 3D pixel. Turns the pixel at the given coordinates in the temporary 3D bitmap on or off.
Set3E <x> <y> <z> <flag>: Set extra 3D pixel. Turns the pixel at the given coordinates in the extra 3D bitmap on or off.
Set3A <num> <x> <y> <z> <flag>: Set custom 3D pixel. Turns the pixel at the given coordinates in the 3D bitmap within custom monochrome bitmap <num> on or off.
Set3C <x> <y> <z> <num>: Set 3D color pixel. Sets the color value of the pixel at the given coordinates of the 3D bitmap within the color bitmap to <num>.
Set3CT <x> <y> <z> <num>: Set temporary 3D color pixel. Sets the color value of the pixel at the given coordinates on the temporary 3D color bitmap to <num>.
Set3CE <x> <y> <z> <num>: Set extra 3D color pixel. Sets the color value of the pixel at the given coordinates on the extra 3D color bitmap to <num>.
Set3CA <num1> <x> <y> <z> <num2>: Set custom 3D color pixel. Sets the color value of the pixel at the given coordinates of the 3D bitmap within custom color bitmap <num1> to <num2>.
Set3X <x> <y> <z> <dir> <num>: Set 3D texture. Sets the texture on the block at the given coordinates facing the given direction. This means setting the appropriate bits of a pixel on the 3D bitmap custom color bitmap indicated by nTextureWall to <num>.
Set3Y <x> <y> <z> <dir> <num>: Set 3D texture. Like SetY but for 3D bitmaps. Sets the texture on the block at the given coordinates facing the given direction. This means setting the appropriate bits of a pixel on the 3D custom color bitmap indicated by nTextureWall to <num>.
ZapTexture <num>: This will find the first set pixel along the direction the dot is facing, and set the texture on the side of the block facing the dot to <num>. This is similar to the commands on the Zap Dot submenu, and is like shooting a paintball at a wall to change its texture.
MarkX2: Like the Mark 'X' At Dot command but affects ceiling markings instead of floor markings. This will set nSkyMark to a new custom bitmap if not already set.
EraseX2: Like the Erase 'X' At Dot command but affects ceiling markings instead of floor markings.
Turtle <string>: Draws a sequence of lines in the main bitmap. The <string> contains a sequence of subactions indicating what to draw next. Most actions consist of a letter followed by a number (no whitespace between or within actions) and draw a line starting from the current pen position, as stored in the nXTurtle and nYTurtle variables, and automatically update the pen position variables to the new end position. Like the “draw” command in BASIC.
U<num>, D<num>, L<num>, R<num>: Draws from the current position up, down, left, or right that many pixels.
E<num>, F<num>, G<num>, H<num>: Draws from the current position northeast, southeast, southwest, and northwest that many pixels.
M<num>,<num>: Move. Draws to the specified coordinates, regardless of the current position. If either of these numbers has a “+” or “-” sign, that coordinate will be relative to the current position. For example “M10,20” draws to pixel coordinate (10, 20) while “M-10,+20” draws down and to the left that many pixels from the current position.
B<action>: Blank. Causes the next action to just update the pen position, and not do any drawing.
N<action>: No update. Causes the next action to not update the pen position.
C<flag>: Color. Sets the color of the lines to draw. “C1” means to draw white, and “C0” means black.
S<num>: Scale. Sets the scale for all relative motion, i.e. how many pixels each unit should cover. For example “S2” means a future action like “R10” will draw right 20 instead of just 10 pixels.
A<num>: Angle. Sets a rotation to apply to all relative motion. “A0” is normal, “A1” rotates everything to the right 90 degrees, “A2” rotates 180 degrees, and “A3” rotates everything left 90 degrees. For example “A1” means a future action like “R10” will draw down 10 units instead of right.
O<char><num>, O<flag>: Arc. Draws an arc or 1/4 of a circle of radius <num>. The <char> ranges from “A” to “H” and indicates the direction the arc is drawn from the current position. “OA” arcs up then to the right, “OB” arcs right then up (both end up in the same place as the “E” action). “OC” arcs right then down, “OD” arcs down then right (both end in same place as “F”). “OE” arcs down then left, “OF” arcs left then down (both end in same place as “G”). “OG” arcs left then up, “OH” arcs up then left (both end in same place as “H”). If “O” is immediately followed by a number it sets the type of arc to draw. “O1” means to draw a curve, and “O0” means to draw a right angle.
T<char><string><char>, T<flag>: Text. Draws text, where the text to print is bracketed between two instances of the character <char>. For example “T_HI_” prints “HI”. If <char> is “T”, there is no end <char>, where text drawing will continue to end of the entire macro string (useful if <string> may contain any characters). If “T” is immediately followed by a number it sets the font to use when printing. “T0” means to use a simple font where characters are 5 pixels high and variable width, “T1” means a fixed width font where all characters fit within a 5x9 pixel box, “T2” means a fixed width 8x13 pixel font where the characters are formed by a single unicursal line that never overlaps itself (used by the “Word Mazes” script to create Mazes with the solution path spelling a word), and “T3” means a fixed width font where all characters fit within a 8x14 pixel box. The “T1” font supports characters in the high-Ascii 128-255 range. Its glyphs cover the common Windows-1252 codepage, which is a superset of ISO 8859-1 (Latin 1) but with extra characters defined for the 128-159 range.
`: Fill. Runs the Fill At Dot command at the pen position.
~: Flood. Runs the Flood At Dot command at the pen position.
_: Reset. Changes all internal turtle variables to their defaults, specifically the current coordinates, color, scale, angle, arc type, and font. Useful for initializing to a consistent state and avoiding side effects of previous usages of the operation.
TextDraw <string> <x> <y>: Draws a string of text on the main monochrome bitmap. The coordinates specify the upper left corner of the text’s bounding box. The font used is specified by the TextFont operation.
TextFont <font> <size> <weight>: Specifies the font to use in the TextDraw operation, along with its size and weight. The size indicates the height in pixels, and the weight is the boldness, in which 0 is default, 400 is normal, and higher numbers like 700 are bold. Unlike the text abilities in the Turtle operation, this allows access to installed system fonts.
Perimeter: Counts the perimeter of an area of on pixels in the monochrome bitmap, displaying the total length in pixels, the number of sides, and the average side length. The total length will also be returned in @z. The shape measured will be that under the dot, or the first shape from the top of the bitmap if the dot isn’t over an on pixel. If No Corner Hopping is off, then pixels connected only by corners will be considered the same shape, in which the counting will include both.
Thicken2 <pixels>: Like the Thicken command except thickens each on pixel in the main monochrome bitmap by the specified number of pixels. If No Corner Hopping in Dot Settings is off, then each pixel will become a <pixels> by <pixels> square instead of a circle of <pixels> diameter.
BlendN: Sets the color bitmap to an equal blending together of N other color bitmaps. The other bitmaps are assumed to be stacked vertically within the temporary color bitmap, in which N is determined by the bitmap’s overall height. Black pixels in any bitmap are skipped, and make that subbitmap not contribute to the result.
Convex: Looks at the on pixels within the main bitmap, and fills in all concave inlets, holes, and areas between disconnected sections within it. In other words, this does the same as wrapping a rubber band around the set of on pixels, and filling in everything inside the band, leaving a convex shape.
AllMoire: Creates a moire pattern in the main bitmap, composed of lines radiating from the center of the bitmap to the edges.
2ndLineUntil <flag>: Draws a line on the main monochrome bitmap from the dot to the 2nd dot, in the Drag Is Erase color from Dot Settings. If the line bumps into an existing pixel of the color of the line, drawing stops. Afterward @x and @y will contain the coordinates of the pixel that was hit (if <flag> is True), or the coordinates of the pixel immediately before the location hit (if <flag> is False). Either way, @z will contain whether the line drawing hit an on pixel and stopped prematurely. This is used by the “Mouse Maze” script to draw lines that stop if you run into a wall.
2ndPutStretch <x1> <y1> <x2> <y2>: Fills the color bitmap with the contents of an arbitrary shaped quadrilateral within the temporary color bitmap, stretched to the bounds of the color bitmap. The upper left corner is defined by the dot, the lower right by the 2nd dot, upper right by <x1>, <y1>, and lower left by <x2>, <y2>. This can be used to help create a straight down aerial view of a life size Maze from a photo taken at an oblique angle.
NoIsland <x> <y>: Draws a line of on pixels connecting two detached islands of on pixels with each other. This starts with the island under <x>, <y>, where if there’s no island there, starts with the first island from the top of the bitmap. Once the start island is determined, the shortest line possible is drawn to the next nearest island. Normally this always connects islands with the same shortest path, however if Find A Path Finds Random Path is set, this will randomly pick among the set of shortest paths. Afterward @z is the length of the line, or 0 if there were no separate islands to connect.
NoIslands: Like NoIsland except it runs multiple times until all islands are connected. Afterward @z is the number of times islands were connected, i.e. one less than the total number of islands on the original bitmap. This is used by the “Word Mazes” script when making Mazes in the shape of words, to connect all the letters.
4D3D <color1> <color2> <color3>: Converts a 4D Maze to a 3D Maze. A list of 3D Mazes will be placed along the X-axis in the main and color bitmaps, where the 4th dimension will be represented by colored portals between these 3D Mazes. The portals will appear as semitransparent sections in the perspective inside view, where the semitransparent pixels get defined in the extra monochrome bitmap. In the color bitmap, walls will be in the inside 3D Wall color, and passages will be in the inside Wall color. Portals back along the 4th dimension will have color <color1>, portals forward along the 4th dimension will have color <color2>, and places where there are portals both back and forward at the same spot will have color <color3>. This is used by the “4D Mazes” script to convert the 4D Maze into a form that can be navigated in perspective inside view.
ND: Creates a perfect N-Dimensional Maze in the main bitmap, represented as a multidimensional grid of 2D levels. The size of the Maze to create is specified in the Size or Maze Size dialogs, where the 3D X and Y fields are the number of pixels along the 1st and 2nd dimensions, Z is the pixels along the 3rd and higher dimensions, and W is the number of dimensions. The various ND Maze operations are used by the “5D Mazes” script.
DeadEndND: Solves an N-Dimensional Maze, by filling in all dead ends. The dimensions of the Maze are defined by the Size dialogs.
DrawND <x> <y> <num1> <num2> <color>: Draws an N-Dimensional Maze in the active bitmap. The Maze is drawn centered around coordinates <x>, <y>. A set of N custom variables starting with slot <num1> indicate one’s current location within the Maze to later highlight. N pairs of custom variables starting with slot <num2> indicate the horizontal and vertical offsets to give to each dimension’s axis. Afterward the dot will be set to the coordinates in the bitmap where the current location in the ND Maze mapped to, and the 2nd dot will be set to the coordinates of the far corner i.e. the exit.
When an N-Dimensional Maze is drawn on the main monochrome bitmap, if <color> is non-black, the Maze will be drawn in the Wall color, otherwise it will be in the passage color. When drawn on the color bitmap, each axis has passage edges drawn in a different color of the rainbow as defined in the Replace Color dialog, which makes it easier to distinguish the different dimensions. If the Drag Move Dot setting is on, coloring will instead highlight edges based on their distance from one’s location within the Maze, with nearer locations in earlier colors of the rainbow. If the Drag Bit Dot setting is on, vertexes will be highlighted by 3x3 pixel spots in <color>, which makes them easier to see.
MoveND <num1> <num2> <x> <y>: Moves an N-Dimensional point to an adjacent cell in a ND Maze. A set of N custom variables starting with slot <num1> indicate one’s current location within the Maze, and N pairs of custom variables starting with slot <num2> indicate the horizontal and vertical screen offsets each dimension’s axis has. The ND point at <num1> will be moved down an available passage to the cell that maps nearest to screen coordinates <x>, <y> (doing nothing if the closest ND cell is the current point). Afterward the dot is updated to the coordinates where the current (possibly changed) location in the ND Maze mapped to, and @z is set to whether the ND dot has moved to the far corner i.e. the exit.
FractalPart <x> <y> <w> <num>: Like the Fractal Maze creation command, however this creates just a subsection of the fractal Maze instead of the whole thing, allowing viewing of Mazes too large to fit in a bitmap. This creates the section at coordinates <x>, <y> at depth <w>, with the fractal Maze itself defined by random number seed <num>. This actually creates a 4x4 grid of sections surrounding the coordinates. Afterward @x will be set to the horizontal cell location of the entrance, and @y the horizontal location of the exit. This is used by the “World’s Largest Maze” script to create the section of the giant virtual Maze nearest your location.
FractalPart3 <x> <y> <z> <w> <num>: Like the Fractal Maze creation command for 3D Mazes, however this creates just a subsection of the 3D fractal Maze instead of the whole thing, allowing viewing of Mazes too large to fit in a bitmap. This creates the section at coordinates <x>, <y>, <z> at depth <w>, with the fractal Maze itself defined by random number seed <num>. This actually creates a 2x2x2 grid of sections surrounding the coordinates. Afterward @x will be set to the horizontal cell location of the entrance, and @y the horizontal location of the exit. This is used by the “World’s Largest Maze” script to create the section of the giant 3D virtual Maze nearest your location.
VirtualPerfect <edges>: Creates or adds on to part of a Maze in memory using the hunt and kill algorithm, in which only part of the Maze is stored in the main bitmap. The dot indicates the current coordinates, and will be updated upon return. The <edges> parameter is a group of flags indicating which edges the current section being worked upon is adjacent to, in which 1 means top, 2 means left, 3 bottom, and 4 right. This operation will create the Maze until one of the edges is reached. Afterward @z will contain how many cells were created. This operation can be used to compose a Maze larger than will fit in memory at once, by creating one section at a time, although it’s the responsibility of the caller to save created sections to disk and load other sections appropriately for the next phase of creation.
VirtualAldous <edges>: Like VirtualPerfect except creates or adds on to part of a Maze using the Aldous Broder algorithm.
VirtualRecurs <edges> <stack>: Like VirtualPerfect except creates or adds on to part of a Maze using the recursive backtracking algorithm. The stack used by this algorithm is stored in the temporary bitmap, which should be n by 1 pixels, where n is two times the number of entries in the stack. (Because the stack stores directions, two bits are needed to represent four possible numbers.) The <stack> parameter indicates the initial stack offset in the temporary bitmap. This operation will create the Maze until one of the edges is reached, or one of the ends of the stack is reached. Afterward @y will contain the new stack offset. The “Virtual Mazes” script that comes with the program uses this operation to create large recursive backtracking Mazes in a grid of bitmaps (along with using other bitmaps temporarily for the stack). This script doesn’t have its own menu option, but it is available in the sources subdirectory of the installation.
DrawLevel <z> <x> <y> <xx> <xy> <yx> <yy>: Treats level <z> in the 3D bitmap in the temporary bitmap as an orthogonal Maze and draws it at coordinates <x>, <y> on the main bitmap. Walls are always one pixel thick, however passages can be of greater sizes and displayed in different orientations. The offset for each horizontal cell is in <xx> and <xy> (normally zero), and the offset for each vertical cell is in <yx> (normally zero) and <yy>. This is used by the “Demos” script to display Mazes on the surface of a cube.
CustomIterate: Changes the Custom Paths field in the Labyrinth Settings dialog to the next valid Labyrinth. This does the same as creating a Custom Labyrinth with the Custom Autoiterate flag set, except this doesn’t draw the new Labyrinth. Afterward @z will contain whether incrementing failed because Don’t Autostart Infinite was on and there were no more Labyrinths to create of the current size.
Dungeon <num1> <num2> <num3> <num4> <num5>: Draws a dungeon style Maze in the main bitmap formed of random rooms and connecting passages, similar to dungeon levels seen in the computer games Rogue and Nethack.
<num1>: The number of rooms to create. Note there may be fewer rooms actually created if a place for the last rooms can’t be found. If <num1> is 1 the whole bitmap will be filled with one big room, while if <num1> is 0 the whole bitmap will be filled with a Maze.
<num2>: The number of connecting passages between rooms (beyond the minimum number required to ensure all the rooms are connected with each other).
<num3>: The maximum horizontal and vertical pixel size of each room, where a 3x3 room is the minimum.
<num4>: The percentage of places where passages connect with rooms, that should contain closed doors (as opposed to doorless openings).
<num5>: Whether the dungeon should be marked with an entrance and exit. If the 10’s place is non-zero, there will be a passage from the top edge of the bitmap to a room, otherwise the entrance will be a hole in the ceiling somewhere in a random room. The position of the dot will be moved to this entrance. If the 1’s place is non-zero, there will not be an exit to the dungeon, otherwise there will be an exit hole in the floor somewhere in the middle of a random room.
If Bitmap Is 3D is on, the dungeon will be made within a level, otherwise pits in the floor and ceiling won’t be created since it’s a 2D bitmap. If the color bitmap exists, it will be made into a copy of the dungeon with the following coloring: Walls = light gray, Passages = dark gray, Rooms = gray, Walls of rooms = red, Doors = green, Ceiling and floor pits = black. If the temporary bitmap exists, it will have on pixels where doors are. This is used by the “Dragonslayer Game” script to create its dungeon levels.
ZoomSprite: This replaces the active bitmap with a zoomed version of itself. Each pixel is replaced with a square section from the temporary bitmap. The status of a pixel in the monochrome bitmap and its four neighbors determines which section of the temporary bitmap is used for the zoomed pixel at that coordinate. The width of the temporary bitmap divided by four determines the zoom factor and the size of each section. On pixels use the first four rows of the temporary bitmap, where the 16 combinations of the status of their four neighbors as shown below determines which section gets used. If there’s not enough rows in the temporary bitmap, combinations out of bounds are solid on or white pixels. Off pixels are replaced with solid off or black pixels, unless rows 5 through 8 in the temporary bitmap are present, in which case those rows are used instead.
# . . .
.#. ##. .#. .##
. . # .
# . . #
##. ##. .## .##
. # # .
# # . #
### ##. ### .##
. # # #
# . # .
.#. ### ### .#.
# . # .
DrawSeen <num>: This highlights pixels on the color bitmap that are visible from the dot. Pixels within a distance of <num> pixels along a line of sight from the dot, that aren’t blocked by on pixels in the monochrome bitmap, will be set to the corresponding pixel in the temporary color bitmap. If <num> is negative, pixels within a circular region will be uncovered, otherwise pixels within a square region will be. If No Corner Hopping is off, this allows one to “see” between on pixels connected diagonally.
If the monochrome bitmap is active, this will instead do a simple visibility check from the coordinates of the dot. Off pixels in the monochrome bitmap that are definitely behind on pixels will also be turned on. This will be done within a distance of <num> pixels from the dot.
Palette: Replaces colors in the main bitmap based on the temporary bitmap. For each color in the main bitmap, treat it as a 24 bit number index into the temporary bitmap. If a color index is too large to fit within the bounds of the temporary bitmap, or that temporary bitmap pixel is 0, then do nothing, otherwise replace the original color with the color at that index.
SymmetricX: Like the Make Symmetric command except modifies the current Maze to be horizontally symmetric, reflected across the up down axis. Note reflected Mazes are hard to have perfect, where either the entire reflection axis will be one long passage, there will be at least one asymmetry, or a combination of both.
SymmetricY: Like the Make Symmetric command except modifies the current Maze to be vertically symmetric, reflected across the left right axis.
SymmetricZ: Like the Make Symmetric command except modifies the current Maze to be symmetric around the center, with one quadrant duplicated and rotated four times. Note this Maze can only be symmetric when it has an odd number of passages, in which case the solution path must pass through the center cell. Mazes with an even number of passages will have a single asymmetry in them.
ZoomBiasPic: Zooms the monochrome bitmap, such that each 2x2 pixel area becomes a 3x3 pixel area. The middle column areas of each cell will be set based on the brightness of the color bitmap’s corresponding pixels. This is used to zoom a Maze such that its passage and wall thicknesses look similar to a background picture.
Overview2: This is like the Overview command, except it draws an orthographic overview such that each block is seen edge on (instead of face on). The top of each block will be diamond shaped, with the scene being not unlike the layout in real time strategy games such as StarCraft or Age of Empires. As with Overview, the Depth Size draw setting indicates the height of each block. The Vertical Size here indicates the pixel height of each edge of the diamond, and Horizontal Size indicates how many pixels wide each step along those edges are. With Depth Size set to 10, good values for Horizontal and Vertical Height are 2 and 3.
Altitude <num1> <num2>: Creates a display similar to the Render Bitmap Overview command when applied to a 2D bitmap, however here each block has its own height, forming a 3D bar graph or a bar graph over a 2D array. The height values come from the color bitmap. If the color bitmap is active, the display will be drawn in the color bitmap (replacing the height values input source) and the color of each block will be taken from the temporary color bitmap. Each height is scaled by <num1>, where 1000 means one unit in the color bitmap maps to one pixel in the display. The max value allowed for a color bitmap pixel is in <num2>, where numbers higher are capped to this height. If the scale factor <num1> is negative, then the scale used will be such that the tallest block drawn will be exactly <num2> pixels high. This is used by the “Mandelbrot Set Fractal” script to draw 3D overviews of the fractal.
GetWireframe <num> <var>: Fetches line number <num> from the wireframe scene in memory and stores it in 7 custom variables starting with index <var>. For example, “GetWireframe 0 10” will store the X, Y, and Z coordinates of the two endpoints of the first line in custom variables #10 through #15, and its color in variable #16.
SetWireframe <num> <var>: Defines line number <num> in the wireframe scene in memory with the 7 custom variables starting with index <var>. For example, “SetWireframe 0 10” will set the X, Y, and Z coordinates of the two endpoints of the first line with custom variables #10 through #15, and set color from variable #16. This does nothing if <num> is outside the limit of the number of lines in the wireframe, so set nWireframeSize if you want to change the number of lines in memory.
GetPatch <num> <var>: Fetches patch number <num> from the patch scene in memory and stores it in 19 custom variables starting with index <var>. The first 16 variables store the four vertexes of the patch, in X, Y, and Z coordinates, and then whether the edge connected with the point is highlighted. The 17th variable stores the number of vertexes used in the patch (which is always either 3 or 4), the 18th stores the color, and the 19th the patch’s transparency.
SetPatch <num> <var>: Defines patch number <num> in the patch scene in memory with the 19 custom variables starting with index <var>. The 19 custom variables define the three or four vertexes, the number of vertexes in use, the color, and transparency, in the same layout as GetPatch. This does nothing if <num> is outside the limit of the number of patches in the scene, so set nPatchSize if you want to change the number of patches in memory.
GetStar <num1> <num2> <num3>: Fetches the horizontal and vertical coordinates, along with the RGB color, of star number <num2> displayed in the perspective view. If <num1> is 0, gets the star from the perspective inside view, otherwise gets the star from the wireframe or patch view. The three values are stored in custom variables starting with index <num3>.
SetStar <num1> <num2> <numx> <numy> <string>: Sets the horizontal and vertical coordinates, along with the color, of star number <num2> displayed in the perspective view. If <num1> is 0, sets the star in the perspective inside view, otherwise sets the star in the wireframe or patch view.
Stereogram <num1> <num2>: Creates a random dot stereogram in the active bitmap, where the patterns in the stereogram will horizontally repeat after <num1> pixels. The stereogram is made from the contents of the main bitmap, where on pixels in it will appear to have a depth or farness of <num2> when compared to off pixels. Typical values for <num1> and <num2> are 50 and 10. Normally the dots placed are random, where stereograms on the color bitmap take their colors from the blend range defined in the Replace Color dialog. If the temporary bitmap is set and the same size as the main bitmap, then the pattern will be taken from the corresponding pixels on the temporary bitmap.
SetLife <string>: Defines the behavior of the Life Generate command. The <string> must be two strings of digits ranging from 0-8 separated by a slash. The first sequence indicates neighbor counts which keep a cell alive, and the second neighbor counts which cause a new cell to be born. The default for Conway’s Life is “23/3” which indicates cells live if they have 2 or 3 neighbors, and cells are born if they have 3 neighbors. Interesting values for <string> related to Mazes are “12345/3” (called “Maze”) and “1234/3” (called “Mazectric”), which produce Mazelike patterns filled with one pixel wide passages and walls, and the occasional room.
Evolution <num> <flag>: Creates a type of cyclic cellular automaton in the color bitmap. The pattern will have <num> different colors, where the colors fade through the blend range defined in the Replace Color dialog. If <flag> is false, a new pattern will be initialized with all colors set randomly, else the existing pattern will evolve a step. Each color flows into its orthogonal neighbor, if those neighbors are one color less than it. If Edge Behavior is set to Torus Wrapping, the colors can flow around the edges of the bitmap. If No Corner Hopping is off, flowing will happen in all eight directions instead of just the four compass directions. Note the temporary color bitmap is used to store the color indexes of each pixel. This is used by the “Demos” script.
Mandelbrot <x1> <y1> <x2> <y2> <num>: Draws a Mandelbrot set fractal in the color bitmap. The coordinate pairs define the rectangle of the Mandelbrot set to map to the bounds of the color bitmap, where the numbers are divided by a billion, e.g. 1500000000 means 1.5. The depth or number of iterations to do before considering a pixel infinite depth and making it black is <num>. Colors for depths come from the blend defined in the Replace Color dialog. This forms the basis of the “Mandelbrot Set Fractal” script.
MandelbrotGet: This operation sets @x and @y to the coordinates of a random color pixel in the color bitmap that’s adjacent to a black pixel. Returns the center if there are no such pixels. Priority will be given to color pixels adjacent to a low number of black pixels. This is used by the “Mandelbrot Set Fractal” script to find an interesting spot when zooming in randomly.
Contrast: Sets the active bitmap to highlight contrast or differences between pixels. Each pixel is set to the maximum difference between it and all neighboring pixels. If No Corner Hopping is set, this considers the four orthogonal neighboring pixels, otherwise this considers all eight neighboring pixels including diagonals. The edge of the bitmap is considered to be next to off or black pixels. For the monochrome bitmap this sets a pixel if any of its neighbors have a different value than it, while for the color bitmap this compares the three RGB channels separately. This operation can be used to detect and highlight sharp edges in a picture, which can convert an imported Maze image into something that Daedalus can solve.
GroundVar2: Like the Ground Variable command, but also allows for areas to be based on a particular height, and areas to be forced to be a particular height. If the main color bitmap exists, then pixels in it are base heights to add random values to. If the temporary color bitmap exists, then non-zero pixels in it are heights that will be guaranteed within the result (and nearby pixels will gradually fade to those heights). This is used by the “Jareth’s Labyrinth” script, to make the overall Labyrinth have higher heights in the middle areas, and also to make certain areas like the floor of the castle be a particular height.
Hunger <num>: Implements the computer AI in the “Hunger Games” script, and isn’t useful outside of it. The low 12 bits of <num> indicates the tribute to determine the best move for, normally ranging from 0-23. If the high 12 bits of <num> are set, they indicate the light radius in squares normal tributes should be able to see at that time of day. Afterward custom variable @z will indicate the action to take, @y will indicate the inventory slot item to operate upon (if applicable), and @x will indicate the direction to move or throw an item in (if applicable). The values for @z are as follows. 0: Do nothing and wait, 1: Use item, 2: Pick up whatever standing over, 3: Move or melee attack in direction, 4: Throw item in direction, 5: Drop item, 6: Climb down, 7: Climb up, 8: Give item, 9: Dig down, 10: Fire launcher, 11: Free tribute from Net, 12: Propose alliance, 13: Claim leadership.
System <num>: Runs system menu commands. If <num> is negative, minimizes the window. If positive, maximizes the window. If 0, restores the window from being minimized or maximized.
Setup: Sets up the program in the Windows environment. This is a shortcut for a combination of the Program Group (User), Desktop Icon, and File Extensions commands.
FileClose <num>: Closes the file handle in <num>. The file should have been opened with the FileOpen function.
FileWrite <num> <var>: Writes variable <var> to the file in handle <num>. If <var> is a number it’s written as decimal text, else if <var> is a string it’s written as a formatted string.
FileWriteByte <num1> <num2>: Writes byte <num2> to the file in handle <num1>.
FileReadStr <num> <var>: Reads the next string from the file in handle <num> and stores it in custom string indicated by <var>.
All dialog fields that are persistent, meaning if they’re changed they’ll still contain the entered value next time the dialog is brought up, have a corresponding scripting variable. There are also some “hidden” variables that are only accessible using scripting. Variable names are basically the name of the field in the dialog (with spaces and other special characters removed). There are a few exceptions, where common variables like the location of the dot have shorter names for convenience, while some names need text added to make them unique. Radio button groups are given the name of their group box, and are implemented by a numeric variable, where 0 is the first choice, 1 the second, etc. Each variable has a prefix character indicating its type. “n” means a standard number, “f” means a number storing a boolean flag, “r” means a number storing a floating point real number, “k” means a number storing a color, and “s” means a string.
******************** File Settings dialog ********************
nCurrentGeneration
nGenerationCutoff
nNewFileCutoff
fUseEllersAlgorithm
fSaveInfiniteToFile
fSaveInfiniteAsDOSText
fDontAutostartInfinite
n2DBitmapXCutoff
n2DBitmapYCutoff
n3DBitmapXCutoff
fSaveTextBitmapsClipped
fLineCharsInTextBitmaps
fSaveTextBitmapsTabbed
******************** Macro Events dialog ********************
nOnMoveOffBitmap
nOnMoveIntoWall
nOnMoveToNewCell
nAfterMoveToNewCell
nOnFollowToNewCell
nAfterRedrawInside
nOnRedrawInside
nOnRunCommand
nOnLeftClick
nOnRightClick
nOnMiddleClick
nOnPrevClick
nOnNextClick
nOnMouseMove
nOnProgramExit
******************** Display Settings dialog ********************
nWhatToDraw
nHowToDrawIt
nHorizontalPixelValue
nVerticalPixelValue
fShowColorBitmap
nWindowHorizontalSize
nWindowVerticalSize
nWindowHorizontalOffset
nWindowVerticalOffset
nHorizontalScroll
nVerticalScroll
fSizeIsDrawableArea
fWindowAlwaysOnTop
fHideMenu
fHideScrollBars
fRedrawWhenBitmapEdited
nDisplayDelay
fAllowPartialScreenUpdates
fShowIndividualPixelEdits
fErrorCheckPixelOperations
fHourglassCursorOnRedraw
fAutorepeatLastCommand
nRepeatDelayInMsec
fPauseTimer
fSkipMessageDisplay
fAllowSoundPlaying
******************** Set Colors dialog ********************
kBorder
kPassage
kWall
kDot
kInsideWall
kSky
kGround
kLine
k3DWall
k3DCeiling
kMountain
kCloud
kFog
fAutorepeatRandomizesWallColor
******************** Random Settings dialog ********************
nRandomSeed
nRandomBias
nRandomRun
******************** Dot Settings dialog ********************
nX
nY
nZ
nDir
nX2
nY2
nZ2
nDir2
f3D
fShowDot
fDotIsCircle
fDotShowsArrow
nDotSize
fWallsImpassable
fNoCornerHopping
fGlancingBlows
fChaseMousePoint
fNoMouseDiagonal
fFollowPassages
nRadarLength
nMoveCount
fMoveByTwo
fDragMoveDot
fDragIsErase
fDragBigDot
fDragByTwo
fDoDragOnTemp
nEdgeBehavior
******************** Inside Settings dialog ********************
nInside
fCompass
fCompassIsExact
fCellLocation
fMapOverlay
fSealedEntrances
fMountains
nPeakHeight
nCloudCount
fSunAndMoon
fRainbow
fStars
nStarCount
rMeteor
fNarrowWalls
nCellSize
nNarrowCellSize
nWallHeight
nViewHeight
nStepHeight
fAllowTextureMapping
rLightFactor
nFogDistance
nClippingPlane
rViewingSpan
nStereoWidth
nSemitransparentWalls
nMotionFrames
nRotationFrames
nUpDownFrames
nMotionVelocity
nRotationVelocity
nUpDownVelocity
nHorizontalOffset
nVerticalOffset
nUpDownOffset
nDirectionOffset
fUpDownSmoothNotFree
******************** Bitmap Size dialog ********************
Size3W
Size3X
Size3Y
Size3Z
******************** Replace Color dialog ********************
fRainbowBlend
fStraightColorBlend
nRainbowStart
nRainbowDistance
kBlend1
kBlend2
******************** Maze Settings dialog ********************
fCreateMazesPolished
fApplyCommandsToRectangleSection
fTeleportToEntranceOnMazeCreation
fConnectPolesNeverAddsDeadEnds
fSolveFillersCheckEveryPixel
fSolveFillersConsiderDotsAsExits
fFindAPathFindsRandomPath
fShowCountOfShortestSolutions
nTweakPassagesChances
nTotalMazesCreated
nClarifyWeaveWallBias
nClarifyWeavePassageBias
nClarifyWeaveRailingBias
nEntrancePositioning
******************** Labyrinth Settings dialog ********************
nLabyrinthType
nCircuitShape
nClassicalSize
fClassicalSizeIsCircuits
sCustomPaths
fCustomAutoiterate
nFanfoldsAllowed
nAsymmetryAllowed
nCircuitPartitioning
nRadiusPartitioning
nCustomAlign
nCustomCenterSize
fLabyrinthRoundedEdges
******************** Create Settings dialog ********************
fCreateWithRiver
fHaveRiverAtEdges
fNoRiverFlowback
nOmegaDimensions
nOmegaInnerDimensions
nOmegaEntranceLocation
nOmegaExitLocation
nOmegaDraw
sPlanair
sSegment
fCreateWithWallAdding
fTreeValueIsRandomChance
nTreeRiverValue
nForestInitial
nForestAddition
nMaxSpirals
nMaxSpiralWalls
nRandomAddition
nFractalX
nFractalY
nNestingLevel
fAllowIsolationInFractal
fCrackLinesMayHeadOff
nCrackLineLength
nCrackPassLimit
nCrackSector
nCavernSparseness
fKruskalBasedOnPicture
fWeaveCrossingsMayCorner
fTiltLinesMakeNoDiamonds
nTiltCellSize
******************** Draw Settings dialog ********************
nHorizontalSize
nVerticalSize
nDepthSize
nHorizontalSizeBias
nVerticalSizeBias
nXStartingLocation
nYStartingLocation
nZStartingLocation
fMoveWithArrowKeys
nXVanishingPoint
nYVanishingPoint
nViewingAngleTheta
nVerticalPitchPhi
nDrawMotionVelocity
nDrawRotationVelocity
fViewFromRight
fMergeBlocksTogether
******************** Obscure Draw Settings dialog ********************
fReflectCoordinates
fShadeSky
fShadeGround
fDrawEdges
fShadeObjects
fDoTouchUps
nBorderWidth
nHorizonWidth
nDistanceScale
nXScale
nYScale
nZScale
kEdge
kSkyHigh
kSkyLow
kGroundHigh
kGroundLow
kObject
nXLightVector
nYLightVector
nZLightVector
******************** Scripting only variables ********************
fScreenSaver: This indicates whether Daedalus is running in screensaver mode. When active, any keyboard or mouse activity will attempt to exit the program.
nMessageTitle: The index of a custom string variable to use for the title of message boxes displayed by the program. If the index is invalid or the string zero length, the default string “Daedalus” is used.
fMessageCopy: If this is set, then whenever Daedalus shows a message box, the text of it will be automatically copied to the Windows clipboard, where it may then be pasted into another program. This is designed for older versions of Windows such as 9x, since on later versions of Windows such as XP, pressing Control+c will copy the text of any message box to the clipboard.
nSkipMessage: Determines the types of message boxes that are suppressed when the Skip Message Display setting is on. Setting this to -1 ignores nothing, and is the same as if Skip Message Display is off. Setting this to 0 ignores standard messages. Setting this to 1 ignores notice category messages too, such as the result of commands. Setting this to 2 ignores warnings as well, such as bad user input. Setting this to 3 ignores serious error conditions, such as out of memory.
nXTurtle & nYTurtle: The pixel coordinates of the current position used by the Turtle operation.
nTurtleS: The current drawing scale used by the Turtle operation.
fShowDot2: Like the Show Dot setting in Dot Settings. When set, the location of the 2nd dot will be visible. The bitmap pixel corresponding to the 2nd dot will be covered with the color in kDot2.
fNoMouseDrag: When set, dragging the mouse in the window won’t update the coordinates of the dot. Left clicking the mouse still teleports the dot as normal. This can be useful when Drag Is Erase is on, where a slight nudge of the mouse when left clicking can make unwanted edits to the bitmap.
nAutorepeat: This indicates the command currently or most recently autorepeated. The values used here are the same as those returned by the Command function.
fFogGround: Normally the Fog Distance inside setting only affects walls, and does not affect wall texture overlays. When this is set, floor and ceiling markings, and the tops and bottoms of walls, along with all wall texture overlays, will also be shaded appropriately based on their distance.
kDot2: When the 2nd dot is visible over one of the pixels as when fShowDot2 is on, this is the color of the 2nd dot.
kSun: The color of the Sun in perspective inside view.
kMoon: The color of the Moon in perspective inside view.
kWall2: The color of the bottoms of walls in perspective inside view. This only affects default height walls when viewed from zero Viewing Height. If this is different from the standard Wall or 3D Wall color, the ceiling will fade between the two colors. If this value is negative, it has no effect on the display.
kSky2: The color of the sky or ceiling at the horizon in perspective inside view. If this is different from the standard Inside Sky color, the sky will be a gradient or gradually fade between the two colors. If this value is negative, it has no effect on the display.
kGround2: The color of the ground or floor at the horizon in perspective inside view. If this is different from the standard Inside Ground color, the ground will fade between the two colors. If this value is negative, it has no effect on the display.
k3DCeiling2: The color of the sky or ceiling at the horizon for 3D Mazes (when below the top level) in perspective inside view. If this is different from the standard 3D Ceiling color, the ceiling will fade between the two colors. If this value is negative, it has no effect on the display.
kMountain2: The color of the top of mountains in perspective inside view. If this is different from the standard Inside Mountain color, mountains will be a gradient or gradually fade between the two colors. If this value is negative, it has no effect on the display.
kCloud2: The color of the bottom of clouds in perspective inside view. If this is different from the standard Inside Cloud color, clouds will be a gradient or gradually fade between the two colors. If this value is negative, it has no effect on the display.
fRainbow: Sets whether a rainbow is drawn in the perspective inside view, which will be positioned opposite the sun. The rainbow will be generated once and placed in custom bitmap -5, and regenerated whenever the window is resized.
nRainbow: Defines how the rainbow is drawn in the perspective inside view. The 1000000’s place and above indicate the height of the rainbow or its diameter in proportion to the window height, ranging from 0 (miniscule) to 99 (touching the top of the screen) and beyond. The 100000’s and 10000’s place indicate the vertical offset of the rainbow, ranging from 0 (as high as possible) to 99 (completely submerged below the horizon). The 1000’s and 100’s place indicate the width of the rainbow arc as a proportion of its radius, ranging from 0 (hairline) to 99 (a solid semicircle). The 10’s and 1’s place indicate the transparency of the rainbow, ranging from 0 (completely opaque) to 99 (completely invisible). If nRainbow is negative, the digit placements will be interpreted the same, however a rainbow won’t be drawn, but rather the existing contents of custom bitmap -5 will be stretched across the appropriate area of the screen.
nGround: Sets the bottom limit for Viewing Height that one can descend to via the Lower command in the perspective inside view. Usually this is 0, but may be lower if one wants to allow worm’s eye views barely above the ground plane, or even a large negative number to allow descending underground.
nHorizon: Indicates the offset of the horizon line in the perspective inside view, as a proportion of the vertical size of the window. The value 0 is the default of the horizon centered in the middle of the window, 1000 has the horizon at the bottom of the window, and -1000 has the horizon at the top of the window.
nSunMoon: This affects the Sun or the Moon in the perspective inside view. When the Sun is being displayed, this indicates the length of the Sun’s rays, as a percentage of the diameter of the Sun’s disk. When the Moon is being displayed, this indicates the phase or percent fullness of the Moon. Positive numbers show a waxing Moon or the left hand side shaded, while negative numbers show a waning Moon.
nSunMoonY: This sets the height of the Sun and Moon in the sky in the perspective inside view. When 0 the middle of the Sun or Moon will intersect the top of the screen, and when 1000 the middle will intersect the horizon. Changing this can simulate the Sun/Moon rising/setting.
nStarColor: This number indicates how stars and meteors in the perspective inside view should be colored. Stars are usually grayscale. The millions place in the number indicates the percentage chance that a star should have some part of its color adjusted, e.g. 20XXXXXX where X is any digit means a 20% chance a star will not just be a shade of gray. The next two digits (100000’s and 10000’s place) indicate how to affect the red component of the color, the next two digits (1000’s and 100’s place) indicate how to affect the green component, and the low two digits (10’s and 1’s place) indicate how to affect the blue component. For each two digit pair, the high digit means how much to allow that component to be decreased, and the low digit means how much to allow the component to be increased. Each digit ranges from 0-9, where 0 means don’t add or subtract at all, 9 means add or subtract 255, and other digits proportion appropriately. For example, 300006 means that for those stars that are colored, up to 85 may be subtracted from its red component, or up to 170 may be added to its blue component. That will make stars have either a cyan (subtracting red) or blue (adding blue) tinge to them. The default value for this number is 10990099 which means a 10% chance a star may have its red or blue components arbitrarily increased or decreased, which allows stars to be red (adding red), cyan (subtracting red), blue (adding blue), or yellow (subtracting blue), but never green (adding green) or magenta (subtracting green).
nStarSize: Determines the maximum brightness of stars in the background of the perspective views, before they’re displayed larger than one pixel. Standard values can range between 0 and 765 (the latter of which is 255x3, or the maximum RGB brightness). If less than 0, then every other star is large (regardless of its brightness).
fSkyAll: Makes the Maze in perspective inside view seem to be suspended in air, instead of on a flat plain. Stars, meteors, and clouds will display over the entire background instead of just the top half, and mountains will display at the bottom instead of the middle. It’s recommended to set the Inside Sky and Ground colors the same with this, to avoid the appearance of a horizon in the middle. This setting also affects the wireframe and patch renderings.
fSky3D: When this flag is set, the ceiling area in 3D Mazes in the perspective inside view will show all the scenery as seen in 2D Mazes and the top level of 3D Mazes. Normally 3D Mazes are rendered as if lower levels are underground, where this can be used to make all floors seem above ground. It’s recommended to set the 3D Ceiling color the same as the Sky color with this, so the sky looks the same on all levels. This is used by the “Survivor Maze #5” script to allow windows that can be looked out on each floor of the vertical Maze.
fFrameDelay: When set, the perspective inside view will show an indicator of the frame delay on the fourth row from the bottom, or how long in milliseconds it took Daedalus to render the scene in question. Note on most systems this value is rounded to units of approximately 15 or 16 milliseconds, so not all numbers are possible.
nFrameDelay: Contains the most recent frame delay number as displayed when fFrameDelay is set. If the value is -1, no perspective inside view has been rendered yet with fFrameDelay on.
fNoCompass: When this flag is set, the compass in perspective inside view will never be shown, even when the Compass inside setting is active. This is used when overriding the default compass display with a macro, to avoid having the standard display of the compass overlap with the customized compass.
fNoLocation: When this flag is set, the location in perspective inside view will never be shown, even when the Cell Location inside setting is active. This is used when overriding the default location display with a macro, such as in the 4D Mazes or Giga Mazes scripts, to avoid having the standard display of the location overlap with the customized location.
fNoSubmerge: When this flag is set, then in the perspective inside view, having the viewing location being inside of a solid or semitransparent block will treat that block as completely invisible.
nStepDown: This is like nStepHeight, and only has an effect when the Step Height mode is active. This controls the maximum amount one is allowed to step down when moving between variable height cells. It can be used to prevent one from stepping off cliffs, but still be able to go down gentle stairs. If this value is negative, one is allowed to fall down any distance.
fRedrawAfter: If this flag is set, and the inside display mode is set to Smooth Movement, and the After Move To New Cell event is set, then animation during movement will not redraw the screen at its final position. Rather it’s assumed that the After Move To New Cell event will redraw the screen. This is used by scripts that involve some edit happening after each time the user moves, such as the monsters updating in the Pac-Man and Dragonslayer scripts. This avoids an extra screen update and hence results in smoother movement, since the screen will be made to update anyway after the monsters move.
This setting also affects the Autorepeat Last Command flag, and will cause it to not automatically update the screen after repeating the command if another update is being done at the same time. For example, if one is moving in the perspective inside view, this will cause a single screen update to cover both the repeated command and the movement, instead of two separate updates, which looks smoother. This is used by scripts such as Safari Maze to have smooth movement combined with background animation.
fMarkColor: Makes the color of floor and ceiling markings in perspective inside view be taken from the temporary color bitmap instead of the main color bitmap as normal. Semitransparent or variable height walls allow both a wall and floor marking to be visible at the same spot, in which case one may want them to have separate colors.
fMarkAll: Makes every cell in the perspective inside view have a ground marking. This is a quick way to have ground markings everywhere without having to maintain the temporary monochrome bitmap with solid on pixels.
fMarkBlock: If this flag is set, then in the perspective inside view, the west and east sides of raised ground elevation markings will be the original color for that cell. The top surface of the ground marking along with the north and south faces will be that color darkened or lightened appropriately. Normally the top of the ground marking is the original cell color, and the four side faces are that color shaded appropriately. This setting allows ground markings and variable height walls of the same color to look the same.
nSkyMark: Turns on ceiling markings in perspective inside view, i.e. points to which custom bitmap slot defines them. On pixels in the monochrome bitmap in that slot indicate where ceiling markings are. The color bitmap indicates the color of markings, where if that color bitmap doesn’t exist, the colors will be same as the floor markings. By default this is -1, meaning ceiling markings are turned off.
nMarkElev: Turns on variable height floor elevations in perspective inside view, i.e. points to which custom bitmap slot defines them. Pixels in the color bitmap there indicate the elevation of each floor square. By default this is -1, meaning variable height floor elevations are turned off.
nWallVariable: Turns on variable height walls in perspective inside view, i.e. points to which custom bitmap slot defines them. On pixels in the monochrome bitmap there indicate which walls are variable height as opposed to default height. Pixels in the color bitmap there indicate the height of each block, where the low 12 bits indicate the top elevation, and the high 12 bits the bottom. By default this is -1, meaning variable height walls are turned off.
nFogLit: Turns on lit textures for cells in the perspective inside view, i.e. points to which custom bitmap slot defines them. On pixels in the monochrome bitmap at that slot determine cells that ignore fog settings. The color bitmap in that slot is ignored. By default this is -1, meaning all cells have the same dimness when fog is set.
nTexture: This contains the index of the texture bitmap to use for the background area in the perspective inside view, for 2D Mazes and the top level of 3D Mazes. If this doesn’t point to a valid texture, the solid inside sky and ground colors are used instead of a texture. Note this variable gets set by the Background apply texture command.
nTexture3: This contains the index of the texture bitmap to use for the background area in the perspective inside view, for all levels in 3D Mazes except the top level. If this doesn’t point to a valid texture, the solid inside 3D ceiling and ground colors are used instead of a texture. Note this variable gets set by the Background apply texture command.
nTextureWall: Turns on wall textures for the vertical surfaces of walls in perspective inside view, i.e. points to which custom bitmap slot defines them. Pixels in the color bitmap in that slot indicate the texture for each face, where each group of 6 bits indicates the texture for the north, west, south, and east faces. By default this is 0, meaning custom bitmap slot #0 is used for texture mapping.
nTextureGround: Turns on floor and ceiling textures in perspective inside view, i.e. points to which custom bitmap slot defines them. Works similar to wall texture mapping, where pixels in the color bitmap in that slot point to the custom bitmap slot containing the textures. The low 12 bits indicate the floor texture, and the high 12 bits the ceiling, where 0 means no texture. The monochrome bitmap there is used for masks, and indicates whether monochrome overlays are black or white. By default this is -1, meaning floor and ceiling textures are turned off.
nTextureBlock: Turns on texture mapping for the top and bottom surfaces of walls in perspective inside view, i.e. points to which custom bitmap slot defines them. Works similar to ground texture mapping, where pixels in the color bitmap in that slot point to the custom bitmap slot containing the textures. The low 12 bits indicate the top texture, and the high 12 bits the bottom, where 0 means no texture. The monochrome bitmap there is used for masks, and indicates whether monochrome overlays are black or white. By default this is -1, meaning block textures are turned off.
nTextureElev: Turns on texture mapping for the sides of elevated ground markings in the perspective inside view, i.e. points to which custom bitmap slot defines them. Works similar to wall texture mapping, in which pixels in the color bitmap in that slot point to the custom bitmap slots containing the textures. The monochrome bitmap in that slot is unused. By default this is -1, meaning ground elevation textures are turned off.
fTextureDual: Controls whether textures on the sides of blocks and elevated ground are duplicated on north/south and west/east faces. If set, then the low 12 bits of a texture index indicate the texture bitmap for the north and south faces, and the high 12 bits of the texture index indicate the texture for the west and east faces. This setting allows more texture possibilities (12 bits instead of just 6 bits when each face has its own texture) however it does mean that textures on opposite sides of a block have to be the same.
fTextureDual2: This only plays a role when fTextureDual is set. This causes the two textures to be duplicated on the north/west and south/east faces of blocks. Normally the two textures are duplicated on the north/south and west/east faces.
fTextureBlend: When set, solid color textures in the perspective inside view (whether opaque or semitransparent) will be blended with the color of the block behind the texture. This is used in the “Hunger Games” script to for example have trees of many different colorings, without having to have a separate tree texture for each color.
nMarkElevX1, nMarkElevY1, nMarkElevX2, nMarkElevY2: Controls how hills are generated by the Ground Elevation command. The “X” variables indicate the frequency of hills or how often wrinkles happen, and the “Y” variables indicate the amplitude of hills or how high they can reach. Both the “1” and “2” values are generated randomly and added together. Usually the “1” numbers are larger and define a rough general shape, and the “2” numbers are smaller and define detail within it, resulting in a simple fractal.
nMazeCellMax: Sets the number of cells to allow generating in a Maze before stopping the command. If negative, commands will never stop prematurely. Commands will automatically decrement this variable, so subsequent Maze generations won’t halt unless the variable is reset. This allows freezing a command part way through for saving or other purposes. For example, the “Hunger Games” script uses this in combination with Prim’s Algorithm to create random inkblot shapes to use for lakes, mountains, and meadows.
nHuntType: Determines how the hunt and kill Maze generation algorithm command hunts for cells that aren’t yet part of the Maze. Setting this to 0 searches horizontal row by row until a new cell is found, which is simple but can result in a horizontal bias. Setting this to 1 alternates searching in both rows and columns until a new cell is found, which is more balanced. Setting this to 2 searches outward from the last cell in a spiral pattern until a new cell is found, which appears even smoother but can be slower.
nFractalDepth: Indicates the maximum chip depth to search for solutions in the Find Recursive Fractal Maze solving command.
nFractalLength: Indicates the maximum step length to search for solutions in the Find Recursive Fractal command.
nFractalType: The type of fractal Maze created by the FractalPart operation. If 0, the Maze will be nested cells created using the hunt and kill algorithm. If 1, the Maze will be created with the binary tree algorithm. If 2, the Maze will be created with the recursive division algorithm. If 3, the Maze will be a unicursal Labyrinth. If 4, the Maze will be a variation of the classical seven circuit Labyrinth with a number of circuits depending on the Maze’s size. If 5, the Maze will be a Hilbert curve Labyrinth. This setting can be seen in action in the “World’s Largest Maze” script, by pressing F10 to set the algorithm.
nStretch: This affects the Stretch To Window display setting. When set to 0, some rows will simply be skipped. When set to 1, then if any row in the range mapping to the displayed pixel is on the pixel will be on. When set to 2, then if any row is off the pixel will be off. This is basically a wrapper around the SetStretchBltMode Windows API. Note on some machines, values 1 and 2 will display slower. Other machines don’t support this at all, where changing the variable will have no visible effect.
fGraphNumber: This flag affects the Graph Distance and Graph Walls commands, the various “With Color” commands on the Dot Color submenu, the Mandelbrot operation, and how color pixel values are displayed in the Dot Settings dialog. When set, color pixels won’t be set to colors as defined in the Replace Color dialog, but rather pixels will be set to raw distance numbers. This can for example be used by a script to determine the number of moves you are from the entrance or exit of a Maze as you move around.
nGrayscale: This value affects the Make Grayscale command, and indicates the brightness to give to each of the RGB channels. The first three digits indicate the red brightness, the second three the green brightness, and the last three the blue brightness. Each three digit number is a fraction ranging from 0 (minimum) to 999 (maximum), where all three shouldn’t add to over 1000. The default value is 299587114, which indicates brightness factors of 0.299, 0.587, 0.114 for the RGB channels. If this value is negative, each channel will be given an equal 1/3 brightness factor.
fArrowKeysFree: This setting only plays a role when Move With Arrow Keys in Draw Settings is on. It causes movement in the wireframe and patch renderings to feel more fluid, like playing a video game. You don’t have to wait for key repeat to kick in, which means holding down a key immediately continuously moves, and you can also hold down two keys at once (e.g. move forward plus rotate) and have them both take effect. The speed at which continuous movement happens is controlled by the Repeat Delay In Msec field in Display Settings. This is like the Very Free Movement Inside Display Mode, but applied to the wireframe and patch renderings.
rTransparency: Daedalus supports semitransparency in perspective patch renderings. This sets the default transparency to use for patches in patch files loaded into the program that don’t already have a transparency defined for them, and also the transparency to use for patches created with the Make Patch Bitmap Overview command. This value ranges from 0 to 10000, where 0 is no transparency, and 10000 is completely invisible. This setting also affects how transparent semitransparent walls are in the perspective inside view.
nFogDistance2: Daedalus supports fog effects in perspective patch renderings. If this field is non-zero, the color of patches will increasingly fade the farther away they are. The larger the number, the greater the distance before the wall color will completely fade. Specifically it’s equal to the number of draw units before the fade limit is reached. The color things fade to is stored in the Edge Color obscure draw setting.
nWireWidth: Determines the maximum width of lines drawn in the wireframe display. Setting this to 0 always draws hairline thin one pixel wide lines, no matter their distance from the viewer. Setting this to 1 draws close lines one pixel wider horizontally, and the remainder as with setting 0. Setting this to 2 draws closer lines one pixel wider horizontally and vertically, and farther lines as with settings 1 and 0. Setting this to 3 draws the closest lines two pixels wider horizontally and vertically, and farther lines as with lower settings.
fWireSort: Determines whether lines in the wireframe display are sorted by distance before being drawn, to ensure that far away lines aren’t drawn on top of close lines. This generally isn’t necessary when the wireframe line width stored in nWireWidth is low, because intersecting lines will have little if any overlapping area. Sorting may slow down the rendering time, which is why there’s an option to turn it off.
nWireDistance: This setting only plays a role when the wireframe width setting nWireWidth is more than zero. It determines how many coordinate units away from the viewer the midpoint of lines must get before they’re displayed in the next narrower category.
nDrawFaceOrigin: Determines whether the wireframe and patch displays force the rendering to face the origin, pointing at X, Y, Z coordinate 0, 0, 0. Setting this to 0 doesn’t face the origin at all. Setting 1 makes the rendering face the origin, but doesn’t affect the actual direction one is moving in Draw Settings, which allows one to move along one trajectory while continually facing the origin. Setting 2 makes the rendering face the origin, and also updates the actual direction one is facing in Draw Settings, which allows one to sidestep in order to continually circle around the origin.
fStereo3D: This only plays a role when nStereo is non-zero, and stereoscopic graphics are being displayed. When this is set, the stereoscopic image will be made for classic 3D glasses, with red and cyan monochrome images for each eye overlapping. (This is in contrast to the completely separate left eye and right eye images drawn side by side as is normal.)
nWireframeSize: Contains the current number of line segments in the wireframe scene in memory. This variable can be changed to truncate the list or add space for new lines at the end of the list.
nPatchSize: Contains the current number of patches in the patch scene in memory. This variable can be changed to truncate the list or add space for new patches at the end of the list.
fMandelbrotShip: When this is set, the Mandelbrot operation will generate the “Burning Ship” style of fractal instead of the standard Mandelbrot fractal. The Burning Ship has an asymmetric image (unlike Mandelbrot) which looks like a ship with flames on its deck. It is produced by a similar formula as Mandelbrot, except the absolute value is taken of each dimension before squaring. The Burning Ship can be toggled to in the “Mandelbrot Set Fractal” script by pressing F11.
nSoundDelay: Controls the behavior of sounds played with the Sound operation. If negative, sounds are played synchronously, and the program will pause until the sound finishes. Otherwise, sounds are played asynchronously, and the program will continue running while the sound plays. If a sound is already playing when the Sound operation is called again, then the old sound will be interrupted and stopped when the new sound begins. If positive, this variable indicates how long in milliseconds the old sound should be allowed to play before the new sound interrupts it. For example, if set to 3000, and a sound was started one second ago, then the program will pause for two seconds before interrupting the old sound. This ensures a sound can play for a minimum length of time before the next sound starts.
nFileLock: Points to a custom string variable naming a mutex to use when reading files. A mutex is an operating system feature which ensures mutual exclusion, so that two processes aren’t accessing a file at the same time. If the file is locked by another program using the same mutex, then Daedalus won’t just fail right away, but will rather wait up to one second for the other process to release the mutex. This is used in the creation of videos such as https://www.youtube.com/watch?v=UdRaDGXBV-0 in which Daedalus is continually reloading a file and rendering a scene, while another process is continually updating and rewriting the contents of that file.
fRndOld: Controls whether the random number generator generates numbers using the system “rand()” function. The default random number generator in Daedalus is faster and has much better randomness properties, so this should only be set to reproduce behavior from versions of the program before 3.1.
fNoExit: When set, the program won’t exit. Attempting to exit will display a warning message. In the command line only version of the program, after running the initial command line, the program will continually prompt in the console for additional command lines to run.
nAllocations: Contains the total number of memory allocation buffers currently held by the program, incrementing each time a new buffer is allocated, and decrementing each time a buffer is freed. If this variable isn’t zero when the program exits, a memory leak error message will be displayed.
nAllocsTotal: Contains the total number of memory allocation buffers ever held by the program, incrementing each time a new buffer is allocated, and never decrementing. Combined with the nAllocations variable, this can be used to analyze memory usage behaviors of the program.
nAllocsSize: Contains the total size in bytes of all memory allocation buffers ever made by the program, increasing each time a new buffer is allocated, and never decreasing. Combined with the other memory allocation variables, this can be used to analyze memory usage behaviors of the program.
******************** Constants ********************
False: Constant. Always returns 0.
True: Constant. Always returns 1.
Off: Constant. Always returns 0.
On: Constant. Always returns 1.
Color constants: Each solid color that can be entered into color fields in dialogs is also a constant with the same name. The 23 color constants are: Black, Maroon, DkGreen, Maize, DkBlue, Purple, DkCyan, LtGray, Gray, Red, Green, Yellow, Blue, Magenta, Cyan, White, Grey, Violet, Aqua, DkGray, Orange, Pink, Brown.
******************** Arithmetic functions ********************
Add <num1> <num2>: Addition. Returns the sum of <num1> and <num2>.
Sub <num1> <num2>: Subtraction. Returns <num2> subtracted from <num1>.
Mul <num1> <num2>: Multiplication. Returns <num1> times <num2>.
Div <num1> <num2>: Division. Returns <num1> divided by <num2>. If <num2> is 0, returns 0.
Mod <num1> <num2>: Modulus. Returns the remainder when <num1> is divided by <num2>. If <num2> is 0, returns 0.
Neg <num>: Negation. Returns the negative of <num>.
Inc <num>: Increment. Returns <num> plus 1.
Dec <num>: Decrement. Returns <num> minus 1.
Pow <num1> <num2>: Power. Returns <num1> raised to the <num2> power. If <num2> is negative, returns 1. If the result overflows, returns 0.
******************** Boolean functions ********************
Equ <num1> <num2>: Equality. Returns whether <num1> equals <num2>.
Neq <num1> <num2>: Inequality. Returns whether <num1> does not equal <num2>.
Lt <num1> <num2>: Less than. Returns whether <num1> is less than <num2>.
Gt <num1> <num2>: Greater than. Returns whether <num1> is greater than <num2>.
Lte <num1> <num2>: Less than or equal. Returns whether <num1> is less than or equal to <num2>.
Gte <num1> <num2>: Greater than or equal. Returns whether <num1> is greater than or equal to <num2>.
Not <num>: Logical not. Returns whether <num> is zero. Like the “!” operator in C.
And <num1> <num2>: Bitwise and. Returns the bits of <num1> anded with <num2>. This function does not do short circuit evaluation, in that both arguments are always evaluated even if the first is false. Like the “&” operator in C.
Or <num1> <num2>: Bitwise or. Returns the bits of <num1> ored with <num2>. This function does not do short circuit evaluation, in that both arguments are always evaluated even if the first is true. Like the “|” operator in C.
Xor <num1> <num2>: Logical exclusive or. Returns the bits of <num1> exclusive ored with <num2>. Like the “^” operator in C.
Inv <num>: Logical inverse. Returns <num> with all its bits flipped. Like the “~” operator in C.
<< <num1> <num2>: Shift left. Returns <num1> with all its bits shifted left <num2> times. Like the “<<“ operator in C.
>> <num1> <num2>: Shift right. Returns <num1> with all its bits shifted right <num2> times. Like the “>>“ operator in C.
&& <num1> <num2>: Logical and. Returns whether both <num1> and <num2> are non-zero. This function does not do short circuit evaluation, in that both arguments are always evaluated even if the first is false. Like the “&&” operator in C.
|| <num1> <num2>: Logical or. Returns whether either <num1> or <num2> are non-zero. This function does not do short circuit evaluation, in that both arguments are always evaluated even if the first is true. Like the “||” operator in C.
******************** Mathematical functions ********************
Odd <num>: Odd. Returns whether <num> is an odd number.
Abs <num>: Absolute value. Returns the absolute value of <num>.
Sgn <num>: Sign. Returns the sign of <num>. Returns -1 if it’s negative, 0 if zero, and 1 if positive.
Min <num1> <num2>: Minimum. Returns the minimum of <num1> and <num2>.
Max <num1> <num2>: Maximum. Returns the maximum of <num1> and <num2>.
Tween <num> <num1> <num2>: Between. Returns whether Num lies within the range of Num1 to Num2. This is basically a shorthand version of “And Gte <Num> <Num1> Lte <Num> <Num2>”.
Rnd <num1> <num2>: Random. Returns a random number between <num1> and <num2>.
?: <flag> <num1> <num2>: If/else. If <flag> is true, returns <num1>, otherwise returns <num2>. This function does not do short circuit evaluation, in that all arguments are evaluated regardless of the flag. Like the “?:” operator in C.
Sqr <num>: Square root. Return the square root of <num>, rounded down. For negative numbers this returns the same value as if the number were positive.
Dist <num1> <num2> <num3> <num4>: Distance. Returns the distance between coordinates <num1>, <num2> and <num3>, <num4>.
Ln <num1> <num2>: Logarithm. Returns <num1> times the natural or base “e” logarithm of <num2>.
Sin <num1> <num2>: Sine. Returns <num1> times the sine of <num2> degrees. Useful for plotting the vertical coordinates along a circle of radius <num1>.
Cos <num1> <num2>: Cosine. Returns <num1> times the cosine of <num2> degrees. Useful for plotting the horizontal coordinates along a circle of radius <num1>.
Tan <num1> <num2>: Tangent. Returns <num1> times the tangent of <num2> degrees.
Asin <num1> <num2>: ArcSine. Returns the inverse sine of <num1> divided by <num2>, in degrees.
Acos <num1> <num2>: ArcCosine. Returns the inverse cosine of <num1> divided by <num2>, in degrees.
Atan <num1> <num2>: ArcTangent. Returns the inverse tangent of <num1> divided by <num2>, in degrees.
Ang <num1> <num2>: Angle. Returns the angle in degrees (ranging from 0 to 359) of a line going from the origin to coordinates <num1>, <num2>.
Sin2 <num1> <num2> <num3>: Sine. Like Sin but assumes a circle is divided into <num3> equal slices instead of 360 degrees. Useful for when precision to a fraction of a degree or an odd ratio is needed.
Cos2 <num1> <num2> <num3>: Cosine. Like Cos but assumes a circle is divided into <num3> equal slices instead of 360 degrees.
Tan2 <num1> <num2> <num3>: Tangent. Like Tan but assumes a circle is divided into <num3> equal slices instead of 360 degrees.
Asin2 <num1> <num2> <num3>: ArcSine. Like Asin but assumes a circle is divided into <num3> slices instead of 360 degrees. Useful for when precision to a fraction of a degree or an odd ratio is needed.
Acos2 <num1> <num2> <num3>: ArcCosine. Like Acos but assumes a circle is divided into <num3> equal slices instead of 360 degrees.
Atan2 <num1> <num2> <num3>: ArcTangent. Like Atan but assumes a circle is divided into <num3> equal slices instead of 360 degrees.
Ang2 <num1> <num2> <num3>: Angle. Like Ang but assumes a circle is divided into <num3> slices instead of 360 degrees. Useful for when precision to a fraction of a degree or an odd ratio is needed.
******************** String functions ********************
Len <string>: Length. Returns the number of characters in <string>. If <string> is invalid, returns 0.
Char <string> <num>: Character. Returns the ASCII value of the <num>th character in <string>. If <string> is invalid or <num> references a character beyond the limits of the string, returns -1.
Num <string>: Number. Returns <string> converted to a number. Useful for getting a number from the result of the GetString operation.
Real <string> <num>: Real number. Like Num but multiplies the result by 10 to the <num> power, or shifts the decimal point to the left by <num>. Useful to parse a floating point real number into a fixed point integer.
EquStr <string1> <string2>: String equality. Returns whether <string1> equals <string2>.
NeqStr <string1> <string2>: String inequality. Returns whether <string1> does not equal <string2>.
LtStr <string1> <string2>: String less than. Returns whether <string1> is less than <string2> in ASCII sorting order.
GtStr <string1> <string2>: String greater than. Returns whether <string1> is greater than <string2> in ASCII sorting order.
LteStr <string1> <string2>: String less than or equal. Returns whether <string1> is less than or equal to <string2>.
GteStr <string1> <string2>: String greater than or equal. Returns whether <string1> is greater than or equal to <string2>.
EquStrI <string1> <string2>: String equality. Like EquStr but does a case insensitive string compare.
NeqStrI <string1> <string2>: String inequality. Like NeqStr but does a case insensitive string compare.
LtStrI <string1> <string2>: String less than. Like LtStr but does a case insensitive string compare.
GtStrI <string1> <string2>: String greater than. Like GtStr but does a case insensitive string compare.
LteStrI <string1> <string2>: String less than or equal. Like LteStr but does a case insensitive string compare.
GteStrI <string1> <string2>: String greater than or equal. Like GteStr but does a case insensitive string compare.
InChar <string> <num>: Returns the position of the first instance of character <num> within <string>. If <string> is invalid or the character isn’t anywhere in the string, returns -1.
******************** Daedalus specific functions ********************
SizeX: Horizontal size. Returns the horizontal pixel size of the main bitmap.
SizeY: Vertical size. Returns the vertical pixel size of the main bitmap.
SizeCX: Horizontal color size. Returns the horizontal pixel size of the color bitmap.
SizeCY: Vertical color size. Returns the vertical pixel size of the color bitmap.
Get <x> <y>: Get pixel. Returns the state of the pixel at the given coordinates on the main bitmap. Returns off for coordinates not on the bitmap.
GetT <x> <y>: Get temporary pixel. Returns the state of the pixel at the given coordinates on the temporary bitmap.
GetE <x> <y>: Get extra pixel. Returns the state of the pixel at the given coordinates on the extra bitmap.
GetA <num> <x> <y>: Get custom pixel. Returns the state of the pixel at the given coordinates on custom monochrome bitmap <num>.
GetC <x> <y>: Get color pixel. Returns the color value of the pixel at the given coordinates on the color bitmap. Returns black for coordinates not on the bitmap.
GetCT <x> <y>: Get temporary color pixel. Returns the color of the pixel at the given coordinates on the temporary color bitmap.
GetCE <x> <y>: Get extra color pixel. Returns the color of the pixel at the given coordinates on the extra color bitmap.
GetCA <num> <x> <y>: Get custom color pixel. Returns the color value of the pixel at the given coordinates on custom color bitmap <num>.
GetX <x> <y> <dir>: Get texture. Returns the texture of the block at the given coordinates facing the given direction. This means looking at appropriate bits of a pixel in custom color bitmap nTextureWall. If <dir> is -1, returns the color value of the whole pixel.
GetH <x> <y>: Get height. Returns the top elevation of the variable height wall at the given coordinates in a 2D bitmap. If variable height walls aren’t active or there’s no variable height wall at that location, it returns 0.
GetM <x> <y>: Get ground elevation. Returns the value of the pixel at the given coordinates of custom color bitmap nMarkElev.
Get3 <x> <y> <z>: Get 3D pixel. Returns the state of the pixel at the given coordinates of the 3D bitmap within the main bitmap.
Get3T <x> <y> <z>: Get temporary 3D pixel. Returns the state of the pixel at the given coordinates on the temporary 3D bitmap.
Get3E <x> <y> <z>: Get extra 3D pixel. Returns the state of the pixel at the given coordinates on the extra 3D bitmap.
Get3A <num> <x> <y> <z>: Get custom 3D pixel. Returns the state of the pixel at the given coordinates of the 3D bitmap within custom monochrome bitmap <num>.
Get3C <x> <y> <z>: Get 3D color pixel. Returns the color of the pixel at the given coordinates of the 3D bitmap within the color bitmap.
Get3CT <x> <y> <z>: Get temporary 3D color pixel. Returns the color of the pixel at the given coordinates on the temporary 3D color bitmap.
Get3CE <x> <y> <z>: Get extra 3D color pixel. Returns the color of the pixel at the given coordinates on the extra 3D color bitmap.
Get3CA <num> <x> <y> <z>: Get custom 3D color pixel. Returns the color of the pixel at the given coordinates of the 3D bitmap within custom color bitmap <num>.
Get3X <x> <y> <z> <dir>: Get 3D texture. Returns the texture of the block at the given coordinates facing the given direction. This means looking at appropriate bits of a pixel on the 3D bitmap within custom color bitmap nTextureWall.
Get3H <x> <y> <z>: Get 3D height. Returns the top elevation of the variable height wall at the given coordinates in a 3D bitmap.
Get3M <x> <y> <z>: Get 3D ground elevation. Returns the value of the pixel at the given coordinates of the 3D bitmap within custom color bitmap nMarkElev.
Pixels: Count pixels. Returns the number of on pixels in the main bitmap. This is the same value as displayed by the Count Pixels command.
RGB <red> <green> <blue>: Make color. Returns a 24 bit color value given red, green, and blue parts, each ranging from 0 to 255.
RGBR <color>: Red part. Returns the red part of the given color value, a number ranging from 0 to 255.
RGBG <color>: Green part. Returns the green part of the given color value, a number ranging from 0 to 255.
RGBB <color>: Blue part. Returns the blue part of the given color value, a number ranging from 0 to 255.
GrayN <num>: Grayscale color. Returns a 24 bit color value given the intensity to use, ranging from 0 to 255.
Light <color>: Lighten color. Returns a color twice as light, half way between it and white.
Dark <color>: Darken color. Returns a color twice as dark, half way between it and black.
Shade <color> <num>: Shade color. Returns the color darkened (for negative numbers) or lightened (for positive numbers). The shading number should range from -100 to 100, where the farther it is from 0, the darker or lighter the color.
Blend <color1> <color2>: Blend colors. Returns a color half way between <color1> and <color2>.
Hue <num>: Rainbow hue. Returns a color of the rainbow. The hue number should range from 0 to 360, where 0 is red, 120 is green, and so on. The color range here can be modified by the pattern settings in the Replace Color dialog.
HSL <hue> <saturation> <luminosity>: Make color. Returns a 24 bit color value given hue (ranging from 0 to 3600), saturation (ranging from 0 to 1000), and luminosity (ranging from 0 to 1000) parts.
Dlg: Dialog color. Brings up the Windows Color picker dialog, where you can visually select among a palette of colors or specify a color in terms of red/green/blue or hue/saturation/luminosity. When you leave the dialog, its current color will be returned.
NWSE <north> <west> <south> <east>: Make texture. Returns a 24 bit color value for the textures of a pixel, given the north, west, south, and east textures, each ranging from 0 to 63. Used to make colors for the bitmap defined by nTextureWall.
UD <up> <down>: Make wall. Returns a 24 bit color value for the elevations of a variable height wall, given the top and bottom heights, each ranging from 0 to 4095. The default wall height is 256.
UdU <color>: Extract wall up. Returns the high 12 bits of <color>. This can be used to access the elevation or texture of the top face of blocks, given a pixel from the relevant bitmap.
UdD <color>: Extract wall down. Returns the low 12 bits of <color>. This can be used to access the elevation or texture of the bottom face of blocks, given a pixel from the relevant bitmap.
Timer: Returns the number of seconds that have passed since the program was started or the timer was last reset. This is the same value as displayed by the Query Timer command.
Timer2: Returns the number of milliseconds that have passed. This value rounded to the nearest thousands is the same value as returned by the Timer function and as displayed by the Query Timer command.
Var <num>: Returns the number in custom variable <num>.
Command <string>: Returns the index for the command action in <string>, the same index as used by the Enable and Disable operations, the On Run Command event, and the Autorepeat variable. Returns -1 if <string> doesn’t correspond to any command. The number returned for a particular command is very likely to change from version to version of the program.
Eval <string>: Returns <string> evaluated as a numeric parameter. A stronger version of the Num function, since this will parse and evaluate functions within the string.
Event <num>: Returns whether a system event has happened and is waiting to be processed by the system. Event 0 returns whether a key has been pressed, and Event 1 returns whether a mouse button has been clicked.
Version: Constant. Returns the version of Daedalus, with the major version in the 1000’s place and the minor version in the 100’s place, e.g. 3500 for version 3.5.
FileOpen <file> <num>: Opens the string <file>. If <num> is 0 opens the file for reading, if 1 creates a new file for writing, if 2 appends to an existing file for writing. Returns a handle to the file opened, which is 0 if the open failed. The FileClose operation should be used to close the file when done.
FileReadNum <num>: Returns the next number, stored as text in decimal form, from the open file in handle <num>.
FileReadByte <num>: Returns the next byte from the open file in handle <num>.
FileEnd <num>: Returns whether the file opened for reading in handle <num> is at the end of file, with nothing left to read.
An event is an occurrence in the program which can be made to automatically trigger a macro execution. Events can be manually defined in the Macro Events dialog on the Macros submenu, or automatically defined by command lines. The list of events, the macro variables which define them, and their name in the Macro Events dialog, are below:
Variable Name
nOnMoveOffBitmap On Move Off Bitmap
nOnMoveIntoWall On Move Into Wall
nOnMoveToNewCell On Move To New Cell
nAfterMoveToNewCell After Move To New Cell
nOnFollowToNewCell On Follow To New Cell
nAfterRedrawInside After Redraw Inside
nOnRedrawInside On Redraw Inside
nOnRunCommand On Run Command
nOnLeftClick On Left Mouse Click
nOnRightClick On Right Mouse Click
nOnMiddleClick On Middle Mouse Click
nOnPrevClick On Previous Mouse Click
nOnNextClick On Next Mouse Click
nOnMouseMove On Mouse Move
nOnProgramExit On Program Exit
Parameters and return values: When certain event macros are called, custom variables @x, @y, and @z are automatically set beforehand as parameters. Also for some events, custom variables are looked at after the event returns, which change subsequent program behavior.
Motion events: For On Move Off Bitmap, On Move Into Wall, On Move To New Cell, and On Follow To New Cell, @x, @y, and @z contain the new bitmap coordinates the dot is trying to move to, i.e. the coordinate off the bitmap, inside the wall, or another cell. The current location of the dot will be adjacent or nearby these coordinates. After the macro returns, @z determines whether to do the default behavior.
On Move Off Bitmap: If @z is non-zero, the dot won’t move off the
bitmap.
On Move Into Wall: If @z is non-zero, the dot will move into the wall as if it
were space.
On Move To New Cell: If @z is non-zero, the dot won’t move to the new cell.
On Follow to New Cell: If @z is non-zero, the dot will stop at the current
point as if there were a junction there.
After Move To New Cell: When this event macro is run, @x, @y, and @z contain the new coordinates of the dot, which it just moved to.
On Redraw Inside: After the macro returns, if the value of fRedrawWhenBitmapEdited has been changed (toggled from its original value) then the screen won’t be redrawn.
On Run Command: When this event macro is run, @x contains the ASCII value of the key pressed to invoke the command, if any, otherwise @x is zero. @y contains the index of the command about to be run, where this index is the same as returned by the Command function. After the macro returns, if @z is non-zero, the command won’t run. This can be used to disable or override the functionality of commands.
Mouse events: For all mouse events (On Left Mouse Click, On Right Mouse Click, On Middle Mouse Click, On Previous Mouse Click, On Next Mouse Click, and On Mouse Move), @x and @y contain the coordinates clicked on or being passed over. For overhead view this means the bitmap pixel clicked on. For inside view, @x and @y range from (-10000, -10000) for the upper left corner of the window to (10000, 10000) for the lower right. For both views, @z contains the coordinates of the raw pixel within the window clicked on, with the horizontal coordinate in the low 16 bits, and the vertical in the high 16 bits. For all mouse events, after the macro returns, if @z is non-zero, the normal behavior of the click will be skipped, otherwise the normal behavior will be done then.
On Program Exit: After this event macro returns, if @z is non-zero, the program won’t terminate.
Texture mapping in the perspective inside view is determined by a special set of bitmaps. Just as there’s a list of custom variables and strings, there’s a special list of custom monochrome bitmaps and custom color bitmaps, beyond the standard main, temporary, and extra bitmaps. The commands on the Apply Texture submenu work by automatically changing these bitmaps appropriately. Custom bitmaps don’t have to be used for textures, in which they also define ceiling markings and variable height walls, and can even just be used as a place for scripts to store extra bitmaps. For purposes of texture mapping, a custom color bitmap is called a texture, and a custom monochrome bitmap is called a mask. Custom bitmaps are accessed through the CopyMask, CopyTexture, SwapMask, SwapTexture, DeleteMask, and DeleteTexture operations.
Texture 0 (or the texture indicated by nTextureWall) determines which texture bitmaps are displayed where. For each block in the inside view, the corresponding pixel in texture 0 determines the texture for each of the block’s four walls. In the 24 bit color value in each pixel of texture 0, the low 6 bits 0-5 determine the texture of the wall facing direction 0 or North, bits 6-11 the texture of direction 1 or West, bits 12-17 direction 2 or South, and the high 6 bits 18-23 the texture of direction 3 or East. The number contained in each set of bits determines the index of the texture and mask bitmaps to apply to that wall. If this number is zero, or the desired pixel is outside the bounds of texture 0, then the wall has no texture. Note 6 bits can store numbers from 0-63, and since value 0 is special indicating no texture, that means the maximum number of different wall textures that can be displayed at a time is 63.
If variable fTextureDual is set, then texture bits are interpreted differently. When set, the low 12 bits 0-11 of a texture index indicate the texture bitmap for the north and south faces, and the high 12 bits 12-23 of the texture index indicate the texture for the west and east faces. That means walls will have the same north/south and west/east face textures. 12 bits can store numbers from 0-4095, which means this option allows 4095 different wall textures to be displayed at a time, with the limitation of opposite sides of walls having the same texture. If variable fTextureDual2 is set, then the fTextureDual variable will instead cause the two textures to be duplicated on the north/west faces of blocks for bits 0-11, and south/east faces for bits 12-23.
The texture and mask bitmaps at a non-zero index together determine the texture mapping to display on a wall. If the texture bitmap exists, and the mask bitmap doesn’t, then the wall will be solidly covered by the color texture, same as the result produced by the Color Walls apply texture command. If the mask bitmap exists, and the texture bitmap doesn’t, then the wall will have the mask bitmap overlaying it, i.e. a black or white etching on the normal wall color, same as the result produced by the Overlay Walls command. If both bitmaps exist, then the wall will have the color texture overlaying it, same as the results produced by the Color Overlay Walls command. If neither bitmap exists, then the wall will have no texture.
Mask 0 (or the mask indicated by nTextureWall) determines how to use the mask bitmap at a particular index, if present. If a pixel in mask 0 corresponding to a block is off, or the pixel is outside the bounds of the mask bitmap, then the black pixels in the mask at the actual index are given focus. That means either off pixels in the mask will overlay the wall as black pixels, or on pixels in the mask will appear as pixels from the color texture and off pixels will be the wall’s color. If a pixel in mask 0 is on, then white pixels in the actual mask are given focus. That means either on pixels in the mask will overlay the wall as white pixels, or off pixels in the mask will appear as pixels from the color texture and on pixels will be the wall’s color.
Other parts of the perspective inside view can be texture mapped too. Variable nTexture points to the texture bitmap to use for the background area, for 2D Mazes and the top level of 3D Mazes. Variable nTexture3 points to the texture bitmap to use for the background area for all levels in 3D Mazes except the top level. Variable nTextureGround points to the textures to use for floor and ceiling textures, in which the low 12 bits of each pixel indicate the floor texture, and the high 12 bits the ceiling, where 0 means no texture. Variable nTextureBlock points to the textures to use for the top and bottom surfaces of walls, in which the low 12 bits indicate the top texture, and the high 12 bits the bottom, where 0 means no texture. Variable nTextureElev points to the textures to use for the sides of elevated ground markings, in which the bits are divided the same as for block sides.
IMPORTANT NOTICE: Daedalus and all Maze generation and general graphics routines used in this program are Copyright (C) 1998-2024 by Walter D. Pullen. Permission is granted to freely use, modify, and distribute these routines provided these credits and notices remain unmodified with any altered or distributed versions of the program. The user does have all rights to Mazes and other graphic output they make in Daedalus, like a novel created in a word processor.
More formally: This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful and inspiring, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details, a copy of which is in the LICENSE.HTM included with Daedalus, and at http://www.gnu.org
O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O
* Walter D. "Cruiser1" Pullen :) ! Astara@msn.com *
O Find your way through life's Maze: http://www.astrolog.org/labyrnth.htm O
* "Who am I, What am I? As I am, I am not. But as we are, I AM. And to *
O you my creation, My Perfect Love is your Perfect Freedom. And I will be O
* with you forever and ever, until the End, and then forever more." - GOD *
O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O*O