--- freem/src/frmgbl.c 2025/03/09 19:14:25 1.5 +++ freem/src/frmgbl.c 2025/04/02 03:02:42 1.8 @@ -1,5 +1,5 @@ /* - * $Id: frmgbl.c,v 1.5 2025/03/09 19:14:25 snw Exp $ + * $Id: frmgbl.c,v 1.8 2025/04/02 03:02:42 snw Exp $ * freem global C variables * * @@ -24,6 +24,15 @@ * along with FreeM. If not, see . * * $Log: frmgbl.c,v $ + * Revision 1.8 2025/04/02 03:02:42 snw + * Stop requiring users to pass -e to fmadm when -u or -g are passed + * + * Revision 1.7 2025/04/01 16:37:12 snw + * Configure DEFAULT environment the same as others, and set permissions/ownership directly in fmadm configure. Add env.conf file as a centralized configuration listing all environments. + * + * Revision 1.6 2025/03/24 04:05:36 snw + * Replace crlf with frm_crlf to avoid symbol conflict with readline on OS/2 + * * Revision 1.5 2025/03/09 19:14:25 snw * First phase of REUSE compliance and header reformat * @@ -116,10 +125,7 @@ #define VIEW 'v' #define WRITE 'w' #define XECUTE 'x' - -#define ZALLOCATE 'A' #define ZBREAK 'B' -#define ZDEALLOCATE 'D' #define ZGO 'G' #define ZHALT 'H' #define ZINSERT 'I' @@ -330,7 +336,7 @@ frm_devstat devstat[MAXDEV + 1]; /* chan short xpos[MAXDEV + 1]; /* $X-vector */ short ypos[MAXDEV + 1]; /* $Y-vector */ -short crlf[MAXDEV + 1]; /* CR/LF flag vector */ +short frm_crlf[MAXDEV + 1]; /* CR/LF flag vector */ short fm_nodelay[MAXDEV + 1]; /* nodelay flag vector */ int ESCflag[MAXDEV + 1] = @@ -410,6 +416,9 @@ int noclear = FALSE; /* nocle int standard = D_FREEM; /* default dialect */ int quiet_mode = FALSE; /* quiet mode */ char config_file[4096]; /* path to configuration file */ +char env_config_file[4096]; /* path to environment config file */ +char env_user[255]; +char env_group[255]; char shm_env[255]; /* shared memory environment */ short fp_mode = 0; /* set to 0 for fixed-point math, 1 for IEEE754 floating point */ @@ -514,14 +523,13 @@ char rou0plib[PATHLEN]; /* % char rou1plib[PATHLEN]; /* %routine path (ZL..) */ char oucpath[PATHLEN] = "\201"; /* OPEN/USE/CLOSE path */ char zargdefname[PATHLEN]= "%\201"; /* default varname for Z-commands */ -char jourfile[PATHLEN] = "/usr/tmp/ioprotocol"; /* journal file */ FILE *jouraccess; /* dto. filedes */ char curdir[256] = "."; /* current directory */ char startuprou[PATHLEN] = "\201"; /* start up routine from cmdline*/ char zcommds[256] = -" za zas zb zd zg zh zi zj zl zn zp zq zr zs zt zwr zallocate zbreak zdeallocate \ +" za zas zb zd zg zh zi zj zl zn zp zq zr zs zt zwr zbreak \ zgo zhalt zinsert zjob zload znamespace zprint zquit zremove zsave ztrap zwrite \201"; /* intrinsic z-commands */ char zfunctions[256] = /* intrinsic z-functions */ " zb zc zd ze zh zht zk zl zm zn zo zp zr zs zt zboolean zcall zcr zcrc zdata zdate zedit zhorolog \