=================================================================== RCS file: /home/cvs/OpenXM_contrib2/asir2000/builtin/file.c,v retrieving revision 1.27 retrieving revision 1.33 diff -u -p -r1.27 -r1.33 --- OpenXM_contrib2/asir2000/builtin/file.c 2009/03/13 04:45:15 1.27 +++ OpenXM_contrib2/asir2000/builtin/file.c 2015/08/06 10:01:51 1.33 @@ -45,20 +45,20 @@ * DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE, * PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE. * - * $OpenXM: OpenXM_contrib2/asir2000/builtin/file.c,v 1.26 2008/11/19 13:12:43 ohara Exp $ + * $OpenXM: OpenXM_contrib2/asir2000/builtin/file.c,v 1.32 2015/03/15 19:31:30 ohara Exp $ */ #include "ca.h" #include "parse.h" #include "ox.h" #include "base.h" -#if !defined(VISUAL) +#if !defined(VISUAL) && !defined(__MINGW32__) && !defined(__MINGW64__) #include "unistd.h" #endif #if defined(PARI) #include "genpari.h" #endif -#if defined(VISUAL) +#if defined(VISUAL) || defined(__MINGW32__) || defined(__MINGW64__) #include #include #include @@ -68,6 +68,8 @@ #define R_OK 0x04 #endif +void Psprintf(NODE,STRING *); + void Pget_rootdir(); void Paccess(),Premove_file(); void Pbsave_enc(), Pbload_enc(); @@ -81,6 +83,7 @@ void Pput_word(), Pget_word(); void Ppurge_stdin(); void Pfprintf(); void Pimport(); +void Pgetpid(); extern int des_encryption; extern char *asir_libdir; @@ -114,6 +117,7 @@ struct ftab file_tab[] = { {"bload_compat",Pbload_compat,1}, {"bsave_cmo",Pbsave_cmo,2}, {"bload_cmo",Pbload_cmo,1}, + {"getpid",Pgetpid,0}, {0,0,0}, }; @@ -504,7 +508,7 @@ void Pbload_cmo(NODE arg,Obj *rp) static struct oSTRING rootdir; -#if defined(VISUAL) +#if defined(VISUAL) || defined(__MINGW32__) || defined(__MINGW64__) void get_rootdir(char *name,int len) { LONG ret; @@ -516,11 +520,11 @@ void get_rootdir(char *name,int len) strcpy(name,rootdir.body); return; } - - if ( access("UseCurrentDir",0) >= 0 ) { - GetCurrentDirectory(BUFSIZ,name); + if ( GetModuleFileName(NULL,name,BUFSIZ) ) { slash = strrchr(name,'\\'); - if ( slash ) + *slash = 0; + slash = strrchr(name,'\\'); + if ( slash ) *slash = 0; return; } @@ -583,6 +587,18 @@ void Pget_rootdir(STRING *rp) *rp = &rootdir; } +void Pgetpid(Q *rp) +{ + int id; + +#if defined(VISUAL) || defined(__MINGW32__) || defined(__MINGW64__) + id = GetCurrentProcessId(); +#else + id = getpid(); +#endif + STOQ(id,*rp); +} + #if defined(DES_ENC) void Pbsave_enc(NODE arg,Obj *rp) { @@ -685,7 +701,7 @@ void Paccess(NODE arg,Q *rp) *rp = 0; } -#if defined(VISUAL) +#if defined(VISUAL) || defined(__MINGW32__) || defined(__MINGW64__) int process_id() { return GetCurrentProcessId();