From 3150c6870338b4aecab8b908fda895bbd389d107 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fredrik=20H=C3=BCbinette=20=28Hubbe=29?= <hubbe@hubbe.net> Date: Sun, 5 Apr 1998 20:21:53 -0700 Subject: [PATCH] moved to master.pike.in Rev: lib/master.pike:1.68(DEAD) --- .gitattributes | 1 - lib/master.pike | 826 ------------------------------------------------ 2 files changed, 827 deletions(-) delete mode 100644 lib/master.pike diff --git a/.gitattributes b/.gitattributes index 4d84e43d9a..7624c855ce 100644 --- a/.gitattributes +++ b/.gitattributes @@ -19,7 +19,6 @@ testfont binary /bin/httpd.pike foreign_ident /bin/mkpeep.pike foreign_ident /bin/test_pike.pike foreign_ident -/lib/master.pike foreign_ident /lib/master.pike.in foreign_ident /lib/modules/ADT.pmod/Table.pmod foreign_ident /lib/modules/ADT.pmod/queue.pike foreign_ident diff --git a/lib/master.pike b/lib/master.pike deleted file mode 100644 index 51dc1518d1..0000000000 --- a/lib/master.pike +++ /dev/null @@ -1,826 +0,0 @@ -/* $Id: master.pike,v 1.67 1998/03/22 05:21:34 hubbe Exp $ - * - * Master-file for Pike. - */ - -int is_absolute_path(string p) -{ -#ifdef __NT__ - p=replace(p,"\\","/"); - if(sscanf(p,"%[a-zA-Z]:",string s) && sizeof(s)==1) - return 1; -#endif - return p[0]=='/'; -} - -string *explode_path(string p) -{ -#ifdef __NT__ - p=replace(p,"\\","/"); -#endif - return p/"/"; -} - -string dirname(string x) -{ - string *tmp=explode_path(x); - return tmp[..sizeof(tmp)-2]*"/"; -} - -string basename(string x) -{ - string *tmp=explode_path(x); - return tmp[-1]; -} - - -#define GETCWD_CACHE -#define FILE_STAT_CACHE - -#define UNDEFINED (([])[0]) -#define error(X) throw( ({ (X), backtrace()[0..sizeof(backtrace())-2] }) ) - -string describe_backtrace(mixed *trace); -object low_cast_to_object(string oname, string current_file); - -string _master_file_name; -string pike_library_path; -string *pike_include_path=({}); -string *pike_module_path=({}); -string *pike_program_path=({}); -int want_warnings; - -program compile_string(string data, void|string name) -{ - return compile(cpp(data,name||"-")); -} - -program compile_file(string file) -{ - return compile(cpp(_static_modules.files()->file(file,"r")->read(),file)); -} - - -#ifdef GETCWD_CACHE -string current_path; -int cd(string s) -{ - current_path=0; - return predef::cd(s); -} - -string getcwd() -{ - return current_path || (current_path=predef::getcwd()); -} -#endif - -string combine_path_with_cwd(string path) -{ - return combine_path(is_absolute_path(path)?"/":getcwd(),path); -} - -#ifdef FILE_STAT_CACHE - -#define FILE_STAT_CACHE_TIME 20 - -int invalidate_time; -mapping(string:multiset(string)) dir_cache = ([]); - -mixed *master_file_stat(string x) -{ - string file, dir=combine_path_with_cwd(x); - - file=basename(dir); - dir=dirname(dir); - - multiset(string) d; - if(time() > invalidate_time) - { - dir_cache=([]); - invalidate_time=time()+FILE_STAT_CACHE_TIME; - } - if(zero_type(d=dir_cache[dir])) - { - if(string *tmp=get_dir(dir)) - { - d=dir_cache[dir]=aggregate_multiset(@tmp); - }else{ - dir_cache[dir]=0; - } - } - - if(d && !d[file]) return 0; - - return predef::file_stat(x); -} -#else -#define master_file_stat file_stat -#endif - -mapping (string:string) environment=([]); - - -mixed getenv(string|void s) -{ - if(!s) return environment; - return environment[s]; -} - -void putenv(string var, string val) -{ - environment[var]=val; -} - - -void add_include_path(string tmp) -{ - tmp=combine_path_with_cwd(tmp); - pike_include_path-=({tmp}); - pike_include_path=({tmp})+pike_include_path; -} - -void remove_include_path(string tmp) -{ - tmp=combine_path_with_cwd(tmp); - pike_include_path-=({tmp}); -} - -void add_module_path(string tmp) -{ - tmp=combine_path_with_cwd(tmp); - pike_module_path-=({tmp}); - pike_module_path=({tmp})+pike_module_path; -} - - -void remove_module_path(string tmp) -{ - tmp=combine_path_with_cwd(tmp); - pike_module_path-=({tmp}); -} - - -void add_program_path(string tmp) -{ - tmp=combine_path_with_cwd(tmp); - pike_program_path-=({tmp}); - pike_program_path=({tmp})+pike_program_path; -} - - -void remove_program_path(string tmp) -{ - tmp=combine_path_with_cwd(tmp); - pike_program_path-=({tmp}); -} - - -mapping (string:program) programs=(["/master":object_program(this_object())]); - -#define capitalize(X) (upper_case((X)[..0])+(X)[1..]) - -static program low_findprog(string pname, string ext) -{ - program ret; - array s; - string fname=pname+ext; - if(ret=programs[fname]) return ret; - if( (s=master_file_stat(fname)) - && s[1]>=0 ) - { - switch(ext) - { - case "": - case ".pike": - if ( mixed e=catch { ret=compile_file(fname); } ) - { - if(arrayp(e) && - sizeof(e)==2 && - arrayp(e[1]) && - sizeof(e[1]) == sizeof(backtrace())) - e[1]=({}); - throw(e); - } - break; -#if constant(load_module) - case ".so": - ret=load_module(fname); -#endif /* load_module */ - } - return programs[fname]=ret; - }else{ - return UNDEFINED; - } -} - -static program findprog(string pname, string ext) -{ - switch(ext) - { - case ".pike": - case ".so": - return low_findprog(pname,ext); - - default: - pname+=ext; - return - low_findprog(pname,"") || - low_findprog(pname,".pike") || - low_findprog(pname,".so"); - } -} - -/* This function is called when the driver wants to cast a string - * to a program, this might be because of an explicit cast, an inherit - * or a implict cast. In the future it might receive more arguments, - * to aid the master finding the right program. - */ -program cast_to_program(string pname, string current_file) -{ - string ext; - string nname; - array(string) tmp=explode_path(pname); - - if(sscanf(reverse(tmp[-1]),"%s.%s",ext, nname)) - { - ext="."+reverse(ext); - tmp[-1]=reverse(nname); - pname=tmp*"/"; - }else{ - ext=""; - } - if(is_absolute_path(pname)) - { - pname=combine_path("/",pname); - return findprog(pname,ext); - }else{ - string cwd; - if(current_file) - { - cwd=dirname(current_file); - }else{ - cwd=getcwd(); - } - - if(program ret=findprog(combine_path(cwd,pname),ext)) - return ret; - - foreach(pike_program_path, string path) - if(program ret=findprog(combine_path(path,pname),ext)) - return ret; - - return 0; - } -} - -/* This function is called when an error occurs that is not caught - * with catch(). It's argument consists of: - * ({ error_string, backtrace }) where backtrace is the output from the - * backtrace() efun. - */ -void handle_error(mixed *trace) -{ - predef::trace(0); - werror(describe_backtrace(trace)); -} - -object new(mixed prog, mixed ... args) -{ - if(stringp(prog)) - prog=cast_to_program(prog,backtrace()[-2][0]); - return prog(@args); -} - -/* Note that create is called before add_precompiled_program - */ -void create() -{ - add_constant("basename",basename); - add_constant("dirname",dirname); - add_constant("is_absolute_path",is_absolute_path); - add_constant("explode_path",explode_path); - - add_constant("compile_string",compile_string); - add_constant("compile_file",compile_file); - add_constant("add_include_path",add_include_path); - add_constant("remove_include_path",remove_include_path); - add_constant("add_module_path",add_module_path); - add_constant("remove_module_path",remove_module_path); - add_constant("add_program_path",add_program_path); - add_constant("remove_program_path",remove_program_path); - add_constant("describe_backtrace",describe_backtrace); - add_constant("mkmultiset",lambda(mixed *a) { return aggregate_multiset(@a); }); - add_constant("strlen",sizeof); - add_constant("new",new); - add_constant("clone",new); - add_constant("UNDEFINED",UNDEFINED); - -#ifdef GETCWD_CACHE - add_constant("cd",cd); - add_constant("getcwd",getcwd); -#endif - - random_seed(time() + (getpid() * 0x11111111)); -} - -/* - * This function is called whenever a inherit is called for. - * It is supposed to return the program to inherit. - * The first argument is the argument given to inherit, and the second - * is the file name of the program currently compiling. Note that the - * file name can be changed with #line, or set by compile_string, so - * it can not be 100% trusted to be a filename. - * previous_object(), can be virtually anything in this function, as it - * is called from the compiler. - */ -program handle_inherit(string pname, string current_file) -{ - return cast_to_program(pname, current_file); -} - -mapping (program:object) objects=([object_program(this_object()):this_object()]); - -object low_cast_to_object(string oname, string current_file) -{ - program p; - object o; - - p=cast_to_program(oname, current_file); - if(!p) return 0; - if(!(o=objects[p])) o=objects[p]=p(); - return o; -} - -/* This function is called when the drivers wants to cast a string - * to an object because of an implict or explicit cast. This function - * may also receive more arguments in the future. - */ -object cast_to_object(string oname, string current_file) -{ - if(object o=low_cast_to_object(oname, current_file)) - return o; - error("Cast to object failed\n"); -} - -class dirnode -{ - string dirname; - object tm; - mixed module; - mapping cache=([]); - - void create(string name, object the_master) - { - dirname=name; - tm=the_master; - - if(module=tm->findmodule(dirname+"/module")) - if(mixed tmp=module->_module_value) - module=tmp; - } - - object|program ind(string index) - { - if(module) if(object o=module[index]) return o; - - index = dirname+"/"+index; - if(object o=tm->findmodule(index)) - { - if(mixed tmp=o->_module_value) o=tmp; - return o; - } - return (program) index; - } - - object|program `[](string index) - { - mixed ret; - if(!zero_type(ret=cache[index])) - { - if(ret) return ret; - return UNDEFINED; - } - return cache[index]=ind(index); - } -}; - -static mapping(string:mixed) fc=([]); - -object findmodule(string fullname) -{ - mixed *stat; - object o; - if(!zero_type(o=fc[fullname])) - { - return o; - } - - if(mixed *stat=master_file_stat(fullname+".pmod")) - { - if(stat[1]==-2) - return fc[fullname]=dirnode(fullname+".pmod",this_object()); - } - - if(o=low_cast_to_object(fullname+".pmod","/.")) - return fc[fullname]=o; - -#if constant(load_module) - if(master_file_stat(fullname+".so")) - return fc[fullname]=low_cast_to_object(fullname,"/."); -#endif - - return fc[fullname]=UNDEFINED; -} - -mixed resolv(string identifier, string|void current_file) -{ - mixed ret; - string *tmp,path; - - if(current_file) - { - tmp=explode_path(current_file); - tmp[-1]=identifier; - path=combine_path_with_cwd( tmp*"/"); - ret=findmodule(path); - } - - if(!ret) - { - foreach(pike_module_path, path) - { - string file=combine_path(path,identifier); - if(ret=findmodule(file)) break; - } - - if(!ret) - { - string path=combine_path(pike_library_path+"/modules",identifier); - ret=findmodule(path); - } - } - - - if(ret) - { - if(mixed tmp=ret->_module_value) ret=tmp; - return ret; - } - return UNDEFINED; -} - -/* This function is called when all the driver is done with all setup - * of modules, efuns, tables etc. etc. and is ready to start executing - * _real_ programs. It receives the arguments not meant for the driver - * and an array containing the environment variables on the same form as - * a C program receives them. - */ -void _main(string *argv, string *env) -{ - int i; - object script; - object tmp; - string a,b; - mixed *q; - - foreach(env,a) if(sscanf(a,"%s=%s",a,b)) environment[a]=b; - add_constant("getenv",getenv); - add_constant("putenv",putenv); - - add_constant("write",_static_modules.files()->file("stdout")->write); - - _master_file_name=backtrace()[-1][0]; - q=explode_path(_master_file_name); - pike_library_path = combine_path_with_cwd(q[0..sizeof(q)-2] * "/"); - - add_include_path(pike_library_path+"/include"); - add_module_path(pike_library_path+"/modules"); - add_program_path(getcwd()); - add_module_path(getcwd()); - - _master_file_name=combine_path(getcwd(), _master_file_name); - - q=(getenv("PIKE_INCLUDE_PATH")||"")/":"-({""}); - for(i=sizeof(q)-1;i>=0;i--) add_include_path(q[i]); - - q=(getenv("PIKE_PROGRAM_PATH")||"")/":"-({""}); - for(i=sizeof(q)-1;i>=0;i--) add_program_path(q[i]); - - q=(getenv("PIKE_MODULE_PATH")||"")/":"-({""}); - for(i=sizeof(q)-1;i>=0;i--) add_module_path(q[i]); - - - if(sizeof(argv)>1 && sizeof(argv[1]) && argv[1][0]=='-') - { - tmp=resolv("Getopt"); - - q=tmp->find_all_options(argv,({ - ({"version",tmp->NO_ARG,({"-v","--version"})}), - ({"help",tmp->NO_ARG,({"-h","--help"})}), - ({"execute",tmp->HAS_ARG,({"-e","--execute"})}), - ({"modpath",tmp->HAS_ARG,({"-M","--module-path"})}), - ({"ipath",tmp->HAS_ARG,({"-I","--include-path"})}), - ({"ppath",tmp->HAS_ARG,({"-P","--program-path"})}), - ({"warnings",tmp->NO_ARG,({"-w","--warnings"})}), - ({"ignore",tmp->HAS_ARG,"-ms"}), - ({"ignore",tmp->MAY_HAVE_ARG,"-Ddatpl",0,1}) - }), 1); - - /* Parse -M and -I backwards */ - for(i=sizeof(q)-1;i>=0;i--) - { - switch(q[i][0]) - { - case "modpath": - add_module_path(q[i][1]); - break; - - case "ipath": - add_include_path(q[i][1]); - break; - - case "ppath": - add_program_path(q[i][1]); - break; - - case "warnings": - want_warnings++; - break; - } - } - - foreach(q, mixed *opts) - { - switch(opts[0]) - { - case "version": - werror(version() + " Copyright (C) 1994-1997 Fredrik Hübinette\n" - "Pike comes with ABSOLUTELY NO WARRANTY; This is free software and you are\n" - "welcome to redistribute it under certain conditions; Read the files\n" - "COPYING and DISCLAIMER in the Pike distribution for more details.\n"); - exit(0); - - case "help": - werror("Usage: pike [-driver options] script [script arguments]\n" - "Driver options include:\n" - " -I --include-path=<p>: Add <p> to the include path\n" - " -M --module-path=<p> : Add <p> to the module path\n" - " -P --program-path=<p>: Add <p> to the program path\n" - " -e --execute=<cmd> : Run the given command instead of a script.\n" - " -h --help : see this message\n" - " -v --version : See what version of pike you have.\n" - " -s# : Set stack size\n" - " -m <file> : Use <file> as master object.\n" - " -d -d# : Increase debug (# is how much)\n" - " -t -t# : Increase trace level\n" - ); - exit(0); - - case "execute": - compile_string("#include <simulate.h>\nmixed create(){"+opts[1]+";}")(); - exit(0); - } - } - - argv=tmp->get_args(argv,1); - } - - if(sizeof(argv)==1) - { - argv=explode_path(argv[0]); - argv[-1]="hilfe"; - argv=({ argv*"/" }); - if(!master_file_stat(argv[0])) - { - if(master_file_stat("/usr/local/bin/hilfe")) - argv[0]="/usr/local/bin/hilfe"; - else if(master_file_stat("../bin/hilfe")) - argv[0]="../bin/hilfe"; - else - { - werror("Couldn't find hilfe.\n"); - exit(1); - } - } - }else{ - argv=argv[1..]; - } - - program tmp=(program)argv[0]; - - if(!tmp) - { - werror("Pike: Couldn't find script to execute.\n"); - exit(1); - } - - object script=tmp(); - - if(!script->main) - { - werror("Error: "+argv[0]+" has no main().\n"); - exit(1); - } - - i=script->main(sizeof(argv),argv,env); - if(i >=0) exit(i); -} - -mixed inhibit_compile_errors; - -void set_inhibit_compile_errors(mixed f) -{ - inhibit_compile_errors=f; -} - -string trim_file_name(string s) -{ - if(getenv("SHORT_PIKE_ERRORS")) return basename(s); - return s; -} - -/* - * This function is called whenever a compiling error occurs, - * Nothing strange about it. - * Note that previous_object cannot be trusted in ths function, because - * the compiler calls this function. - */ -void compile_error(string file,int line,string err) -{ - if(!inhibit_compile_errors) - { - werror(sprintf("%s:%d:%s\n",trim_file_name(file),line,err)); - } - else if(functionp(inhibit_compile_errors)) - { - inhibit_compile_errors(file,line,err); - } -} - -/* - * This function is called whenever a compiling error occurs, - * Nothing strange about it. - * Note that previous_object cannot be trusted in ths function, because - * the compiler calls this function. - */ -void compile_warning(string file,int line,string err) -{ - if(!inhibit_compile_errors) - { - if(want_warnings) - werror(sprintf("%s:%d:%s\n",trim_file_name(file),line,err)); - } -} - - -/* This function is called whenever an #include directive is encountered - * it receives the argument for #include and should return the file name - * of the file to include - * Note that previous_object cannot be trusted in ths function, because - * the compiler calls this function. - */ -string handle_include(string f, - string current_file, - int local_include) -{ - string *tmp, path; - - if(local_include) - { - tmp=explode_path(current_file); - tmp[-1]=f; - path=combine_path_with_cwd(tmp*"/"); - if(!master_file_stat(path)) return 0; - } - else - { - foreach(pike_include_path, path) - { - path=combine_path(path,f); - if(master_file_stat(path)) - break; - else - path=0; - } - - if(!path) - { - path=combine_path(pike_library_path+"/include",f); - if(!master_file_stat(path)) path=0; - } - } - - if(path) - { - /* Handle preload */ - - if(path[-1]=='h' && path[-2]=='.' && - master_file_stat(path[0..sizeof(path)-2]+"pre.pike")) - { - cast_to_object(path[0..sizeof(path)-2]+"pre.pike","/"); - } - } - - return path; -} - -string read_include(string f) -{ - return _static_modules->files()->file(f,"r")->read(); -} - -// FIXME -string stupid_describe(mixed m) -{ - switch(string typ=sprintf("%t",m)) - { - case "int": - case "float": - return (string)m; - - case "string": - if(sizeof(m) < 60 && sscanf(m,"%*[-a-zAZ0-9.~`!@#$%^&*()_]%n",int i) && i==sizeof(m)) - { - return "\""+m+"\""; - } - - case "array": - case "mapping": - case "multiset": - return typ+"["+sizeof(m)+"]"; - - default: - return sprintf("%t",m); - } -} - -/* It is possible that this should be a real efun, - * it is currently used by handle_error to convert a backtrace to a - * readable message. - */ -string describe_backtrace(mixed *trace) -{ - int e; - string ret; - - if(arrayp(trace) && sizeof(trace)==2 && stringp(trace[0])) - { - ret=trace[0]; - trace=trace[1]; - }else{ - ret=""; - } - - if(!arrayp(trace)) - { - ret+="No backtrace.\n"; - }else{ - for(e=sizeof(trace)-1;e>=0;e--) - { - mixed tmp; - string row; - - tmp=trace[e]; - if(stringp(tmp)) - { - row=tmp; - } - else if(arrayp(tmp)) - { - row=""; - if(sizeof(tmp)>=3) - { - if(functionp(tmp[2])) - row=function_name(tmp[2]); - else - row="unknown function"; - - row+="("; - for(int e=3;e<sizeof(tmp);e++) - { - row+=stupid_describe(tmp[e])+","; - } - - if(sizeof(tmp)>3) - row=row[..sizeof(row)-2]; - row+=") in "; - } - - if(sizeof(tmp)>=2 && stringp(tmp[0]) && intp(tmp[1])) - { - row+="line "+tmp[1]+" in "+trim_file_name(tmp[0]); - }else{ - row+="Unknown program"; - } - } - else - { - row="Destructed object"; - } - ret+=row+"\n"; - } - } - - return ret; -} -- GitLab