version 1.20, 2009/02/26 16:08:11 |
version 1.26, 2009/03/06 14:13:47 |
|
|
#include <time.h> |
#include <time.h> |
#endif |
#endif |
|
|
|
#include "private.h" |
|
|
/* |
/* |
* Convert scalars to and from string format. |
* Various string-literal operations: converting scalars to and from |
|
* strings, etc. |
*/ |
*/ |
|
|
#include "private.h" |
struct mdoc_secname { |
|
const char *name; |
|
int flag; |
|
#define MSECNAME_META (1 << 0) |
|
}; |
|
|
|
/* Section names corresponding to mdoc_sec. */ |
|
|
|
static const struct mdoc_secname secnames[] = { |
|
{ "PROLOGUE", MSECNAME_META }, |
|
{ "BODY", MSECNAME_META }, |
|
{ "NAME", 0 }, |
|
{ "LIBRARY", 0 }, |
|
{ "SYNOPSIS", 0 }, |
|
{ "DESCRIPTION", 0 }, |
|
{ "IMPLEMENTATION NOTES", 0 }, |
|
{ "RETURN VALUES", 0 }, |
|
{ "ENVIRONMENT", 0 }, |
|
{ "FILES", 0 }, |
|
{ "EXAMPLES", 0 }, |
|
{ "DIAGNOSTICS", 0 }, |
|
{ "COMPATIBILITY", 0 }, |
|
{ "ERRORS", 0 }, |
|
{ "SEE ALSO", 0 }, |
|
{ "STANDARDS", 0 }, |
|
{ "HISTORY", 0 }, |
|
{ "AUTHORS", 0 }, |
|
{ "CAVEATS", 0 }, |
|
{ "BUGS", 0 }, |
|
{ NULL, 0 } |
|
}; |
|
|
#ifdef __linux__ |
#ifdef __linux__ |
extern char *strptime(const char *, const char *, struct tm *); |
extern char *strptime(const char *, const char *, struct tm *); |
#endif |
#endif |
Line 61 mdoc_isescape(const char *p) |
|
Line 94 mdoc_isescape(const char *p) |
|
/* FALLTHROUGH */ |
/* FALLTHROUGH */ |
case ('e'): |
case ('e'): |
return(2); |
return(2); |
|
case ('*'): |
|
if (0 == *++p || ! isgraph((u_char)*p)) |
|
return(0); |
|
switch (*p) { |
|
case ('('): |
|
if (0 == *++p || ! isgraph((u_char)*p)) |
|
return(0); |
|
return(4); |
|
case ('['): |
|
for (c = 3, p++; *p && ']' != *p; p++, c++) |
|
if ( ! isgraph((u_char)*p)) |
|
break; |
|
return(*p == ']' ? c : 0); |
|
default: |
|
break; |
|
} |
|
return(3); |
case ('('): |
case ('('): |
if (0 == *++p || ! isgraph((int)*p)) |
if (0 == *++p || ! isgraph((u_char)*p)) |
return(0); |
return(0); |
if (0 == *++p || ! isgraph((int)*p)) |
if (0 == *++p || ! isgraph((u_char)*p)) |
return(0); |
return(0); |
return(4); |
return(4); |
case ('['): |
case ('['): |
Line 74 mdoc_isescape(const char *p) |
|
Line 124 mdoc_isescape(const char *p) |
|
} |
} |
|
|
for (c = 3, p++; *p && ']' != *p; p++, c++) |
for (c = 3, p++; *p && ']' != *p; p++, c++) |
if ( ! isgraph((int)*p)) |
if ( ! isgraph((u_char)*p)) |
break; |
break; |
|
|
return(*p == ']' ? c : 0); |
return(*p == ']' ? c : 0); |
Line 133 mdoc_isdelim(const char *p) |
|
Line 183 mdoc_isdelim(const char *p) |
|
enum mdoc_sec |
enum mdoc_sec |
mdoc_atosec(const char *p) |
mdoc_atosec(const char *p) |
{ |
{ |
|
const struct mdoc_secname *n; |
|
int i; |
|
|
assert(p); |
for (i = 0, n = secnames; n->name; n++, i++) |
if (0 == strcmp(p, "NAME")) |
if ( ! (n->flag & MSECNAME_META)) |
return(SEC_NAME); |
if (xstrcmp(p, n->name)) |
else if (0 == strcmp(p, "RETURN VALUES")) |
return((enum mdoc_sec)i); |
return(SEC_RETURN_VALUES); |
|
else if (0 == strcmp(p, "SEE ALSO")) |
|
return(SEC_SEE_ALSO); |
|
else if (0 == strcmp(p, "SYNOPSIS")) |
|
return(SEC_SYNOPSIS); |
|
else if (0 == strcmp(p, "DESCRIPTION")) |
|
return(SEC_DESCRIPTION); |
|
else if (0 == strcmp(p, "ENVIRONMENT")) |
|
return(SEC_ENVIRONMENT); |
|
else if (0 == strcmp(p, "FILES")) |
|
return(SEC_FILES); |
|
else if (0 == strcmp(p, "EXAMPLES")) |
|
return(SEC_EXAMPLES); |
|
else if (0 == strcmp(p, "DIAGNOSTICS")) |
|
return(SEC_DIAGNOSTICS); |
|
else if (0 == strcmp(p, "ERRORS")) |
|
return(SEC_ERRORS); |
|
else if (0 == strcmp(p, "STANDARDS")) |
|
return(SEC_STANDARDS); |
|
else if (0 == strcmp(p, "HISTORY")) |
|
return(SEC_HISTORY); |
|
else if (0 == strcmp(p, "AUTHORS")) |
|
return(SEC_AUTHORS); |
|
else if (0 == strcmp(p, "CAVEATS")) |
|
return(SEC_CAVEATS); |
|
else if (0 == strcmp(p, "BUGS")) |
|
return(SEC_BUGS); |
|
|
|
return(SEC_CUSTOM); |
return(SEC_CUSTOM); |
} |
} |
Line 189 mdoc_atotime(const char *p) |
|
Line 214 mdoc_atotime(const char *p) |
|
return(mktime(&tm)); |
return(mktime(&tm)); |
|
|
return(0); |
return(0); |
} |
|
|
|
|
|
enum mdoc_msec |
|
mdoc_atomsec(const char *p) |
|
{ |
|
|
|
if (0 == strcmp(p, "1")) |
|
return(MSEC_1); |
|
else if (0 == strcmp(p, "2")) |
|
return(MSEC_2); |
|
else if (0 == strcmp(p, "3")) |
|
return(MSEC_3); |
|
else if (0 == strcmp(p, "3f")) |
|
return(MSEC_3f); |
|
else if (0 == strcmp(p, "3p")) |
|
return(MSEC_3p); |
|
else if (0 == strcmp(p, "4")) |
|
return(MSEC_4); |
|
else if (0 == strcmp(p, "5")) |
|
return(MSEC_5); |
|
else if (0 == strcmp(p, "6")) |
|
return(MSEC_6); |
|
else if (0 == strcmp(p, "7")) |
|
return(MSEC_7); |
|
else if (0 == strcmp(p, "8")) |
|
return(MSEC_8); |
|
else if (0 == strcmp(p, "9")) |
|
return(MSEC_9); |
|
else if (0 == strcmp(p, "X11")) |
|
return(MSEC_X11); |
|
else if (0 == strcmp(p, "X11R6")) |
|
return(MSEC_X11R6); |
|
else if (0 == strcmp(p, "local")) |
|
return(MSEC_local); |
|
else if (0 == strcmp(p, "n")) |
|
return(MSEC_n); |
|
else if (0 == strcmp(p, "unass")) |
|
return(MSEC_unass); |
|
else if (0 == strcmp(p, "draft")) |
|
return(MSEC_draft); |
|
else if (0 == strcmp(p, "paper")) |
|
return(MSEC_paper); |
|
|
|
return(MSEC_DEFAULT); |
|
} |
|
|
|
|
|
enum mdoc_vol |
|
mdoc_atovol(const char *p) |
|
{ |
|
|
|
if (0 == strcmp(p, "AMD")) |
|
return(VOL_AMD); |
|
else if (0 == strcmp(p, "IND")) |
|
return(VOL_IND); |
|
else if (0 == strcmp(p, "KM")) |
|
return(VOL_KM); |
|
else if (0 == strcmp(p, "LOCAL")) |
|
return(VOL_LOCAL); |
|
else if (0 == strcmp(p, "PRM")) |
|
return(VOL_PRM); |
|
else if (0 == strcmp(p, "PS1")) |
|
return(VOL_PS1); |
|
else if (0 == strcmp(p, "SMM")) |
|
return(VOL_SMM); |
|
else if (0 == strcmp(p, "URM")) |
|
return(VOL_URM); |
|
else if (0 == strcmp(p, "USD")) |
|
return(VOL_USD); |
|
|
|
return(VOL_DEFAULT); |
|
} |
|
|
|
|
|
enum mdoc_arch |
|
mdoc_atoarch(const char *p) |
|
{ |
|
|
|
if (0 == strcmp(p, "alpha")) |
|
return(ARCH_alpha); |
|
else if (0 == strcmp(p, "amd64")) |
|
return(ARCH_amd64); |
|
else if (0 == strcmp(p, "amiga")) |
|
return(ARCH_amiga); |
|
else if (0 == strcmp(p, "arc")) |
|
return(ARCH_arc); |
|
else if (0 == strcmp(p, "arm")) |
|
return(ARCH_arm); |
|
else if (0 == strcmp(p, "armish")) |
|
return(ARCH_armish); |
|
else if (0 == strcmp(p, "aviion")) |
|
return(ARCH_aviion); |
|
else if (0 == strcmp(p, "hp300")) |
|
return(ARCH_hp300); |
|
else if (0 == strcmp(p, "hppa")) |
|
return(ARCH_hppa); |
|
else if (0 == strcmp(p, "hppa64")) |
|
return(ARCH_hppa64); |
|
else if (0 == strcmp(p, "i386")) |
|
return(ARCH_i386); |
|
else if (0 == strcmp(p, "landisk")) |
|
return(ARCH_landisk); |
|
else if (0 == strcmp(p, "luna88k")) |
|
return(ARCH_luna88k); |
|
else if (0 == strcmp(p, "mac68k")) |
|
return(ARCH_mac68k); |
|
else if (0 == strcmp(p, "macppc")) |
|
return(ARCH_macppc); |
|
else if (0 == strcmp(p, "mvme68k")) |
|
return(ARCH_mvme68k); |
|
else if (0 == strcmp(p, "mvme88k")) |
|
return(ARCH_mvme88k); |
|
else if (0 == strcmp(p, "mvmeppc")) |
|
return(ARCH_mvmeppc); |
|
else if (0 == strcmp(p, "pmax")) |
|
return(ARCH_pmax); |
|
else if (0 == strcmp(p, "sgi")) |
|
return(ARCH_sgi); |
|
else if (0 == strcmp(p, "socppc")) |
|
return(ARCH_socppc); |
|
else if (0 == strcmp(p, "sparc")) |
|
return(ARCH_sparc); |
|
else if (0 == strcmp(p, "sparc64")) |
|
return(ARCH_sparc64); |
|
else if (0 == strcmp(p, "sun3")) |
|
return(ARCH_sun3); |
|
else if (0 == strcmp(p, "vax")) |
|
return(ARCH_vax); |
|
else if (0 == strcmp(p, "zaurus")) |
|
return(ARCH_zaurus); |
|
|
|
return(ARCH_DEFAULT); |
|
} |
|
|
|
|
|
enum mdoc_att |
|
mdoc_atoatt(const char *p) |
|
{ |
|
|
|
assert(p); |
|
if (0 == strcmp(p, "v1")) |
|
return(ATT_v1); |
|
else if (0 == strcmp(p, "v2")) |
|
return(ATT_v2); |
|
else if (0 == strcmp(p, "v3")) |
|
return(ATT_v3); |
|
else if (0 == strcmp(p, "v4")) |
|
return(ATT_v4); |
|
else if (0 == strcmp(p, "v5")) |
|
return(ATT_v5); |
|
else if (0 == strcmp(p, "v6")) |
|
return(ATT_v6); |
|
else if (0 == strcmp(p, "v7")) |
|
return(ATT_v7); |
|
else if (0 == strcmp(p, "32v")) |
|
return(ATT_32v); |
|
else if (0 == strcmp(p, "V.1")) |
|
return(ATT_V1); |
|
else if (0 == strcmp(p, "V.2")) |
|
return(ATT_V2); |
|
else if (0 == strcmp(p, "V.3")) |
|
return(ATT_V3); |
|
else if (0 == strcmp(p, "V.4")) |
|
return(ATT_V4); |
|
|
|
return(ATT_DEFAULT); |
|
} |
|
|
|
|
|
char * |
|
mdoc_type2a(enum mdoc_type type) |
|
{ |
|
switch (type) { |
|
case (MDOC_ROOT): |
|
return("root"); |
|
case (MDOC_BLOCK): |
|
return("block"); |
|
case (MDOC_HEAD): |
|
return("block-head"); |
|
case (MDOC_BODY): |
|
return("block-body"); |
|
case (MDOC_TAIL): |
|
return("block-tail"); |
|
case (MDOC_ELEM): |
|
return("elem"); |
|
case (MDOC_TEXT): |
|
return("text"); |
|
default: |
|
break; |
|
} |
|
|
|
abort(); |
|
/* NOTREACHED */ |
|
} |
|
|
|
|
|
const char * |
|
mdoc_arch2a(enum mdoc_arch arch) |
|
{ |
|
|
|
switch (arch) { |
|
case (ARCH_alpha): |
|
return("Alpha"); |
|
case (ARCH_amd64): |
|
return("AMD64"); |
|
case (ARCH_amiga): |
|
return("Amiga"); |
|
case (ARCH_arc): |
|
return("ARC"); |
|
case (ARCH_arm): |
|
return("ARM"); |
|
case (ARCH_armish): |
|
return("ARMISH"); |
|
case (ARCH_aviion): |
|
return("AViiON"); |
|
case (ARCH_hp300): |
|
return("HP300"); |
|
case (ARCH_hppa): |
|
return("HPPA"); |
|
case (ARCH_hppa64): |
|
return("HPPA64"); |
|
case (ARCH_i386): |
|
return("i386"); |
|
case (ARCH_landisk): |
|
return("LANDISK"); |
|
case (ARCH_luna88k): |
|
return("Luna88k"); |
|
case (ARCH_mac68k): |
|
return("Mac68k"); |
|
case (ARCH_macppc): |
|
return("MacPPC"); |
|
case (ARCH_mvme68k): |
|
return("MVME68k"); |
|
case (ARCH_mvme88k): |
|
return("MVME88k"); |
|
case (ARCH_mvmeppc): |
|
return("MVMEPPC"); |
|
case (ARCH_pmax): |
|
return("PMAX"); |
|
case (ARCH_sgi): |
|
return("SGI"); |
|
case (ARCH_socppc): |
|
return("SOCPPC"); |
|
case (ARCH_sparc): |
|
return("SPARC"); |
|
case (ARCH_sparc64): |
|
return("SPARC64"); |
|
case (ARCH_sun3): |
|
return("Sun3"); |
|
case (ARCH_vax): |
|
return("VAX"); |
|
case (ARCH_zaurus): |
|
return("Zaurus"); |
|
case (ARCH_DEFAULT): |
|
return(NULL); |
|
default: |
|
break; |
|
} |
|
|
|
abort(); |
|
/* NOTREACHED */ |
|
} |
|
|
|
|
|
const char * |
|
mdoc_vol2a(enum mdoc_vol vol) |
|
{ |
|
|
|
switch (vol) { |
|
case (VOL_AMD): |
|
return("OpenBSD Ancestral Manual Documents"); |
|
case (VOL_IND): |
|
return("OpenBSD Manual Master Index"); |
|
case (VOL_KM): |
|
return("OpenBSD Kernel Manual"); |
|
case (VOL_LOCAL): |
|
return("OpenBSD Local Manual"); |
|
case (VOL_PRM): |
|
return("OpenBSD Programmer's Manual"); |
|
case (VOL_PS1): |
|
return("OpenBSD Programmer's Supplementary Documents"); |
|
case (VOL_SMM): |
|
return("OpenBSD System Manager's Manual"); |
|
case (VOL_URM): |
|
return("OpenBSD Reference Manual"); |
|
case (VOL_USD): |
|
return("OpenBSD User's Supplementary Documents"); |
|
case (VOL_DEFAULT): |
|
return(NULL); |
|
default: |
|
break; |
|
} |
|
|
|
abort(); |
|
/* NOTREACHED */ |
|
} |
|
|
|
|
|
const char * |
|
mdoc_msec2a(enum mdoc_msec msec) |
|
{ |
|
|
|
switch (msec) { |
|
case(MSEC_1): |
|
return("1"); |
|
case(MSEC_2): |
|
return("2"); |
|
case(MSEC_3): |
|
return("3"); |
|
case(MSEC_3f): |
|
return("3f"); |
|
case(MSEC_3p): |
|
return("3p"); |
|
case(MSEC_4): |
|
return("4"); |
|
case(MSEC_5): |
|
return("5"); |
|
case(MSEC_6): |
|
return("6"); |
|
case(MSEC_7): |
|
return("7"); |
|
case(MSEC_8): |
|
return("8"); |
|
case(MSEC_9): |
|
return("9"); |
|
case(MSEC_X11): |
|
return("X11"); |
|
case(MSEC_X11R6): |
|
return("X11R6"); |
|
case(MSEC_local): |
|
return("local"); |
|
case(MSEC_n): |
|
return("n"); |
|
case(MSEC_unass): |
|
/* FALLTHROUGH */ |
|
case(MSEC_draft): |
|
return("draft"); |
|
case(MSEC_paper): |
|
return("paper"); |
|
case(MSEC_DEFAULT): |
|
return(NULL); |
|
default: |
|
break; |
|
} |
|
|
|
abort(); |
|
/* NOTREACHED */ |
|
} |
|
|
|
|
|
const char * |
|
mdoc_st2a(int c) |
|
{ |
|
char *p; |
|
|
|
switch (c) { |
|
case(MDOC_p1003_1_88): |
|
p = "IEEE Std 1003.1-1988 (\\(lqPOSIX\\(rq)"; |
|
break; |
|
case(MDOC_p1003_1_90): |
|
p = "IEEE Std 1003.1-1990 (\\(lqPOSIX\\(rq)"; |
|
break; |
|
case(MDOC_p1003_1_96): |
|
p = "ISO/IEC 9945-1:1996 (\\(lqPOSIX\\(rq)"; |
|
break; |
|
case(MDOC_p1003_1_2001): |
|
p = "IEEE Std 1003.1-2001 (\\(lqPOSIX\\(rq)"; |
|
break; |
|
case(MDOC_p1003_1_2004): |
|
p = "IEEE Std 1003.1-2004 (\\(lqPOSIX\\(rq)"; |
|
break; |
|
case(MDOC_p1003_1): |
|
p = "IEEE Std 1003.1 (\\(lqPOSIX\\(rq)"; |
|
break; |
|
case(MDOC_p1003_1b): |
|
p = "IEEE Std 1003.1b (\\(lqPOSIX\\(rq)"; |
|
break; |
|
case(MDOC_p1003_1b_93): |
|
p = "IEEE Std 1003.1b-1993 (\\(lqPOSIX\\(rq)"; |
|
break; |
|
case(MDOC_p1003_1c_95): |
|
p = "IEEE Std 1003.1c-1995 (\\(lqPOSIX\\(rq)"; |
|
break; |
|
case(MDOC_p1003_1g_2000): |
|
p = "IEEE Std 1003.1g-2000 (\\(lqPOSIX\\(rq)"; |
|
break; |
|
case(MDOC_p1003_2_92): |
|
p = "IEEE Std 1003.2-1992 (\\(lqPOSIX.2\\(rq)"; |
|
break; |
|
case(MDOC_p1387_2_95): |
|
p = "IEEE Std 1387.2-1995 (\\(lqPOSIX.7.2\\(rq)"; |
|
break; |
|
case(MDOC_p1003_2): |
|
p = "IEEE Std 1003.2 (\\(lqPOSIX.2\\(rq)"; |
|
break; |
|
case(MDOC_p1387_2): |
|
p = "IEEE Std 1387.2 (\\(lqPOSIX.7.2\\(rq)"; |
|
break; |
|
case(MDOC_isoC_90): |
|
p = "ISO/IEC 9899:1990 (\\(lqISO C90\\(rq)"; |
|
break; |
|
case(MDOC_isoC_amd1): |
|
p = "ISO/IEC 9899/AMD1:1995 (\\(lqISO C90\\(rq)"; |
|
break; |
|
case(MDOC_isoC_tcor1): |
|
p = "ISO/IEC 9899/TCOR1:1994 (\\(lqISO C90\\(rq)"; |
|
break; |
|
case(MDOC_isoC_tcor2): |
|
p = "ISO/IEC 9899/TCOR2:1995 (\\(lqISO C90\\(rq)"; |
|
break; |
|
case(MDOC_isoC_99): |
|
p = "ISO/IEC 9899:1999 (\\(lqISO C99\\(rq)"; |
|
break; |
|
case(MDOC_ansiC): |
|
p = "ANSI X3.159-1989 (\\(lqANSI C\\(rq)"; |
|
break; |
|
case(MDOC_ansiC_89): |
|
p = "ANSI X3.159-1989 (\\(lqANSI C\\(rq)"; |
|
break; |
|
case(MDOC_ansiC_99): |
|
p = "ANSI/ISO/IEC 9899-1999 (\\(lqANSI C99\\(rq)"; |
|
break; |
|
case(MDOC_ieee754): |
|
p = "IEEE Std 754-1985"; |
|
break; |
|
case(MDOC_iso8802_3): |
|
p = "ISO 8802-3: 1989"; |
|
break; |
|
case(MDOC_xpg3): |
|
p = "X/Open Portability Guide Issue 3 " |
|
"(\\(lqXPG3\\(rq)"; |
|
break; |
|
case(MDOC_xpg4): |
|
p = "X/Open Portability Guide Issue 4 " |
|
"(\\(lqXPG4\\(rq)"; |
|
break; |
|
case(MDOC_xpg4_2): |
|
p = "X/Open Portability Guide Issue 4.2 " |
|
"(\\(lqXPG4.2\\(rq)"; |
|
break; |
|
case(MDOC_xpg4_3): |
|
p = "X/Open Portability Guide Issue 4.3 " |
|
"(\\(lqXPG4.3\\(rq)"; |
|
break; |
|
case(MDOC_xbd5): |
|
p = "X/Open System Interface Definitions Issue 5 " |
|
"(\\(lqXBD5\\(rq)"; |
|
break; |
|
case(MDOC_xcu5): |
|
p = "X/Open Commands and Utilities Issue 5 " |
|
"(\\(lqXCU5\\(rq)"; |
|
break; |
|
case(MDOC_xsh5): |
|
p = "X/Open System Interfaces and Headers Issue 5 " |
|
"(\\(lqXSH5\\(rq)"; |
|
break; |
|
case(MDOC_xns5): |
|
p = "X/Open Networking Services Issue 5 " |
|
"(\\(lqXNS5\\(rq)"; |
|
break; |
|
case(MDOC_xns5_2d2_0): |
|
p = "X/Open Networking Services Issue 5.2 Draft 2.0 " |
|
"(\\(lqXNS5.2D2.0\\(rq)"; |
|
break; |
|
case(MDOC_xcurses4_2): |
|
p = "X/Open Curses Issue 4 Version 2 " |
|
"(\\(lqXCURSES4.2\\(rq)"; |
|
break; |
|
case(MDOC_susv2): |
|
p = "Version 2 of the Single UNIX Specification"; |
|
break; |
|
case(MDOC_susv3): |
|
p = "Version 3 of the Single UNIX Specification"; |
|
break; |
|
case(MDOC_svid4): |
|
p = "System V Interface Definition, Fourth Edition " |
|
"(\\(lqSVID4\\(rq)"; |
|
break; |
|
default: |
|
p = NULL; |
|
break; |
|
} |
|
|
|
return(p); |
|
} |
|
|
|
|
|
const char * |
|
mdoc_att2a(enum mdoc_att c) |
|
{ |
|
char *p; |
|
|
|
switch (c) { |
|
case(ATT_v1): |
|
p = "Version 1 AT&T UNIX"; |
|
break; |
|
case(ATT_v2): |
|
p = "Version 2 AT&T UNIX"; |
|
break; |
|
case(ATT_v3): |
|
p = "Version 3 AT&T UNIX"; |
|
break; |
|
case(ATT_v4): |
|
p = "Version 4 AT&T UNIX"; |
|
break; |
|
case(ATT_v5): |
|
p = "Version 5 AT&T UNIX"; |
|
break; |
|
case(ATT_v6): |
|
p = "Version 6 AT&T UNIX"; |
|
break; |
|
case(ATT_v7): |
|
p = "Version 7 AT&T UNIX"; |
|
break; |
|
case(ATT_32v): |
|
p = "Version 32V AT&T UNIX"; |
|
break; |
|
case(ATT_V1): |
|
p = "AT&T System V.1 UNIX"; |
|
break; |
|
case(ATT_V2): |
|
p = "AT&T System V.2 UNIX"; |
|
break; |
|
case(ATT_V3): |
|
p = "AT&T System V.3 UNIX"; |
|
break; |
|
case(ATT_V4): |
|
p = "AT&T System V.4 UNIX"; |
|
break; |
|
default: |
|
p = "AT&T UNIX"; |
|
break; |
|
} |
|
|
|
return(p); |
|
} |
} |
|
|
|
|