📄 unix.c
字号:
#ifndef MTS
/****************************/
/* Function close_outfile() */
/****************************/
void close_outfile()
{
static short yday[]={0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334};
time_t m_time;
int yr, mo, dy, hh, mm, ss, leap, days;
struct utimbuf tp;
# define YRBASE 1970
#ifndef BSD4_4
#ifdef BSD
static struct timeb tbp;
#else /* !BSD */
extern long timezone;
#endif /* ?BSD */
#endif /* !BSD4_4 */
/*---------------------------------------------------------------------------
If symbolic links are supported, allocate a storage area, put the uncom-
pressed "data" in it, and create the link. Since we know it's a symbolic
link to start with, we shouldn't have to worry about overflowing unsigned
ints with unsigned longs.
---------------------------------------------------------------------------*/
#ifdef SYMLINKS
if (symlnk) {
unsigned ucsize = (unsigned)lrec.ucsize;
char *linktarget = (char *)malloc((unsigned)lrec.ucsize+1);
fclose(outfile); /* close "data" file... */
outfile = fopen(filename, FOPR); /* ...and reopen for reading */
if (!linktarget || (fread(linktarget, 1, ucsize, outfile) != ucsize)) {
FPRINTF(stderr, "\nwarning: symbolic link (%s) failed\n",
filename);
if (linktarget)
free(linktarget);
fclose(outfile);
return;
}
fclose(outfile); /* close "data" file for good... */
unlink(filename); /* ...and delete it */
linktarget[ucsize] = '\0';
FPRINTF(stdout, "-> %s ", linktarget);
if (symlink(linktarget, filename)) /* create the real link */
perror("symlink error");
free(linktarget);
return; /* can't set time on symlinks */
}
#endif /* SYMLINKS */
fclose(outfile);
/*---------------------------------------------------------------------------
Change the file permissions from default ones to those stored in the
zipfile.
---------------------------------------------------------------------------*/
#ifndef NO_CHMOD
if (chmod(filename, 0xffff & pInfo->file_attr))
perror("chmod (file attributes) error");
#endif
/*---------------------------------------------------------------------------
Convert from MSDOS-format local time and date to Unix-format 32-bit GMT
time: adjust base year from 1980 to 1970, do usual conversions from
yy/mm/dd hh:mm:ss to elapsed seconds, and account for timezone and day-
light savings time differences.
---------------------------------------------------------------------------*/
yr = ((lrec.last_mod_file_date >> 9) & 0x7f) + (1980 - YRBASE);
mo = ((lrec.last_mod_file_date >> 5) & 0x0f) - 1;
dy = (lrec.last_mod_file_date & 0x1f) - 1;
hh = (lrec.last_mod_file_time >> 11) & 0x1f;
mm = (lrec.last_mod_file_time >> 5) & 0x3f;
ss = (lrec.last_mod_file_time & 0x1f) * 2;
/* leap = # of leap yrs from YRBASE up to but not including current year */
leap = ((yr + YRBASE - 1) / 4); /* leap year base factor */
/* how many days from YRBASE to this year? (& add expired days this year) */
days = (yr * 365) + (leap - 492) + yday[mo];
/* if year is a leap year and month is after February, add another day */
if ((mo > 1) && ((yr+YRBASE)%4 == 0) && ((yr+YRBASE) != 2100))
++days; /* OK through 2199 */
/* convert date & time to seconds relative to 00:00:00, 01/01/YRBASE */
m_time = ((days + dy) * 86400) + (hh * 3600) + (mm * 60) + ss;
/* adjust for local timezone */
#ifdef BSD
#ifdef BSD4_4
m_time -= localtime(&m_time)->tm_gmtoff; /* seconds EAST of GMT: subtr. */
#else
ftime(&tbp); /* get `timezone' */
m_time += tbp.timezone * 60L; /* seconds WEST of GMT: add */
#endif /* ?BSD4_4 */
#else /* !BSD */
tzset(); /* get `timezone' */
m_time += timezone; /* seconds WEST of GMT: add */
#endif /* ?BSD */
/* adjust for daylight savings time (or local equivalent) */
#ifndef BSD4_4 /* (DST already added to tm_gmtoff, so skip tm_isdst) */
if (localtime(&m_time)->tm_isdst)
m_time -= 60L * 60L; /* adjust for daylight savings time */
#endif
/* set the file's access and modification times */
tp.actime = tp.modtime = m_time;
if (utime(filename, &tp)) {
#ifdef AOS_VS
FPRINTF(stderr, "... can't set time for %s", filename);
#else
FPRINTF(stderr, "warning: can't set the time for %s\n", filename);
#endif
FFLUSH(stderr);
}
} /* end function close_outfile() */
#endif /* !MTS */
#ifndef SFX
/************************/
/* Function version() */
/************************/
void version()
{
extern char Far CompiledWith[];
#if defined(CRAY) || defined(NetBSD)
char buf1[40];
#if defined(CRAY)
char buf2[40];
#endif
#endif
PRINTF(LoadFarString(CompiledWith),
#ifdef __GNUC__
"gcc ", __VERSION__,
#else
# if defined(CRAY) && defined(_RELEASE)
"cc ", (sprintf(buf1, "version %d", _RELEASE), buf1),
# else
# ifdef __VERSION__
"cc ", __VERSION__,
# else
"cc", "",
# endif
# endif
#endif
"Unix",
#if defined(sgi) || defined(__sgi)
" (Silicon Graphics IRIX)",
#else
#ifdef sun
# ifdef sparc
# ifdef __SVR4
" (Sun Sparc/Solaris)",
# else /* may or may not be SunOS */
" (Sun Sparc)",
# endif
# else
# if defined(sun386) || defined(i386)
" (Sun 386i)",
# else
# if defined(mc68020) || defined(__mc68020__)
" (Sun 3)",
# else /* mc68010 or mc68000: Sun 2 or earlier */
" (Sun 2)",
# endif
# endif
# endif
#else
#ifdef __hpux
" (HP/UX)",
#else
#ifdef __osf__
" (DEC OSF/1)",
#else
#ifdef _AIX
" (IBM AIX)",
#else
#ifdef aiws
" (IBM RT/AIX)",
#else
#if defined(CRAY) || defined(cray)
# ifdef _UNICOS
(sprintf(buf2, " (Cray UNICOS release %d)", _UNICOS), buf2),
# else
" (Cray UNICOS)",
# endif
#else
#if defined(uts) || defined(UTS)
" (Amdahl UTS)",
#else
#ifdef NeXT
# ifdef mc68000
" (NeXTStep/black)",
# else
" (NeXTStep for Intel)",
# endif
#else /* the next dozen or so are somewhat order-dependent */
#ifdef LINUX
" (Linux)",
#else
#ifdef MINIX
" (Minix)",
#else
#ifdef M_UNIX
" (SCO Unix)",
#else
#ifdef M_XENIX
" (SCO Xenix)",
#else
#ifdef __NetBSD__
# ifdef NetBSD0_8
(sprintf(buf1, " (NetBSD 0.8%c)", (char)(NetBSD0_8 - 1 + 'A')), buf1),
# else
# ifdef NetBSD0_9
(sprintf(buf1, " (NetBSD 0.9%c)", (char)(NetBSD0_9 - 1 + 'A')), buf1),
# else
# ifdef NetBSD1_0
(sprintf(buf1, " (NetBSD 1.0%c)", (char)(NetBSD1_0 - 1 + 'A')), buf1),
# else
(BSD4_4 == 0.5)? " (NetBSD before 0.9)" : " (NetBSD 1.1 or later)",
# endif
# endif
# endif
#else
#ifdef __FreeBSD__
(BSD4_4 == 0.5)? " (FreeBSD 1.x)" : " (FreeBSD 2.0 or later)",
#else
#ifdef __bsdi__
(BSD4_4 == 0.5)? " (BSD/386 1.0)" : " (BSD/386 1.1 or later)",
#else
#ifdef __386BSD__
(BSD4_4 == 1)? " (386BSD, post-4.4 release)" : " (386BSD)",
#else
#if defined(i486) || defined(__i486) || defined(__i486__)
" (Intel 486)",
#else
#if defined(i386) || defined(__i386) || defined(__i386__)
" (Intel 386)",
#else
#ifdef pyr
" (Pyramid)",
#else
#ifdef ultrix
# ifdef mips
" (DEC/MIPS)",
# else
# ifdef vax
" (DEC/VAX)",
# else /* __alpha? */
" (DEC/Alpha)",
# endif
# endif
#else
#ifdef gould
" (Gould)",
#else
#ifdef MTS
" (MTS)",
#else
#ifdef __convexc__
" (Convex)",
#else
"",
#endif /* Convex */
#endif /* MTS */
#endif /* Gould */
#endif /* DEC */
#endif /* Pyramid */
#endif /* 386 */
#endif /* 486 */
#endif /* 386BSD */
#endif /* BSDI BSD/386 */
#endif /* NetBSD */
#endif /* FreeBSD */
#endif /* SCO Xenix */
#endif /* SCO Unix */
#endif /* Minix */
#endif /* Linux */
#endif /* NeXT */
#endif /* Amdahl */
#endif /* Cray */
#endif /* RT/AIX */
#endif /* AIX */
#endif /* OSF/1 */
#endif /* HP/UX */
#endif /* Sun */
#endif /* SGI */
#ifdef __DATE__
" on ", __DATE__
#else
"", ""
#endif
);
} /* end function version() */
#endif /* !SFX */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -