12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007 |
- #ifdef VMS
- #define NO_ZIPUP_H
- #include "zip.h"
- #include "zipup.h"
- #include <stdio.h>
- #include <string.h>
- #include <jpidef.h>
- #include <fab.h> /* Needed only in old environments. */
- #include <nam.h> /* Needed only in old environments. */
- #include <starlet.h>
- #include <ssdef.h>
- #include <stsdef.h>
- #ifdef vax
- # define __VAX 1
- #endif
- #ifdef __VAX
- # define GVTC (unsigned int)
- #else
- # define GVTC
- #endif
- #ifdef UTIL
- # include "vms.h"
- #else
- #include "vms_pk.c"
- #include "vms_im.c"
- #endif
- #ifndef ERR
- #define ERR(x) (((x)&1)==0)
- #endif
- #ifndef NULL
- #define NULL (void*)(0L)
- #endif
- int vms_stat( char *file, stat_t *s)
- {
- int status;
- int staterr;
- struct FAB fab;
- struct NAM_STRUCT nam;
- struct XABFHC fhc;
-
- if( (staterr=stat(file,s)) == 0
- && ( s->st_size >= 0
- || (s->st_mode & S_IFREG) == 0
- )
- ) return staterr;
-
- fab = cc$rms_fab;
- nam = CC_RMS_NAM;
- fhc = cc$rms_xabfhc;
- fab.FAB_NAM = &nam;
- fab.fab$l_xab = (char*)(&fhc);
- #ifdef NAML$C_MAXRSS
- fab.fab$l_dna = (char *) -1;
- fab.fab$l_fna = (char *) -1;
- #endif
- FAB_OR_NAML( fab, nam).FAB_OR_NAML_FNA = file;
- FAB_OR_NAML( fab, nam).FAB_OR_NAML_FNS = strlen( file);
- fab.fab$b_fac = FAB$M_GET;
- status = sys$open(&fab);
- fab.fab$l_xab = (char*)0L;
- sys$close(&fab);
- if( !ERR(status) )
- {
- if( fhc.xab$l_ebk > 0 )
- s->st_size = ( fhc.xab$l_ebk-1 ) * 512 + fhc.xab$w_ffb;
- else if( fab.fab$b_org == FAB$C_IDX
- || fab.fab$b_org == FAB$C_REL
- || fab.fab$b_org == FAB$C_HSH )
-
- s->st_size = fhc.xab$l_hbk * 512;
- else
- s->st_size = fhc.xab$w_ffb;
- return 0;
- }
- else
- return status;
- }
- #define FAC_IZ_ZIP 1955
- #ifndef CTL_FAC_IZ_ZIP
-
- # define CTL_FAC_IZ_ZIP ((0x1 << 12)| FAC_IZ_ZIP)
- # define MSG_FAC_SPEC 0x8000
- #else
-
- # define OLD_STATUS
- # ifndef MSG_FAC_SPEC
- # define MSG_FAC_SPEC 0x0
- # endif
- #endif
- void vms_exit(e)
- int e;
- {
- {
- #ifndef OLD_STATUS
-
- exit( (CTL_FAC_IZ_ZIP << 16) |
- MSG_FAC_SPEC |
- (e << 4) |
- (ziperrors[ e].severity & 0x07)
- );
- #else
-
- exit(
- (e == ZE_OK) ? SS$_NORMAL :
- ((CTL_FAC_IZ_ZIP << 16) |
- MSG_FAC_SPEC |
- (e << 4) |
- (ziperrors[ e].severity & 0x07)
- )
- );
- #endif
- }
- }
- void version_local()
- {
- static ZCONST char CompiledWith[] = "Compiled with %s%s for %s%s%s%s.\n\n";
- #ifdef VMS_VERSION
- char *chrp1;
- char *chrp2;
- char buf[40];
- char vms_vers[ 16];
- int ver_maj;
- #endif
- #ifdef __DECC_VER
- char buf2[40];
- int vtyp;
- #endif
- #ifdef VMS_VERSION
-
- strncpy( vms_vers, VMS_VERSION, sizeof( vms_vers));
- chrp1 = strchr( vms_vers, ' ');
- if (chrp1 != NULL)
- *chrp1 = '\0';
-
- ver_maj = 0;
- chrp1 = strchr( &vms_vers[ 1], '.');
- for (chrp2 = &vms_vers[ 1];
- chrp2 < chrp1;
- ver_maj = ver_maj* 10+ *(chrp2++)- '0');
- #endif
- printf(CompiledWith,
- #ifdef __GNUC__
- "gcc ", __VERSION__,
- #else
- # if defined(DECC) || defined(__DECC) || defined (__DECC__)
- "DEC C",
- # ifdef __DECC_VER
- (sprintf(buf2, " %c%d.%d-%03d",
- ((vtyp = (__DECC_VER / 10000) % 10) == 6 ? 'T' :
- (vtyp == 8 ? 'S' : 'V')),
- __DECC_VER / 10000000,
- (__DECC_VER % 10000000) / 100000, __DECC_VER % 1000), buf2),
- # else
- "",
- # endif
- # else
- # ifdef VAXC
- "VAX C", "",
- # else
- "unknown compiler", "",
- # endif
- # endif
- #endif
- #ifdef VMS_VERSION
- # if defined( __alpha)
- "OpenVMS",
- (sprintf( buf, " (%s Alpha)", vms_vers), buf),
- # elif defined( __ia64)
- "OpenVMS",
- (sprintf( buf, " (%s IA64)", vms_vers), buf),
- # else
- (ver_maj >= 6) ? "OpenVMS" : "VMS",
- (sprintf( buf, " (%s VAX)", vms_vers), buf),
- # endif
- #else
- "VMS",
- "",
- #endif
- #ifdef __DATE__
- " on ", __DATE__
- #else
- "", ""
- #endif
- );
- }
- char *tempname( char *zip)
-
- {
- char *temp_name;
- int sts;
- static int pid;
- static int pid_len;
- struct /* Item list for GETJPIW. */
- {
- short buf_len;
- short itm_cod;
- int *buf;
- int *ret_len;
- int term;
- } jpi_itm_lst = { sizeof( pid), JPI$_PID, &pid, &pid_len };
-
- static char zip_tmp_nam[ 16] = "ZI<unique>.;";
- struct FAB fab;
- struct NAM_STRUCT nam;
- char exp_str[ NAM_MAXRSS+ 1];
- #ifdef VMS_UNIQUE_TEMP_BY_TIME
-
- sprintf( &zip_tmp_nam[ 2], "%08X", time( NULL));
- #else
-
- sts = sys$getjpiw( 0, 0, 0, &jpi_itm_lst, 0, 0, 0);
- sprintf( &zip_tmp_nam[ 2], "%08X", pid);
- #endif
-
- if (tempath != NULL)
- zip = tempath;
-
- fab = cc$rms_fab;
- nam = CC_RMS_NAM;
- fab.FAB_NAM = &nam;
-
- #ifdef NAML$C_MAXRSS
- fab.fab$l_dna = (char *) -1;
- fab.fab$l_fna = (char *) -1;
- #endif
-
- FAB_OR_NAML( fab, nam).FAB_OR_NAML_DNA = zip;
- FAB_OR_NAML( fab, nam).FAB_OR_NAML_DNS = strlen( zip);
-
- FAB_OR_NAML( fab, nam).FAB_OR_NAML_FNA = zip_tmp_nam;
- FAB_OR_NAML( fab, nam).FAB_OR_NAML_FNS = strlen( zip_tmp_nam);
- nam.NAM_ESA = exp_str;
- nam.NAM_ESS = NAM_MAXRSS;
- nam.NAM_NOP = NAM_M_SYNCHK;
- temp_name = NULL;
- sts = sys$parse( &fab, 0, 0);
- if ((sts& STS$M_SEVERITY) == STS$M_SUCCESS)
- {
-
- strcpy( nam.NAM_L_TYPE, ".;");
-
- temp_name = malloc( strlen( nam.NAM_ESA)+ 1);
- if (temp_name != NULL)
- {
- strcpy( temp_name, nam.NAM_ESA);
- }
- }
- return temp_name;
- }
- #define DEF_DEVDIRNAM "SYS$DISK:[].zip"
- char *ziptyp( char *s)
- {
- int status;
- int exp_len;
- struct FAB fab;
- struct NAM_STRUCT nam;
- char result[ NAM_MAXRSS+ 1];
- char exp[ NAM_MAXRSS+ 1];
- char *p;
- fab = cc$rms_fab;
- nam = CC_RMS_NAM;
- fab.FAB_NAM = &nam;
- #ifdef NAML$C_MAXRSS
- fab.fab$l_dna =(char *) -1;
- fab.fab$l_fna = (char *) -1;
- #endif
-
- FAB_OR_NAML( fab, nam).FAB_OR_NAML_FNA = s;
- FAB_OR_NAML( fab, nam).FAB_OR_NAML_FNS = strlen( s);
-
- FAB_OR_NAML( fab, nam).FAB_OR_NAML_DNA = DEF_DEVDIRNAM;
- FAB_OR_NAML( fab, nam).FAB_OR_NAML_DNS = sizeof( DEF_DEVDIRNAM)- 1;
- nam.NAM_ESA = exp;
- nam.NAM_ESS = NAM_MAXRSS;
- nam.NAM_RSA = result;
- nam.NAM_RSS = NAM_MAXRSS;
- status = sys$parse(&fab);
- if ((status & 1) == 0)
- {
-
- if ((p = malloc( strlen( s)+ 1)) != NULL )
- {
- strcpy( p, s);
- }
- return p;
- }
-
- exp_len = nam.NAM_ESL;
-
- nam.NAM_ESA = NULL;
- nam.NAM_ESS = 0;
- status = sys$search(&fab);
- if (status & 1)
- {
- if ((p = malloc( nam.NAM_RSL+ 1)) != NULL )
- {
- result[ nam.NAM_RSL] = '\0';
- strcpy( p, result);
- }
- }
- else
- {
- if ((p = malloc( exp_len+ 1)) != NULL )
- {
- exp[ exp_len] = '\0';
- strcpy( p, exp);
- }
- }
- return p;
- }
- char *vms_file_version( char *s)
- {
- int status;
- struct FAB fab;
- struct NAM_STRUCT nam;
- char *p;
- static char exp[ NAM_MAXRSS+ 1];
- fab = cc$rms_fab;
- nam = CC_RMS_NAM;
- fab.FAB_NAM = &nam;
- #ifdef NAML$C_MAXRSS
- fab.fab$l_dna =(char *) -1;
- fab.fab$l_fna = (char *) -1;
- #endif
-
- FAB_OR_NAML( fab, nam).FAB_OR_NAML_FNA = s;
- FAB_OR_NAML( fab, nam).FAB_OR_NAML_FNS = strlen( s);
- nam.NAM_ESA = exp;
- nam.NAM_ESS = NAM_MAXRSS;
- nam.NAM_NOP = NAM_M_SYNCHK;
- status = sys$parse(&fab);
- if ((status & 1) == 0)
- {
-
- exp[ 0] = '\0';
- p = exp;
- }
- else
- {
-
- p = nam.NAM_L_VER;
- p[ nam.NAM_B_VER] = '\0';
- }
- return p;
- }
- #define DIAG_FLAG (verbose >= 2)
- #define RMS_DEQ_DEFAULT 16384
- #define RMS_MBC_DEFAULT 127
- #define RMS_MBF_DEFAULT 2
- typedef struct
- {
- short buf_len;
- short itm_cod;
- void *buf;
- int *ret_len;
- } jpi_item_t;
- static int rms_defaults_known = 0;
- static unsigned short rms_ext;
- static char rms_mbc;
- static unsigned char rms_mbf;
- unsigned short rms_ext_active;
- char rms_mbc_active;
- unsigned char rms_mbf_active;
- static int rms_ext_len;
- static int rms_mbc_len;
- static int rms_mbf_len;
- #ifndef JPI$_RMS_EXTEND_SIZE
- # define JPI$_RMS_EXTEND_SIZE 542
- #endif
- #ifndef JPI$_RMS_DFMBC
- # define JPI$_RMS_DFMBC 535
- #endif
- #ifndef JPI$_RMS_DFMBFSDK
- # define JPI$_RMS_DFMBFSDK 536
- #endif
- struct
- {
- jpi_item_t rms_ext_itm;
- jpi_item_t rms_mbc_itm;
- jpi_item_t rms_mbf_itm;
- int term;
- } jpi_itm_lst =
- { { 2, JPI$_RMS_EXTEND_SIZE, &rms_ext, &rms_ext_len },
- { 1, JPI$_RMS_DFMBC, &rms_mbc, &rms_mbc_len },
- { 1, JPI$_RMS_DFMBFSDK, &rms_mbf, &rms_mbf_len },
- 0
- };
- int get_rms_defaults()
- {
- int sts;
- sts = sys$getjpiw( 0, 0, 0, &jpi_itm_lst, 0, 0, 0);
- if ((sts& STS$M_SEVERITY) != STS$M_SUCCESS)
- {
-
- rms_defaults_known = -1;
- }
- else
- {
-
- rms_defaults_known = 1;
- }
- if (rms_defaults_known > 0)
- {
-
- rms_ext_active = RMS_DEQ_DEFAULT;
- rms_mbc_active = RMS_MBC_DEFAULT;
- rms_mbf_active = RMS_MBF_DEFAULT;
-
- if (rms_ext > 0)
- {
- rms_ext_active = rms_ext;
- }
-
- if (rms_mbc > 0)
- {
- rms_mbc_active = rms_mbc;
- }
-
- if (rms_mbf > 0)
- {
- rms_mbf_active = rms_mbf;
- }
- }
- if (DIAG_FLAG)
- {
- fprintf( stderr,
- "Get RMS defaults. getjpi sts = %%x%08x.\n",
- sts);
- if (rms_defaults_known > 0)
- {
- fprintf( stderr,
- " Default: deq = %6d, mbc = %3d, mbf = %3d.\n",
- rms_ext, rms_mbc, rms_mbf);
- }
- }
- return sts;
- }
- #ifdef __DECC
- int fopm_id = FOPM_ID;
- int fopr_id = FOPR_ID;
- int fopw_id = FOPW_ID;
- int fhow_id = FHOW_ID;
- int acc_cb( int *id_arg, struct FAB *fab, struct RAB *rab)
- {
- int sts;
- if (rms_defaults_known == 0)
- {
- get_rms_defaults();
- }
- if (rms_defaults_known > 0)
- {
-
- fab-> fab$w_deq = rms_ext_active;
- rab-> rab$b_mbc = rms_mbc_active;
- rab-> rab$b_mbf = rms_mbf_active;
-
- fab-> fab$v_tef = 1;
-
- if (rms_mbf_active > 1)
- {
- rab-> rab$v_rah = 1;
- rab-> rab$v_wbh = 1;
- }
- if (DIAG_FLAG)
- {
- fprintf( mesg,
- "Open callback. ID = %d, deq = %6d, mbc = %3d, mbf = %3d.\n",
- *id_arg, fab-> fab$w_deq, rab-> rab$b_mbc, rab-> rab$b_mbf);
- }
- }
- return 0;
- }
- #endif
- #ifdef __DECC
- #ifdef __CRTL_VER
- #if !defined( __VAX) && (__CRTL_VER >= 70301000)
- #include <unixlib.h>
- int decc_init_done = -1;
- typedef struct
- {
- char *name;
- int value;
- } decc_feat_t;
- decc_feat_t decc_feat_array[] = {
-
- { "DECC$ARGV_PARSE_STYLE", 1 },
-
- { "DECC$EFS_CASE_PRESERVE", 1 },
-
- { "DECC$EFS_CHARSET", 1 },
-
- { (char *)NULL, 0 } };
- static void decc_init( void)
- {
- int feat_index;
- int feat_value;
- int feat_value_max;
- int feat_value_min;
- int i;
- int sts;
- decc_init_done = 1;
- for (i = 0; decc_feat_array[ i].name != NULL; i++)
- {
-
- feat_index = decc$feature_get_index( decc_feat_array[ i].name);
- if (feat_index >= 0)
- {
-
- feat_value = decc$feature_get_value( feat_index, 1);
- feat_value_min = decc$feature_get_value( feat_index, 2);
- feat_value_max = decc$feature_get_value( feat_index, 3);
- if ((decc_feat_array[ i].value >= feat_value_min) &&
- (decc_feat_array[ i].value <= feat_value_max))
- {
-
- if (feat_value != decc_feat_array[ i].value)
- {
- sts = decc$feature_set_value( feat_index,
- 1,
- decc_feat_array[ i].value);
- }
- }
- else
- {
-
- printf( " INVALID DECC FEATURE VALUE, %d: %d <= %s <= %d.\n",
- feat_value,
- feat_value_min, decc_feat_array[ i].name, feat_value_max);
- }
- }
- else
- {
-
- printf( " UNKNOWN DECC FEATURE: %s.\n", decc_feat_array[ i].name);
- }
- }
- }
- #pragma nostandard
- #pragma extern_model save
- #pragma extern_model strict_refdef "LIB$INITIALIZ" 2, nopic, nowrt
- const int spare[ 8] = { 0 };
- #pragma extern_model strict_refdef "LIB$INITIALIZE" 2, nopic, nowrt
- void (*const x_decc_init)() = decc_init;
- #pragma extern_model restore
- #pragma extern_model save
- int LIB$INITIALIZE( void);
- #pragma extern_model strict_refdef
- int dmy_lib$initialize = (int) LIB$INITIALIZE;
- #pragma extern_model restore
- #pragma standard
- #endif
- #endif
- #endif
- #endif
|