gloo-lang 1.0.1 → 1.2.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitignore +1 -0
- data/.ruby-gemset +1 -0
- data/.ruby-version +1 -0
- data/lib/VERSION +1 -1
- data/lib/gloo_lang/app/engine.rb +47 -12
- data/lib/gloo_lang/app/log.rb +42 -3
- data/lib/gloo_lang/app/platform.rb +8 -0
- data/lib/gloo_lang/core/heap.rb +2 -2
- data/lib/gloo_lang/persist/disc_mech.rb +87 -0
- data/lib/gloo_lang/persist/file_loader.rb +3 -2
- data/lib/gloo_lang/persist/file_saver.rb +2 -1
- data/lib/gloo_lang/persist/persist_man.rb +6 -19
- metadata +5 -81
- data/Gemfile.lock +0 -68
- data/lib/gloo_lang/app/help.rb +0 -118
- data/lib/gloo_lang/help/app/application.txt +0 -22
- data/lib/gloo_lang/help/app/configuration.txt +0 -7
- data/lib/gloo_lang/help/app/default_help.txt +0 -14
- data/lib/gloo_lang/help/app/logging.txt +0 -16
- data/lib/gloo_lang/help/core/color.txt +0 -31
- data/lib/gloo_lang/help/core/error.txt +0 -33
- data/lib/gloo_lang/help/core/events.txt +0 -21
- data/lib/gloo_lang/help/core/gloo_system.txt +0 -57
- data/lib/gloo_lang/help/core/here.txt +0 -30
- data/lib/gloo_lang/help/core/it.txt +0 -23
- data/lib/gloo_lang/help/core/ops.txt +0 -16
- data/lib/gloo_lang/help/core/pathname.txt +0 -29
- data/lib/gloo_lang/help/objs/basic/alias.txt +0 -36
- data/lib/gloo_lang/help/objs/basic/boolean.txt +0 -28
- data/lib/gloo_lang/help/objs/basic/container.txt +0 -33
- data/lib/gloo_lang/help/objs/basic/decimal.txt +0 -28
- data/lib/gloo_lang/help/objs/basic/integer.txt +0 -27
- data/lib/gloo_lang/help/objs/basic/script.txt +0 -29
- data/lib/gloo_lang/help/objs/basic/string.txt +0 -28
- data/lib/gloo_lang/help/objs/basic/text.txt +0 -27
- data/lib/gloo_lang/help/objs/basic/untyped.txt +0 -22
- data/lib/gloo_lang/help/objs/cli/banner.txt +0 -49
- data/lib/gloo_lang/help/objs/cli/bar.txt +0 -37
- data/lib/gloo_lang/help/objs/cli/colorize.txt +0 -33
- data/lib/gloo_lang/help/objs/cli/confirm.txt +0 -26
- data/lib/gloo_lang/help/objs/cli/menu.txt +0 -44
- data/lib/gloo_lang/help/objs/cli/menu_item.txt +0 -26
- data/lib/gloo_lang/help/objs/cli/pastel.txt +0 -43
- data/lib/gloo_lang/help/objs/cli/prompt.txt +0 -27
- data/lib/gloo_lang/help/objs/cli/select.txt +0 -34
- data/lib/gloo_lang/help/objs/ctrl/each.txt +0 -48
- data/lib/gloo_lang/help/objs/ctrl/repeat.txt +0 -38
- data/lib/gloo_lang/help/objs/data/markdown.txt +0 -25
- data/lib/gloo_lang/help/objs/data/mysql.txt +0 -40
- data/lib/gloo_lang/help/objs/data/query.txt +0 -37
- data/lib/gloo_lang/help/objs/data/sqlite.txt +0 -26
- data/lib/gloo_lang/help/objs/data/table.txt +0 -46
- data/lib/gloo_lang/help/objs/dev/git_repo.txt +0 -36
- data/lib/gloo_lang/help/objs/dev/stats.txt +0 -36
- data/lib/gloo_lang/help/objs/dt/date.txt +0 -23
- data/lib/gloo_lang/help/objs/dt/datetime.txt +0 -24
- data/lib/gloo_lang/help/objs/dt/time.txt +0 -23
- data/lib/gloo_lang/help/objs/ror/erb.txt +0 -37
- data/lib/gloo_lang/help/objs/ror/eval.txt +0 -24
- data/lib/gloo_lang/help/objs/snd/play.txt +0 -23
- data/lib/gloo_lang/help/objs/snd/say.txt +0 -28
- data/lib/gloo_lang/help/objs/system/file.txt +0 -48
- data/lib/gloo_lang/help/objs/system/ssh_exec.txt +0 -30
- data/lib/gloo_lang/help/objs/system/system.txt +0 -32
- data/lib/gloo_lang/help/objs/web/http_get.txt +0 -35
- data/lib/gloo_lang/help/objs/web/http_post.txt +0 -34
- data/lib/gloo_lang/help/objs/web/json.txt +0 -34
- data/lib/gloo_lang/help/objs/web/slack.txt +0 -33
- data/lib/gloo_lang/help/objs/web/teams.txt +0 -30
- data/lib/gloo_lang/help/objs/web/uri.txt +0 -38
- data/lib/gloo_lang/help/verbs/alert.txt +0 -33
- data/lib/gloo_lang/help/verbs/beep.txt +0 -25
- data/lib/gloo_lang/help/verbs/cls.txt +0 -24
- data/lib/gloo_lang/help/verbs/context.txt +0 -43
- data/lib/gloo_lang/help/verbs/create.txt +0 -33
- data/lib/gloo_lang/help/verbs/execute.txt +0 -27
- data/lib/gloo_lang/help/verbs/help.txt +0 -34
- data/lib/gloo_lang/help/verbs/if.txt +0 -37
- data/lib/gloo_lang/help/verbs/list.txt +0 -34
- data/lib/gloo_lang/help/verbs/load.txt +0 -38
- data/lib/gloo_lang/help/verbs/move.txt +0 -42
- data/lib/gloo_lang/help/verbs/put.txt +0 -38
- data/lib/gloo_lang/help/verbs/quit.txt +0 -25
- data/lib/gloo_lang/help/verbs/run.txt +0 -41
- data/lib/gloo_lang/help/verbs/save.txt +0 -26
- data/lib/gloo_lang/help/verbs/show.txt +0 -30
- data/lib/gloo_lang/help/verbs/tell.txt +0 -34
- data/lib/gloo_lang/help/verbs/unless.txt +0 -38
- data/lib/gloo_lang/help/verbs/version.txt +0 -32
- data/lib/gloo_lang/help/verbs/wait.txt +0 -29
- data/lib/gloo_lang/verbs/help.rb +0 -264
- data/lib/gloo_lang/verbs/version.rb +0 -37
data/lib/gloo_lang/app/help.rb
DELETED
@@ -1,118 +0,0 @@
|
|
1
|
-
# Author:: Eric Crane (mailto:eric.crane@mac.com)
|
2
|
-
# Copyright:: Copyright (c) 2019 Eric Crane. All rights reserved.
|
3
|
-
#
|
4
|
-
# Help system.
|
5
|
-
#
|
6
|
-
|
7
|
-
module GlooLang
|
8
|
-
module App
|
9
|
-
class Help
|
10
|
-
|
11
|
-
APPLICATION = 'application'.freeze
|
12
|
-
|
13
|
-
attr_accessor :topics
|
14
|
-
|
15
|
-
#
|
16
|
-
# Set up the help system.
|
17
|
-
# We won't load help topics until we know we need them.
|
18
|
-
#
|
19
|
-
def initialize( engine )
|
20
|
-
@engine = engine
|
21
|
-
@topics = nil
|
22
|
-
end
|
23
|
-
|
24
|
-
#
|
25
|
-
# Show application help.
|
26
|
-
# This is the what is shown when help is run from the CLI.
|
27
|
-
#
|
28
|
-
def show_app_help
|
29
|
-
puts Info.display_title unless @engine.args.quiet?
|
30
|
-
self.show_topic APPLICATION
|
31
|
-
end
|
32
|
-
|
33
|
-
#
|
34
|
-
# Check to see if there is a topic by the given name.
|
35
|
-
#
|
36
|
-
def topic?( name )
|
37
|
-
lazy_load_index
|
38
|
-
|
39
|
-
return @topics.key?( name )
|
40
|
-
end
|
41
|
-
|
42
|
-
#
|
43
|
-
# Is the current topic Markdown?
|
44
|
-
#
|
45
|
-
def topic_is_md?( name )
|
46
|
-
lazy_load_index
|
47
|
-
|
48
|
-
topic_file = @topics[ name ]
|
49
|
-
return topic_file.end_with? '.md'
|
50
|
-
end
|
51
|
-
|
52
|
-
#
|
53
|
-
# Show a help topic, optionally paginaged.
|
54
|
-
# If the content of the help page fits on a single
|
55
|
-
# screen, it won't paginate.
|
56
|
-
#
|
57
|
-
def page_topic( topic )
|
58
|
-
return if @engine.args.quiet?
|
59
|
-
|
60
|
-
data = self.get_topic_data( topic )
|
61
|
-
page = data.lines.count > Settings.page_size( @engine )
|
62
|
-
@engine.platform.show( data, topic_is_md?( topic ), page )
|
63
|
-
end
|
64
|
-
|
65
|
-
#
|
66
|
-
# Show a help topic.
|
67
|
-
#
|
68
|
-
def show_topic( topic )
|
69
|
-
return if @engine.args.quiet?
|
70
|
-
|
71
|
-
data = self.get_topic_data( topic )
|
72
|
-
@engine.platform.show( data, topic_is_md?( topic ), false )
|
73
|
-
end
|
74
|
-
|
75
|
-
#
|
76
|
-
# Get topic data.
|
77
|
-
#
|
78
|
-
def get_topic_data( topic )
|
79
|
-
lazy_load_index
|
80
|
-
|
81
|
-
topic_file = @topics[ topic ]
|
82
|
-
return nil unless topic_file
|
83
|
-
|
84
|
-
File.read topic_file
|
85
|
-
end
|
86
|
-
|
87
|
-
#
|
88
|
-
# Lazy load topic index.
|
89
|
-
# We'll only load the index the first time a help topic
|
90
|
-
# is requested. After that we'll use the cached index.
|
91
|
-
#
|
92
|
-
def lazy_load_index
|
93
|
-
return if @topics
|
94
|
-
|
95
|
-
@topics = {}
|
96
|
-
@engine.log.debug 'loading help file index...'
|
97
|
-
|
98
|
-
pn = File.dirname( File.absolute_path( __FILE__ ) )
|
99
|
-
pn = File.dirname( pn )
|
100
|
-
|
101
|
-
root = File.join( pn, 'help', '**/*.txt' )
|
102
|
-
Dir.glob( root ).each do |txt_file|
|
103
|
-
key = File.basename( txt_file, '.txt' )
|
104
|
-
@topics[ key ] = txt_file
|
105
|
-
end
|
106
|
-
|
107
|
-
root = File.join( pn, 'help', '**/*.md' )
|
108
|
-
Dir.glob( root ).each do |md_file|
|
109
|
-
key = File.basename( md_file, '.md' )
|
110
|
-
@topics[ key ] = md_file
|
111
|
-
end
|
112
|
-
|
113
|
-
@engine.log.debug "Found #{@topics.count} help files"
|
114
|
-
end
|
115
|
-
|
116
|
-
end
|
117
|
-
end
|
118
|
-
end
|
@@ -1,22 +0,0 @@
|
|
1
|
-
GLOO APPLICATION
|
2
|
-
|
3
|
-
DESCRIPTION
|
4
|
-
Gloo scripting language. A scripting language built on ruby.
|
5
|
-
More information coming soon.
|
6
|
-
|
7
|
-
SYNOPSIS
|
8
|
-
gloo [global option] [file]
|
9
|
-
|
10
|
-
GLOBAL OPTIONS
|
11
|
-
--cli - Run in CLI mode
|
12
|
-
- If no options are specified, this is the default.
|
13
|
-
--version - Show application version
|
14
|
-
--help - Show this help page
|
15
|
-
|
16
|
-
FILE
|
17
|
-
TODO: document running a gloo script
|
18
|
-
how to reference files by relative path in gloo folder
|
19
|
-
and also by absolute path
|
20
|
-
|
21
|
-
SEE ALSO
|
22
|
-
application, configuration
|
@@ -1,14 +0,0 @@
|
|
1
|
-
GLOO HELP
|
2
|
-
|
3
|
-
TODO: write this article
|
4
|
-
|
5
|
-
LISTS
|
6
|
-
Show options for object and verb lists
|
7
|
-
|
8
|
-
DETAIL
|
9
|
-
How to get help detail for verbs and objects
|
10
|
-
How to see a help pages
|
11
|
-
How to see a list of help pages (topics)
|
12
|
-
|
13
|
-
SEE ALSO
|
14
|
-
application, configuration
|
@@ -1,16 +0,0 @@
|
|
1
|
-
GLOO APPLICATION LOGGING
|
2
|
-
|
3
|
-
DESCRIPTION
|
4
|
-
Gloo writes to the gloo.log as well as to the console.
|
5
|
-
Debug messages are written to the log only, but other messages
|
6
|
-
are also written to the console unless the application is
|
7
|
-
running in quiet mode.
|
8
|
-
|
9
|
-
CONFIGURATION
|
10
|
-
The application logs folder is in the gloo folder.
|
11
|
-
When gloo is run, the gloo.log file will be written to.
|
12
|
-
|
13
|
-
TAIL
|
14
|
-
Example tail command to watch the gloo log:
|
15
|
-
|
16
|
-
tail -f ~/gloo/logs/gloo.log
|
@@ -1,31 +0,0 @@
|
|
1
|
-
COLOR
|
2
|
-
|
3
|
-
DESCRIPTION
|
4
|
-
The following colors can be used by the show verb to display
|
5
|
-
colored text:
|
6
|
-
|
7
|
-
red
|
8
|
-
blue
|
9
|
-
green
|
10
|
-
white
|
11
|
-
black
|
12
|
-
yellow
|
13
|
-
|
14
|
-
The color names are considered as virtual objects but may
|
15
|
-
also be referenced in variables. See the example below.
|
16
|
-
|
17
|
-
EXAMPLE
|
18
|
-
Here are some examples of expression usage:
|
19
|
-
|
20
|
-
#
|
21
|
-
# Show multiple messages in color
|
22
|
-
#
|
23
|
-
colors [can] :
|
24
|
-
var [string] : red
|
25
|
-
on_load [script] :
|
26
|
-
show "red" (colors.var)
|
27
|
-
show "blue" (blue)
|
28
|
-
show "green" (green)
|
29
|
-
|
30
|
-
SEE ALSO
|
31
|
-
show
|
@@ -1,33 +0,0 @@
|
|
1
|
-
ERROR
|
2
|
-
|
3
|
-
DESCRIPTION
|
4
|
-
Gloo has a special 'error' variable that's not part of the normal
|
5
|
-
object heap. The error will be empty most of the time, but
|
6
|
-
if a command results in an error, this variable will hold the
|
7
|
-
error message until the next command is executed. The error
|
8
|
-
is a string and can be accessed by simply referring to the
|
9
|
-
path-name 'error'.
|
10
|
-
|
11
|
-
EXAMPLE
|
12
|
-
To see the last error:
|
13
|
-
|
14
|
-
> show error
|
15
|
-
|
16
|
-
To run a command that generates an error:
|
17
|
-
|
18
|
-
> put 3 into
|
19
|
-
'put' must include 'into' target
|
20
|
-
|
21
|
-
Then, showing the error
|
22
|
-
|
23
|
-
> show error
|
24
|
-
'put' must include 'into' target
|
25
|
-
|
26
|
-
But, as mentioned, the next command will clear out the last error.
|
27
|
-
If you need to keep track of the result of a command, you should
|
28
|
-
put the error into another object.
|
29
|
-
|
30
|
-
> create err as string
|
31
|
-
> put 3 into
|
32
|
-
> put error into err
|
33
|
-
|
@@ -1,21 +0,0 @@
|
|
1
|
-
EVENTS
|
2
|
-
|
3
|
-
DESCRIPTION
|
4
|
-
Scripts can be written to be triggered by events. The current list is as
|
5
|
-
follows, but it is expected that the list of events will grow.
|
6
|
-
|
7
|
-
on_load - run when a script loads
|
8
|
-
on_unload - run when an object receives an unload message
|
9
|
-
|
10
|
-
TODO: add event types.
|
11
|
-
|
12
|
-
EXAMPLE
|
13
|
-
Show a message when a file is loaded:
|
14
|
-
|
15
|
-
start [container] :
|
16
|
-
on_load [script] : show "Welcome back!" (white)
|
17
|
-
|
18
|
-
Show a message when a file unloaded:
|
19
|
-
|
20
|
-
done [container] :
|
21
|
-
on_unload [script] : show "See ya soon!" (white)
|
@@ -1,57 +0,0 @@
|
|
1
|
-
GLOO SYSTEM OBJECTS
|
2
|
-
|
3
|
-
DESCRIPTION
|
4
|
-
The gloo system objects are virtual objects. That is that they
|
5
|
-
can be accessed like other objects. But the values are set by
|
6
|
-
the system. The values cannot be updated. The other difference
|
7
|
-
is that the virtual objects do not show up in the object heap.
|
8
|
-
|
9
|
-
ACCESS
|
10
|
-
The gloo objects can be accessed through the 'gloo' root level
|
11
|
-
virtual object designation. There is also a shortcut for the virtual
|
12
|
-
object path: '$'. For example, to see the current user:
|
13
|
-
|
14
|
-
> show gloo.user
|
15
|
-
|
16
|
-
Or:
|
17
|
-
|
18
|
-
> show $.user
|
19
|
-
|
20
|
-
Some objects include an '_' to separate words. As an alternative,
|
21
|
-
a '.' can be used instead. The following commands are treated as
|
22
|
-
identical:
|
23
|
-
|
24
|
-
> show gloo.working_dir
|
25
|
-
> show gloo.working.dir
|
26
|
-
> show $.working_dir
|
27
|
-
> show $.working.dir
|
28
|
-
|
29
|
-
OBJECTS
|
30
|
-
|
31
|
-
IDENTITY
|
32
|
-
gloo.hostname # Get the system hostname.
|
33
|
-
gloo.user # Get the logged in User.
|
34
|
-
|
35
|
-
SPECIAL CHARS
|
36
|
-
gloo.line # A carriage return (line feed) character.
|
37
|
-
|
38
|
-
FILE SYSTEM
|
39
|
-
gloo.user_home # Get the user's home directory.
|
40
|
-
gloo.working_dir # Get the working directory.
|
41
|
-
gloo.gloo_home # Get the gloo home directory
|
42
|
-
gloo.gloo_config # Get the gloo configuration directory
|
43
|
-
gloo.gloo_projects # Get the gloo projects directory
|
44
|
-
gloo.gloo_log # Get the gloo logging directory
|
45
|
-
|
46
|
-
SCREEN
|
47
|
-
gloo.screen_lines # Get the number of lines on screen.
|
48
|
-
gloo.screen_cols # Get the number of columns on screen.
|
49
|
-
|
50
|
-
PLATFORM
|
51
|
-
gloo.platform_cpu # Get the platform CPU
|
52
|
-
gloo.platform_os # Get the platform Operating System
|
53
|
-
gloo.platform_version # Get the platform version
|
54
|
-
gloo.platform_windows? # Is the platform Windows?
|
55
|
-
gloo.platform_unix? # Is the platform Unix?
|
56
|
-
gloo.platform_linux? # Is the platform Linux?
|
57
|
-
gloo.platform_mac? # Is the platform Mac?
|
@@ -1,30 +0,0 @@
|
|
1
|
-
HERE
|
2
|
-
|
3
|
-
DESCRIPTION
|
4
|
-
Gloo scripts can use relative referencing to access objects
|
5
|
-
without specifying the full path. This relative referencing is
|
6
|
-
referred to with the 'here' operator: ^
|
7
|
-
|
8
|
-
EXAMPLE
|
9
|
-
In the following script, the here reference is used several times:
|
10
|
-
|
11
|
-
#
|
12
|
-
# Use here reference.
|
13
|
-
#
|
14
|
-
here [can] :
|
15
|
-
s [str] : local string
|
16
|
-
on_load [script] : show ^.s
|
17
|
-
a [can] :
|
18
|
-
s [str] : A string
|
19
|
-
b [can] :
|
20
|
-
s [str] : B string
|
21
|
-
on_load [script] :
|
22
|
-
show ^.s
|
23
|
-
show ^^.s
|
24
|
-
|
25
|
-
A single use of '^' means: refer to an object at the same level
|
26
|
-
as the running script. It tells the interpreter to 'look here'
|
27
|
-
for the object.
|
28
|
-
|
29
|
-
Use of two ^^ here references means to go up a level, and
|
30
|
-
so forth.
|
@@ -1,23 +0,0 @@
|
|
1
|
-
IT
|
2
|
-
|
3
|
-
DESCRIPTION
|
4
|
-
'It' is a special virtual object. 'It' contains the value of
|
5
|
-
the last expression or command run. Not all commands result in
|
6
|
-
a change to the value of it.
|
7
|
-
|
8
|
-
EXAMPLE
|
9
|
-
Get the value of an expression and store it somewhere for later use:
|
10
|
-
|
11
|
-
#
|
12
|
-
# Example of usage of 'it'.
|
13
|
-
#
|
14
|
-
it_example [can] :
|
15
|
-
result [int] :
|
16
|
-
on_load [script] :
|
17
|
-
show 3 + 4
|
18
|
-
put it into ^.result
|
19
|
-
show ^.result
|
20
|
-
|
21
|
-
Running this script will show 7 twice. The first time will be the
|
22
|
-
result of the addition. The second time will be showing the
|
23
|
-
result object.
|
@@ -1,29 +0,0 @@
|
|
1
|
-
PATHNAME
|
2
|
-
|
3
|
-
DESCRIPTION
|
4
|
-
All gloo object data and scripts are stored in a heap of objects or
|
5
|
-
just "the heap". The heap is hierarchical, with some objects having
|
6
|
-
children objects. To reference an object, we use a "pathname". The
|
7
|
-
pathname starts with the root level object then has a period, ".",
|
8
|
-
then the child object name, and so forth. "a.b.c" refers to the "c"
|
9
|
-
object in the "b" container, which is in the "a" container.
|
10
|
-
|
11
|
-
ROOT
|
12
|
-
The word "root" is not needed when referring to objects. In some
|
13
|
-
special cases, "root" can be used to point to the first level of
|
14
|
-
the object heap. One such use would be with the "context" verb.
|
15
|
-
|
16
|
-
EXAMPLE
|
17
|
-
Here is an example of objects and a pathname reference to an
|
18
|
-
object within the hierarchy:
|
19
|
-
|
20
|
-
#
|
21
|
-
# Hierarchical containers.
|
22
|
-
#
|
23
|
-
a [can] :
|
24
|
-
b [can] :
|
25
|
-
c [string] : Hello World
|
26
|
-
on_load [script] : show a.b.c
|
27
|
-
|
28
|
-
SEE ALSO
|
29
|
-
context
|
@@ -1,36 +0,0 @@
|
|
1
|
-
ALIAS OBJECT TYPE
|
2
|
-
NAME: alias
|
3
|
-
SHORTCUT: ln
|
4
|
-
|
5
|
-
DESCRIPTION
|
6
|
-
A pointer to another object.
|
7
|
-
Normal path-name references will refere to the aliased object.
|
8
|
-
To refer to the alias itself, add an * at the end of the path-name.
|
9
|
-
This is neeed, for example, to set the value of the alias.
|
10
|
-
The value of the alias is merely the path-name of the
|
11
|
-
referenced object.
|
12
|
-
|
13
|
-
CHILDREN
|
14
|
-
None
|
15
|
-
|
16
|
-
MESSAGES
|
17
|
-
The alias will reflect the mesages of the object to which
|
18
|
-
it points.
|
19
|
-
The alias itself can receive the following message:
|
20
|
-
resolve - Check to see if the object referenced exists.
|
21
|
-
Sets it to true or false.
|
22
|
-
|
23
|
-
EXAMPLE
|
24
|
-
|
25
|
-
a [can] :
|
26
|
-
s [string] : a string
|
27
|
-
i [integer] : 13
|
28
|
-
ln [alias] : a.s
|
29
|
-
on_load [script] :
|
30
|
-
show a.ln
|
31
|
-
show a.ln*
|
32
|
-
put 'a.i' into a.ln*
|
33
|
-
put 7 into a.ln
|
34
|
-
show a.ln
|
35
|
-
|
36
|
-
SEE ALSO
|
@@ -1,28 +0,0 @@
|
|
1
|
-
BOOLEAN OBJECT TYPE
|
2
|
-
NAME: boolean
|
3
|
-
SHORTCUT: bool
|
4
|
-
|
5
|
-
DESCRIPTION
|
6
|
-
A boolean value.
|
7
|
-
Value will be either true or false.
|
8
|
-
|
9
|
-
CHILDREN
|
10
|
-
None
|
11
|
-
|
12
|
-
MESSAGES
|
13
|
-
not - Set the boolean to the opposite of what it is now.
|
14
|
-
true - Set the boolean to true.
|
15
|
-
false - Set the boolean to false.
|
16
|
-
|
17
|
-
EXAMPLE
|
18
|
-
|
19
|
-
b [can] :
|
20
|
-
flag [boolean] : true
|
21
|
-
on_load [script] :
|
22
|
-
show b.flag
|
23
|
-
put false into b.flag
|
24
|
-
show b.flag
|
25
|
-
tell b.flag to not
|
26
|
-
show b.flag
|
27
|
-
|
28
|
-
SEE ALSO
|
@@ -1,33 +0,0 @@
|
|
1
|
-
CONTAINER OBJECT TYPE
|
2
|
-
NAME: container
|
3
|
-
SHORTCUT: can
|
4
|
-
|
5
|
-
DESCRIPTION
|
6
|
-
A container of other objects.
|
7
|
-
A container is similar to a folder in a file system.
|
8
|
-
It can contain any number of objects including other containers.
|
9
|
-
The container structure provides direct access to any object
|
10
|
-
within it through the object.object.object path-name structure.
|
11
|
-
|
12
|
-
CHILDREN
|
13
|
-
None by default. But any container can have any number of
|
14
|
-
objects added to it.
|
15
|
-
|
16
|
-
MESSAGES
|
17
|
-
count - Count the number of children objects in the container.
|
18
|
-
The result is put in <it>.
|
19
|
-
delete_children - Delete all children objects from the container.
|
20
|
-
show_key_value_tbl - Show a table with key (name) and values
|
21
|
-
for all children in the container.
|
22
|
-
|
23
|
-
EXAMPLE
|
24
|
-
|
25
|
-
can [can] :
|
26
|
-
data [can] :
|
27
|
-
1 : one
|
28
|
-
2 : two
|
29
|
-
3 : three
|
30
|
-
on_load [script] :
|
31
|
-
tell can.data to show_key_value_table
|
32
|
-
|
33
|
-
SEE ALSO
|
@@ -1,28 +0,0 @@
|
|
1
|
-
DECIMAL OBJECT TYPE
|
2
|
-
NAME: decimal
|
3
|
-
SHORTCUT: num
|
4
|
-
|
5
|
-
DESCRIPTION
|
6
|
-
A decimal (numeric) value.
|
7
|
-
|
8
|
-
CHILDREN
|
9
|
-
None
|
10
|
-
|
11
|
-
MESSAGES
|
12
|
-
round - Round to the nearest whole value.
|
13
|
-
If an optional parameter is included, round to the
|
14
|
-
precision specified.
|
15
|
-
|
16
|
-
EXAMPLE
|
17
|
-
|
18
|
-
d [can] :
|
19
|
-
x [decimal] : 100
|
20
|
-
on_load [script] :
|
21
|
-
show d.x
|
22
|
-
put d.x / 3 into d.x
|
23
|
-
show d.x
|
24
|
-
tell d.x to round (1)
|
25
|
-
show d.x
|
26
|
-
|
27
|
-
SEE ALSO
|
28
|
-
integer
|
@@ -1,27 +0,0 @@
|
|
1
|
-
INTEGER OBJECT TYPE
|
2
|
-
NAME: integer
|
3
|
-
SHORTCUT: int
|
4
|
-
|
5
|
-
DESCRIPTION
|
6
|
-
An integer (numeric) value.
|
7
|
-
|
8
|
-
CHILDREN
|
9
|
-
None
|
10
|
-
|
11
|
-
MESSAGES
|
12
|
-
inc - Increment the integer value by 1.
|
13
|
-
dec - Decrement the integer value by 1.
|
14
|
-
|
15
|
-
EXAMPLE
|
16
|
-
|
17
|
-
i [can] :
|
18
|
-
x [integer] : 0
|
19
|
-
on_load [script] :
|
20
|
-
show i.x
|
21
|
-
tell i.x to inc
|
22
|
-
show i.x
|
23
|
-
put i.x * 10 into i.x
|
24
|
-
show i.x
|
25
|
-
|
26
|
-
SEE ALSO
|
27
|
-
decimal
|
@@ -1,29 +0,0 @@
|
|
1
|
-
SCRIPT OBJECT TYPE
|
2
|
-
NAME: script
|
3
|
-
SHORTCUT: cmd
|
4
|
-
|
5
|
-
DESCRIPTION
|
6
|
-
An exectutable script.
|
7
|
-
|
8
|
-
CHILDREN
|
9
|
-
None
|
10
|
-
|
11
|
-
MESSAGES
|
12
|
-
run - Run the script.
|
13
|
-
The script can be run by telling the object or run.
|
14
|
-
It can all be executed with the run verb.
|
15
|
-
|
16
|
-
EXAMPLE
|
17
|
-
|
18
|
-
script [can] :
|
19
|
-
on_load [script] :
|
20
|
-
show "Showing multiple lines..."
|
21
|
-
show script.msg1
|
22
|
-
show script.msg2
|
23
|
-
show script.msg3
|
24
|
-
show "Done."
|
25
|
-
msg1 [string] : one
|
26
|
-
msg2 [string] : two
|
27
|
-
msg3 [string] : three
|
28
|
-
|
29
|
-
SEE ALSO
|
@@ -1,28 +0,0 @@
|
|
1
|
-
STRING OBJECT TYPE
|
2
|
-
NAME: string
|
3
|
-
SHORTCUT: str
|
4
|
-
|
5
|
-
DESCRIPTION
|
6
|
-
A string value.
|
7
|
-
|
8
|
-
CHILDREN
|
9
|
-
None
|
10
|
-
|
11
|
-
MESSAGES
|
12
|
-
up - Convert the string to uppercase.
|
13
|
-
down - Convert the string to lowercase.
|
14
|
-
size - Get the size of the string.
|
15
|
-
|
16
|
-
EXAMPLE
|
17
|
-
|
18
|
-
s [can] :
|
19
|
-
msg [string] : Hello World!
|
20
|
-
on_load [script] :
|
21
|
-
show s.msg
|
22
|
-
tell s.msg to up
|
23
|
-
show s.msg
|
24
|
-
tell s.msg to size
|
25
|
-
show it
|
26
|
-
|
27
|
-
SEE ALSO
|
28
|
-
text
|
@@ -1,27 +0,0 @@
|
|
1
|
-
TEXT OBJECT TYPE
|
2
|
-
NAME: text
|
3
|
-
SHORTCUT: txt
|
4
|
-
|
5
|
-
DESCRIPTION
|
6
|
-
A longer, multi-line text string.
|
7
|
-
Use BEGIN and END to mark the text range.
|
8
|
-
|
9
|
-
CHILDREN
|
10
|
-
None
|
11
|
-
|
12
|
-
MESSAGES
|
13
|
-
edit - Edit the text field in the default editor.
|
14
|
-
page - Show the text, paginated.
|
15
|
-
|
16
|
-
EXAMPLE
|
17
|
-
|
18
|
-
t [container] :
|
19
|
-
msg [txt] : BEGIN
|
20
|
-
I will now write a poem
|
21
|
-
of two lines or less
|
22
|
-
END
|
23
|
-
on_load [script] :
|
24
|
-
show t.msg
|
25
|
-
|
26
|
-
SEE ALSO
|
27
|
-
string
|