--- freem/src/frmgbl.c 2025/03/24 04:05:36 1.6 +++ freem/src/frmgbl.c 2025/04/03 01:41:02 1.9 @@ -1,5 +1,5 @@ /* - * $Id: frmgbl.c,v 1.6 2025/03/24 04:05:36 snw Exp $ + * $Id: frmgbl.c,v 1.9 2025/04/03 01:41:02 snw Exp $ * freem global C variables * * @@ -24,6 +24,15 @@ * along with FreeM. If not, see . * * $Log: frmgbl.c,v $ + * Revision 1.9 2025/04/03 01:41:02 snw + * New features frozen; prepare 0.63.0-rc1 + * + * 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 * @@ -119,10 +128,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' @@ -413,6 +419,10 @@ 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 env_enabled[10]; char shm_env[255]; /* shared memory environment */ short fp_mode = 0; /* set to 0 for fixed-point math, 1 for IEEE754 floating point */ @@ -517,14 +527,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 \