- *Scl
- A global variable holding the current fixpoint input scale. See also Numbers and scl.
: (str "123.45")  # Default value of '*Scl' is 0
-> (123)
: (setq *Scl 3)
-> 3
: (str "123.45")
-> (123450)
: 123.4567
-> 123457
: 12.3456
-> 12346
 
- *Sig1
- *Sig2
- Global variables holding (possibly empty) prgbodies, which
will be executed when a SIGUSR1 signal (or a SIGUSR2 signal, respectively) is
sent to the current process. See alsoalarm,sigioand*Hup.
: (de *Sig1 (msg 'SIGUSR1))
-> *Sig1
 
- *Solo
- A global variable indicating exclusive database access. Its value is
0initially, set toT(orNIL) during
cooperative database locks whenlockis successfully called with aNIL(or non-NIL)
argument. See also*Zap.
: *Solo
-> 0
: (lock *DB)
-> NIL
: *Solo
-> NIL
: (rollback)
-> T
: *Solo
-> 0
: (lock)
-> NIL
: *Solo
-> T
: (rollback)
-> T
: *Solo
-> T
 
- +Sn
- Prefix class for maintaining indexes according to a modified soundex
algorithm, for tolerant name searches, to +Stringrelations. Typically used in
combination with the+Idxprefix
class. See also Database.
(rel nm (+Sn +Idx +String))  # Name
 
- +String
- Class for string (transient symbol) relations, a subclass of +Symbol. Accepts an optional argument for
the string length (currently not used). See also Database.
(rel nm (+Sn +Idx +String))  # Name, indexed by soundex and substrings
 
- +Swap
- Prefix class for +relations
where the data are to be stored in the value of a separate external symbol
instead of the relation's object. Typically used for data which are relatively
large and/or rarely accessed. Doesn't work with bidirectional relations
(+Jointor+index). See also Database.
(rel pw (+Swap +String))               # Password
(rel nr (+Swap +List +Number))         # List of bignums
 
- +Symbol
- Class for symbolic relations, a subclass of +relation. Objects of that class typically
maintain internal symbols, as opposed to the more often-used+Stringfor transient symbols. See also Database.
(rel perm (+List +Symbol))  # Permission list
 
- same/3
- Pilog predicate that succeeds if the first
argument matches the result of applying the getalgorithm to the following arguments.
Typically used as filter predicate inselect/3database queries. See alsoisa/2,bool/3,range/3,head/3,fold/3,part/3andtolr/3.
: (?
   @Nr 2
   @Nm "Spare"
   (select (@Item)
      ((nr +Item @Nr) (nm +Item @Nm))
      (same @Nr @Item nr)
      (head @Nm @Item nm) ) )
 @Nr=2 @Nm="Spare" @Item={3-2}
 
- (scan 'tree ['fun] ['any1] ['any2] ['flg])
- Scans through a database tree by applying funto all key-value
pairs.funshould be a function accepting two arguments for key and
value. It defaults toprintln.any1andany2may specify a range of keys. Ifany2is greater thanany1, the traversal will be in
opposite direction. Note that the keys need not to be atomic, depending on the
application's index structure. Ifflgis non-NIL,
partial keys are skipped. See alsotree,iter,initandstep.
: (scan (tree 'nm '+Item))
("ASLRSNSTRSTN" {3-3} . T) {3-3}
("Additive" {3-4}) {3-4}
("Appliance" {3-6}) {3-6}
("Auxiliary Construction" . {3-3}) {3-3}
("Construction" {3-3}) {3-3}
("ENNSNNTTTF" {3-4} . T) {3-4}
("Enhancement Additive" . {3-4}) {3-4}
("Fittings" {3-5}) {3-5}
("GTSTFLNS" {3-6} . T) {3-6}
("Gadget Appliance" . {3-6}) {3-6}
...
: (scan (tree 'nm '+Item) println NIL T T)  # 'flg' is non-NIL
("Auxiliary Construction" . {3-3}) {3-3}
("Enhancement Additive" . {3-4}) {3-4}
("Gadget Appliance" . {3-6}) {3-6}
("Main Part" . {3-1}) {3-1}
("Metal Fittings" . {3-5}) {3-5}
("Spare Part" . {3-2}) {3-2}
("Testartikel" . {3-8}) {3-8}
-> {7-6}
 
- (scl 'num [. prg]) -> num
- If prgis given, it binds*Scldynamically tonumduring the
execution ofprg. Otherwise, it sets*Sclglobally tonum. See also Numbers.
: (scl 0)
-> 0
: (str "123.45")
-> (123)
: (scl 1)
-> 1
: (read)
123.45
-> 1235
: (scl 3)
-> 3
: (str "123.45")
-> (123450)
: (scl 1 (str "123.45"))
-> (1235)
: *Scl
-> 3
 
- (script 'any ..) -> any
- The first anyargument isloaded, with the remaining argumentspassed as variable arguments. They can be
accessed withnext,arg,argsandrest. With that, the syntax in the script is
the same as that in the body of a function with variable arguments (see lambda expressions, "when the CAR is the symbol @").
$ cat x
(* (next) (next))
$ pil +
: (script "x" 3 4)
-> 12
 
- (sect 'lst 'lst) -> lst
- Returns the intersection of the lstarguments. See alsodiff.
: (sect (1 2 3 4) (3 4 5 6))
-> (3 4)
: (sect (1 2 3) (4 5 6))
-> NIL
 
- (seed 'any) -> cnt
- Initializes the random generator's seed, and returns a pseudo random number
in the range -2147483648 .. +2147483647. See also randandhash.
: (seed "init string")
-> 2015582081
: (rand)
-> -706917003
: (rand)
-> 1224196082
: (seed (time))
-> 128285383
 
- (seek 'fun 'lst ..) -> lst
- Applies funtolstand all successive CDRs, until
non-NILis returned. Returns the tail oflststarting
with that element (and stores the non-NILvalue in the global
variable@@), orNILiffundid not return non-NILfor any element oflst. When additionallstarguments are given, they are
passed tofunin the same way. See alsofind,pick.
: (seek '((X) (> (car X) 9)) (1 5 8 12 19 22))
-> (12 19 22)
 
- (select [var ..] cls [hook|T] [var val ..]) -> obj | NIL
- (Debug mode only) Interactive database function, loosely modelled after the
SQL 'SELECT' command. A (limited) front-end to the Pilogselect/3predicate. When called with only aclsargument,selectsteps through all objects of that
class, andshows their complete
contents (this is analog to 'SELECT * from CLS'). Ifclsis
followed by attribute/value specifications, the search is limited to these
values (this is analog to 'SELECT * from CLS where VAR = VAL'). If between theselectfunction andclsone or several attribute names
are supplied, only these attribute (instead of the fullshow) are
printed. These attribute specifications may also be lists, then thegetalgorithm will be used to retrieve related
data. See alsoupdate, Database and Pilog.
: (select +Item)                       # Show all items
{3-1} (+Item)
   nr 1
   pr 29900
   inv 100
   sup {2-1}
   nm "Main Part"
{3-2} (+Item)
   nr 2
   pr 1250
   inv 100
   sup {2-2}
   nm "Spare Part"
.                                      # Stop
-> {3-2}
: (select +Item nr 3)                  # Show only item 3
{3-3} (+Item)
   nr 3
   sup {2-1}
   pr 15700
   nm "Auxiliary Construction"
   inv 100
.                                      # Stop
-> {3-3}
# Show selected attributes for items 3 through 3
: (select nr nm pr (sup nm) +Item nr (3 . 5))
3 "Auxiliary Construction" 157.00 "Active Parts Inc." {3-3}
4 "Enhancement Additive" 9.99 "Seven Oaks Ltd." {3-4}
5 "Metal Fittings" 79.80 "Active Parts Inc." {3-5}
-> NIL
 
- select/3
- Pilog database predicate that allows combined
searches over +indexand other
relations. It takes a list of Pilog variables, a list of generator clauses, and
an arbitrary number of filter clauses. The functionality is described in detail
in The 'select' Predicate. See alsodb/3,isa/2,same/3,bool/3,range/3,head/3,fold/3,part/3,tolr/3andremote/2.
: (?
   @Nr (2 . 5)          # Select all items with numbers between 2 and 5
   @Sup "Active"        # and suppliers matching "Active"
   (select (@Item)                                  # Bind results to '@Item'
      ((nr +Item @Nr) (nm +CuSu @Sup (sup +Item)))  # Generator clauses
      (range @Nr @Item nr)                          # Filter clauses
      (part @Sup @Item sup nm) ) )
 @Nr=(2 . 5) @Sup="Active" @Item={3-3}
 @Nr=(2 . 5) @Sup="Active" @Item={3-5}
-> NIL
 
- (send 'msg 'obj ['any ..]) -> any
- Sends the message msgto the objectobj,
optionally with argumentsany. If the message cannot be located inobj, its classes and superclasses, an error"Bad
message"is issued. See also OO Concepts,try,method,meth,superandextra.
: (send 'stop> Dlg)  # Equivalent to (stop> Dlg)
-> NIL
 
- (seq 'cnt|sym1) -> sym | NIL
- Sequential single step: Returns the first external symbol in the
cnt'th database file, or the next external symbol followingsym1in the database, orNILwhen the end of the
database is reached. See alsofree.
: (pool "db")
-> T
: (seq *DB)
-> {2}
: (seq @)
-> {3}
 
- (set 'var 'any ..) -> any
- Stores new values anyin thevararguments. See
alsosetq,val,swap,conanddef.
: (set 'L '(a b c)  (cdr L) 999)
-> 999
: L
-> (a 999 c)
 
- (set! 'obj 'any) -> any
- Transaction wrapper function for set. Note that for setting the value of entities
typically theset!>message
is used. See alsonew!,request!,put!andinc!.
(set! Obj (* Count Size))  # Setting a non-entity object to a numeric value
 
- (setq var 'any ..) -> any
- Stores new values anyin thevararguments. See
alsoset,valanddef.
: (setq  A 123  B (list A A))  # Set 'A' to 123, then 'B' to (123 123)
-> (123 123)
 
- (show 'any ['sym|cnt ..]) -> any
- Shows the name, value and property list of a symbol found by applying the
getalgorithm toanyand
the following arguments. See alsoeditandview.
: (setq A 123456)
-> 123456
: (put 'A 'x 1)
-> 1
: (put 'A 'lst (9 8 7))
-> (9 8 7)
: (put 'A 'flg T)
-> T
: (show 'A)
A 123456
   flg
   lst (9 8 7)
   x 1
-> A
: (show 'A 'lst 2)
-> 8
 
- show/1
- Pilog predicate that always succeeds, and shows
the name, value and property list of the argument symbol. See also show.
: (? (db nr +Item 2 @Item) (show @Item))
{3-2} (+Item)
   nm "Spare Part"
   nr 2
   pr 1250
   inv 100
   sup {2-2}
 @Item={3-2}
-> NIL
 
- (sigio 'cnt . prg) -> cnt
- Sets a signal handler prgfor SIGIO on the file descriptorcnt. Returns the file descriptor. See alsoalarm,*Hupand*Sig[12].
# First session
: (sigio (setq *SigSock (port T 4444))  # Register signal handler at UDP port
   (while (udp *SigSock)                # Queue all received data
      (fifo '*SigQueue @) ) )
-> 3
# Second session
: (for I 7 (udp "localhost" 4444 I))  # Send numbers to first session
# First session
: (fifo '*SigQueue)
-> 1
: (fifo '*SigQueue)
-> 2
 
- (size 'any) -> cnt
- Returns the "size" of any. For numbers this is the number of
bytes needed for the value, for external symbols it is the number of bytes it
would occupy in the database, for other symbols it is the number of bytes
occupied by the UTF-8 representation of the name, and for lists it is the total
number of cells in this list and all its sublists. See alsolengthandbytes.
: (size "abc")
-> 3
: (size "äbc")
-> 4
: (size 127)  # One byte
-> 1
: (size 128)  # Two bytes (eight bits plus sign bit!)
-> 2
: (size (1 (2) 3))
-> 4
: (size (1 2 3 .))
-> 3
 
- (skip ['any]) -> sym
- Skips all whitespace (and comments if anyis given) in the
input stream. Returns the next available character, orNILupon end
of file. See alsopeekandeof.
$ cat a
# Comment
abcd
$ pil +
: (in "a" (skip "#"))
-> "a"
 
- (solve 'lst [. prg]) -> lst
- Evaluates a Pilog query and, returns the list
of result sets. If prgis given, it is executed for each result
set, with all Pilog variables bound to their matching values, and returns a list
of the results. See alsopilog,?,goalandprove.
: (solve '((append @X @Y (a b c))))
-> (((@X) (@Y a b c)) ((@X a) (@Y b c)) ((@X a b) (@Y c)) ((@X a b c) (@Y)))
: (solve '((append @X @Y (a b c))) @X)
-> (NIL (a) (a b) (a b c))
 
- (sort 'lst ['fun]) -> lst
- Returns a sorted list by destructively exchanging the elements of
lst. Iffunis given, it is used as a "less than"
predicate for comparisons. Typically,sortis used in combination
with by, giving shorter and often more efficient
solutions than with the predicate function. See also Comparing,group,maxi,minianduniq.
: (sort '(a 3 1 (1 2 3) d b 4 T NIL (a b c) (x y z) c 2))
-> (NIL 1 2 3 4 a b c d (1 2 3) (a b c) (x y z) T)
: (sort '(a 3 1 (1 2 3) d b 4 T NIL (a b c) (x y z) c 2) >)
-> (T (x y z) (a b c) (1 2 3) d c b a 4 3 2 1 NIL)
: (by cadr sort '((1 4 3) (5 1 3) (1 2 4) (3 8 5) (6 4 5)))
-> ((5 1 3) (1 2 4) (1 4 3) (6 4 5) (3 8 5))
 
- (space ['cnt]) -> cnt
- Prints cntspaces, or a single space whencntis
not given. See alsobeep,prinandchar.
: (space)
 -> 1
: (space 1)
 -> 1
: (space 2)
  -> 2
 
- (sp? 'any) -> flg
- Returns Twhen the argumentanyisNIL, or if it is a string (symbol) that consists only of whitespace
characters.
: (sp? "  ")
-> T
: (sp? "ABC")
-> NIL
: (sp? 123)
-> NIL
 
- (split 'lst 'any ..) -> lst
- Splits lstat all places containing an elementanyand returns the resulting list of sublists. See alsostem.
: (split (1 a 2 b 3 c 4 d 5 e 6) 'e 3 'a)
-> ((1) (2 b) (c 4 d 5) (6))
: (mapcar pack (split (chop "The quick brown fox") " "))
-> ("The" "quick" "brown" "fox")
 
- (sqrt 'num ['flg|num]) -> num
- Returns the square root of the numargument. Ifflgis given and non-NIL, the result will be rounded.
If in addition to thatflgis a number, the first argument will be
multiplied with it before doing the square root calculation. See also*/.
: (sqrt 64)
-> 8
: (sqrt 1000)
-> 31
: (sqrt 1000 T)
-> 32
: (sqrt 10000000000000000000000000000000000000000)
-> 100000000000000000000
: (scl 6)
-> 6
: (sqrt 2.0 1.0)
-> 1414214
 
- (ssl 'host 'path . prg) -> any
- Executes prgin an input stream (usingin) from "@bin/ssl" requestingpathfromhost.
: (ssl "picolisp.com" "wiki/?home" (line T))
-> "<!DOCTYPE html>"
 
- (stack ['cnt]) -> cnt | (.. sym . cnt)
- (64-bit version only) Maintains the stack segment size for coroutines (the main stack segment is limited -
while at least one coroutine is running - to four times that size). If called
without a cntargument, or if already one or more coroutines are
running, the current size in kilobytes is returned. Otherwise, the stack segment
size is set to the new value (default 64 kB). If there are running coroutines,
their tags will beconsed in front of
the size. See alsoheap.
$ ulimit -s unlimited  &&  pil +  # Guarantee stack space
: (stack)      # Current size
-> 64          # 64 kB
: (stack 200)  # Set to 200 kB
-> 200
: (co 'inc (let N 0 (loop (yield (inc 'N)))))  # Create two coroutines
-> 1
: (co 'dec (let N 0 (loop (yield (dec 'N)))))
-> -1
: (stack)
-> (dec inc . 200)
 
- (stamp ['dat 'tim]|['T]) -> sym
- Returns a date-time string in the form "YYYY-MM-DD HH:MM:SS". If
datandtimis missing, the current date and time is
used. IfTis passed, the current Coordinated Universal Time (UTC)
is used instead. See alsodateandtime.
: (stamp)
-> "2000-09-12 07:48:04"
: (stamp (date) 0)
-> "2000-09-12 00:00:00"
: (stamp (date 2000 1 1) (time 12 0 0))
-> "2000-01-01 12:00:00"
 
- (state 'var (sym|lst exe [. prg]) ..) -> any
- Implements a finite state machine. The variable varholds the
current state as a symbolic value. When a clause is found that contains the
current state in its CARsym|lstvalue, and where theexein its CADR evaluates to non-NIL, the current
state will be set to that value, the bodyprgin the CDDR will be
executed, and the result returned.Tis a catch-all for any state.
If no state-condition matches,NILis returned. See alsocase,condandjob.
: (de tst ()
   (job '((Cnt . 4))
      (state '(start)
         (start 'run
            (printsp 'start) )
         (run (and (gt0 (dec 'Cnt)) 'run)
            (printsp 'run) )
         (run 'stop
            (printsp 'run) )
         (stop 'start
            (setq Cnt 4)
            (println 'stop) ) ) ) )
-> tst
: (do 12 (tst))
start run run run run stop
start run run run run stop
-> stop
: (pp 'tst)
(de tst NIL
   (job '((Cnt . 4))
      (state '(start)
      ...
-> tst
: (do 3 (tst))
start run run -> run
: (pp 'tst)
(de tst NIL
   (job '((Cnt . 2))
      (state '(run)
      ...
-> tst
 
- (stem 'lst 'any ..) -> lst
- Returns the tail of lstthat does not contain any of theanyarguments.(stem 'lst 'any ..)is equivalent to(last (split 'lst 'any ..)). See alsotailandsplit.
: (stem (chop "abc/def\\ghi") "/" "\\")
-> ("g" "h" "i")
 
- (step 'lst ['flg]) -> any
- Single-steps iteratively through a database tree. lstis a
structure as received frominit. Ifflgis non-NIL, partial keys are skipped. The key for
each returned value is stored in the global variable@@. See alsotree,scan,iter,leafandfetch.
: (setq Q (init (tree 'nr '+Item) 3 5))
-> (((3 . 5) ((3 NIL . {3-3}) (4 NIL . {3-4}) (5 NIL . {3-5}) (6 NIL . {3-6}) (7 NIL . {3-8}))))
: (get (step Q) 'nr)
-> 3
: (get (step Q) 'nr)
-> 4
: (get (step Q) 'nr)
-> 5
: (get (step Q) 'nr)
-> NIL
 
- (store 'tree 'any1 'any2 ['(num1 . num2)])
- Stores a value any2for the keyany1in a database
tree.num1is a database file number, as used innew(defaulting to 1), andnum2a
database block size (defaulting to 256). Whenany2isNIL, the corresponding entry is deleted from the tree. See alsotreeandfetch.
: (store (tree 'nr '+Item) 2 '{3-2})
 
- (str 'sym ['sym1]) -> lst
- (str 'lst) -> sym
- In the first form, the string symis parsed into a list. This
mechanism is also used byload. Ifsym1is given, it should specify a set of characters, andstrwill then return a list of tokens analog toread. The second form does the reverse
operation by building a string from a list. See alsoany,nameandsym.
: (str "a (1 2) b")
-> (a (1 2) b)
: (str '(a "Hello" DEF))
-> "a \"Hello\" DEF"
: (str "a*3+b*4" "_")
-> (a "*" 3 "+" b "*" 4)
 
- (str? 'any) -> sym | NIL
- Returns the argument anywhen it is a transient symbol
(string), otherwiseNIL. See alsosym?,box?andext?.
: (str? 123)
-> NIL
: (str? '{ABC})
-> NIL
: (str? 'abc)
-> NIL
: (str? "abc")
-> "abc"
 
- (strDat 'sym) -> dat
- Converts a string symin the date format of the currentlocaleto adate. See alsoexpDat,$datanddatStr.
: (strDat "2007-06-01")
-> 733134
: (strDat "01.06.2007")
-> NIL
: (locale "DE" "de")
-> NIL
: (strDat "01.06.2007")
-> 733134
: (strDat "1.6.2007")
-> 733134
 
- (strip 'any) -> any
- Strips all leading quotesymbols fromany.
: (strip 123)
-> 123
: (strip '''(a))
-> (a)
: (strip (quote quote a b c))
-> (a b c)
 
- (struct 'num 'any 'any ..) -> any
- (64-bit version only) Creates or extracts data structures, suitable to be
passed to or returned from nativeC
functions. The firstnumargument should be a native value, either
a scalar, or a pointer obtained by calling functions likemalloc().
The second argumentanyis a result
specification, while all following initialization items are stored in the structure
pointed to by the first argument. See also Native C
Calls.
: (scl 2)
-> 2
## /* We assume the following C structure */
## typedef struct value {
##    int x, y;
##    double a, b, c;
##    long z;
##    char nm[4];
## } value;
# Allocate structure
: (setq P (native "@" "malloc" 'N 44))
-> 9204032
# Store two integers, three doubles, one long, and four characters
: (struct P 'N -7 -4 (1.0 0.11 0.22 0.33) (7 . 8) 65 66 67 0)
-> 9204032
# Extract the structure
: (struct P '((I . 2) (1.0 . 3) N (C . 4)))
-> ((7 4) (11 22 33) 7 ("A" "B" "C"))
# Do both in a single call (allowing conversions of data types)
: (struct P
   '((I . 2) (1.0 . 3) N (C . 4))
   -7 -4 (1.0 0.11 0.22 0.33) (7 . 8) 65 66 67 0 )
-> ((7 4) (11 22 33) 7 ("A" "B" "C"))
# De-allocate structure
: (native "@" "free" NIL P)
-> NIL
 
- (sub? 'any1 'any2) -> any2 | NIL
- Returns any2when the string representation ofany1is a substring of the string representation ofany2. See alsopre?,offsetandindex.
: (sub? "def" "abcdefg")
-> "abcdefg"
: (sub? "abb" "abcdefg")
-> NIL
: (sub? NIL "abcdefg")
-> "abcdefg"
: (sub? "def" '(a b c d e f g))
-> "abcdefg"
: (sub? '(d e f) "abcdefg")
-> "abcdefg"
 
- (subr 'sym) -> num
- Converts a Lisp-function that was previously converted with exprback to a SUBR function.
: car
-> 67313448
: (expr 'car)
-> (@ (pass $385260187))
: (subr 'car)
-> 67313448
: car
-> 67313448
 
- (sum 'fun 'lst ..) -> num
- Applies funto each element oflst. When
additionallstarguments are given, their elements are also passed
tofun. Returns the sum of all numeric values returned fromfun.
: (setq A 1  B 2  C 3)
-> 3
: (sum val '(A B C))
-> 6
: (sum * (3 4 5) (5 6 7))        # Vector dot product
-> 74
: (sum                           # Total size of symbol list values
   '((X)
      (and (pair (val X)) (size @)) )
   (what) )
-> 32021
 
- (super ['any ..]) -> any
- Can only be used inside methods. Sends the current message to the current
object This, this time starting the search for a method at the
superclass(es) of the class where the current method was found. See also OO Concepts,extra,method,meth,sendandtry.
(dm stop> ()         # 'stop>' method of current class
   (super)           # Call the 'stop>' method of the superclass
   ... )             # other things
 
- (swap 'var 'any) -> any
- Set the value of vartoany, and return the
previous value. See alsoxchgandset.
: (setq A 7  L (1 2 3))
-> (1 2 3)
: (swap (cdr L) (swap 'A 'xyz))
-> 2
: A
-> xyz
: L
-> (1 7 3)
 
- (sym 'any) -> sym
- Generate the printed representation of anyinto the name of a
new symbolsym. This is the reverse operation ofany. See alsonameandstr.
: (sym '(abc "Hello" 123))
-> "(abc \"Hello\" 123)"
 
- (sym? 'any) -> flg
- Returns Twhen the argumentanyis a symbol. See
alsonum?,atom,pair,str?,box?andext?.
: (sym? 'a)
-> T
: (sym? NIL)
-> T
: (sym? 123)
-> NIL
: (sym? '(a b))
-> NIL
 
- (symbols) -> lst
- (symbols 'lst) -> lst
- (symbols 'lst . prg) -> any
- (symbols 'sym1 'sym2 ..) -> lst
- (64-bit version only) Creates and manages namespaces of internal symbols: In
the first form, the current list of namespaces is returned. In the second form,
the current namespace list is set to lst, and the previous
namespace list is returned. In the third form, the current namespace list is set
tolstduring the execution ofprg, and the result is
returned. In the fourth form,sym1is initialized to a new
namespace if its value isNILand not modified otherwise, andsym1,sym2and all following arguments are set as the
current namespace list. See alsopico,nsp,local,import,internandload.
: (symbols 'myLib 'pico)
-> (pico)
myLib: (de foo (X)
   (bar (inc X)) )
-> foo
myLib: (symbols 'pico)
-> (myLib pico)
: (pp 'foo)
(de foo . NIL)
-> foo
: (pp 'myLib~foo)
(de "foo" (X)
   ("bar" (inc X)) )
-> "foo"
: (symbols '(myLib pico))
-> (pico)
myLib: (pp 'foo)
(de foo (X)
   (bar (inc X)) )
-> foo
myLib:
 
- (sync) -> flg
- Waits for pending data from all family processes. While other processes are
still sending data (via the tellmechanism), aselectsystem call is executed for all file
descriptors and timers in theVALof the global variable*Run. When used in a non-database context,(tell)should be called in the end to inform the parent process
that it may grant synchronization to other processes waiting forsync. In a database context, wheresyncis usually
called bydbSync, this is not
necessary because it is done internally bycommitorrollback.
See alsokeyandwait.
: (or (lock) (sync))       # Ensure database consistency
-> T                       # (numeric process-id if lock failed)
 
- (sys 'any ['any]) -> sym
- Returns or sets a system environment variable.
: (sys "TERM")  # Get current value
-> "xterm"
: (sys "TERM" "vt100")  # Set new value
-> "vt100"
: (sys "TERM")
-> "vt100"