1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
|
/*
* gawkmisc.atr --- miscellanious gawk routines that are OS specific.
*/
/*
* Copyright (C) 1986, 1988, 1989, 1991-1993 the Free Software Foundation, Inc.
*
* This file is part of GAWK, the GNU implementation of the
* AWK Progamming Language.
*
* GAWK is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* GAWK is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
*/
#include <string.h>
char quote = '\'';
#ifndef DEFPATH
char *defpath = ".,c:\\lib\\awk,c:\\gnu\\lib\\awk";
#else
char *defpath = DEFPATH;
#endif
char envsep = ',';
/* gawk_name --- pull out the "gawk" part from how the OS called us */
char *
gawk_name(filespec)
const char *filespec;
{
char *p, *q;
p = (char *)filespec;
if ((q = strrchr(p, '\\')) != NULL)
p = q + 1;
if ((q = strrchr(p, '/')) != NULL)
p = q + 1;
if ((q = strchr(p, '.')) != NULL)
*q = '\0';
strlwr(p);
return (p == NULL ? (char *)filespec : (char *)p);
}
/* os_arg_fixup --- fixup the command line */
void
os_arg_fixup(argcp, argvp)
int *argcp;
char ***argvp;
{
/* no-op */
return;
}
/* os_devopen --- open special per-OS devices */
int
os_devopen(name, flag)
const char *name;
int flag;
{
/* no-op */
return INVALID_HANDLE;
}
/* optimal_bufsize --- determine optimal buffer size */
int
optimal_bufsize(fd, stb)
int fd;
struct stat *stb;
{
/* force all members to zero in case OS doesn't use all of them. */
memset(stb, '\0', sizeof(struct stat));
/* The atari has the st_blksize structure, so we just use it. */
#define DEFBLKSIZE (stb->st_blksize ? stb->st_blksize : BUFSIZ)
/*
* On ST redirected stdin does not have a name attached
* (this could be hard to do to) and fstat would fail
*/
if (fd == 0 || isatty(fd))
return BUFSIZ;
if (fstat(fd, stb) == -1)
fatal("can't stat fd %d (%s)", fd, strerror(errno));
if (lseek(fd, (off_t)0, 0) == -1) /* not a regular file */
return DEFBLKSIZE;
if (stb->st_size > 0 && stb->st_size < DEFBLKSIZE) /* small file */
return stb->st_size;
return DEFBLKSIZE;
}
/* ispath --- return true if path has directory components */
int
ispath(file)
const char *file;
{
return (strchr(file, '/') != NULL || strchr(file, '\\') != NULL);
}
/* isdirpunct --- return true if char is a directory separator */
int
isdirpunct(c)
int c;
{
return (c == '/' || c == '\\');
}
|