X-Git-Url: https://perl5.git.perl.org/perl5.git/blobdiff_plain/ed6116ce9b9d13712ea252ee248b0400653db7f9..d5a71f3055c3a1145f32dafabd5c3bba8ef27f4d:/opcode.pl diff --git a/opcode.pl b/opcode.pl index 321188e..eb64e8d 100755 --- a/opcode.pl +++ b/opcode.pl @@ -1,6 +1,8 @@ #!/usr/bin/perl +unlink "opcode.h", "opnames.h"; open(OC, ">opcode.h") || die "Can't create opcode.h: $!\n"; +open(ON, ">opnames.h") || die "Can't create opnames.h: $!\n"; select OC; # Read data. @@ -9,9 +11,15 @@ while () { chop; next unless $_; next if /^#/; - ($key, $name, $check, $flags, $args) = split(/\t+/, $_, 5); + ($key, $desc, $check, $flags, $args) = split(/\t+/, $_, 5); + + warn qq[Description "$desc" duplicates $seen{$desc}\n] if $seen{$desc}; + die qq[Opcode "$key" duplicates $seen{$key}\n] if $seen{$key}; + $seen{$desc} = qq[description of opcode "$key"]; + $seen{$key} = qq[opcode "$key"]; + push(@ops, $key); - $name{$key} = $name; + $desc{$key} = $desc; $check{$key} = $check; $ckname{$check}++; $flags{$key} = $flags; @@ -21,24 +29,49 @@ while () { # Emit defines. $i = 0; -print "typedef enum {\n"; +print <<"END"; +/* !!!!!!! DO NOT EDIT THIS FILE !!!!!!! + This file is built by opcode.pl from its data. Any changes made here + will be lost! +*/ + +#define Perl_pp_i_preinc Perl_pp_preinc +#define Perl_pp_i_predec Perl_pp_predec +#define Perl_pp_i_postinc Perl_pp_postinc +#define Perl_pp_i_postdec Perl_pp_postdec + +END + +print ON <<"END"; +/* !!!!!!! DO NOT EDIT THIS FILE !!!!!!! + This file is built by opcode.pl from its data. Any changes made here + will be lost! +*/ + +typedef enum opcode { +END + for (@ops) { - print "\t", &tab(3,"OP_\U$_,"), "/* ", $i++, " */\n"; + print ON "\t", &tab(3,"OP_\U$_,"), "/* ", $i++, " */\n"; } -print "} opcode;\n"; -print "\n#define MAXO ", scalar @ops, "\n\n"; +print ON "\t", &tab(3,"OP_max"), "\n"; +print ON "} opcode;\n"; +print ON "\n#define MAXO ", scalar @ops, "\n\n"; -# Emit opnames. +# Emit op names and descriptions. print <pp_proto.h' or die "Error creating pp_proto.h: $!"; +open PPSYM, '>pp.sym' or die "Error creating pp.sym: $!"; + +print PP <<"END"; +/* !!!!!!! DO NOT EDIT THIS FILE !!!!!!! + This file is built by opcode.pl from its data. Any changes made here + will be lost! +*/ + +END + +print PPSYM <<"END"; +# +# !!!!!!! DO NOT EDIT THIS FILE !!!!!!! +# This file is built by opcode.pl from its data. Any changes made here +# will be lost! +# + END + +for (sort keys %ckname) { + print PP "PERL_CKDEF(Perl_$_)\n"; + print PPSYM "Perl_$_\n"; +#OP *\t", &tab(3,$_),"(OP* o);\n"; +} + +print PP "\n\n"; + +for (@ops) { + next if /^i_(pre|post)(inc|dec)$/; + print PP "PERL_PPDEF(Perl_pp_$_)\n"; + print PPSYM "Perl_pp_$_\n"; +} + +close PP or die "Error closing pp_proto.h: $!"; +close PPSYM or die "Error closing pp.sym: $!"; + ########################################################################### sub tab { local($l, $t) = @_; @@ -150,437 +278,548 @@ sub tab { $t; } ########################################################################### + +# Some comments about 'T' opcode classifier: + +# Safe to set if the ppcode uses: +# tryAMAGICbin, tryAMAGICun, SETn, SETi, SETu, PUSHn, PUSHTARG, SETTARG, +# SETs(TARG), XPUSHn, XPUSHu, + +# Unsafe to set if the ppcode uses dTARG or [X]RETPUSH[YES|NO|UNDEF] + +# lt and friends do SETs (including ncmp, but not scmp) + +# Additional mode of failure: the opcode can modify TARG before it "used" +# all the arguments (or may call an external function which does the same). +# If the target coincides with one of the arguments ==> kaboom. + +# pp.c pos substr each not OK (RETPUSHUNDEF) +# substr vec also not OK due to LV to target (are they???) +# ref not OK (RETPUSHNO) +# trans not OK (dTARG; TARG = sv_newmortal();) +# ucfirst etc not OK: TMP arg processed inplace +# quotemeta not OK (unsafe when TARG == arg) +# each repeat not OK too due to array context +# pack split - unknown whether they are safe +# sprintf: is calling do_sprintf(TARG,...) which can act on TARG +# before other args are processed. + +# Suspicious wrt "additional mode of failure" (and only it): +# schop, chop, postinc/dec, bit_and etc, negate, complement. + +# Also suspicious: 4-arg substr, sprintf, uc/lc (POK_only), reverse, pack. + +# substr/vec: doing TAINT_off()??? + +# pp_hot.c +# readline - unknown whether it is safe +# match subst not OK (dTARG) +# grepwhile not OK (not always setting) +# join not OK (unsafe when TARG == arg) + +# Suspicious wrt "additional mode of failure": concat (dealt with +# in ck_sassign()), join (same). + +# pp_ctl.c +# mapwhile flip caller not OK (not always setting) + +# pp_sys.c +# backtick glob warn die not OK (not always setting) +# warn not OK (RETPUSHYES) +# open fileno getc sysread syswrite ioctl accept shutdown +# ftsize(etc) readlink telldir fork alarm getlogin not OK (RETPUSHUNDEF) +# umask select not OK (XPUSHs(&PL_sv_undef);) +# fileno getc sysread syswrite tell not OK (meth("FILENO" "GETC")) +# sselect shm* sem* msg* syscall - unknown whether they are safe +# gmtime not OK (list context) + +# Suspicious wrt "additional mode of failure": warn, die, select. + __END__ +# New ops always go at the very end + # Nothing. null null operation ck_null 0 stub stub ck_null 0 -scalar scalar ck_fun s S +scalar scalar ck_fun s% S # Pushy stuff. -pushmark pushmark ck_null s -wantarray wantarray ck_null is +pushmark pushmark ck_null s0 +wantarray wantarray ck_null is0 -const constant item ck_null s -interp interpreted string ck_null 0 +const constant item ck_svconst s$ -gvsv scalar variable ck_null ds -gv glob value ck_null ds -padsv private variable ck_null 0 -padav private array ck_null 0 -padhv private hash ck_null 0 -padany private something ck_null 0 +gvsv scalar variable ck_null ds$ +gv glob value ck_null ds$ +gelem glob elem ck_null d2 S S +padsv private variable ck_null ds0 +padav private array ck_null d0 +padhv private hash ck_null d0 +padany private value ck_null d0 -pushre push regexp ck_null 0 +pushre push regexp ck_null d/ # References and stuff. -rv2gv ref-to-glob cast ck_rvconst ds -sv2len scalar value length ck_null ist -rv2sv ref-to-scalar cast ck_rvconst ds -av2arylen array length ck_null is -rv2cv subroutine reference ck_rvconst d -refgen backslash reference ck_null fst L -ref reference-type operator ck_fun st S? -bless bless ck_fun s S S? +rv2gv ref-to-glob cast ck_rvconst ds1 +rv2sv scalar dereference ck_rvconst ds1 +av2arylen array length ck_null is1 +rv2cv subroutine dereference ck_rvconst d1 +anoncode anonymous subroutine ck_anoncode $ +prototype subroutine prototype ck_null s% S +refgen reference constructor ck_spair m1 L +srefgen single ref constructor ck_null fs1 S +ref reference-type operator ck_fun stu% S? +bless bless ck_fun s@ S S? # Pushy I/O. -backtick backticks ck_null t -glob glob ck_glob t -readline ck_null t -rcatline append I/O operator ck_null t +backtick quoted execution (``, qx) ck_open t% +# glob defaults its first arg to $_ +glob glob ck_glob t@ S? +readline ck_null t% +rcatline append I/O operator ck_null t% # Bindable operators. -regcmaybe regexp comp once ck_fun s S -regcomp regexp compilation ck_null s S -match pattern match ck_match d -subst substitution ck_null dis S -substcont substitution cont ck_null dis -trans character translation ck_null is S +regcmaybe regexp internal guard ck_fun s1 S +regcreset regexp internal reset ck_fun s1 S +regcomp regexp compilation ck_null s| S +match pattern match (m//) ck_match d/ +qr pattern quote (qr//) ck_match s/ +subst substitution (s///) ck_null dis/ S +substcont substitution iterator ck_null dis| +trans transliteration (tr///) ck_null is" S # Lvalue operators. - -sassign scalar assignment ck_null s -aassign list assignment ck_null t L L - -schop scalar chop ck_null t -chop chop ck_chop mt L -defined defined operator ck_lfun is S? -undef undef operator ck_lfun s S? -study study ck_fun st S? - -preinc preincrement ck_lfun s S -predec predecrement ck_lfun s S -postinc postincrement ck_lfun st S -postdec postdecrement ck_lfun st S +# sassign is special-cased for op class + +sassign scalar assignment ck_sassign s0 +aassign list assignment ck_null t2 L L + +chop chop ck_spair mts% L +schop scalar chop ck_null stu% S? +chomp chomp ck_spair mTs% L +schomp scalar chomp ck_null sTu% S? +defined defined operator ck_defined isu% S? +undef undef operator ck_lfun s% S? +study study ck_fun su% S? +pos match position ck_lfun stu% S? + +preinc preincrement (++) ck_lfun dIs1 S +i_preinc integer preincrement (++) ck_lfun dis1 S +predec predecrement (--) ck_lfun dIs1 S +i_predec integer predecrement (--) ck_lfun dis1 S +postinc postincrement (++) ck_lfun dIst1 S +i_postinc integer postincrement (++) ck_lfun disT1 S +postdec postdecrement (--) ck_lfun dIst1 S +i_postdec integer postdecrement (--) ck_lfun disT1 S # Ordinary operators. -pow exponentiation ck_null fst S S - -multiply multiplication ck_null fst S S -divide division ck_null fst S S -modulo modulus ck_null ifst S S -repeat repeat ck_repeat mt L S - -add addition ck_null Ifst S S -intadd integer addition ck_null ifst S S -subtract subtraction ck_null fst S S -concat concatenation ck_concat fst S S - -left_shift left bitshift ck_null ifst S S -right_shift right bitshift ck_null ifst S S - -lt numeric lt ck_null ifs S S -gt numeric gt ck_null ifs S S -le numeric le ck_null ifs S S -ge numeric ge ck_null ifs S S -eq numeric eq ck_null ifs S S -ne numeric ne ck_null ifs S S -ncmp spaceship ck_null ifst S S - -slt string lt ck_null ifs S S -sgt string gt ck_null ifs S S -sle string le ck_null ifs S S -sge string ge ck_null ifs S S -seq string eq ck_null ifs S S -sne string ne ck_null ifs S S -scmp string comparison ck_null ifst S S - -bit_and bit and ck_null fst S S -xor xor ck_null fst S S -bit_or bit or ck_null fst S S - -negate negate ck_null fst S -not not ck_null ifs S -complement 1's complement ck_null fst S +pow exponentiation (**) ck_null fsT2 S S + +multiply multiplication (*) ck_null IfsT2 S S +i_multiply integer multiplication (*) ck_null ifsT2 S S +divide division (/) ck_null IfsT2 S S +i_divide integer division (/) ck_null ifsT2 S S +modulo modulus (%) ck_null IifsT2 S S +i_modulo integer modulus (%) ck_null ifsT2 S S +repeat repeat (x) ck_repeat mt2 L S + +add addition (+) ck_null IfsT2 S S +i_add integer addition (+) ck_null ifsT2 S S +subtract subtraction (-) ck_null IfsT2 S S +i_subtract integer subtraction (-) ck_null ifsT2 S S +concat concatenation (.) ck_concat fsT2 S S +stringify string ck_fun fsT@ S + +left_shift left bitshift (<<) ck_bitop fsT2 S S +right_shift right bitshift (>>) ck_bitop fsT2 S S + +lt numeric lt (<) ck_null Iifs2 S S +i_lt integer lt (<) ck_null ifs2 S S +gt numeric gt (>) ck_null Iifs2 S S +i_gt integer gt (>) ck_null ifs2 S S +le numeric le (<=) ck_null Iifs2 S S +i_le integer le (<=) ck_null ifs2 S S +ge numeric ge (>=) ck_null Iifs2 S S +i_ge integer ge (>=) ck_null ifs2 S S +eq numeric eq (==) ck_null Iifs2 S S +i_eq integer eq (==) ck_null ifs2 S S +ne numeric ne (!=) ck_null Iifs2 S S +i_ne integer ne (!=) ck_null ifs2 S S +ncmp numeric comparison (<=>) ck_null Iifst2 S S +i_ncmp integer comparison (<=>) ck_null ifst2 S S + +slt string lt ck_scmp ifs2 S S +sgt string gt ck_scmp ifs2 S S +sle string le ck_scmp ifs2 S S +sge string ge ck_scmp ifs2 S S +seq string eq ck_null ifs2 S S +sne string ne ck_null ifs2 S S +scmp string comparison (cmp) ck_scmp ifst2 S S + +bit_and bitwise and (&) ck_bitop fst2 S S +bit_xor bitwise xor (^) ck_bitop fst2 S S +bit_or bitwise or (|) ck_bitop fst2 S S + +negate negation (-) ck_null Ifst1 S +i_negate integer negation (-) ck_null ifsT1 S +not not ck_null ifs1 S +complement 1's complement (~) ck_bitop fst1 S # High falutin' math. -atan2 atan2 ck_fun fst S S -sin sin ck_fun fst S? -cos cos ck_fun fst S? -rand rand ck_fun st S? -srand srand ck_fun s S? -exp exp ck_fun fst S? -log log ck_fun fst S? -sqrt sqrt ck_fun fst S? +atan2 atan2 ck_fun fsT@ S S +sin sin ck_fun fsTu% S? +cos cos ck_fun fsTu% S? +rand rand ck_fun sT% S? +srand srand ck_fun s% S? +exp exp ck_fun fsTu% S? +log log ck_fun fsTu% S? +sqrt sqrt ck_fun fsTu% S? + +# Lowbrow math. -int int ck_fun fst S? -hex hex ck_fun ist S? -oct oct ck_fun ist S? -abs abs ck_fun fst S? +int int ck_fun fsTu% S? +hex hex ck_fun fsTu% S? +oct oct ck_fun fsTu% S? +abs abs ck_fun fsTu% S? # String stuff. -length length ck_lengthconst ist S -substr substr ck_fun st S S S? -vec vec ck_fun ist S S S +length length ck_lengthconst isTu% S? +substr substr ck_fun st@ S S S? S? +vec vec ck_fun ist@ S S S -index index ck_index ist S S S? -rindex rindex ck_index ist S S S? +index index ck_index isT@ S S S? +rindex rindex ck_index isT@ S S S? -sprintf sprintf ck_fun mst S L -formline formline ck_formline ms S L -ord ord ck_fun ifst S? -chr chr ck_fun fst S? -crypt crypt ck_fun fst S S -ucfirst upper case first ck_fun ft S -lcfirst lower case first ck_fun ft S -uc upper case ck_fun ft S -lc lower case ck_fun ft S +sprintf sprintf ck_fun_locale mfst@ S L +formline formline ck_fun ms@ S L +ord ord ck_fun ifsTu% S? +chr chr ck_fun fsTu% S? +crypt crypt ck_fun fsT@ S S +ucfirst ucfirst ck_fun_locale fstu% S? +lcfirst lcfirst ck_fun_locale fstu% S? +uc uc ck_fun_locale fstu% S? +lc lc ck_fun_locale fstu% S? +quotemeta quotemeta ck_fun fstu% S? # Arrays. -rv2av array deref ck_rvconst dt -aelemfast known array element ck_null s A S -aelem array element ck_aelem s A S -aslice array slice ck_null m A L +rv2av array dereference ck_rvconst dt1 +aelemfast constant array element ck_null s$ A S +aelem array element ck_null s2 A S +aslice array slice ck_null m@ A L -# Associative arrays. +# Hashes. -each each ck_fun t H -values values ck_fun t H -keys keys ck_fun t H -delete delete ck_null s H S -rv2hv associative array deref ck_rvconst dt -helem associative array elem ck_null s H S -hslice associative array slice ck_null m H L +each each ck_fun % H +values values ck_fun t% H +keys keys ck_fun t% H +delete delete ck_delete % S +exists exists ck_exists is% S +rv2hv hash dereference ck_rvconst dt1 +helem hash element ck_null s2@ H S +hslice hash slice ck_null m@ H L # Explosives and implosives. -unpack unpack ck_fun 0 S S -pack pack ck_fun mst S L -split split ck_split t S S S -join join ck_fun mst S L +unpack unpack ck_fun @ S S +pack pack ck_fun mst@ S L +split split ck_split t@ S S S +join join ck_join mst@ S L # List operators. -list list ck_null m L -lslice list slice ck_null 0 H L L -anonlist anonymous list ck_null m L -anonhash anonymous hash ck_null m L +list list ck_null m@ L +lslice list slice ck_null 2 H L L +anonlist anonymous list ([]) ck_fun ms@ L +anonhash anonymous hash ({}) ck_fun ms@ L -splice splice ck_fun m A S S? L -push push ck_fun imst A L -pop pop ck_shift s A -shift shift ck_shift s A -unshift unshift ck_fun imst A L -sort sort ck_sort m C? L -reverse reverse ck_fun mt L +splice splice ck_fun m@ A S? S? L +push push ck_fun imsT@ A L +pop pop ck_shift s% A +shift shift ck_shift s% A +unshift unshift ck_fun imsT@ A L +sort sort ck_sort m@ C? L +reverse reverse ck_fun mt@ L -grepstart grep ck_grep dm C L -grepwhile grep iterator ck_null dt +grepstart grep ck_grep dm@ C L +grepwhile grep iterator ck_null dt| + +mapstart map ck_grep dm@ C L +mapwhile map iterator ck_null dt| # Range stuff. -range flipflop ck_null 0 S S -flip range (or flip) ck_null 0 S S -flop range (or flop) ck_null 0 +range flipflop ck_null | S S +flip range (or flip) ck_null 1 S S +flop range (or flop) ck_null 1 # Control. -and logical and ck_null 0 -or logical or ck_null 0 -cond_expr conditional expression ck_null 0 -andassign logical and assignment ck_null s -orassign logical or assignment ck_null s - -method method lookup ck_null d -entersubr subroutine entry ck_subr dm L -leavesubr subroutine exit ck_null 0 -caller caller ck_fun t S? -warn warn ck_fun imst L -die die ck_fun dimst L -reset reset ck_fun is S? - -lineseq line sequence ck_null 0 -nextstate next statement ck_null s -dbstate debug next statement ck_null s -unstack unstack ck_null s +and logical and (&&) ck_null | +or logical or (||) ck_null | +xor logical xor ck_null fs2 S S +cond_expr conditional expression ck_null d| +andassign logical and assignment (&&=) ck_null s| +orassign logical or assignment (||=) ck_null s| + +method method lookup ck_method d1 +entersub subroutine entry ck_subr dmt1 L +leavesub subroutine exit ck_null 1 +leavesublv lvalue subroutine exit ck_null 1 +caller caller ck_fun t% S? +warn warn ck_fun imst@ L +die die ck_fun dimst@ L +reset symbol reset ck_fun is% S? + +lineseq line sequence ck_null @ +nextstate next statement ck_null s; +dbstate debug next statement ck_null s; +unstack iteration finalizer ck_null s0 enter block entry ck_null 0 -leave block exit ck_null 0 -scope block ck_null 0 -enteriter foreach loop entry ck_null d +leave block exit ck_null @ +scope block ck_null @ +enteriter foreach loop entry ck_null d{ iter foreach loop iterator ck_null 0 -enterloop loop entry ck_null d -leaveloop loop exit ck_null s -return return ck_fun dm L -last last ck_null ds -next next ck_null ds -redo redo ck_null ds -dump dump ck_null ds -goto goto ck_null ds -exit exit ck_fun ds S? - -nswitch numeric switch ck_null d -cswitch character switch ck_null d +enterloop loop entry ck_null d{ +leaveloop loop exit ck_null 2 +return return ck_null dm@ L +last last ck_null ds} +next next ck_null ds} +redo redo ck_null ds} +dump dump ck_null ds} +goto goto ck_null ds} +exit exit ck_exit ds% S? +# continued below + +#nswitch numeric switch ck_null d +#cswitch character switch ck_null d # I/O. -open open ck_fun ist F S? -close close ck_fun is F? -pipe_op pipe ck_fun is F F +open open ck_open ist@ F S? L +close close ck_fun is% F? +pipe_op pipe ck_fun is@ F F -fileno fileno ck_fun ist F -umask umask ck_fun ist S? -binmode binmode ck_fun s F +fileno fileno ck_fun ist% F +umask umask ck_fun ist% S? +binmode binmode ck_fun s@ F S? -tie tie ck_fun idms R S L -untie untie ck_fun is R -dbmopen dbmopen ck_fun is H S S -dbmclose dbmclose ck_fun is H +tie tie ck_fun idms@ R S L +untie untie ck_fun is% R +tied tied ck_fun s% R +dbmopen dbmopen ck_fun is@ H S S +dbmclose dbmclose ck_fun is% H -sselect select system call ck_select t S S S S -select select ck_select st F? +sselect select system call ck_select t@ S S S S +select select ck_select st@ F? -getc getc ck_eof st F? -read read ck_fun imst F R S S? -enterwrite write ck_fun dis F? -leavewrite write exit ck_null 0 +getc getc ck_eof st% F? +read read ck_fun imst@ F R S S? +enterwrite write ck_fun dis% F? +leavewrite write exit ck_null 1 -prtf printf ck_listiob ims F? L -print print ck_listiob ims F? L +prtf printf ck_listiob ims@ F? L +print print ck_listiob ims@ F? L -sysread sysread ck_fun imst F R S S? -syswrite syswrite ck_fun imst F S S S? +sysopen sysopen ck_fun s@ F S S S? +sysseek sysseek ck_fun s@ F S S +sysread sysread ck_fun imst@ F R S S? +syswrite syswrite ck_fun imst@ F S S? S? -send send ck_fun imst F S S S? -recv recv ck_fun imst F R S S +send send ck_fun imst@ F S S S? +recv recv ck_fun imst@ F R S S -eof eof ck_eof is F? -tell tell ck_fun st F? -seek seek ck_fun s F S S -truncate truncate ck_trunc is S S +eof eof ck_eof is% F? +tell tell ck_fun st% F? +seek seek ck_fun s@ F S S +# truncate really behaves as if it had both "S S" and "F S" +truncate truncate ck_trunc is@ S S -fcntl fcntl ck_fun st F S S -ioctl ioctl ck_fun st F S S -flock flock ck_fun ist F S +fcntl fcntl ck_fun st@ F S S +ioctl ioctl ck_fun st@ F S S +flock flock ck_fun isT@ F S # Sockets. -socket socket ck_fun is F S S S -sockpair socketpair ck_fun is F F S S S +socket socket ck_fun is@ F S S S +sockpair socketpair ck_fun is@ F F S S S -bind bind ck_fun is F S -connect connect ck_fun is F S -listen listen ck_fun is F S -accept accept ck_fun ist F F -shutdown shutdown ck_fun ist F S +bind bind ck_fun is@ F S +connect connect ck_fun is@ F S +listen listen ck_fun is@ F S +accept accept ck_fun ist@ F F +shutdown shutdown ck_fun ist@ F S -gsockopt getsockopt ck_fun is F S S -ssockopt setsockopt ck_fun is F S S S +gsockopt getsockopt ck_fun is@ F S S +ssockopt setsockopt ck_fun is@ F S S S -getsockname getsockname ck_fun is F -getpeername getpeername ck_fun is F +getsockname getsockname ck_fun is% F +getpeername getpeername ck_fun is% F # Stat calls. -lstat lstat ck_ftst 0 F -stat stat ck_ftst 0 F -ftrread -R ck_ftst is F -ftrwrite -W ck_ftst is F -ftrexec -X ck_ftst is F -fteread -r ck_ftst is F -ftewrite -w ck_ftst is F -fteexec -x ck_ftst is F -ftis -e ck_ftst is F -fteowned -O ck_ftst is F -ftrowned -o ck_ftst is F -ftzero -z ck_ftst is F -ftsize -s ck_ftst ist F -ftmtime -M ck_ftst st F -ftatime -A ck_ftst st F -ftctime -C ck_ftst st F -ftsock -S ck_ftst is F -ftchr -c ck_ftst is F -ftblk -b ck_ftst is F -ftfile -f ck_ftst is F -ftdir -d ck_ftst is F -ftpipe -p ck_ftst is F -ftlink -l ck_ftst is F -ftsuid -u ck_ftst is F -ftsgid -g ck_ftst is F -ftsvtx -k ck_ftst is F -fttty -t ck_ftst is F -fttext -T ck_ftst is F -ftbinary -B ck_ftst is F +lstat lstat ck_ftst u- F +stat stat ck_ftst u- F +ftrread -R ck_ftst isu- F +ftrwrite -W ck_ftst isu- F +ftrexec -X ck_ftst isu- F +fteread -r ck_ftst isu- F +ftewrite -w ck_ftst isu- F +fteexec -x ck_ftst isu- F +ftis -e ck_ftst isu- F +fteowned -O ck_ftst isu- F +ftrowned -o ck_ftst isu- F +ftzero -z ck_ftst isu- F +ftsize -s ck_ftst istu- F +ftmtime -M ck_ftst stu- F +ftatime -A ck_ftst stu- F +ftctime -C ck_ftst stu- F +ftsock -S ck_ftst isu- F +ftchr -c ck_ftst isu- F +ftblk -b ck_ftst isu- F +ftfile -f ck_ftst isu- F +ftdir -d ck_ftst isu- F +ftpipe -p ck_ftst isu- F +ftlink -l ck_ftst isu- F +ftsuid -u ck_ftst isu- F +ftsgid -g ck_ftst isu- F +ftsvtx -k ck_ftst isu- F +fttty -t ck_ftst is- F +fttext -T ck_ftst isu- F +ftbinary -B ck_ftst isu- F # File calls. -chdir chdir ck_fun ist S? -chown chown ck_fun imst L -chroot chroot ck_fun ist S? -unlink unlink ck_fun imst L -chmod chmod ck_fun imst L -utime utime ck_fun imst L -rename rename ck_fun ist S S -link link ck_fun ist S S -symlink symlink ck_fun ist S S -readlink readlink ck_fun st S? -mkdir mkdir ck_fun ist S S -rmdir rmdir ck_fun ist S? +chdir chdir ck_fun isT% S? +chown chown ck_fun imsT@ L +chroot chroot ck_fun isTu% S? +unlink unlink ck_fun imsTu@ L +chmod chmod ck_fun imsT@ L +utime utime ck_fun imsT@ L +rename rename ck_fun isT@ S S +link link ck_fun isT@ S S +symlink symlink ck_fun isT@ S S +readlink readlink ck_fun stu% S? +mkdir mkdir ck_fun isT@ S S? +rmdir rmdir ck_fun isTu% S? # Directory calls. -open_dir opendir ck_fun is F S -readdir readdir ck_fun 0 F -telldir telldir ck_fun st F -seekdir seekdir ck_fun s F S -rewinddir rewinddir ck_fun s F -closedir closedir ck_fun is F +open_dir opendir ck_fun is@ F S +readdir readdir ck_fun % F +telldir telldir ck_fun st% F +seekdir seekdir ck_fun s@ F S +rewinddir rewinddir ck_fun s% F +closedir closedir ck_fun is% F # Process control. -fork fork ck_null ist -wait wait ck_null ist -waitpid waitpid ck_fun ist S S -system system ck_exec imst S? L -exec exec ck_exec dimst S? L -kill kill ck_fun dimst L -getppid getppid ck_null ist -getpgrp getpgrp ck_fun ist S? -setpgrp setpgrp ck_fun ist S S -getpriority getpriority ck_fun ist S S -setpriority setpriority ck_fun ist S S S +fork fork ck_null ist0 +wait wait ck_null isT0 +waitpid waitpid ck_fun isT@ S S +system system ck_exec imsT@ S? L +exec exec ck_exec dimsT@ S? L +kill kill ck_fun dimsT@ L +getppid getppid ck_null isT0 +getpgrp getpgrp ck_fun isT% S? +setpgrp setpgrp ck_fun isT@ S? S? +getpriority getpriority ck_fun isT@ S S +setpriority setpriority ck_fun isT@ S S S # Time calls. -time time ck_null ist +# NOTE: MacOS patches the 'i' of time() away later when the interpreter +# is created because in MacOS time() is already returning times > 2**31-1, +# that is, non-integers. + +time time ck_null isT0 tms times ck_null 0 -localtime localtime ck_fun t S? -gmtime gmtime ck_fun t S? -alarm alarm ck_fun ist S? -sleep sleep ck_fun ist S? +localtime localtime ck_fun t% S? +gmtime gmtime ck_fun t% S? +alarm alarm ck_fun istu% S? +sleep sleep ck_fun isT% S? # Shared memory. -shmget shmget ck_fun imst S S S -shmctl shmctl ck_fun imst S S S -shmread shmread ck_fun imst S S S S -shmwrite shmwrite ck_fun ist S S S S +shmget shmget ck_fun imst@ S S S +shmctl shmctl ck_fun imst@ S S S +shmread shmread ck_fun imst@ S S S S +shmwrite shmwrite ck_fun imst@ S S S S # Message passing. -msgget msgget ck_fun imst S S -msgctl msgctl ck_fun imst S S S -msgsnd msgsnd ck_fun imst S S S -msgrcv msgrcv ck_fun imst S S S S S +msgget msgget ck_fun imst@ S S +msgctl msgctl ck_fun imst@ S S S +msgsnd msgsnd ck_fun imst@ S S S +msgrcv msgrcv ck_fun imst@ S S S S S # Semaphores. -semget semget ck_fun imst S S S -semctl semctl ck_fun imst S S S S -semop semop ck_fun imst S S S +semget semget ck_fun imst@ S S S +semctl semctl ck_fun imst@ S S S S +semop semop ck_fun imst@ S S # Eval. -require require ck_fun d S? -dofile do 'file' ck_fun d S -entereval eval string ck_eval d S -leaveeval eval exit ck_null 0 S -evalonce eval constant string ck_null d S -entertry eval block ck_null 0 -leavetry eval block exit ck_null 0 +require require ck_require du% S? +dofile do "file" ck_fun d1 S +entereval eval "string" ck_eval d% S +leaveeval eval "string" exit ck_null 1 S +#evalonce eval constant string ck_null d1 S +entertry eval {block} ck_null | +leavetry eval {block} exit ck_null @ # Get system info. -ghbyname gethostbyname ck_fun 0 S -ghbyaddr gethostbyaddr ck_fun 0 S S +ghbyname gethostbyname ck_fun % S +ghbyaddr gethostbyaddr ck_fun @ S S ghostent gethostent ck_null 0 -gnbyname getnetbyname ck_fun 0 S -gnbyaddr getnetbyaddr ck_fun 0 S S +gnbyname getnetbyname ck_fun % S +gnbyaddr getnetbyaddr ck_fun @ S S gnetent getnetent ck_null 0 -gpbyname getprotobyname ck_fun 0 S -gpbynumber getprotobynumber ck_fun 0 S +gpbyname getprotobyname ck_fun % S +gpbynumber getprotobynumber ck_fun @ S gprotoent getprotoent ck_null 0 -gsbyname getservbyname ck_fun 0 S S -gsbyport getservbyport ck_fun 0 S S +gsbyname getservbyname ck_fun @ S S +gsbyport getservbyport ck_fun @ S S gservent getservent ck_null 0 -shostent sethostent ck_fun is S -snetent setnetent ck_fun is S -sprotoent setprotoent ck_fun is S -sservent setservent ck_fun is S -ehostent endhostent ck_null is -enetent endnetent ck_null is -eprotoent endprotoent ck_null is -eservent endservent ck_null is -gpwnam getpwnam ck_fun 0 S -gpwuid getpwuid ck_fun 0 S +shostent sethostent ck_fun is% S +snetent setnetent ck_fun is% S +sprotoent setprotoent ck_fun is% S +sservent setservent ck_fun is% S +ehostent endhostent ck_null is0 +enetent endnetent ck_null is0 +eprotoent endprotoent ck_null is0 +eservent endservent ck_null is0 +gpwnam getpwnam ck_fun % S +gpwuid getpwuid ck_fun % S gpwent getpwent ck_null 0 -spwent setpwent ck_null ist -epwent endpwent ck_null ist -ggrnam getgrnam ck_fun 0 S -ggrgid getgrgid ck_fun 0 S +spwent setpwent ck_null is0 +epwent endpwent ck_null is0 +ggrnam getgrnam ck_fun % S +ggrgid getgrgid ck_fun % S ggrent getgrent ck_null 0 -sgrent setgrent ck_null ist -egrent endgrent ck_null ist -getlogin getlogin ck_null st +sgrent setgrent ck_null is0 +egrent endgrent ck_null is0 +getlogin getlogin ck_null st0 # Miscellaneous. -syscall syscall ck_fun ist S L +syscall syscall ck_fun imst@ S L + +# For multi-threading +lock lock ck_rfun s% S +threadsv per-thread value ck_null ds0 + +# Control (contd.) +setstate set statement info ck_null s; +method_named method with known name ck_null d$