Unix.st
author claus
Wed, 23 Aug 1995 19:50:59 +0200
changeset 406 ed16ba9383c3
parent 384 cc3d110ea879
child 407 4656034aa781
permissions -rw-r--r--
.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     1
"
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
     2
 COPYRIGHT (c) 1988 by Claus Gittinger
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
     3
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     4
a27a279701f8 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
a27a279701f8 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
a27a279701f8 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
a27a279701f8 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
a27a279701f8 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
a27a279701f8 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    11
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    12
a27a279701f8 Initial revision
claus
parents:
diff changeset
    13
Object subclass:#OperatingSystem
a27a279701f8 Initial revision
claus
parents:
diff changeset
    14
       instanceVariableNames:''
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
    15
       classVariableNames:'HostName LastErrorNumber LastExecStatus OSSignals
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
    16
			   SlowFork ForkFailed'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    17
       poolDictionaries:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    18
       category:'System-Support'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    20
a27a279701f8 Initial revision
claus
parents:
diff changeset
    21
OperatingSystem comment:'
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
    22
COPYRIGHT (c) 1988 by Claus Gittinger
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
    23
	     All Rights Reserved
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
    24
406
claus
parents: 384
diff changeset
    25
$Header: /cvs/stx/stx/libbasic/Attic/Unix.st,v 1.48 1995-08-23 17:50:46 claus Exp $
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    26
'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    27
406
claus
parents: 384
diff changeset
    28
!OperatingSystem primitiveFunctions!
claus
parents: 384
diff changeset
    29
claus
parents: 384
diff changeset
    30
%{
claus
parents: 384
diff changeset
    31
#ifdef _AIX
claus
parents: 384
diff changeset
    32
# define WANT_REALPATH
claus
parents: 384
diff changeset
    33
# include <sys/param.h>
claus
parents: 384
diff changeset
    34
# include <errno.h>
claus
parents: 384
diff changeset
    35
# include <sys/stat.h>
claus
parents: 384
diff changeset
    36
#endif
claus
parents: 384
diff changeset
    37
claus
parents: 384
diff changeset
    38
#if !defined(HAS_REALPATH) && defined(WANT_REALPATH)
claus
parents: 384
diff changeset
    39
claus
parents: 384
diff changeset
    40
# ifndef NULL
claus
parents: 384
diff changeset
    41
#  define NULL (char *)0
claus
parents: 384
diff changeset
    42
# endif
claus
parents: 384
diff changeset
    43
claus
parents: 384
diff changeset
    44
#define MAX_READLINKS 32
claus
parents: 384
diff changeset
    45
claus
parents: 384
diff changeset
    46
static
claus
parents: 384
diff changeset
    47
char *realpath(path, resolved_path)
claus
parents: 384
diff changeset
    48
char *path;
claus
parents: 384
diff changeset
    49
char resolved_path [];
claus
parents: 384
diff changeset
    50
{
claus
parents: 384
diff changeset
    51
	char copy_path[MAXPATHLEN];
claus
parents: 384
diff changeset
    52
	char link_path[MAXPATHLEN];
claus
parents: 384
diff changeset
    53
	char *new_path = resolved_path;
claus
parents: 384
diff changeset
    54
	char *max_path;
claus
parents: 384
diff changeset
    55
	int readlinks = 0;
claus
parents: 384
diff changeset
    56
	int n;
claus
parents: 384
diff changeset
    57
claus
parents: 384
diff changeset
    58
	/* Make a copy of the source path since we may need to modify it. */
claus
parents: 384
diff changeset
    59
	strcpy(copy_path, path);
claus
parents: 384
diff changeset
    60
	path = copy_path;
claus
parents: 384
diff changeset
    61
	max_path = copy_path + MAXPATHLEN - 2;
claus
parents: 384
diff changeset
    62
	/* If it's a relative pathname use getwd for starters. */
claus
parents: 384
diff changeset
    63
	if (*path != '/') {
claus
parents: 384
diff changeset
    64
#ifdef HAS_GETCWD
claus
parents: 384
diff changeset
    65
		getcwd(new_path, MAXPATHLEN - 1);
claus
parents: 384
diff changeset
    66
#else
claus
parents: 384
diff changeset
    67
		getwd(new_path);
claus
parents: 384
diff changeset
    68
#endif
claus
parents: 384
diff changeset
    69
		new_path += strlen(new_path);
claus
parents: 384
diff changeset
    70
		if (new_path[-1] != '/')
claus
parents: 384
diff changeset
    71
			*new_path++ = '/';
claus
parents: 384
diff changeset
    72
	}
claus
parents: 384
diff changeset
    73
	else {
claus
parents: 384
diff changeset
    74
		*new_path++ = '/';
claus
parents: 384
diff changeset
    75
		path++;
claus
parents: 384
diff changeset
    76
	}
claus
parents: 384
diff changeset
    77
	/* Expand each slash-separated pathname component. */
claus
parents: 384
diff changeset
    78
	while (*path != '\0') {
claus
parents: 384
diff changeset
    79
		/* Ignore stray "/". */
claus
parents: 384
diff changeset
    80
		if (*path == '/') {
claus
parents: 384
diff changeset
    81
			path++;
claus
parents: 384
diff changeset
    82
			continue;
claus
parents: 384
diff changeset
    83
		}
claus
parents: 384
diff changeset
    84
		if (*path == '.') {
claus
parents: 384
diff changeset
    85
			/* Ignore ".". */
claus
parents: 384
diff changeset
    86
			if (path[1] == '\0' || path[1] == '/') {
claus
parents: 384
diff changeset
    87
				path++;
claus
parents: 384
diff changeset
    88
				continue;
claus
parents: 384
diff changeset
    89
			}
claus
parents: 384
diff changeset
    90
			if (path[1] == '.') {
claus
parents: 384
diff changeset
    91
				if (path[2] == '\0' || path[2] == '/') {
claus
parents: 384
diff changeset
    92
					path += 2;
claus
parents: 384
diff changeset
    93
					/* Ignore ".." at root. */
claus
parents: 384
diff changeset
    94
					if (new_path == resolved_path + 1)
claus
parents: 384
diff changeset
    95
						continue;
claus
parents: 384
diff changeset
    96
					/* Handle ".." by backing up. */
claus
parents: 384
diff changeset
    97
					while ((--new_path)[-1] != '/')
claus
parents: 384
diff changeset
    98
						;
claus
parents: 384
diff changeset
    99
					continue;
claus
parents: 384
diff changeset
   100
				}
claus
parents: 384
diff changeset
   101
			}
claus
parents: 384
diff changeset
   102
		}
claus
parents: 384
diff changeset
   103
		/* Safely copy the next pathname component. */
claus
parents: 384
diff changeset
   104
		while (*path != '\0' && *path != '/') {
claus
parents: 384
diff changeset
   105
			if (path > max_path) {
claus
parents: 384
diff changeset
   106
				errno = ENAMETOOLONG;
claus
parents: 384
diff changeset
   107
				return NULL;
claus
parents: 384
diff changeset
   108
			}
claus
parents: 384
diff changeset
   109
			*new_path++ = *path++;
claus
parents: 384
diff changeset
   110
		}
claus
parents: 384
diff changeset
   111
#ifdef S_IFLNK
claus
parents: 384
diff changeset
   112
		/* Protect against infinite loops. */
claus
parents: 384
diff changeset
   113
		if (readlinks++ > MAX_READLINKS) {
claus
parents: 384
diff changeset
   114
			errno = ELOOP;
claus
parents: 384
diff changeset
   115
			return NULL;
claus
parents: 384
diff changeset
   116
		}
claus
parents: 384
diff changeset
   117
		/* See if latest pathname component is a symlink. */
claus
parents: 384
diff changeset
   118
		*new_path = '\0';
claus
parents: 384
diff changeset
   119
		n = readlink(resolved_path, link_path, MAXPATHLEN - 1);
claus
parents: 384
diff changeset
   120
		if (n < 0) {
claus
parents: 384
diff changeset
   121
			/* EINVAL means the file exists but isn't a symlink. */
claus
parents: 384
diff changeset
   122
			if (errno != EINVAL)
claus
parents: 384
diff changeset
   123
				return NULL;
claus
parents: 384
diff changeset
   124
		}
claus
parents: 384
diff changeset
   125
		else {
claus
parents: 384
diff changeset
   126
			/* Note: readlink doesn't add the null byte. */
claus
parents: 384
diff changeset
   127
			link_path[n] = '\0';
claus
parents: 384
diff changeset
   128
			if (*link_path == '/')
claus
parents: 384
diff changeset
   129
				/* Start over for an absolute symlink. */
claus
parents: 384
diff changeset
   130
				new_path = resolved_path;
claus
parents: 384
diff changeset
   131
			else
claus
parents: 384
diff changeset
   132
				/* Otherwise back up over this component. */
claus
parents: 384
diff changeset
   133
				while (*(--new_path) != '/')
claus
parents: 384
diff changeset
   134
					;
claus
parents: 384
diff changeset
   135
			/* Safe sex check. */
claus
parents: 384
diff changeset
   136
			if (strlen(path) + n >= MAXPATHLEN) {
claus
parents: 384
diff changeset
   137
				errno = ENAMETOOLONG;
claus
parents: 384
diff changeset
   138
				return NULL;
claus
parents: 384
diff changeset
   139
			}
claus
parents: 384
diff changeset
   140
			/* Insert symlink contents into path. */
claus
parents: 384
diff changeset
   141
			strcat(link_path, path);
claus
parents: 384
diff changeset
   142
			strcpy(copy_path, link_path);
claus
parents: 384
diff changeset
   143
			path = copy_path;
claus
parents: 384
diff changeset
   144
		}
claus
parents: 384
diff changeset
   145
#endif /* S_IFLNK */
claus
parents: 384
diff changeset
   146
		*new_path++ = '/';
claus
parents: 384
diff changeset
   147
	}
claus
parents: 384
diff changeset
   148
	/* Delete trailing slash but don't whomp a lone slash. */
claus
parents: 384
diff changeset
   149
	if (new_path != resolved_path + 1 && new_path[-1] == '/')
claus
parents: 384
diff changeset
   150
		new_path--;
claus
parents: 384
diff changeset
   151
	/* Make sure it's null terminated. */
claus
parents: 384
diff changeset
   152
	*new_path = '\0';
claus
parents: 384
diff changeset
   153
	return resolved_path;
claus
parents: 384
diff changeset
   154
}
claus
parents: 384
diff changeset
   155
# define HAS_REALPATH
claus
parents: 384
diff changeset
   156
#endif /* WANT_REALPATH && not HAS_REALPATH */
claus
parents: 384
diff changeset
   157
%}
claus
parents: 384
diff changeset
   158
! !
claus
parents: 384
diff changeset
   159
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   160
!OperatingSystem primitiveDefinitions!
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   161
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   162
%{
a27a279701f8 Initial revision
claus
parents:
diff changeset
   163
a27a279701f8 Initial revision
claus
parents:
diff changeset
   164
#ifdef transputer
a27a279701f8 Initial revision
claus
parents:
diff changeset
   165
# define unlink(f)      ((remove(f) == 0) ? 0 : -1)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   166
#else
a27a279701f8 Initial revision
claus
parents:
diff changeset
   167
# include <signal.h>
a27a279701f8 Initial revision
claus
parents:
diff changeset
   168
a27a279701f8 Initial revision
claus
parents:
diff changeset
   169
# ifdef SYSV
a27a279701f8 Initial revision
claus
parents:
diff changeset
   170
#  include <sys/types.h>
a27a279701f8 Initial revision
claus
parents:
diff changeset
   171
#  include <sys/param.h>
a27a279701f8 Initial revision
claus
parents:
diff changeset
   172
#  include <sys/times.h>
373
00599575a949 cd ../libbasic2
claus
parents: 370
diff changeset
   173
#  include <sys/file.h>
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   174
#  if ! defined(sco3_2)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   175
#   include <unistd.h>
a27a279701f8 Initial revision
claus
parents:
diff changeset
   176
#  endif
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   177
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   178
#  if defined(isc3_2) || defined(sco3_2)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   179
#   include <sys/time.h>
a27a279701f8 Initial revision
claus
parents:
diff changeset
   180
#  endif
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   181
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   182
#  if !defined(isc3_2)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   183
#   if defined(PCS) && defined(mips)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   184
#    include "/usr/include/bsd/sys/time.h"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   185
#    include "/usr/include/sys/time.h"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   186
#   else
a27a279701f8 Initial revision
claus
parents:
diff changeset
   187
#    include <time.h>
a27a279701f8 Initial revision
claus
parents:
diff changeset
   188
#   endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   189
#  endif
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   190
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   191
#  if defined(isc3_2)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   192
#   include <sys/bsdtypes.h>
a27a279701f8 Initial revision
claus
parents:
diff changeset
   193
#  endif
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   194
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   195
# else /* not SYSV */
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   196
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   197
#  include <sys/time.h>
a27a279701f8 Initial revision
claus
parents:
diff changeset
   198
#  include <sys/types.h>
a27a279701f8 Initial revision
claus
parents:
diff changeset
   199
# endif
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   200
359
claus
parents: 357
diff changeset
   201
# ifdef aix
claus
parents: 357
diff changeset
   202
#  include <time.h>
claus
parents: 357
diff changeset
   203
#  include <sys/select.h>
claus
parents: 357
diff changeset
   204
# endif
claus
parents: 357
diff changeset
   205
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   206
# include <pwd.h>
a27a279701f8 Initial revision
claus
parents:
diff changeset
   207
# include <grp.h>
a27a279701f8 Initial revision
claus
parents:
diff changeset
   208
a27a279701f8 Initial revision
claus
parents:
diff changeset
   209
# include <sys/stat.h>
10
claus
parents: 5
diff changeset
   210
# include <errno.h>
claus
parents: 5
diff changeset
   211
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   212
/* 
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   213
 * posix systems should define these ... 
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   214
 * but on some (older) systems, they are not.
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   215
 */
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   216
# ifndef S_IXUSR
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   217
#  ifdef S_IEXEC
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   218
#   define S_IXUSR S_IEXEC
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   219
#   define S_IXGRP (S_IEXEC>>3)
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   220
#   define S_IXOTH (S_IEXEC>>6)
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   221
#  endif
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   222
# endif
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   223
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   224
# ifndef S_IXUSR
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   225
#  define S_IXUSR 0100
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   226
#  define S_IXGRP 0010
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   227
#  define S_IXOTH 0001
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   228
# endif
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   229
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   230
# ifndef S_IRUSR
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   231
#  define S_IRUSR 0400
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   232
#  define S_IRGRP 0040
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   233
#  define S_IROTH 0004
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   234
# endif
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   235
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   236
# ifndef S_IWUSR
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   237
#  define S_IWUSR 0200
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   238
#  define S_IWGRP 0020
40ca7cc6fb9c *** empty log message ***
claus
parents: 185
diff changeset
   239
#  define S_IWOTH 0002
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   240
# endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   241
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   242
# ifndef MAXPATHLEN
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   243
#  include <sys/param.h>
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   244
#  ifndef MAXPATHLEN
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   245
#   define MAXPATHLEN 1024
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   246
#  endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   247
# endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   248
204
0a562ad64bcc uname fixes for unixware
claus
parents: 202
diff changeset
   249
# if defined(HAS_UNAME)
0a562ad64bcc uname fixes for unixware
claus
parents: 202
diff changeset
   250
#  include <sys/utsname.h>
0a562ad64bcc uname fixes for unixware
claus
parents: 202
diff changeset
   251
# endif
0a562ad64bcc uname fixes for unixware
claus
parents: 202
diff changeset
   252
359
claus
parents: 357
diff changeset
   253
# include <stdio.h>
claus
parents: 357
diff changeset
   254
# include <fcntl.h>
claus
parents: 357
diff changeset
   255
claus
parents: 357
diff changeset
   256
#endif /* ! transputer */
234
f03db82ccdd1 errnot cleanup
claus
parents: 216
diff changeset
   257
10
claus
parents: 5
diff changeset
   258
/*
claus
parents: 5
diff changeset
   259
 * on some systems errno is a macro ... check for it here
claus
parents: 5
diff changeset
   260
 */
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   261
#ifndef errno
a27a279701f8 Initial revision
claus
parents:
diff changeset
   262
 extern errno;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   263
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   264
10
claus
parents: 5
diff changeset
   265
/*
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   266
 * some (old ?) systems do not define this ...
10
claus
parents: 5
diff changeset
   267
 */
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   268
#ifndef R_OK
a27a279701f8 Initial revision
claus
parents:
diff changeset
   269
# define R_OK    4       /* Test for Read permission */ 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   270
# define W_OK    2       /* Test for Write permission */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   271
# define X_OK    1       /* Test for eXecute permission */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   272
# define F_OK    0       /* Test for existence of File */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   273
#endif
406
claus
parents: 384
diff changeset
   274
claus
parents: 384
diff changeset
   275
#define UNIX_LIKE
claus
parents: 384
diff changeset
   276
claus
parents: 384
diff changeset
   277
#if defined(NT)  || defined(MSWINDOWS) || defined(OS2) || defined(MSDOS)
claus
parents: 384
diff changeset
   278
# define MSDOS_LIKE
claus
parents: 384
diff changeset
   279
# undef UNIX_LIKE
claus
parents: 384
diff changeset
   280
#endif
claus
parents: 384
diff changeset
   281
claus
parents: 384
diff changeset
   282
#if defined(transputer)
claus
parents: 384
diff changeset
   283
# undef UNIX_LIKE
claus
parents: 384
diff changeset
   284
#endif
claus
parents: 384
diff changeset
   285
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   286
%}
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   287
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   288
2
claus
parents: 1
diff changeset
   289
!OperatingSystem class methodsFor:'documentation'!
claus
parents: 1
diff changeset
   290
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   291
copyright
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   292
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   293
 COPYRIGHT (c) 1988 by Claus Gittinger
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   294
	      All Rights Reserved
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   295
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   296
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   297
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   298
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   299
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   300
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   301
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   302
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   303
!
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   304
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   305
version
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   306
"
406
claus
parents: 384
diff changeset
   307
$Header: /cvs/stx/stx/libbasic/Attic/Unix.st,v 1.48 1995-08-23 17:50:46 claus Exp $
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   308
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   309
!
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   310
2
claus
parents: 1
diff changeset
   311
documentation
claus
parents: 1
diff changeset
   312
"
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   313
    this class gives access to some operating system services;
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   314
    some of it is very specific for unix, so do not depend on
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   315
    things available here in your applications - some may not
370
claus
parents: 369
diff changeset
   316
    be found in other OS's or be slightly different ...
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   317
    Currently, there is only this class available - once more than
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   318
    Unix is supported, the corresponding class will be bound to the
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   319
    global variable OperatingSystem.
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   320
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   321
    (On the other hand: I do not want to hide all features
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   322
     from you - in some situations it MAY be interresting to be
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   323
     able to get down to a select or fork system call easily.
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   324
     You decide - portability vs. functionality)
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   325
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   326
    Class variables:
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   327
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   328
	HostName        <String>        remembered hostname
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   329
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   330
	LastErrorNumber <Integer>       the last value of errno
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   331
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   332
	LastExecStatus  <Integer>       the returned exec status after
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   333
					the last call of system
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   334
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   335
	OSSignals       <Array>         Array of signals to be raised for corresponding
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   336
					OperatingSystem signals.
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   337
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   338
	ForkFailed      <Boolean>       set if a fork (or popen) has failed;
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   339
					ST/X will avoid doing more forks/popens
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   340
					if this flag is set, for a slightly
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   341
					smoother operation.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   342
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   343
	SlowFork      <Boolean>         if set, fork and popen are avoided;
2
claus
parents: 1
diff changeset
   344
"
claus
parents: 1
diff changeset
   345
! !
claus
parents: 1
diff changeset
   346
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   347
!OperatingSystem class methodsFor:'initialization'!
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   348
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   349
initialize
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   350
    "initialize the class"
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   351
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   352
    ObjectMemory addDependent:self
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   353
!
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   354
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   355
update:something
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   356
    something == #earlyRestart ifTrue:[
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   357
	"
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   358
	 flush cached data
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   359
	"
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   360
	HostName := nil.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   361
	LastErrorNumber := nil.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   362
	LastExecStatus := nil
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   363
    ]
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   364
! !
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   365
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   366
!OperatingSystem class methodsFor:'misc'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   367
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   368
slowFork:aBoolean
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   369
    SlowFork := aBoolean
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   370
!
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   371
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   372
exit
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   373
    "shutdown smalltalk immediately - 
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   374
     return 'good'-status (0) to parent unix process."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   375
a27a279701f8 Initial revision
claus
parents:
diff changeset
   376
%{  /* NOCONTEXT */
357
claus
parents: 356
diff changeset
   377
    __mainExit(0);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   378
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   379
    "OperatingSystem exit - dont evaluate this"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   380
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   381
a27a279701f8 Initial revision
claus
parents:
diff changeset
   382
exit:exitCode
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   383
    "shutdown smalltalk immediately -
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   384
     returning an exit-code to the parent unix process."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   385
a27a279701f8 Initial revision
claus
parents:
diff changeset
   386
%{  /* NOCONTEXT */
357
claus
parents: 356
diff changeset
   387
    int code = 1;
claus
parents: 356
diff changeset
   388
claus
parents: 356
diff changeset
   389
    if (__isSmallInteger(exitCode)) {
claus
parents: 356
diff changeset
   390
	code = _intVal(exitCode);
claus
parents: 356
diff changeset
   391
    }
claus
parents: 356
diff changeset
   392
    __mainExit(code);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   393
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   394
    "OperatingSystem exit:1 - dont evaluate this"
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   395
! 
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   396
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   397
exitWithCoreDump
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   398
    "shutdown smalltalk immediately - dumping core.
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   399
     This always returns 'bad'-status to the parent unix process.
357
claus
parents: 356
diff changeset
   400
     Notice, that no cleanup is performed at all - you may have to
claus
parents: 356
diff changeset
   401
     manually remove any tempfiles.
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   402
     Use this only for debugging ST/X itself"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   403
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   404
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   405
    abort();
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   406
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   407
    "OperatingSystem exitWithCoreDump - dont evaluate this"
10
claus
parents: 5
diff changeset
   408
! !
claus
parents: 5
diff changeset
   409
claus
parents: 5
diff changeset
   410
!OperatingSystem class methodsFor:'os queries'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   411
322
ac37e8e9edfb *** empty log message ***
claus
parents: 308
diff changeset
   412
getEnvironment:aStringOrSymbol
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   413
    "get an environment string"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   414
a27a279701f8 Initial revision
claus
parents:
diff changeset
   415
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   416
a27a279701f8 Initial revision
claus
parents:
diff changeset
   417
    char *env;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   418
322
ac37e8e9edfb *** empty log message ***
claus
parents: 308
diff changeset
   419
    if (__isString(aStringOrSymbol) || __isSymbol(aStringOrSymbol)) {
ac37e8e9edfb *** empty log message ***
claus
parents: 308
diff changeset
   420
	env =  (char *)getenv(_stringVal(aStringOrSymbol));
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   421
	if (env) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   422
	    RETURN ( _MKSTRING(env COMMA_CON) );
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   423
	}
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   424
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   425
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   426
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   427
    ^ nil
a27a279701f8 Initial revision
claus
parents:
diff changeset
   428
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   429
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   430
     OperatingSystem getEnvironment:'LANG'
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   431
     OperatingSystem getEnvironment:'LOGIN'
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   432
     OperatingSystem getEnvironment:'HOME'
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   433
     OperatingSystem getEnvironment:'NNTPSERVER'
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   434
     OperatingSystem getEnvironment:'MAIL'
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   435
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   436
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   437
a27a279701f8 Initial revision
claus
parents:
diff changeset
   438
getProcessId
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   439
    "return the (unix-)processId"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   440
a27a279701f8 Initial revision
claus
parents:
diff changeset
   441
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   442
a27a279701f8 Initial revision
claus
parents:
diff changeset
   443
    int pid = 0;
406
claus
parents: 384
diff changeset
   444
#ifdef UNIX_LIKE
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   445
    pid = getpid();
a27a279701f8 Initial revision
claus
parents:
diff changeset
   446
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   447
    RETURN ( _MKSMALLINT(pid) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   448
%}
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   449
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   450
     OperatingSystem getProcessId
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   451
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   452
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   453
a27a279701f8 Initial revision
claus
parents:
diff changeset
   454
getCPUType
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   455
    "return a string giving the type of machine we're running on.
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   456
     This may normally not be of any interrest to you ..."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   457
a27a279701f8 Initial revision
claus
parents:
diff changeset
   458
    |cpu|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   459
    
a27a279701f8 Initial revision
claus
parents:
diff changeset
   460
%{  /* NOCONTEXT */
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   461
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   462
#   ifdef vax
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   463
#    define CPU_STRING "vax"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   464
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   465
#   ifdef mips
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   466
#    define CPU_STRING "mips"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   467
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   468
#   ifdef i386
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   469
#    define CPU_STRING "i386"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   470
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   471
#   ifdef ns32k
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   472
#    define CPU_STRING "ns32k"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   473
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   474
#   ifdef mc68k
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   475
#    define CPU_STRING "mc68k"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   476
#   endif
406
claus
parents: 384
diff changeset
   477
#   ifdef mc88k
claus
parents: 384
diff changeset
   478
#    define CPU_STRING "mc88k"
claus
parents: 384
diff changeset
   479
#   endif
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   480
#   ifdef sparc
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   481
#    define CPU_STRING "sparc"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   482
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   483
#   ifdef hppa
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   484
#    define CPU_STRING "hppa"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   485
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   486
#   ifdef rs6000
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   487
#    define CPU_STRING "rs6000"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   488
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   489
#   ifdef alpha
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   490
#    define CPU_STRING "alpha"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   491
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   492
#   ifdef powerPC
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   493
#    define CPU_STRING "powerPC"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   494
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   495
#   ifdef transputer
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   496
#    define CPU_STRING "transputer"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   497
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   498
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   499
#   ifndef CPU_STRING
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   500
#    define CPU_STRING "unknown"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   501
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   502
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   503
    cpu = _MKSTRING(CPU_STRING COMMA_CON);
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   504
#   undef CPU_STRING
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   505
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   506
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   507
    ^ cpu
a27a279701f8 Initial revision
claus
parents:
diff changeset
   508
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   509
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   510
     OperatingSystem getCPUType
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   511
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   512
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   513
    "examples: are we running on a ss-10/solaris ?"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   514
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   515
     (OperatingSystem getCPUType = 'sparc') 
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   516
     and:[OperatingSystem getOSType = 'solaris']
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   517
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   518
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   519
    "or on a pc/solaris ?"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   520
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   521
     (OperatingSystem getCPUType = 'i386')
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   522
     and:[OperatingSystem getOSType = 'solaris']
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   523
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   524
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   525
a27a279701f8 Initial revision
claus
parents:
diff changeset
   526
getOSType
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   527
    "return a string giving the type of OS we're running on.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   528
     This can be used to adapt programs to certain environment
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   529
     differences (for example: mail-lock strategy ...)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   530
a27a279701f8 Initial revision
claus
parents:
diff changeset
   531
    |os|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   532
a27a279701f8 Initial revision
claus
parents:
diff changeset
   533
%{  /* NOCONTEXT */
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   534
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   535
#   ifdef MSDOS
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   536
#    define OS_STRING "msdos"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   537
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   538
406
claus
parents: 384
diff changeset
   539
#   ifdef MSWINDOWS
claus
parents: 384
diff changeset
   540
#    define OS_STRING "mswindows"
claus
parents: 384
diff changeset
   541
#   endif
claus
parents: 384
diff changeset
   542
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   543
#   ifdef NT
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   544
#    define OS_STRING "nt"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   545
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   546
406
claus
parents: 384
diff changeset
   547
#   ifdef OS2
claus
parents: 384
diff changeset
   548
#    define OS_STRING "os/2"
claus
parents: 384
diff changeset
   549
#   endif
claus
parents: 384
diff changeset
   550
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   551
#   ifdef sinix
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   552
#    define OS_STRING "sinix"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   553
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   554
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   555
#   ifdef ultrix
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   556
#    define OS_STRING "ultrix"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   557
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   558
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   559
#   ifdef sco
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   560
#    define OS_STRING "sco"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   561
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   562
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   563
#   ifdef hpux
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   564
#    define OS_STRING "hpux"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   565
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   566
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   567
#   ifdef LINUX
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   568
#    define OS_STRING "linux"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   569
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   570
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   571
#   ifdef sunos
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   572
#    define OS_STRING "sunos"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   573
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   574
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   575
#   ifdef solaris
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   576
#    define OS_STRING "solaris"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   577
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   578
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   579
#   ifdef IRIS
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   580
#    define OS_STRING "irix"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   581
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   582
359
claus
parents: 357
diff changeset
   583
#   ifdef aix
claus
parents: 357
diff changeset
   584
#    define OS_STRING "aix"
claus
parents: 357
diff changeset
   585
#   endif
claus
parents: 357
diff changeset
   586
406
claus
parents: 384
diff changeset
   587
#   ifdef realIX
claus
parents: 384
diff changeset
   588
#    define OS_STRING "realIX"
claus
parents: 384
diff changeset
   589
#   endif
claus
parents: 384
diff changeset
   590
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   591
    /*
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   592
     * no concrete info; become somewhat vague ...
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   593
     */
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   594
#   ifndef OS_STRING
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   595
#    ifdef MACH
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   596
#     define OS_STRING "mach"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   597
#    endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   598
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   599
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   600
#   ifndef OS_STRING
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   601
#    ifdef BSD
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   602
#     define OS_STRING "bsd"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   603
#    endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   604
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   605
#    ifdef SYSV
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   606
#     ifdef SYSV3
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   607
#      define OS_STRING "sys5.3"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   608
#     else
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   609
#      ifdef SYSV4
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   610
#       define OS_STRING "sys5.4"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   611
#      else
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   612
#       define OS_STRING "sys5"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   613
#      endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   614
#     endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   615
#    endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   616
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   617
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   618
    /*
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   619
     * become very vague ...
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   620
     */
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   621
#   ifndef OS_STRING
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   622
#    ifdef POSIX
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   623
#     define OS_STRING "posix"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   624
#    endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   625
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   626
#   ifndef OS_STRING
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   627
#    ifdef UNIX
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   628
#     define OS_STRING "unix"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   629
#    endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   630
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   631
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   632
#   ifndef OS_STRING
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   633
#    define OS_STRING "unknown"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   634
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   635
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   636
    os = _MKSTRING(OS_STRING COMMA_CON);
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   637
#   undef OS_STRING
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   638
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   639
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   640
    ^ os
a27a279701f8 Initial revision
claus
parents:
diff changeset
   641
a27a279701f8 Initial revision
claus
parents:
diff changeset
   642
    "OperatingSystem getOSType"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   643
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   644
a27a279701f8 Initial revision
claus
parents:
diff changeset
   645
getSystemType
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   646
    "return a string giving the type of system we're running on.
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   647
     This is almost the same as getOSType, but the returned string
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   648
     is slightly different for some systems (i.e. iris vs. irix).
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   649
     Dont depend on this - use getOSType. I dont really see a point
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   650
     here ... (except for slight differences between next/mach and other
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   651
     machs)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   652
a27a279701f8 Initial revision
claus
parents:
diff changeset
   653
    |sys|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   654
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   655
%{
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   656
#   ifdef NEXT
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   657
#    define SYS_STRING "next"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   658
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   659
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   660
#   ifdef IRIS
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   661
#    define SYS_STRING "iris"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   662
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   663
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   664
#   ifdef SYS_STRING
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   665
     sys = _MKSTRING(SYS_STRING COMMA_CON);
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   666
#    undef SYS_STRING
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   667
#   endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   668
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   669
.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   670
    sys isNil ifTrue:[
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   671
	^ self getOSType
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   672
    ].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   673
    ^ sys
a27a279701f8 Initial revision
claus
parents:
diff changeset
   674
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   675
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   676
     OperatingSystem getSystemType
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   677
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   678
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   679
10
claus
parents: 5
diff changeset
   680
getHostName
claus
parents: 5
diff changeset
   681
    "return the hostname we are running on - if there is
claus
parents: 5
diff changeset
   682
     a HOST environment variable, we are much faster here ..."
claus
parents: 5
diff changeset
   683
claus
parents: 5
diff changeset
   684
    |name p|
claus
parents: 5
diff changeset
   685
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   686
    HostName notNil ifTrue:[
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   687
	^ HostName
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   688
    ].
10
claus
parents: 5
diff changeset
   689
    name := self getEnvironment:'HOST'.
204
0a562ad64bcc uname fixes for unixware
claus
parents: 202
diff changeset
   690
0a562ad64bcc uname fixes for unixware
claus
parents: 202
diff changeset
   691
%{  /* STACK: 2048 */
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   692
#if defined(HAS_GETHOSTNAME)
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   693
    char buffer[128];
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   694
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   695
    if (gethostname(buffer, sizeof(buffer)) == 0) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   696
	name = _MKSTRING(buffer COMMA_CON);
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   697
    }
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   698
#else
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   699
# if defined(HAS_UNAME)
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   700
    struct utsname ubuff;
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   701
204
0a562ad64bcc uname fixes for unixware
claus
parents: 202
diff changeset
   702
    if (uname(&ubuff) >= 0) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   703
	name = _MKSTRING(ubuff.nodename COMMA_CON);
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   704
    }
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   705
# endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   706
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   707
%}.
10
claus
parents: 5
diff changeset
   708
    name isNil ifTrue:[
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   709
	"since fork might be slow on some machines, give a warning ..."
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   710
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   711
	ForkFailed ifFalse:[
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   712
	    'please set the HOST shell variable for a faster startup' errorPrintNL.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   713
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   714
	    PipeStream openErrorSignal handle:[:ex |
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   715
		ForkFailed := true.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   716
		'UNIX: cannot fork/popen' errorPrintNL.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   717
		ex return.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   718
	    ] do:[
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   719
		p := PipeStream readingFrom:'hostname'.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   720
		p notNil ifTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   721
		    name := p nextLine.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   722
		    p close
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   723
		]
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   724
	    ]
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   725
	]
10
claus
parents: 5
diff changeset
   726
    ].
claus
parents: 5
diff changeset
   727
    name isNil ifTrue:[
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   728
	'cannot find out hostname' errorPrintNL.
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
   729
	name := 'unknown'.
10
claus
parents: 5
diff changeset
   730
    ].
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   731
    HostName := name.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   732
    ^ name
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   733
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   734
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   735
     OperatingSystem getHostName
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   736
    "
10
claus
parents: 5
diff changeset
   737
!
claus
parents: 5
diff changeset
   738
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   739
isBSDlike
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   740
    "return true, if the OS we're running on is a 'real' unix."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   741
a27a279701f8 Initial revision
claus
parents:
diff changeset
   742
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   743
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   744
#if defined(BSD) || defined(MACH) || defined(SYSV4)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   745
    RETURN ( true );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   746
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   747
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   748
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   749
    ^ false
a27a279701f8 Initial revision
claus
parents:
diff changeset
   750
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   751
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   752
isUNIXlike
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   753
    "return true, if the OS we're running on is a unix like."
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   754
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   755
%{  /* NOCONTEXT */
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   756
406
claus
parents: 384
diff changeset
   757
#if defined(UNIX_LIKE)
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   758
    RETURN ( false );
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   759
#endif
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   760
%}
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   761
.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   762
    ^ true
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   763
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   764
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   765
isMSDOSlike
406
claus
parents: 384
diff changeset
   766
    "return true, if the OS we're running on is dos like 
claus
parents: 384
diff changeset
   767
     (in contrast to unix-like)."
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   768
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   769
%{  /* NOCONTEXT */
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   770
406
claus
parents: 384
diff changeset
   771
#if defined(MSDOS_LIKE)
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   772
    RETURN ( true );
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   773
#endif
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   774
%}
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   775
.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   776
    ^ false
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   777
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   778
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   779
maxFileNameLength
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   780
    "return the max number of characters in a filename.
406
claus
parents: 384
diff changeset
   781
     Actually, the following is somewhat wrong - some systems
claus
parents: 384
diff changeset
   782
     support differnet size depending on the volume.
claus
parents: 384
diff changeset
   783
     We return a somewhat conservative number here."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   784
a27a279701f8 Initial revision
claus
parents:
diff changeset
   785
%{  /* NOCONTEXT */
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   786
 
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   787
    /*
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   788
     * XXX: newer systems provide a query function for this ... use it
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   789
     */
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   790
#   if defined(BSD) || defined(SYSV4) || defined(LONGFILENAMES)
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   791
     RETURN ( _MKSMALLINT(255) );
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   792
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   793
252
   794
#   ifdef realIX
   795
      RETURN ( _MKSMALLINT(127) );
   796
#   endif
   797
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   798
#   ifdef SYSV
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   799
      RETURN ( _MKSMALLINT(14) );
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   800
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   801
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   802
#   ifdef MSDOS
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   803
     RETURN ( _MKSMALLINT(9) );
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   804
#   endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   805
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   806
#   ifdef NT
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   807
     /*
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   808
      * mhmh - depends on the filesystem type
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   809
      */
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   810
     RETURN ( _MKSMALLINT(9) );
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   811
#   endif
406
claus
parents: 384
diff changeset
   812
%}.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   813
    "unix default"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   814
    ^ 14
10
claus
parents: 5
diff changeset
   815
!
claus
parents: 5
diff changeset
   816
claus
parents: 5
diff changeset
   817
supportsIOInterrupts
claus
parents: 5
diff changeset
   818
    "return true, if the OS supports IO availability interrupts 
42
e33491f6f260 *** empty log message ***
claus
parents: 26
diff changeset
   819
     (i.e. SIGPOLL/SIGIO).
e33491f6f260 *** empty log message ***
claus
parents: 26
diff changeset
   820
e33491f6f260 *** empty log message ***
claus
parents: 26
diff changeset
   821
     Currently, this mechanism does not work at all ..."
10
claus
parents: 5
diff changeset
   822
claus
parents: 5
diff changeset
   823
%{  /* NOCONTEXT */
42
e33491f6f260 *** empty log message ***
claus
parents: 26
diff changeset
   824
#ifdef NOTDEF
e33491f6f260 *** empty log message ***
claus
parents: 26
diff changeset
   825
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   826
#   if defined(SIGPOLL) || defined(SIGIO)
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   827
#    if defined(F_GETFL) && defined(F_SETFL)
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   828
#     if defined(FASYNC)
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   829
      /*
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   830
       * mhmh they seem to NOT work on NS2.1
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   831
       */
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   832
#      if !defined(NEXT)
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   833
	RETURN (true);
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   834
#      endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   835
#     endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   836
#    endif
10
claus
parents: 5
diff changeset
   837
#   endif
42
e33491f6f260 *** empty log message ***
claus
parents: 26
diff changeset
   838
e33491f6f260 *** empty log message ***
claus
parents: 26
diff changeset
   839
#endif
10
claus
parents: 5
diff changeset
   840
%}
claus
parents: 5
diff changeset
   841
.
claus
parents: 5
diff changeset
   842
    ^ false
claus
parents: 5
diff changeset
   843
!
claus
parents: 5
diff changeset
   844
claus
parents: 5
diff changeset
   845
supportsNonBlockingIO
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   846
    "return true, if the OS supports nonblocking IO."
10
claus
parents: 5
diff changeset
   847
claus
parents: 5
diff changeset
   848
%{  /* NOCONTEXT */
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   849
#   if defined(F_GETFL) && defined(F_SETFL)
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   850
#    if defined(FNDELAY)
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   851
       RETURN (true);
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   852
#    endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   853
#   endif
10
claus
parents: 5
diff changeset
   854
%}
claus
parents: 5
diff changeset
   855
.
claus
parents: 5
diff changeset
   856
    ^ false
claus
parents: 5
diff changeset
   857
!
claus
parents: 5
diff changeset
   858
claus
parents: 5
diff changeset
   859
supportsSelect
claus
parents: 5
diff changeset
   860
    "return true, if the OS supports selecting on multiple
claus
parents: 5
diff changeset
   861
     filedescriptors via select."
claus
parents: 5
diff changeset
   862
claus
parents: 5
diff changeset
   863
%{  /* NOCONTEXT */
claus
parents: 5
diff changeset
   864
#if defined(sco)
claus
parents: 5
diff changeset
   865
    /*
claus
parents: 5
diff changeset
   866
     * sco has a broken select - always waiting 1 second
claus
parents: 5
diff changeset
   867
     */
claus
parents: 5
diff changeset
   868
    RETURN(false);
claus
parents: 5
diff changeset
   869
#endif
claus
parents: 5
diff changeset
   870
%}
claus
parents: 5
diff changeset
   871
.
claus
parents: 5
diff changeset
   872
    ^ true
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   873
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   874
2
claus
parents: 1
diff changeset
   875
!OperatingSystem class methodsFor:'users & groups'!
claus
parents: 1
diff changeset
   876
claus
parents: 1
diff changeset
   877
getLoginName
claus
parents: 1
diff changeset
   878
    "return a string with the users name"
claus
parents: 1
diff changeset
   879
claus
parents: 1
diff changeset
   880
%{  /* NOCONTEXT */
claus
parents: 1
diff changeset
   881
claus
parents: 1
diff changeset
   882
    char *name = "you";
406
claus
parents: 384
diff changeset
   883
#ifdef UNIX_LIKE
2
claus
parents: 1
diff changeset
   884
    name = (char *)getlogin();
26
8dba727d8981 *** empty log message ***
claus
parents: 18
diff changeset
   885
    if (! name || (name[0] == 0)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   886
	name = (char *)getenv("LOGNAME");
2
claus
parents: 1
diff changeset
   887
    }
claus
parents: 1
diff changeset
   888
#endif
claus
parents: 1
diff changeset
   889
    RETURN ( _MKSTRING(name COMMA_CON) );
claus
parents: 1
diff changeset
   890
%}
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   891
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   892
     OperatingSystem getLoginName
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   893
    "
2
claus
parents: 1
diff changeset
   894
!
claus
parents: 1
diff changeset
   895
claus
parents: 1
diff changeset
   896
getUserNameFromID:aNumber
claus
parents: 1
diff changeset
   897
    "return the user-name-string for a given numeric user-id"
claus
parents: 1
diff changeset
   898
claus
parents: 1
diff changeset
   899
%{  /* NOCONTEXT */
claus
parents: 1
diff changeset
   900
406
claus
parents: 384
diff changeset
   901
#ifdef UNIX_LIKE
2
claus
parents: 1
diff changeset
   902
    struct passwd *p;
claus
parents: 1
diff changeset
   903
252
   904
    if (__isSmallInteger(aNumber)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   905
	p = getpwuid(_intVal(aNumber));
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   906
	if (p) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   907
	    RETURN ( _MKSTRING(p->pw_name COMMA_CON) );
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   908
	}
2
claus
parents: 1
diff changeset
   909
    }
claus
parents: 1
diff changeset
   910
#endif
claus
parents: 1
diff changeset
   911
%}
claus
parents: 1
diff changeset
   912
.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   913
    ^ '? (' , aNumber printString , ')'
2
claus
parents: 1
diff changeset
   914
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   915
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   916
     OperatingSystem getUserNameFromID:0
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   917
     OperatingSystem getUserNameFromID:100
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   918
     OperatingSystem getUserNameFromID:9991 
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   919
    "
2
claus
parents: 1
diff changeset
   920
!
claus
parents: 1
diff changeset
   921
claus
parents: 1
diff changeset
   922
getGroupNameFromID:aNumber
claus
parents: 1
diff changeset
   923
    "return the group-name-string for a given numeric group-id"
claus
parents: 1
diff changeset
   924
claus
parents: 1
diff changeset
   925
%{  /* NOCONTEXT */
claus
parents: 1
diff changeset
   926
406
claus
parents: 384
diff changeset
   927
#ifdef UNIX_LIKE
2
claus
parents: 1
diff changeset
   928
    struct group *g;
claus
parents: 1
diff changeset
   929
252
   930
    if (__isSmallInteger(aNumber)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   931
	g = getgrgid(_intVal(aNumber));
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   932
	if (g) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   933
	    RETURN ( _MKSTRING(g->gr_name COMMA_CON) );
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
   934
	}
2
claus
parents: 1
diff changeset
   935
    }
claus
parents: 1
diff changeset
   936
#endif
claus
parents: 1
diff changeset
   937
%}
claus
parents: 1
diff changeset
   938
.
claus
parents: 1
diff changeset
   939
    ^ '???'
claus
parents: 1
diff changeset
   940
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   941
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   942
     OperatingSystem getGroupNameFromID:0
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   943
     OperatingSystem getGroupNameFromID:10
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   944
    "
2
claus
parents: 1
diff changeset
   945
!
claus
parents: 1
diff changeset
   946
claus
parents: 1
diff changeset
   947
getHomeDirectory
10
claus
parents: 5
diff changeset
   948
    "return the name of the users home directory"
2
claus
parents: 1
diff changeset
   949
claus
parents: 1
diff changeset
   950
    ^ OperatingSystem getEnvironment:'HOME'
claus
parents: 1
diff changeset
   951
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   952
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   953
     OperatingSystem getHomeDirectory
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
   954
    "
406
claus
parents: 384
diff changeset
   955
!
claus
parents: 384
diff changeset
   956
claus
parents: 384
diff changeset
   957
getUserID
claus
parents: 384
diff changeset
   958
    "return the current users (thats you) numeric user id"
claus
parents: 384
diff changeset
   959
claus
parents: 384
diff changeset
   960
%{  /* NOCONTEXT */
claus
parents: 384
diff changeset
   961
claus
parents: 384
diff changeset
   962
#ifdef UNIX_LIKE
claus
parents: 384
diff changeset
   963
    int uid;
claus
parents: 384
diff changeset
   964
claus
parents: 384
diff changeset
   965
    uid = getuid();
claus
parents: 384
diff changeset
   966
    RETURN ( __MKSMALLINT(uid) );
claus
parents: 384
diff changeset
   967
#endif
claus
parents: 384
diff changeset
   968
%}
claus
parents: 384
diff changeset
   969
claus
parents: 384
diff changeset
   970
    "
claus
parents: 384
diff changeset
   971
     OperatingSystem getUserID
claus
parents: 384
diff changeset
   972
    "
claus
parents: 384
diff changeset
   973
!
claus
parents: 384
diff changeset
   974
claus
parents: 384
diff changeset
   975
getEffectiveUserID
claus
parents: 384
diff changeset
   976
    "return the current users (thats you) effective numeric user id.
claus
parents: 384
diff changeset
   977
     This is only different from getUserID, if you have ST/X running
claus
parents: 384
diff changeset
   978
     as a setuid program (of which you should think about twice)."
claus
parents: 384
diff changeset
   979
claus
parents: 384
diff changeset
   980
%{  /* NOCONTEXT */
claus
parents: 384
diff changeset
   981
claus
parents: 384
diff changeset
   982
#ifdef UNIX_LIKE
claus
parents: 384
diff changeset
   983
    int uid;
claus
parents: 384
diff changeset
   984
claus
parents: 384
diff changeset
   985
    uid = geteuid();
claus
parents: 384
diff changeset
   986
    RETURN ( __MKSMALLINT(uid) );
claus
parents: 384
diff changeset
   987
#endif
claus
parents: 384
diff changeset
   988
%}
claus
parents: 384
diff changeset
   989
claus
parents: 384
diff changeset
   990
    "
claus
parents: 384
diff changeset
   991
     OperatingSystem getEffectiveUserID
claus
parents: 384
diff changeset
   992
    "
claus
parents: 384
diff changeset
   993
!
claus
parents: 384
diff changeset
   994
claus
parents: 384
diff changeset
   995
getGroupID
claus
parents: 384
diff changeset
   996
    "return the current users (thats you) numeric group id"
claus
parents: 384
diff changeset
   997
claus
parents: 384
diff changeset
   998
%{  /* NOCONTEXT */
claus
parents: 384
diff changeset
   999
claus
parents: 384
diff changeset
  1000
#ifdef UNIX_LIKE
claus
parents: 384
diff changeset
  1001
    int uid;
claus
parents: 384
diff changeset
  1002
claus
parents: 384
diff changeset
  1003
    uid = getgid();
claus
parents: 384
diff changeset
  1004
    RETURN ( __MKSMALLINT(uid) );
claus
parents: 384
diff changeset
  1005
#endif
claus
parents: 384
diff changeset
  1006
%}
claus
parents: 384
diff changeset
  1007
claus
parents: 384
diff changeset
  1008
    "
claus
parents: 384
diff changeset
  1009
     OperatingSystem getGroupID
claus
parents: 384
diff changeset
  1010
    "
claus
parents: 384
diff changeset
  1011
!
claus
parents: 384
diff changeset
  1012
claus
parents: 384
diff changeset
  1013
getEffectiveGroupID
claus
parents: 384
diff changeset
  1014
    "return the current users (thats you) effective numeric group id.
claus
parents: 384
diff changeset
  1015
     This is only different from getGroupID, if you have ST/X running
claus
parents: 384
diff changeset
  1016
     as a setuid program (of which you should think about twice)."
claus
parents: 384
diff changeset
  1017
claus
parents: 384
diff changeset
  1018
%{  /* NOCONTEXT */
claus
parents: 384
diff changeset
  1019
claus
parents: 384
diff changeset
  1020
#ifdef UNIX_LIKE
claus
parents: 384
diff changeset
  1021
    int uid;
claus
parents: 384
diff changeset
  1022
claus
parents: 384
diff changeset
  1023
    uid = getegid();
claus
parents: 384
diff changeset
  1024
    RETURN ( __MKSMALLINT(uid) );
claus
parents: 384
diff changeset
  1025
#endif
claus
parents: 384
diff changeset
  1026
%}
claus
parents: 384
diff changeset
  1027
claus
parents: 384
diff changeset
  1028
    "
claus
parents: 384
diff changeset
  1029
     OperatingSystem getEffectiveGroupID
claus
parents: 384
diff changeset
  1030
    "
claus
parents: 384
diff changeset
  1031
!
claus
parents: 384
diff changeset
  1032
claus
parents: 384
diff changeset
  1033
userInfoOf:aNameOrID
claus
parents: 384
diff changeset
  1034
    "return a dictionary filled with userinfo. The argument can be either
claus
parents: 384
diff changeset
  1035
     a string with the users name or its numeric id.
claus
parents: 384
diff changeset
  1036
     Notice, that not all systems provide (all of) this info;
claus
parents: 384
diff changeset
  1037
     DOS systems return nothing; 
claus
parents: 384
diff changeset
  1038
     non-SYSV4 systems have no age/comment.
claus
parents: 384
diff changeset
  1039
     Portable applications may want to check the systemType and NOT depend
claus
parents: 384
diff changeset
  1040
     on all keys to be present in the returned dictionary.
claus
parents: 384
diff changeset
  1041
     Another notice: on some systems (SYSV4), the gecos field includes multiple
claus
parents: 384
diff changeset
  1042
     entries (i.e. not just the name), separated by commas. You may want to
claus
parents: 384
diff changeset
  1043
     extract any substring, up to the first comma to get the real life name."
claus
parents: 384
diff changeset
  1044
claus
parents: 384
diff changeset
  1045
    |info name passw uid gid age comment
claus
parents: 384
diff changeset
  1046
     gecos dir shell|
claus
parents: 384
diff changeset
  1047
claus
parents: 384
diff changeset
  1048
%{
claus
parents: 384
diff changeset
  1049
#ifdef UNIX_LIKE
claus
parents: 384
diff changeset
  1050
    struct passwd *buf;
claus
parents: 384
diff changeset
  1051
    int ret;
claus
parents: 384
diff changeset
  1052
claus
parents: 384
diff changeset
  1053
    if (__isString(aNameOrID)) {
claus
parents: 384
diff changeset
  1054
	buf = getpwnam(__stringVal(aNameOrID));
claus
parents: 384
diff changeset
  1055
    } else if (__isSmallInteger(aNameOrID)) {
claus
parents: 384
diff changeset
  1056
	buf = getpwuid(__intVal(aNameOrID));
claus
parents: 384
diff changeset
  1057
    } else {
claus
parents: 384
diff changeset
  1058
	buf = (struct passwd *)0;
claus
parents: 384
diff changeset
  1059
    }
claus
parents: 384
diff changeset
  1060
    if (buf) {
claus
parents: 384
diff changeset
  1061
	name = _MKSTRING(buf->pw_name COMMA_CON);
claus
parents: 384
diff changeset
  1062
	passw = _MKSTRING(buf->pw_passwd COMMA_CON);
claus
parents: 384
diff changeset
  1063
# ifdef SYSV4
claus
parents: 384
diff changeset
  1064
	age = _MKSTRING(buf->pw_age COMMA_CON);
claus
parents: 384
diff changeset
  1065
	comment = _MKSTRING(buf->pw_comment COMMA_CON);
claus
parents: 384
diff changeset
  1066
# endif
claus
parents: 384
diff changeset
  1067
	dir = _MKSTRING(buf->pw_dir COMMA_CON);
claus
parents: 384
diff changeset
  1068
	gecos = _MKSTRING(buf->pw_gecos COMMA_CON);
claus
parents: 384
diff changeset
  1069
	shell = _MKSTRING(buf->pw_shell COMMA_CON);
claus
parents: 384
diff changeset
  1070
claus
parents: 384
diff changeset
  1071
	uid = _MKSMALLINT(buf->pw_uid);
claus
parents: 384
diff changeset
  1072
	gid = _MKSMALLINT(buf->pw_gid);
claus
parents: 384
diff changeset
  1073
    }
claus
parents: 384
diff changeset
  1074
#endif
claus
parents: 384
diff changeset
  1075
%}.
claus
parents: 384
diff changeset
  1076
    name notNil ifTrue:[
claus
parents: 384
diff changeset
  1077
	info := IdentityDictionary new.
claus
parents: 384
diff changeset
  1078
	info at:#name put:name.
claus
parents: 384
diff changeset
  1079
	info at:#passwd put:passw.
claus
parents: 384
diff changeset
  1080
	age notNil ifTrue:[info at:#age put:age].
claus
parents: 384
diff changeset
  1081
	comment notNil ifTrue:[info at:#comment put:comment].
claus
parents: 384
diff changeset
  1082
	info at:#gecos put:gecos.
claus
parents: 384
diff changeset
  1083
	info at:#shell put:shell.
claus
parents: 384
diff changeset
  1084
	info at:#dir put:dir.
claus
parents: 384
diff changeset
  1085
	info at:#uid put:uid.
claus
parents: 384
diff changeset
  1086
	info at:#gid put:gid.
claus
parents: 384
diff changeset
  1087
	^ info
claus
parents: 384
diff changeset
  1088
    ].
claus
parents: 384
diff changeset
  1089
    ^ nil
claus
parents: 384
diff changeset
  1090
claus
parents: 384
diff changeset
  1091
    "
claus
parents: 384
diff changeset
  1092
     OperatingSystem userInfoOf:'root'
claus
parents: 384
diff changeset
  1093
     OperatingSystem userInfoOf:1
claus
parents: 384
diff changeset
  1094
     OperatingSystem userInfoOf:'claus' 
claus
parents: 384
diff changeset
  1095
     OperatingSystem userInfoOf:'fooBar' 
claus
parents: 384
diff changeset
  1096
    "
claus
parents: 384
diff changeset
  1097
!
claus
parents: 384
diff changeset
  1098
2
claus
parents: 1
diff changeset
  1099
! !
claus
parents: 1
diff changeset
  1100
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1101
!OperatingSystem class methodsFor:'error messages'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1102
85
claus
parents: 77
diff changeset
  1103
currentErrorNumber
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1104
    "returns the OS's last error nr (i.e. the value of errno).
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1105
     Notice, that the value of this flag is only valid immediately
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1106
     after the error occurred - it gets updated with every other
85
claus
parents: 77
diff changeset
  1107
     request to the OS.
claus
parents: 77
diff changeset
  1108
     Use lastErrorNumber - currentErrorNumber is invalidated by
claus
parents: 77
diff changeset
  1109
     many, many internal calls."
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1110
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1111
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1112
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1113
     RETURN ( _MKSMALLINT(errno) );
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1114
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1115
     "
85
claus
parents: 77
diff changeset
  1116
      OperatingSystem currentErrorNumber
claus
parents: 77
diff changeset
  1117
     "
claus
parents: 77
diff changeset
  1118
!
claus
parents: 77
diff changeset
  1119
claus
parents: 77
diff changeset
  1120
lastErrorNumber
claus
parents: 77
diff changeset
  1121
    "return the last error number"
claus
parents: 77
diff changeset
  1122
claus
parents: 77
diff changeset
  1123
    ^ LastErrorNumber
claus
parents: 77
diff changeset
  1124
claus
parents: 77
diff changeset
  1125
     "
claus
parents: 77
diff changeset
  1126
      OperatingSystem lastErrorNumber
claus
parents: 77
diff changeset
  1127
     "
claus
parents: 77
diff changeset
  1128
!
claus
parents: 77
diff changeset
  1129
claus
parents: 77
diff changeset
  1130
lastExecStatus
claus
parents: 77
diff changeset
  1131
    "return the last execution status"
claus
parents: 77
diff changeset
  1132
claus
parents: 77
diff changeset
  1133
    ^ LastExecStatus
claus
parents: 77
diff changeset
  1134
claus
parents: 77
diff changeset
  1135
     "
claus
parents: 77
diff changeset
  1136
      OperatingSystem lastExecStatus
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1137
     "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1138
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1139
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  1140
lastErrorString
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  1141
    "return a message string describing the last error"
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  1142
85
claus
parents: 77
diff changeset
  1143
    ^ self errorTextForNumber:LastErrorNumber
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1144
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1145
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1146
     OperatingSystem lastErrorString
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1147
    "
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  1148
!
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  1149
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1150
errorTextForNumber:errNr
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1151
    "return a message string from a unix errorNumber 
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1152
     (as returned by a system call). 
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1153
     Should be replaced by a resource lookup."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1154
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1155
%{
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1156
    /* claus:
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1157
     * I made this some primitive code, since errnos are not
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1158
     * standard across unixes
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1159
     */
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1160
    char *msg = "unknown error";
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1161
    char buffer[50];
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1162
252
  1163
    if (__isSmallInteger(errNr)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1164
	switch (_intVal(errNr)) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1165
	    /*
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1166
	     * POSIX errnos - these should be defined
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1167
	     */
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1168
	    case EPERM:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1169
		msg = "Operation not permitted";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1170
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1171
	    case ENOENT:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1172
		msg = "No such file or directory";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1173
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1174
	    case ESRCH:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1175
		msg = "No such process";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1176
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1177
	    case EINTR:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1178
		msg = "Interrupted system call";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1179
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1180
	    case EIO:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1181
		msg = "I/O error";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1182
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1183
	    case ENXIO:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1184
		msg = "No such device or address";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1185
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1186
	    case E2BIG:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1187
		msg = "Arg list too long";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1188
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1189
	    case ENOEXEC:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1190
		msg = "Exec format error";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1191
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1192
	    case EBADF:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1193
		msg = "Bad file number";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1194
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1195
	    case ECHILD:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1196
		msg = "No child processes";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1197
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1198
#if !defined(EWOULDBLOCK) && defined(EAGAIN) && (EWOULDBLOCK != EAGAIN)
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1199
	    case EAGAIN:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1200
		msg = "Try again";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1201
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1202
#endif
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1203
	    case ENOMEM:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1204
		msg = "Out of memory";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1205
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1206
	    case EACCES:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1207
		msg = "Permission denied";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1208
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1209
	    case EFAULT:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1210
		msg = "Bad address";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1211
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1212
	    case EBUSY:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1213
		msg = "Device or resource busy";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1214
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1215
	    case EEXIST:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1216
		msg = "File exists";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1217
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1218
	    case EXDEV:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1219
		msg = "Cross-device link";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1220
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1221
	    case ENODEV:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1222
		msg = "No such device";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1223
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1224
	    case ENOTDIR:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1225
		msg = "Not a directory";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1226
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1227
	    case EISDIR:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1228
		msg = "Is a directory";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1229
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1230
	    case EINVAL:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1231
		msg = "Invalid argument";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1232
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1233
	    case ENFILE:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1234
		msg = "File table overflow";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1235
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1236
	    case EMFILE:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1237
		msg = "Too many open files";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1238
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1239
	    case ENOTTY:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1240
		msg = "Not a typewriter";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1241
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1242
	    case EFBIG:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1243
		msg = "File too large";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1244
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1245
	    case ENOSPC:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1246
		msg = "No space left on device";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1247
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1248
	    case ESPIPE:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1249
		msg = "Illegal seek";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1250
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1251
	    case EROFS:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1252
		msg = "Read-only file system";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1253
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1254
	    case EMLINK:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1255
		msg = "Too many links";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1256
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1257
	    case EPIPE:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1258
		msg = "Broken pipe";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1259
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1260
	    case EDOM:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1261
		msg = "Math argument out of domain";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1262
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1263
	    case ERANGE:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1264
		msg = "Math result not representable";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1265
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1266
#ifdef EDEADLK
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  1267
# if EDEADLK != EWOULDBLOCK
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1268
	    case EDEADLK:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1269
		msg = "Resource deadlock would occur";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1270
		break;
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  1271
# endif
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1272
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1273
#ifdef ENAMETOOLONG
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1274
	    case ENAMETOOLONG:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1275
		msg = "File name too long";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1276
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1277
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1278
#ifdef ENOLCK
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1279
	    case ENOLCK:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1280
		msg = "No record locks available";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1281
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1282
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1283
#ifdef ENOSYS
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1284
	    case ENOSYS:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1285
		msg = "Function not implemented";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1286
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1287
#endif
359
claus
parents: 357
diff changeset
  1288
#if defined(ENOTEMPTY) && (ENOTEMPTY != EEXIST)
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1289
	    case ENOTEMPTY:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1290
		msg = "Directory not empty";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1291
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1292
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1293
#ifdef EILSEQ
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1294
	    case EILSEQ:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1295
		msg = "Illegal byte sequence";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1296
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1297
#endif
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1298
	    /*
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1299
	     * XPG3 errnos - defined on most systems
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1300
	     */
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1301
#ifdef ENOTBLK
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1302
	    case ENOTBLK:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1303
		msg = "Block device required";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1304
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1305
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1306
#ifdef ETXTBSY
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1307
	    case ETXTBSY:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1308
		msg = "Text file busy";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1309
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1310
#endif
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1311
	    /*
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1312
	     * some others
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1313
	     */
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1314
#ifdef EWOULDBLOCK
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1315
	    case EWOULDBLOCK:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1316
		msg = "Operation would block";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1317
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1318
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1319
#ifdef ENOMSG
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1320
	    case ENOMSG:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1321
		msg = "No message of desired type";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1322
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1323
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1324
#ifdef ELOOP
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1325
	    case ELOOP:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1326
		msg = "Too many levels of symbolic links";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1327
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1328
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1329
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1330
	    /*
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1331
	     * some stream errors
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1332
	     */
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1333
#ifdef ETIME
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1334
	    case ETIME:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1335
		msg = "Timer expired";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1336
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1337
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1338
#ifdef ENOSR
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1339
	    case ENOSR:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1340
		msg = "Out of streams resources";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1341
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1342
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1343
#ifdef ENOSTR
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1344
	    case ENOSTR:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1345
		msg = "Device not a stream";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1346
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1347
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1348
#ifdef ECOMM
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1349
	    case ECOMM:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1350
		msg = "Communication error on send";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1351
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1352
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1353
#ifdef EPROTO
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1354
	    case EPROTO:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1355
		msg = "Protocol error";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1356
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1357
#endif
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1358
	    /*
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1359
	     * nfs errors
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1360
	     */
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1361
#ifdef ESTALE
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1362
	    case ESTALE:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1363
		msg = "Stale NFS file handle";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1364
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1365
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1366
#ifdef EREMOTE
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1367
	    case EREMOTE:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1368
		msg = "Too many levels of remote in path";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1369
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1370
#endif
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1371
	    /*
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1372
	     * some networking errors
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1373
	     */
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1374
#ifdef EINPROGRESS
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1375
	    case EINPROGRESS:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1376
		msg = "Operation now in progress";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1377
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1378
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1379
#ifdef EALREADY
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1380
	    case EALREADY:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1381
		msg = "Operation already in progress";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1382
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1383
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1384
#ifdef ENOTSOCK
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1385
	    case ENOTSOCK:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1386
		msg = "Socket operation on non-socket";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1387
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1388
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1389
#ifdef EDESTADDRREQ
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1390
	    case EDESTADDRREQ:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1391
		msg = "Destination address required";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1392
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1393
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1394
#ifdef EMSGSIZE
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1395
	    case EMSGSIZE:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1396
		msg = "Message too long";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1397
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1398
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1399
#ifdef EPROTOTYPE
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1400
	    case EPROTOTYPE:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1401
		msg = "Protocol wrong type for socket";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1402
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1403
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1404
#ifdef ENOPROTOOPT
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1405
	    case ENOPROTOOPT:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1406
		msg = "Protocol not available";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1407
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1408
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1409
#ifdef EPROTONOSUPPORT
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1410
	    case EPROTONOSUPPORT:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1411
		msg = "Protocol not supported";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1412
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1413
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1414
#ifdef ESOCKTNOSUPPORT
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1415
	    case ESOCKTNOSUPPORT:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1416
		msg = "Socket type not supported";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1417
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1418
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1419
#ifdef EOPNOTSUPP
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1420
	    case EOPNOTSUPP:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1421
		msg = "Operation not supported on socket";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1422
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1423
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1424
#ifdef EPFNOSUPPORT
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1425
	    case EPFNOSUPPORT:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1426
		msg = "Protocol family not supported";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1427
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1428
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1429
#ifdef EAFNOSUPPORT
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1430
	    case EAFNOSUPPORT:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1431
		msg = "Address family not supported by protocol family";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1432
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1433
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1434
#ifdef EADDRINUSE
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1435
	    case EADDRINUSE:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1436
		msg = "Address already in use";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1437
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1438
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1439
#ifdef EADDRNOTAVAIL
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1440
	    case EADDRNOTAVAIL:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1441
		msg = "Can\'t assign requested address";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1442
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1443
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1444
#ifdef ETIMEDOUT
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1445
	    case ETIMEDOUT:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1446
		msg = "Connection timed out";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1447
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1448
#endif
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1449
#ifdef ECONNREFUSED
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1450
	    case ECONNREFUSED:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1451
		msg = "Connection refused";
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1452
		break;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1453
#endif
362
claus
parents: 359
diff changeset
  1454
#ifdef ENETDOWN
claus
parents: 359
diff changeset
  1455
	    case ENETDOWN:
claus
parents: 359
diff changeset
  1456
		msg = "Network is down";
claus
parents: 359
diff changeset
  1457
		break;
claus
parents: 359
diff changeset
  1458
#endif
claus
parents: 359
diff changeset
  1459
#ifdef ENETUNREACH
claus
parents: 359
diff changeset
  1460
	    case ENETUNREACH:
claus
parents: 359
diff changeset
  1461
		msg = "Network is unreachable";
claus
parents: 359
diff changeset
  1462
		break;
claus
parents: 359
diff changeset
  1463
#endif
claus
parents: 359
diff changeset
  1464
#ifdef ENETRESET
claus
parents: 359
diff changeset
  1465
	    case ENETRESET:
claus
parents: 359
diff changeset
  1466
		msg = "Network dropped conn due to reset";
claus
parents: 359
diff changeset
  1467
		break;
claus
parents: 359
diff changeset
  1468
#endif
claus
parents: 359
diff changeset
  1469
#ifdef ECONNABORTED
claus
parents: 359
diff changeset
  1470
	    case ECONNABORTED:
claus
parents: 359
diff changeset
  1471
		msg = "Software caused connection abort";
claus
parents: 359
diff changeset
  1472
		break;
claus
parents: 359
diff changeset
  1473
#endif
claus
parents: 359
diff changeset
  1474
#ifdef ECONNRESET
claus
parents: 359
diff changeset
  1475
	    case ECONNRESET:
claus
parents: 359
diff changeset
  1476
		msg = "Connection reset by peer";
claus
parents: 359
diff changeset
  1477
		break;
claus
parents: 359
diff changeset
  1478
#endif
claus
parents: 359
diff changeset
  1479
#ifdef EISCONN
claus
parents: 359
diff changeset
  1480
	    case EISCONN:
claus
parents: 359
diff changeset
  1481
		msg = "Socket is already connected";
claus
parents: 359
diff changeset
  1482
		break;
claus
parents: 359
diff changeset
  1483
#endif
claus
parents: 359
diff changeset
  1484
#ifdef ENOTCONN
claus
parents: 359
diff changeset
  1485
	    case ENOTCONN:
claus
parents: 359
diff changeset
  1486
		msg = "Socket is not connected";
claus
parents: 359
diff changeset
  1487
		break;
claus
parents: 359
diff changeset
  1488
#endif
claus
parents: 359
diff changeset
  1489
#ifdef ESHUTDOWN
claus
parents: 359
diff changeset
  1490
	    case ESHUTDOWN:
claus
parents: 359
diff changeset
  1491
		msg = "Can't send after socket shutdown";
claus
parents: 359
diff changeset
  1492
		break;
claus
parents: 359
diff changeset
  1493
#endif
claus
parents: 359
diff changeset
  1494
#ifdef EHOSTDOWN
claus
parents: 359
diff changeset
  1495
	    case EHOSTDOWN:
claus
parents: 359
diff changeset
  1496
		msg = "Host is down";
claus
parents: 359
diff changeset
  1497
		break;
claus
parents: 359
diff changeset
  1498
#endif
claus
parents: 359
diff changeset
  1499
#ifdef EHOSTUNREACH
claus
parents: 359
diff changeset
  1500
	    case EHOSTUNREACH:
claus
parents: 359
diff changeset
  1501
		msg = "No route to host";
claus
parents: 359
diff changeset
  1502
		break;
claus
parents: 359
diff changeset
  1503
#endif
claus
parents: 359
diff changeset
  1504
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1505
	    default:
368
a3c21a89ec37 *** empty log message ***
claus
parents: 362
diff changeset
  1506
		{
a3c21a89ec37 *** empty log message ***
claus
parents: 362
diff changeset
  1507
#ifdef THISCONTEXT_IN_REGISTER
a3c21a89ec37 *** empty log message ***
claus
parents: 362
diff changeset
  1508
		    extern OBJ __thisContext__;
a3c21a89ec37 *** empty log message ***
claus
parents: 362
diff changeset
  1509
		    __thisContext__ = __thisContext;
a3c21a89ec37 *** empty log message ***
claus
parents: 362
diff changeset
  1510
#endif
a3c21a89ec37 *** empty log message ***
claus
parents: 362
diff changeset
  1511
		    sprintf(buffer, "ErrorNr: %d", _intVal(errNr));
a3c21a89ec37 *** empty log message ***
claus
parents: 362
diff changeset
  1512
#ifdef THISCONTEXT_IN_REGISTER
a3c21a89ec37 *** empty log message ***
claus
parents: 362
diff changeset
  1513
		    __thisContext = __thisContext__;
a3c21a89ec37 *** empty log message ***
claus
parents: 362
diff changeset
  1514
		    __thisContext__ = nil;
a3c21a89ec37 *** empty log message ***
claus
parents: 362
diff changeset
  1515
#endif
a3c21a89ec37 *** empty log message ***
claus
parents: 362
diff changeset
  1516
		}
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1517
		msg = buffer;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1518
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  1519
	}
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1520
    }
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1521
    RETURN (_MKSTRING(msg COMMA_CON));
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1522
%}
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1523
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1524
345
claus
parents: 329
diff changeset
  1525
!OperatingSystem class methodsFor:'OS signal constants'!
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1526
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1527
sigHUP
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1528
    "return the signal number for SIGHUP
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1529
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1530
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1531
%{  /* NOCONTEXT */
406
claus
parents: 384
diff changeset
  1532
#ifdef SIGHUP
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1533
    return _MKSMALLINT(SIGHUP);
406
claus
parents: 384
diff changeset
  1534
#else
claus
parents: 384
diff changeset
  1535
    return _MKSMALLINT(0);
claus
parents: 384
diff changeset
  1536
#endif
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1537
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1538
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1539
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1540
sigINT
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1541
    "return the signal number for SIGINT
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1542
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1543
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1544
%{  /* NOCONTEXT */
406
claus
parents: 384
diff changeset
  1545
#ifdef SIGINT
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1546
    return _MKSMALLINT(SIGINT);
406
claus
parents: 384
diff changeset
  1547
#else
claus
parents: 384
diff changeset
  1548
    return _MKSMALLINT(0);
claus
parents: 384
diff changeset
  1549
#endif
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1550
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1551
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1552
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1553
sigQUIT
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1554
    "return the signal number for SIGQUIT
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1555
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1556
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1557
%{  /* NOCONTEXT */
406
claus
parents: 384
diff changeset
  1558
#ifdef SIGQUIT
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1559
    return _MKSMALLINT(SIGQUIT);
406
claus
parents: 384
diff changeset
  1560
#else
claus
parents: 384
diff changeset
  1561
    return _MKSMALLINT(0);
claus
parents: 384
diff changeset
  1562
#endif
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1563
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1564
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1565
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1566
sigILL
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1567
    "return the signal number for SIGILL - 0 if not supported by OS
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1568
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1569
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1570
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1571
#ifdef SIGILL
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1572
    return _MKSMALLINT(SIGILL);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1573
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1574
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1575
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1576
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1577
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1578
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1579
sigTRAP
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1580
    "return the signal number for SIGTRAP - 0 if not supported by OS
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1581
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1582
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1583
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1584
#ifdef SIGTRAP
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1585
    return _MKSMALLINT(SIGTRAP);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1586
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1587
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1588
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1589
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1590
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1591
345
claus
parents: 329
diff changeset
  1592
sigABRT
claus
parents: 329
diff changeset
  1593
    "return the signal number for SIGABRT - 0 if not supported by OS
claus
parents: 329
diff changeset
  1594
     (the numeric value is not the same across unix-systems)"
claus
parents: 329
diff changeset
  1595
claus
parents: 329
diff changeset
  1596
%{  /* NOCONTEXT */
claus
parents: 329
diff changeset
  1597
#ifdef SIGABRT
claus
parents: 329
diff changeset
  1598
    return _MKSMALLINT(SIGABRT);
claus
parents: 329
diff changeset
  1599
#else
claus
parents: 329
diff changeset
  1600
    return _MKSMALLINT(0);
claus
parents: 329
diff changeset
  1601
#endif
claus
parents: 329
diff changeset
  1602
%}
claus
parents: 329
diff changeset
  1603
!
claus
parents: 329
diff changeset
  1604
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1605
sigIOT
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1606
    "return the signal number for SIGIOT - 0 if not supported by OS
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1607
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1608
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1609
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1610
#ifdef SIGIOT
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1611
    return _MKSMALLINT(SIGIOT);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1612
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1613
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1614
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1615
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1616
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1617
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1618
sigEMT
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1619
    "return the signal number for SIGEMT - 0 if not supported by OS
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1620
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1621
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1622
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1623
#ifdef SIGEMT
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1624
    return _MKSMALLINT(SIGEMT);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1625
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1626
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1627
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1628
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1629
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1630
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1631
sigFP
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1632
    "return the signal number for SIGFP - 0 if not supported by OS
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1633
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1634
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1635
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1636
#ifdef SIGFPE
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1637
    return _MKSMALLINT(SIGFPE);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1638
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1639
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1640
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1641
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1642
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1643
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1644
sigKILL
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1645
    "return the signal number for SIGKILL
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1646
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1647
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1648
%{  /* NOCONTEXT */
406
claus
parents: 384
diff changeset
  1649
#ifdef SIGKILL
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1650
    return _MKSMALLINT(SIGKILL);
406
claus
parents: 384
diff changeset
  1651
#else
claus
parents: 384
diff changeset
  1652
    return _MKSMALLINT(0);
claus
parents: 384
diff changeset
  1653
#endif
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1654
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1655
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1656
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1657
sigBUS
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1658
    "return the signal number for SIGBUS - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1659
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1660
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1661
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1662
#ifdef SIGBUS
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1663
    return _MKSMALLINT(SIGBUS);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1664
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1665
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1666
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1667
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1668
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1669
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1670
sigSEGV
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1671
    "return the signal number for SIGSEGV - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1672
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1673
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1674
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1675
#ifdef SIGSEGV
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1676
    return _MKSMALLINT(SIGSEGV);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1677
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1678
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1679
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1680
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1681
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1682
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1683
sigSYS
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1684
    "return the signal number for SIGSYS - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1685
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1686
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1687
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1688
#ifdef SIGSYS
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1689
    return _MKSMALLINT(SIGSYS);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1690
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1691
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1692
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1693
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1694
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1695
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1696
sigPIPE
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1697
    "return the signal number for SIGPIPE - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1698
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1699
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1700
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1701
#ifdef SIGPIPE
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1702
    return _MKSMALLINT(SIGPIPE);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1703
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1704
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1705
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1706
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1707
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1708
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1709
sigALRM
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1710
    "return the signal number for SIGALRM - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1711
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1712
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1713
%{  /* NOCONTEXT */
406
claus
parents: 384
diff changeset
  1714
#ifdef SIGALRM
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1715
    return _MKSMALLINT(SIGALRM);
406
claus
parents: 384
diff changeset
  1716
#else
claus
parents: 384
diff changeset
  1717
    return _MKSMALLINT(0);
claus
parents: 384
diff changeset
  1718
#endif
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1719
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1720
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1721
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1722
sigTERM
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1723
    "return the signal number for SIGTERM - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1724
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1725
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1726
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1727
#ifdef SIGTERM
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1728
    return _MKSMALLINT(SIGTERM);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1729
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1730
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1731
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1732
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1733
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1734
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1735
sigURG
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1736
    "return the signal number for SIGURG - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1737
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1738
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1739
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1740
#if defined(SIGURG)
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1741
    return _MKSMALLINT(SIGURG);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1742
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1743
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1744
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1745
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1746
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1747
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1748
sigSTOP
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1749
    "return the signal number for SIGSTOP - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1750
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1751
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1752
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1753
#if defined(SIGSTOP)
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1754
    return _MKSMALLINT(SIGSTOP);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1755
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1756
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1757
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1758
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1759
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1760
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1761
sigTSTP
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1762
    "return the signal number for SIGTSTP - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1763
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1764
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1765
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1766
#if defined(SIGTSTP)
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1767
    return _MKSMALLINT(SIGTSTP);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1768
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1769
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1770
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1771
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1772
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1773
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1774
sigCONT
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1775
    "return the signal number for SIGCONT - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1776
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1777
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1778
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1779
#if defined(SIGCONT)
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1780
    return _MKSMALLINT(SIGCONT);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1781
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1782
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1783
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1784
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1785
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1786
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1787
sigCHLD
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1788
    "return the signal number for SIGCHLD - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1789
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1790
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1791
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1792
#if defined(SIGCHLD)
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1793
    return _MKSMALLINT(SIGCHLD);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1794
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1795
# if  defined(SIGCLD)
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1796
    return _MKSMALLINT(SIGCLD);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1797
# else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1798
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1799
# endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1800
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1801
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1802
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1803
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1804
sigTTIN
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1805
    "return the signal number for SIGTTIN - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1806
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1807
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1808
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1809
#if defined(SIGTTIN)
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1810
    return _MKSMALLINT(SIGTTIN);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1811
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1812
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1813
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1814
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1815
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1816
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1817
sigTTOU
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1818
    "return the signal number for SIGTTOU - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1819
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1820
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1821
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1822
#if defined(SIGTTOU)
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1823
    return _MKSMALLINT(SIGTTOU);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1824
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1825
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1826
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1827
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1828
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1829
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1830
sigIO
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1831
    "return the signal number for SIGIO - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1832
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1833
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1834
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1835
#if defined(SIGIO)
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1836
    return _MKSMALLINT(SIGIO);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1837
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1838
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1839
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1840
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1841
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1842
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1843
sigPOLL
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1844
    "return the signal number for SIGPOLL - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1845
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1846
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1847
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1848
#if defined(SIGPOLL)
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1849
    return _MKSMALLINT(SIGPOLL);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1850
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1851
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1852
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1853
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1854
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1855
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1856
sigXCPU
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1857
    "return the signal number for SIGXCPU - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1858
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1859
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1860
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1861
#if defined(SIGXCPU)
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1862
    return _MKSMALLINT(SIGXCPU);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1863
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1864
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1865
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1866
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1867
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1868
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1869
sigXFSZ
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1870
    "return the signal number for SIGXFSZ - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1871
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1872
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1873
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1874
#if defined(SIGXFSZ)
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1875
    return _MKSMALLINT(SIGXFSZ);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1876
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1877
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1878
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1879
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1880
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1881
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1882
sigVTALRM
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1883
    "return the signal number for SIGVTALRM - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1884
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1885
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1886
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1887
#if defined(SIGVTALRM)
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1888
    return _MKSMALLINT(SIGVTALRM);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1889
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1890
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1891
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1892
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1893
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1894
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1895
sigPROF
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1896
    "return the signal number for SIGPROF - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1897
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1898
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1899
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1900
#if defined(SIGPROF)
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1901
    return _MKSMALLINT(SIGPROF);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1902
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1903
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1904
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1905
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1906
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1907
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1908
sigWINCH
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1909
    "return the signal number for SIGWINCH - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1910
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1911
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1912
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1913
#if defined(SIGWINCH)
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1914
    return _MKSMALLINT(SIGWINCH);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1915
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1916
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1917
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1918
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1919
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1920
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1921
sigLOST
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1922
    "return the signal number for SIGLOST - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1923
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1924
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1925
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1926
#if defined(SIGLOST)
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1927
    return _MKSMALLINT(SIGLOST);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1928
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1929
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1930
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1931
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1932
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1933
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1934
sigUSR1
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1935
    "return the signal number for SIGUSR1 - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1936
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1937
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1938
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1939
#if defined(SIGUSR1)
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1940
    return _MKSMALLINT(SIGUSR1);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1941
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1942
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1943
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1944
%}
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1945
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1946
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1947
sigUSR2
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1948
    "return the signal number for SIGUSR2 - 0 if not supported
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1949
     (the numeric value is not the same across unix-systems)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1950
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1951
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1952
#if defined(SIGUSR2)
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1953
    return _MKSMALLINT(SIGUSR2);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1954
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1955
    return _MKSMALLINT(0);
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1956
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  1957
%}
359
claus
parents: 357
diff changeset
  1958
!
claus
parents: 357
diff changeset
  1959
claus
parents: 357
diff changeset
  1960
sigMSG
claus
parents: 357
diff changeset
  1961
    "return the signal number for SIGMSG - 0 if not supported
claus
parents: 357
diff changeset
  1962
     (seems to be an AIX special)"
claus
parents: 357
diff changeset
  1963
claus
parents: 357
diff changeset
  1964
%{  /* NOCONTEXT */
claus
parents: 357
diff changeset
  1965
#if defined(SIGMSG)
claus
parents: 357
diff changeset
  1966
    return _MKSMALLINT(SIGMSG);
claus
parents: 357
diff changeset
  1967
#else
claus
parents: 357
diff changeset
  1968
    return _MKSMALLINT(0);
claus
parents: 357
diff changeset
  1969
#endif
claus
parents: 357
diff changeset
  1970
%}
claus
parents: 357
diff changeset
  1971
!
claus
parents: 357
diff changeset
  1972
claus
parents: 357
diff changeset
  1973
sigPWR
claus
parents: 357
diff changeset
  1974
    "return the signal number for SIGPWR - 0 if not supported
claus
parents: 357
diff changeset
  1975
     (not available on all systems)"
claus
parents: 357
diff changeset
  1976
claus
parents: 357
diff changeset
  1977
%{  /* NOCONTEXT */
claus
parents: 357
diff changeset
  1978
#if defined(SIGPWR)
claus
parents: 357
diff changeset
  1979
    return _MKSMALLINT(SIGPWR);
claus
parents: 357
diff changeset
  1980
#else
claus
parents: 357
diff changeset
  1981
    return _MKSMALLINT(0);
claus
parents: 357
diff changeset
  1982
#endif
claus
parents: 357
diff changeset
  1983
%}
claus
parents: 357
diff changeset
  1984
!
claus
parents: 357
diff changeset
  1985
claus
parents: 357
diff changeset
  1986
sigMIGRATE
claus
parents: 357
diff changeset
  1987
    "return the signal number for SIGMIGRATE - 0 if not supported
claus
parents: 357
diff changeset
  1988
     (seems to be an AIX special)"
claus
parents: 357
diff changeset
  1989
claus
parents: 357
diff changeset
  1990
%{  /* NOCONTEXT */
claus
parents: 357
diff changeset
  1991
#if defined(SIGMIGRATE)
claus
parents: 357
diff changeset
  1992
    return _MKSMALLINT(SIGMIGRATE);
claus
parents: 357
diff changeset
  1993
#else
claus
parents: 357
diff changeset
  1994
    return _MKSMALLINT(0);
claus
parents: 357
diff changeset
  1995
#endif
claus
parents: 357
diff changeset
  1996
%}
claus
parents: 357
diff changeset
  1997
!
claus
parents: 357
diff changeset
  1998
claus
parents: 357
diff changeset
  1999
sigPRE
claus
parents: 357
diff changeset
  2000
    "return the signal number for SIGPRE - 0 if not supported
claus
parents: 357
diff changeset
  2001
     (seems to be an AIX special)"
claus
parents: 357
diff changeset
  2002
claus
parents: 357
diff changeset
  2003
%{  /* NOCONTEXT */
claus
parents: 357
diff changeset
  2004
#if defined(SIGPRE)
claus
parents: 357
diff changeset
  2005
    return _MKSMALLINT(SIGPRE);
claus
parents: 357
diff changeset
  2006
#else
claus
parents: 357
diff changeset
  2007
    return _MKSMALLINT(0);
claus
parents: 357
diff changeset
  2008
#endif
claus
parents: 357
diff changeset
  2009
%}
claus
parents: 357
diff changeset
  2010
!
claus
parents: 357
diff changeset
  2011
claus
parents: 357
diff changeset
  2012
sigGRANT
claus
parents: 357
diff changeset
  2013
    "return the signal number for SIGGRANT - 0 if not supported
claus
parents: 357
diff changeset
  2014
     (seems to be an AIX special)"
claus
parents: 357
diff changeset
  2015
claus
parents: 357
diff changeset
  2016
%{  /* NOCONTEXT */
claus
parents: 357
diff changeset
  2017
#if defined(SIGGRANT)
claus
parents: 357
diff changeset
  2018
    return _MKSMALLINT(SIGGRANT);
claus
parents: 357
diff changeset
  2019
#else
claus
parents: 357
diff changeset
  2020
    return _MKSMALLINT(0);
claus
parents: 357
diff changeset
  2021
#endif
claus
parents: 357
diff changeset
  2022
%}
claus
parents: 357
diff changeset
  2023
!
claus
parents: 357
diff changeset
  2024
claus
parents: 357
diff changeset
  2025
sigRETRACT
claus
parents: 357
diff changeset
  2026
    "return the signal number for SIGRETRACT - 0 if not supported
claus
parents: 357
diff changeset
  2027
     (seems to be an AIX special)"
claus
parents: 357
diff changeset
  2028
claus
parents: 357
diff changeset
  2029
%{  /* NOCONTEXT */
claus
parents: 357
diff changeset
  2030
#if defined(SIGRETRACT)
claus
parents: 357
diff changeset
  2031
    return _MKSMALLINT(SIGRETRACT);
claus
parents: 357
diff changeset
  2032
#else
claus
parents: 357
diff changeset
  2033
    return _MKSMALLINT(0);
claus
parents: 357
diff changeset
  2034
#endif
claus
parents: 357
diff changeset
  2035
%}
claus
parents: 357
diff changeset
  2036
!
claus
parents: 357
diff changeset
  2037
claus
parents: 357
diff changeset
  2038
sigSOUND
claus
parents: 357
diff changeset
  2039
    "return the signal number for SIGSOUND - 0 if not supported
claus
parents: 357
diff changeset
  2040
     (seems to be an AIX special)"
claus
parents: 357
diff changeset
  2041
claus
parents: 357
diff changeset
  2042
%{  /* NOCONTEXT */
claus
parents: 357
diff changeset
  2043
#if defined(SIGSOUND)
claus
parents: 357
diff changeset
  2044
    return _MKSMALLINT(SIGSOUND);
claus
parents: 357
diff changeset
  2045
#else
claus
parents: 357
diff changeset
  2046
    return _MKSMALLINT(0);
claus
parents: 357
diff changeset
  2047
#endif
claus
parents: 357
diff changeset
  2048
%}
claus
parents: 357
diff changeset
  2049
!
claus
parents: 357
diff changeset
  2050
claus
parents: 357
diff changeset
  2051
sigSAK
claus
parents: 357
diff changeset
  2052
    "return the signal number for SIGSAK - 0 if not supported
claus
parents: 357
diff changeset
  2053
     (seems to be an AIX special)"
claus
parents: 357
diff changeset
  2054
claus
parents: 357
diff changeset
  2055
%{  /* NOCONTEXT */
claus
parents: 357
diff changeset
  2056
#if defined(SIGSAK)
claus
parents: 357
diff changeset
  2057
    return _MKSMALLINT(SIGSAK);
claus
parents: 357
diff changeset
  2058
#else
claus
parents: 357
diff changeset
  2059
    return _MKSMALLINT(0);
claus
parents: 357
diff changeset
  2060
#endif
claus
parents: 357
diff changeset
  2061
%}
370
claus
parents: 369
diff changeset
  2062
!
claus
parents: 369
diff changeset
  2063
claus
parents: 369
diff changeset
  2064
sigDANGER
claus
parents: 369
diff changeset
  2065
    "return the signal number for SIGDANGER - 0 if not supported
claus
parents: 369
diff changeset
  2066
     (seems to be an AIX special)"
claus
parents: 369
diff changeset
  2067
claus
parents: 369
diff changeset
  2068
%{  /* NOCONTEXT */
claus
parents: 369
diff changeset
  2069
#if defined(SIGSAK)
claus
parents: 369
diff changeset
  2070
    return _MKSMALLINT(SIGSAK);
claus
parents: 369
diff changeset
  2071
#else
claus
parents: 369
diff changeset
  2072
    return _MKSMALLINT(0);
claus
parents: 369
diff changeset
  2073
#endif
claus
parents: 369
diff changeset
  2074
%}
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2075
! !
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2076
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2077
!OperatingSystem class methodsFor:'interrupts & signals'!
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2078
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2079
nameForSignal:aSignalNumber
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2080
    "for a given Unix signalnumber, return a descriptive string"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2081
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2082
    aSignalNumber == self sigHUP    ifTrue:[^ 'hangup'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2083
    aSignalNumber == self sigINT    ifTrue:[^ 'interrupt'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2084
    aSignalNumber == self sigKILL   ifTrue:[^ 'kill'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2085
    aSignalNumber == self sigQUIT   ifTrue:[^ 'quit'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2086
    aSignalNumber == self sigILL    ifTrue:[^ 'illegal instruction'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2087
    aSignalNumber == self sigTRAP   ifTrue:[^ 'trap'].
345
claus
parents: 329
diff changeset
  2088
    aSignalNumber == self sigABRT   ifTrue:[^ 'abort'].
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2089
    aSignalNumber == self sigIOT    ifTrue:[^ 'iot trap'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2090
    aSignalNumber == self sigEMT    ifTrue:[^ 'emt trap'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2091
    aSignalNumber == self sigFP     ifTrue:[^ 'fp exception'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2092
    aSignalNumber == self sigBUS    ifTrue:[^ 'bus error'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2093
    aSignalNumber == self sigSEGV   ifTrue:[^ 'segmentation violation'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2094
    aSignalNumber == self sigSYS    ifTrue:[^ 'bad system call'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2095
    aSignalNumber == self sigPIPE   ifTrue:[^ 'broken pipe'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2096
    aSignalNumber == self sigALRM   ifTrue:[^ 'alarm timer'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2097
    aSignalNumber == self sigTERM   ifTrue:[^ 'termination'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2098
    aSignalNumber == self sigSTOP   ifTrue:[^ 'stop'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2099
    aSignalNumber == self sigTSTP   ifTrue:[^ 'tty stop'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2100
    aSignalNumber == self sigCONT   ifTrue:[^ 'continue'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2101
    aSignalNumber == self sigCHLD   ifTrue:[^ 'child death'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2102
    aSignalNumber == self sigTTIN   ifTrue:[^ 'background tty input'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2103
    aSignalNumber == self sigTTOU   ifTrue:[^ 'background tty output'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2104
    aSignalNumber == self sigIO     ifTrue:[^ 'io available'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2105
    aSignalNumber == self sigXCPU   ifTrue:[^ 'cpu time expired'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2106
    aSignalNumber == self sigXFSZ   ifTrue:[^ 'file size limit'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2107
    aSignalNumber == self sigVTALRM ifTrue:[^ 'virtual alarm timer'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2108
    aSignalNumber == self sigPROF   ifTrue:[^ 'profiling timer'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2109
    aSignalNumber == self sigWINCH  ifTrue:[^ 'winsize changed'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2110
    aSignalNumber == self sigLOST   ifTrue:[^ 'resource lost'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2111
    aSignalNumber == self sigUSR1   ifTrue:[^ 'user signal 1'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2112
    aSignalNumber == self sigUSR2   ifTrue:[^ 'user signal 2'].
359
claus
parents: 357
diff changeset
  2113
    aSignalNumber == self sigMSG    ifTrue:[^ 'HFT message'].
claus
parents: 357
diff changeset
  2114
    aSignalNumber == self sigPWR    ifTrue:[^ 'power-fail'].
claus
parents: 357
diff changeset
  2115
    aSignalNumber == self sigPRE    ifTrue:[^ 'programming exception'].
claus
parents: 357
diff changeset
  2116
    aSignalNumber == self sigGRANT  ifTrue:[^ 'HFT access wanted'].
claus
parents: 357
diff changeset
  2117
    aSignalNumber == self sigRETRACT ifTrue:[^ 'HFT access relinquish'].
claus
parents: 357
diff changeset
  2118
    aSignalNumber == self sigSOUND   ifTrue:[^ 'HFT sound complete'].
370
claus
parents: 369
diff changeset
  2119
    aSignalNumber == self sigDANGER  ifTrue:[^ 'low on paging space'].
359
claus
parents: 357
diff changeset
  2120
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2121
    "notice: many systems map SIGPOLL and/or SIGUSR onto SIGIO
359
claus
parents: 357
diff changeset
  2122
	     therefore, keep SIGIO always above the two below" 
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2123
    aSignalNumber == self sigPOLL   ifTrue:[^ 'io available'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2124
    aSignalNumber == self sigURG    ifTrue:[^ 'urgent'].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2125
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2126
    ^ 'unknown signal'
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2127
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2128
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2129
     OperatingSystem nameForSignal:9
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2130
     OperatingSystem nameForSignal:(OperatingSystem sigPOLL) 
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2131
    "
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2132
!
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2133
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2134
interruptPending
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2135
    "return true, if an interrupt is pending. The returned value is
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2136
     invalid if interrupts are not currently blocked, since otherwise 
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2137
     the interrupt is usually already handled before arriving here,
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2138
     or may be served while returning from here."
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2139
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2140
%{   /* NOCONTEXT */
329
claus
parents: 322
diff changeset
  2141
     extern OBJ __INTERRUPTPENDING();
claus
parents: 322
diff changeset
  2142
claus
parents: 322
diff changeset
  2143
     RETURN ( __INTERRUPTPENDING() );
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2144
%}        
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2145
!
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2146
10
claus
parents: 5
diff changeset
  2147
blockInterrupts
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2148
    "disable interrupt processing - if disabled, incoming
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2149
     interrupts will be registered and handled as soon as
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2150
     interrupts are reenabled by OperatingSystemclass>>unblockInterrupts.
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2151
     Returns the previous blocking status i.e. true if interrupts
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2152
     where already blocked. You need this information for proper
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2153
     unblocking, in case of nested block/unblock calls."
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2154
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2155
%{  /* NOCONTEXT */
356
claus
parents: 354
diff changeset
  2156
    extern OBJ __BLOCKINTERRUPTS();
claus
parents: 354
diff changeset
  2157
claus
parents: 354
diff changeset
  2158
    return ( __BLOCKINTERRUPTS() );
10
claus
parents: 5
diff changeset
  2159
%}
claus
parents: 5
diff changeset
  2160
!
claus
parents: 5
diff changeset
  2161
claus
parents: 5
diff changeset
  2162
unblockInterrupts
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2163
    "enable interrupt processing - if any interrupts are pending,
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2164
     these will be handled immediately.
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2165
     When unblocking interrupts, take care of nested block/unblock
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2166
     calls - you must only unblock after a blockcall if they where
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2167
     really not blocked before. See OperatingSystemclass>>blockInterrupts."
10
claus
parents: 5
diff changeset
  2168
%{
356
claus
parents: 354
diff changeset
  2169
    extern void __UNBLOCKINTERRUPTS();
claus
parents: 354
diff changeset
  2170
claus
parents: 354
diff changeset
  2171
    __UNBLOCKINTERRUPTS();
10
claus
parents: 5
diff changeset
  2172
%}
claus
parents: 5
diff changeset
  2173
!
claus
parents: 5
diff changeset
  2174
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2175
disableSignal:signalNumber
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2176
    "disable (Unix-) signal processing for signalNumber.
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2177
     Dont confuse Unix signals with smalltalk signals.
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2178
     WARNING: for some signals, it is no good idea to disable
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2179
     them; for example, disabling the SIGINT signal turns off ^C
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2180
     handling.
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2181
     Also, NOTICE that signal numbers are not portable between unix
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2182
     systems - use OperatingSystem sigXXX to get the numeric value for
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2183
     a signal.
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2184
     Use only for fully debugged stand alone applications."
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2185
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2186
%{  /* NOCONTEXT */
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2187
252
  2188
    if (__isSmallInteger(signalNumber)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2189
	signal(_intVal(signalNumber), SIG_IGN);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2190
	RETURN (self);
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2191
    }
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2192
%}.
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2193
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2194
     this error is triggered on non-integer argument
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2195
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2196
    self primitiveFailed
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2197
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2198
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2199
     'now, ^C is totally ignored ...' printNewline.
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2200
     OperatingSystem disableSignal:(OperatingSystem sigINT).
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2201
     1 to:1000000 do:[:i| ].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2202
     OperatingSystem enableSignal:(OperatingSystem sigINT).
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2203
     '^C handled again.' printNewline
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2204
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2205
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2206
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2207
defaultSignal:signalNumber
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2208
    "revert to the default action on arrival of a (Unix-)signal.
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2209
     Dont confuse Unix signals with smalltalk signals.
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2210
     WARNING: for some signals, it is no good idea to revert to default;
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2211
     for example, the default for SIGINT (i.e. ^C) is to exit; while the
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2212
     default for SIGQUIT (^ \) is to dump core.
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2213
     Also, NOTICE that signal numbers are not portable between unix
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2214
     systems - use OperatingSystem sigXXX to get the numeric value for
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2215
     a signal."
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2216
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2217
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2218
252
  2219
    if (__isSmallInteger(signalNumber)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2220
	signal(_intVal(signalNumber), SIG_DFL);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2221
	RETURN (self);
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2222
    }
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2223
%}.
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2224
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2225
     this error is triggered on non-integer argument
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2226
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2227
    self primitiveFailed
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2228
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2229
    "you better save a snapshot image before trying this ..."
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2230
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2231
     'if you hit ^C now, Smalltalk will exit immediately' printNewline.
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2232
     OperatingSystem defaultSignal:(OperatingSystem sigINT).
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2233
     1 to:1000000 do:[:i| ].
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2234
     OperatingSystem enableSignal:(OperatingSystem sigINT).
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2235
     'normal ^C handling again.' printNewline
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2236
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2237
!
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2238
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2239
enableSignal:signalNumber
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2240
    "enable (Unix-)signal processing for signalNumber.
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2241
     Dont confuse Unix signals with smalltalk signals.
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2242
     The signal will be delivered to one of the standard handlers
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2243
     (SIGINT, SIGQUIT, etc) or to a general handler, which
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2244
     sends #signalInterrupt:.
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2245
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2246
     NOTICE that signal numbers are not portable between unix
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2247
     systems - use OperatingSystem sigXXX to get the numeric value for
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2248
     a signal."
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2249
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2250
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2251
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2252
#ifdef NSIG
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2253
# define SIG_LIMIT NSIG
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2254
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2255
# ifdef SIGUSR2
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2256
#  define SIG_LIMIT SIGUSR2
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2257
# else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2258
#  ifdef SIGUSR
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2259
#   define SIG_LIMIT SIGUSR
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2260
#  endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2261
# endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2262
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2263
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2264
#if defined(SIGPOLL) && !defined(SIGIO)
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2265
# define SIGIO SIGPOLL
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2266
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2267
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2268
#ifdef SIGCHLD
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2269
# define CHILD_SIGNAL   SIGCHLD
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2270
#else
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2271
# ifdef SIGCLD
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2272
#  define CHILD_SIGNAL  SIGCLD
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2273
# endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2274
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2275
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2276
    int sigNr;
329
claus
parents: 322
diff changeset
  2277
    extern void __signalUserInterrupt();
claus
parents: 322
diff changeset
  2278
    extern void __signalFpExceptionInterrupt();
claus
parents: 322
diff changeset
  2279
    extern void __signalIoInterrupt();
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2280
#ifdef CHILD_SIGNAL
329
claus
parents: 322
diff changeset
  2281
    extern void __signalChildInterrupt();
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2282
#endif
329
claus
parents: 322
diff changeset
  2283
    extern void __signalPIPEInterrupt();
claus
parents: 322
diff changeset
  2284
    extern void __signalBUSInterrupt();
claus
parents: 322
diff changeset
  2285
    extern void __signalSEGVInterrupt();
claus
parents: 322
diff changeset
  2286
    extern void __signalTimerInterrupt();
claus
parents: 322
diff changeset
  2287
    extern void __signalInterrupt();
213
3b56a17534fd *** empty log message ***
claus
parents: 204
diff changeset
  2288
    void (*handler)();
3b56a17534fd *** empty log message ***
claus
parents: 204
diff changeset
  2289
#ifdef HAS_SIGACTION
3b56a17534fd *** empty log message ***
claus
parents: 204
diff changeset
  2290
    struct sigaction act, oldAct;
3b56a17534fd *** empty log message ***
claus
parents: 204
diff changeset
  2291
#endif
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2292
252
  2293
    if (__isSmallInteger(signalNumber)
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2294
     && ((sigNr = _intVal(signalNumber)) > 0)
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2295
     &&  (sigNr <= SIG_LIMIT)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2296
	/*
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2297
	 * standard signals are forced into standard handlers
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2298
	 * - all others go into general signalInterrupt
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2299
	 */
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2300
#if defined(SIGPOLL) && defined(SIGIO)
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2301
	if (sigNr == SIGPOLL)
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2302
	    sigNr = SIGIO;
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2303
#endif
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2304
	switch (sigNr) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2305
	    case SIGINT:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2306
	    case SIGQUIT:
329
claus
parents: 322
diff changeset
  2307
		handler = __signalUserInterrupt;
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2308
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2309
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2310
	    case SIGFPE:
329
claus
parents: 322
diff changeset
  2311
		handler = __signalFpExceptionInterrupt;
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2312
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2313
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2314
	    case SIGPIPE:
329
claus
parents: 322
diff changeset
  2315
		handler = __signalPIPEInterrupt;
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2316
		break;
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2317
#ifdef SIGBUS
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2318
	    case SIGBUS:
329
claus
parents: 322
diff changeset
  2319
		handler = __signalBUSInterrupt;
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2320
		break;
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2321
#endif
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2322
	    case SIGSEGV:
329
claus
parents: 322
diff changeset
  2323
		handler = __signalSEGVInterrupt;
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2324
		break;
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2325
#ifdef SIGIO
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2326
	    case SIGIO:
329
claus
parents: 322
diff changeset
  2327
		handler = __signalIoInterrupt;
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2328
		break;
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2329
#endif
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2330
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2331
#ifdef CHILD_SIGNAL
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2332
	    case CHILD_SIGNAL:
329
claus
parents: 322
diff changeset
  2333
		handler = __signalChildInterrupt;
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2334
		break;
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2335
#endif
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2336
	    case SIGALRM:
329
claus
parents: 322
diff changeset
  2337
		handler = __signalTimerInterrupt;
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2338
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2339
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2340
	    default:
329
claus
parents: 322
diff changeset
  2341
		handler = __signalInterrupt;
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2342
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2343
	}
213
3b56a17534fd *** empty log message ***
claus
parents: 204
diff changeset
  2344
#ifdef HAS_SIGACTION
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2345
	act.sa_flags = SA_RESTART;
373
00599575a949 cd ../libbasic2
claus
parents: 370
diff changeset
  2346
	sigemptyset(&act.sa_mask);
00599575a949 cd ../libbasic2
claus
parents: 370
diff changeset
  2347
	act.sa_handler = handler;
213
3b56a17534fd *** empty log message ***
claus
parents: 204
diff changeset
  2348
	sigaction(sigNr, &act, &oldAct);
3b56a17534fd *** empty log message ***
claus
parents: 204
diff changeset
  2349
#else
3b56a17534fd *** empty log message ***
claus
parents: 204
diff changeset
  2350
	signal(sigNr, handler);
3b56a17534fd *** empty log message ***
claus
parents: 204
diff changeset
  2351
#endif
3b56a17534fd *** empty log message ***
claus
parents: 204
diff changeset
  2352
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2353
	/*
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2354
	 * maybe, we should return the old enable-status
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2355
	 * as boolean here ...
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2356
	 */
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2357
	RETURN (self);
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2358
    }
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2359
%}.
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2360
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2361
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2362
     this error is triggered on non-integer argument, or
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2363
     if the signal number is not in the valid range (1..NSIG)
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2364
    "
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2365
    self primitiveFailed
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2366
!
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2367
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2368
enableUserInterrupts
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2369
    "enable userInterrupt (^C) handling;
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2370
     when enabled, ^C in the terminal window will send the message
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2371
     'userInterrupt' to the UserInterruptHandler object."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2372
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2373
    ^ self enableSignal:(self sigINT)
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2374
!
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2375
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2376
enableQuitInterrupts
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2377
    "enable quitInterrupt (usually ^\) handling, and make it a userinterrupt.
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2378
     (the default will dump core and exit - which is not a good idea for
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2379
      end-user applications ...)"
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2380
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2381
    ^ self enableSignal:(self sigQUIT)
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2382
!
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2383
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2384
disableUserInterrupts
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2385
    "disable userInterrupt processing;
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2386
     when disabled, no ^C processing takes place.
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2387
     Use this only for debugged stand-alone applications, since
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2388
     no exit to the debugger is possible with user interrupts disabled.
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2389
     Be WARNED."
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2390
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2391
    ^ self disableSignal:(self sigINT)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2392
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2393
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2394
enableFpExceptionInterrupts
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2395
    "enable floating point exception interrupts (if the
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2396
     architecture supports it).
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2397
     after enabling, fpu-exceptions will send the message 
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2398
     'fpuExceptionInterrupt' to the FPUExceptionInterruptHandler object."
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2399
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2400
    ^ self enableSignal:(self sigFP)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2401
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2402
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2403
enableHardSignalInterrupts
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2404
    "enable hard signal exception interrupts (trap, buserror & segm. violation).
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2405
     after enabling, these exceptions will send the message 
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2406
     'signalInterrupt' to the SignalInterruptHandler object."
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2407
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2408
%{  /* NOCONTEXT */
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2409
329
claus
parents: 322
diff changeset
  2410
    extern void __signalPIPEInterrupt();
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2411
#ifdef SIGBUS
329
claus
parents: 322
diff changeset
  2412
    extern void __signalBUSInterrupt();
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2413
#endif
329
claus
parents: 322
diff changeset
  2414
    extern void __signalSEGVInterrupt();
claus
parents: 322
diff changeset
  2415
claus
parents: 322
diff changeset
  2416
    signal(SIGPIPE, __signalPIPEInterrupt);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2417
#ifdef SIGBUS
329
claus
parents: 322
diff changeset
  2418
    signal(SIGBUS,  __signalBUSInterrupt);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2419
#endif
329
claus
parents: 322
diff changeset
  2420
    signal(SIGSEGV, __signalSEGVInterrupt);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2421
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2422
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2423
10
claus
parents: 5
diff changeset
  2424
enableIOInterruptsOn:fd
claus
parents: 5
diff changeset
  2425
    "turn on IO interrupts for a filedescriptor"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2426
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2427
%{  /* NOCONTEXT */
10
claus
parents: 5
diff changeset
  2428
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2429
    int ret, flags, f;
329
claus
parents: 322
diff changeset
  2430
    extern void __signalIoInterrupt();
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2431
    static int firstCall = 1;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2432
10
claus
parents: 5
diff changeset
  2433
#if defined(F_GETFL) && defined(F_SETFL)
claus
parents: 5
diff changeset
  2434
# if defined(FASYNC)
252
  2435
    if (__isSmallInteger(fd)) {
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2436
	if (firstCall) {
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2437
	    firstCall = 0;
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2438
#  ifdef SIGIO
329
claus
parents: 322
diff changeset
  2439
	    signal(SIGIO, __signalIoInterrupt);
10
claus
parents: 5
diff changeset
  2440
#  endif
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2441
#  ifdef SIGPOLL
329
claus
parents: 322
diff changeset
  2442
	    signal(SIGPOLL, __signalIoInterrupt);
10
claus
parents: 5
diff changeset
  2443
#  endif
101
b26288c3a005 *** empty log message ***
claus
parents: 95
diff changeset
  2444
#  ifdef SIGURG
329
claus
parents: 322
diff changeset
  2445
	    signal(SIGURG, __signalIoInterrupt);
101
b26288c3a005 *** empty log message ***
claus
parents: 95
diff changeset
  2446
#  endif
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2447
	}
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2448
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2449
	f = _intVal(fd);
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2450
	flags = fcntl(f, F_GETFL, 0);
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2451
	/*
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2452
	 * if already set, there is no need for this syscall ...
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2453
	 */
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2454
	if (flags & FASYNC) {
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2455
	    ret = flags;
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2456
	} else {
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2457
	    ret = fcntl(f, F_SETFL, flags | FASYNC);
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2458
	    if (ret >= 0) ret = flags;
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2459
	}
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2460
	RETURN ( _MKSMALLINT(ret) );
10
claus
parents: 5
diff changeset
  2461
    }
claus
parents: 5
diff changeset
  2462
# endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2463
#endif
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2464
%}.
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2465
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2466
     this error is triggered on non-integer argument
101
b26288c3a005 *** empty log message ***
claus
parents: 95
diff changeset
  2467
     or if the system does not support SIGIO
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2468
    "
10
claus
parents: 5
diff changeset
  2469
    self primitiveFailed
claus
parents: 5
diff changeset
  2470
!
claus
parents: 5
diff changeset
  2471
claus
parents: 5
diff changeset
  2472
disableIOInterruptsOn:fd
claus
parents: 5
diff changeset
  2473
    "turn off IO interrupts for a filedescriptor"
claus
parents: 5
diff changeset
  2474
claus
parents: 5
diff changeset
  2475
%{  /* NOCONTEXT */
claus
parents: 5
diff changeset
  2476
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2477
    int ret, flags, f;
10
claus
parents: 5
diff changeset
  2478
claus
parents: 5
diff changeset
  2479
#if defined(F_GETFL) && defined(F_SETFL)
claus
parents: 5
diff changeset
  2480
# if defined(FASYNC)
252
  2481
    if (__isSmallInteger(fd)) {
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2482
	f = _intVal(fd);
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2483
	flags = fcntl(f, F_GETFL, 0);
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2484
	/*
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2485
	 * if already clear, there is no need for this syscall ...
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2486
	 */
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2487
	if (flags & FASYNC) {
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2488
	    ret = fcntl(f, F_SETFL, flags & ~FASYNC);
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2489
	    if (ret >= 0) ret = flags;
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2490
	} else {
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2491
	    ret = flags;
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2492
	}
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2493
	RETURN ( _MKSMALLINT(ret) );
10
claus
parents: 5
diff changeset
  2494
    }
claus
parents: 5
diff changeset
  2495
# endif
claus
parents: 5
diff changeset
  2496
#endif
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2497
%}.
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2498
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2499
     this error is triggered on non-integer argument
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2500
     or if the OS does not support IO interrupts.
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2501
    "
10
claus
parents: 5
diff changeset
  2502
    self primitiveFailed
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2503
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2504
2
claus
parents: 1
diff changeset
  2505
enableChildSignalInterrupts
claus
parents: 1
diff changeset
  2506
    "enable childSignal interrupts 
claus
parents: 1
diff changeset
  2507
     (SIGCHLD, if the architecture supports it).
claus
parents: 1
diff changeset
  2508
     after enabling, these signals will send the message 
claus
parents: 1
diff changeset
  2509
     'childSignalInterrupt' to the ChildSignalInterruptHandler object."
claus
parents: 1
diff changeset
  2510
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2511
    ^ self enableSignal:(self sigCHLD)
2
claus
parents: 1
diff changeset
  2512
!
claus
parents: 1
diff changeset
  2513
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2514
startSpyTimer
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2515
    "trigger a spyInterrupt, to be signalled after some short (virtual) time.
359
claus
parents: 357
diff changeset
  2516
     This is used by the old MessageTally for profiling.
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2517
     Should be changed to use real profiling timer if available.
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2518
     On systems, where no virtual timer is available, use the real timer
359
claus
parents: 357
diff changeset
  2519
     (which is of course less correct).
claus
parents: 357
diff changeset
  2520
     OBSOLETE: the new messageTally runs as a high prio process, not using 
claus
parents: 357
diff changeset
  2521
	       spy interrupts."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2522
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2523
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2524
329
claus
parents: 322
diff changeset
  2525
    extern void __spyInterrupt();
10
claus
parents: 5
diff changeset
  2526
#if defined(ITIMER_VIRTUAL)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2527
    struct itimerval dt;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2528
213
3b56a17534fd *** empty log message ***
claus
parents: 204
diff changeset
  2529
# ifndef xxxSYSV4
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2530
#  if defined(BSD) || defined(HAS_SIGSETMASK)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2531
    sigsetmask(0);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2532
#  endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2533
# endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2534
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2535
# ifdef SIGVTALRM
329
claus
parents: 322
diff changeset
  2536
    signal(SIGVTALRM, __spyInterrupt);
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2537
# else
329
claus
parents: 322
diff changeset
  2538
    signal(SIGALRM, __spyInterrupt);
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2539
# endif
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2540
348
claus
parents: 345
diff changeset
  2541
    dt.it_interval.tv_sec = 0;
claus
parents: 345
diff changeset
  2542
    dt.it_interval.tv_usec = 0;
claus
parents: 345
diff changeset
  2543
    dt.it_value.tv_sec = 0;
claus
parents: 345
diff changeset
  2544
    dt.it_value.tv_usec = 1000;   /* 1000 Hz */
claus
parents: 345
diff changeset
  2545
    setitimer(ITIMER_VIRTUAL, &dt, 0);
claus
parents: 345
diff changeset
  2546
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2547
    RETURN (true);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2548
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2549
%}
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2550
.
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2551
    ^ false
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2552
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2553
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2554
stopSpyTimer
359
claus
parents: 357
diff changeset
  2555
    "stop spy timing - disable spy timer.
claus
parents: 357
diff changeset
  2556
     OBSOLETE: the new messageTally runs as a high prio process, not using 
claus
parents: 357
diff changeset
  2557
	       spy interrupts."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2558
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2559
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2560
10
claus
parents: 5
diff changeset
  2561
#if defined(ITIMER_VIRTUAL)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2562
    struct itimerval dt;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2563
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2564
    dt.it_interval.tv_sec = 0;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2565
    dt.it_interval.tv_usec = 0;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2566
    dt.it_value.tv_sec = 0;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2567
    dt.it_value.tv_usec = 0;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2568
    setitimer(ITIMER_VIRTUAL, &dt, 0);
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2569
    RETURN (true);
10
claus
parents: 5
diff changeset
  2570
#endif
claus
parents: 5
diff changeset
  2571
%}
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2572
.
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2573
    ^ false
10
claus
parents: 5
diff changeset
  2574
!
claus
parents: 5
diff changeset
  2575
claus
parents: 5
diff changeset
  2576
enableTimer:millis
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2577
    "trigger a timerInterrupt, to be signalled after some (real) time."
10
claus
parents: 5
diff changeset
  2578
claus
parents: 5
diff changeset
  2579
%{  /* NOCONTEXT */
claus
parents: 5
diff changeset
  2580
329
claus
parents: 322
diff changeset
  2581
    extern void __signalTimerInterrupt();
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2582
10
claus
parents: 5
diff changeset
  2583
#if defined(ITIMER_REAL)
claus
parents: 5
diff changeset
  2584
    struct itimerval dt;
claus
parents: 5
diff changeset
  2585
213
3b56a17534fd *** empty log message ***
claus
parents: 204
diff changeset
  2586
# ifndef xxxSYSV4
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2587
#  if defined(BSD) || defined(HAS_SIGSETMASK)
10
claus
parents: 5
diff changeset
  2588
    sigsetmask(0);
claus
parents: 5
diff changeset
  2589
#  endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2590
# endif
329
claus
parents: 322
diff changeset
  2591
    signal(SIGALRM, __signalTimerInterrupt);
348
claus
parents: 345
diff changeset
  2592
claus
parents: 345
diff changeset
  2593
    dt.it_interval.tv_sec = 0;
claus
parents: 345
diff changeset
  2594
    dt.it_interval.tv_usec = 0;
claus
parents: 345
diff changeset
  2595
    dt.it_value.tv_sec = _intVal(millis) / 1000;
claus
parents: 345
diff changeset
  2596
    dt.it_value.tv_usec = (_intVal(millis) % 1000) * 1000;  
claus
parents: 345
diff changeset
  2597
    setitimer(ITIMER_REAL, &dt, 0);
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2598
    RETURN (true);
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2599
#endif
10
claus
parents: 5
diff changeset
  2600
%}
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2601
.
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2602
    ^ false
10
claus
parents: 5
diff changeset
  2603
!
claus
parents: 5
diff changeset
  2604
claus
parents: 5
diff changeset
  2605
disableTimer
claus
parents: 5
diff changeset
  2606
    "disable timer interrupt"
claus
parents: 5
diff changeset
  2607
claus
parents: 5
diff changeset
  2608
%{  /* NOCONTEXT */
claus
parents: 5
diff changeset
  2609
claus
parents: 5
diff changeset
  2610
#if defined(ITIMER_REAL)
claus
parents: 5
diff changeset
  2611
    struct itimerval dt;
claus
parents: 5
diff changeset
  2612
claus
parents: 5
diff changeset
  2613
    dt.it_interval.tv_sec = 0;
claus
parents: 5
diff changeset
  2614
    dt.it_interval.tv_usec = 0;
claus
parents: 5
diff changeset
  2615
    dt.it_value.tv_sec = 0;
claus
parents: 5
diff changeset
  2616
    dt.it_value.tv_usec = 0;
claus
parents: 5
diff changeset
  2617
    setitimer(ITIMER_REAL, &dt, 0);
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2618
    RETURN (true);
10
claus
parents: 5
diff changeset
  2619
#endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2620
%}
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2621
.
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  2622
    ^ false
123
98771547e5ce OSSignals now here
claus
parents: 101
diff changeset
  2623
!
98771547e5ce OSSignals now here
claus
parents: 101
diff changeset
  2624
98771547e5ce OSSignals now here
claus
parents: 101
diff changeset
  2625
operatingSystemSignal:signalNumber
98771547e5ce OSSignals now here
claus
parents: 101
diff changeset
  2626
    "return the signal to be raised when an 
98771547e5ce OSSignals now here
claus
parents: 101
diff changeset
  2627
     operatingSystem-signal occurs, or nil"
98771547e5ce OSSignals now here
claus
parents: 101
diff changeset
  2628
98771547e5ce OSSignals now here
claus
parents: 101
diff changeset
  2629
    OSSignals notNil ifTrue:[
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2630
	^ OSSignals at:signalNumber ifAbsent:[nil]
123
98771547e5ce OSSignals now here
claus
parents: 101
diff changeset
  2631
    ].
98771547e5ce OSSignals now here
claus
parents: 101
diff changeset
  2632
    ^ nil
98771547e5ce OSSignals now here
claus
parents: 101
diff changeset
  2633
!
98771547e5ce OSSignals now here
claus
parents: 101
diff changeset
  2634
98771547e5ce OSSignals now here
claus
parents: 101
diff changeset
  2635
operatingSystemSignal:signalNumber install:aSignal
98771547e5ce OSSignals now here
claus
parents: 101
diff changeset
  2636
    "install a signal to be raised when an operatingSystem-signal occurs"
98771547e5ce OSSignals now here
claus
parents: 101
diff changeset
  2637
98771547e5ce OSSignals now here
claus
parents: 101
diff changeset
  2638
    OSSignals isNil ifTrue:[
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2639
	OSSignals := Array new:32
123
98771547e5ce OSSignals now here
claus
parents: 101
diff changeset
  2640
    ].
98771547e5ce OSSignals now here
claus
parents: 101
diff changeset
  2641
    OSSignals at:signalNumber put:aSignal
370
claus
parents: 369
diff changeset
  2642
!
claus
parents: 369
diff changeset
  2643
claus
parents: 369
diff changeset
  2644
sendSignal:signalNumber to:processId
claus
parents: 369
diff changeset
  2645
    "send a unix signal to some process (maybe myself).
claus
parents: 369
diff changeset
  2646
     Returns false if any error occurred, true otherwise.
claus
parents: 369
diff changeset
  2647
claus
parents: 369
diff changeset
  2648
     Do not confuse UNIX signals with Smalltalk-Signals."
claus
parents: 369
diff changeset
  2649
%{
claus
parents: 369
diff changeset
  2650
    if (__bothSmallInteger(signalNumber, processId)) {
claus
parents: 369
diff changeset
  2651
	if (kill(__intVal(processId), __intVal(signalNumber)) < 0) {
claus
parents: 369
diff changeset
  2652
	    OperatingSystem_LastErrorNumber = _MKSMALLINT(errno);
claus
parents: 369
diff changeset
  2653
	    RETURN ( false );
claus
parents: 369
diff changeset
  2654
	}
claus
parents: 369
diff changeset
  2655
	RETURN ( true );
claus
parents: 369
diff changeset
  2656
    }
claus
parents: 369
diff changeset
  2657
%}.
claus
parents: 369
diff changeset
  2658
    self primitiveFailed
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2659
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2660
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2661
!OperatingSystem class methodsFor:'time and date'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2662
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2663
getTimeLow
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2664
    "return low 16 bits of current time. 
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2665
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2666
     OBSOLETE: Dont use this method, use getTimeParts.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2667
     This method will not always return the correct time 
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2668
     if used together with getTimeHi, since a wrap between 
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2669
     the two getTimeXXX sends could occur.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2670
     WARNING: this method will vanish - dont use it."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2671
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2672
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2673
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2674
    RETURN ( _MKSMALLINT(time(0) & 0xFFFF) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2675
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2676
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2677
    "OperatingSystem getTimeLow"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2678
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2679
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2680
getTimeHi
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2681
    "return hi 16 bits of current time. 
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2682
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2683
     OBSOLETE: Dont use this method, use getTimeParts.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2684
     This method will NOT always return the correct time
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2685
     if used together with getTimeHi, since a wrap between 
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2686
     the two getTimeXXX sends could occur.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2687
     WARNING: this method will vanish - dont use it."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2688
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2689
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2690
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2691
    RETURN ( _MKSMALLINT((time(0) >> 16) & 0xFFFF) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2692
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2693
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2694
    "OperatingSystem getTimeHi"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2695
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2696
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2697
getTimeParts
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2698
    "return the current time as an array of 2 integers representing
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2699
     the current time (usually low 16bits / hi 16 bits) in some OS
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2700
     dependent way.
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2701
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2702
     On unix, the values represent the seconds since 1970, on other
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2703
     systems this may be different.
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2704
     WARNING:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2705
       for portability, never use these values directly, but pass them
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2706
       to #computeTimeParts and/or #computeDatePartsOf:, which know how to 
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2707
       interpret them.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2708
       Better yet, use Date>>today and Time>>now for ST-80 compatibility."
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2709
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2710
    |low hi|
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2711
%{
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2712
    int now;
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2713
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2714
    now = time(0);
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2715
    hi  = _MKSMALLINT((now >> 16) & 0xFFFF);
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2716
    low = _MKSMALLINT(now & 0xFFFF);
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2717
%}
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2718
.
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2719
    ^ Array with:low with:hi
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2720
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2721
    "OperatingSystem getTimeParts"
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2722
!
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2723
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2724
getTimeInto:aBlock
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2725
    "evaluate the argument aBlock, passing the time-parts of
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2726
     the current time as arguments.
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2727
     See comment in 'OperatingSystem>>getTimeParts' on what to
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2728
     do with those parts."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2729
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2730
    |low hi|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2731
%{ 
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2732
    int now;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2733
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2734
    now = time(0);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2735
    hi  = _MKSMALLINT((now >> 16) & 0xFFFF);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2736
    low = _MKSMALLINT(now & 0xFFFF);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2737
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2738
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2739
    aBlock value:low value:hi
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2740
241
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2741
    "OperatingSystem getTimeInto:[:low :hi | low printNewline. hi printNewline]"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2742
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2743
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2744
getTime
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2745
    "return current Time in some OS dependent representation.
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2746
     (on unix, its the seconds since 1970).
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2747
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2748
     WARNING: this is OperatingSystem dependent - for portable code,
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2749
     use getTimeParts and compute*PartsOf:and:for:.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2750
     Better yet, use Date>>today or Time>>now for fully ST-80 compatible code."
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2751
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2752
    OperatingSystem getTimeInto:[:low :hi | ^ hi*16r10000 + low]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2753
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2754
    "
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2755
     OperatingSystem getTime
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2756
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2757
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2758
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2759
computeDatePartsOf:timeParts for:aBlock
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2760
    "compute year, month and day from the ostime in timeParts,
241
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2761
     and evaluate the argument, a 3-arg block with these.
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2762
     Conversion is to localtime including any daylight saving adjustments."
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2763
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2764
     ^ self computeDatePartsOf:(timeParts at:1) and:(timeParts at:2) for:aBlock
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2765
!
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2766
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2767
computeTimePartsOf:timeParts for:aBlock
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2768
    "compute hour, minute and seconds from the ostime in timeParts,
241
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2769
     and evaluate the argument, a 3-arg block with these.
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2770
     Conversion is to localtime including any daylight saving adjustments."
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2771
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2772
     ^ self computeTimePartsOf:(timeParts at:1) and:(timeParts at:2) for:aBlock
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2773
!
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2774
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2775
computeDatePartsOf:timeLow and:timeHi for:aBlock
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2776
    "compute year, month and day from the time-parts timeLow and
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2777
     timeHi and evaluate the argument, a 3-arg block with these.
241
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2778
     Conversion is to localtime including any daylight saving adjustments.
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2779
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2780
     This method was added to avoid LargeInteger arithmetic and to be
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2781
     independent of how the OperatingSystem represents time;
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2782
     the time-parts expected are those returned by getTimeParts."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2783
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2784
    |year month day|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2785
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2786
    ((timeLow isMemberOf:SmallInteger) and:[timeHi isMemberOf:SmallInteger])
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2787
    ifFalse:[
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2788
	^ self primitiveFailed
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2789
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2790
%{
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2791
    struct tm *tmPtr;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2792
    long t;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2793
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2794
    t = (_intVal(timeHi) << 16) | _intVal(timeLow);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2795
    tmPtr = localtime(&t);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2796
    year = _MKSMALLINT(tmPtr->tm_year + 1900);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2797
    month = _MKSMALLINT(tmPtr->tm_mon + 1);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2798
    day = _MKSMALLINT(tmPtr->tm_mday);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2799
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2800
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2801
    aBlock value:year value:month value:day
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2802
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2803
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2804
computeTimePartsOf:timeLow and:timeHi for:aBlock
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2805
    "compute hours, minutes and seconds from the time-parts timeLow and
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2806
     timeHi and evaluate the argument, a 3-arg block with these.
241
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2807
     Conversion is to localtime including any daylight saving adjustments.
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2808
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2809
     This method was added to avoid LargeInteger arithmetic and to be
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2810
     independent of how the OperatingSystem represents time;
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2811
     the time-parts expected are those returned by getTimeParts."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2812
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2813
    |hours minutes seconds|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2814
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2815
    ((timeLow isMemberOf:SmallInteger) and:[timeHi isMemberOf:SmallInteger])
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2816
    ifFalse:[
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2817
	^ self primitiveFailed
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2818
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2819
%{
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2820
    struct tm *tmPtr;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2821
    long t;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2822
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2823
    t = (_intVal(timeHi) << 16) | _intVal(timeLow);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2824
    tmPtr = localtime(&t);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2825
    hours = _MKSMALLINT(tmPtr->tm_hour);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2826
    minutes = _MKSMALLINT(tmPtr->tm_min);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2827
    seconds = _MKSMALLINT(tmPtr->tm_sec);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2828
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2829
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2830
    aBlock value:hours value:minutes value:seconds
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2831
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2832
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2833
computeTimeAndDateFrom:timeParts
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2834
    "given an Array containing the OS-dependent time, return an Array
241
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2835
     containing year, month, day, hour, minute and seconds.
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2836
     Conversion is to localtime including any daylight saving adjustments."
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2837
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2838
    |low hi year month day hours minutes seconds ret|
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2839
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2840
    low := timeParts at:1.
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2841
    hi := timeParts at:2.
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2842
%{
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2843
    struct tm *tmPtr;
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2844
    long t;
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2845
252
  2846
    if (__bothSmallInteger(low, hi)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2847
	t = (_intVal(hi) << 16) | _intVal(low);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2848
	tmPtr = localtime(&t);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2849
	hours = _MKSMALLINT(tmPtr->tm_hour);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2850
	minutes = _MKSMALLINT(tmPtr->tm_min);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2851
	seconds = _MKSMALLINT(tmPtr->tm_sec);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2852
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2853
	year = _MKSMALLINT(tmPtr->tm_year + 1900);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2854
	month = _MKSMALLINT(tmPtr->tm_mon + 1);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2855
	day = _MKSMALLINT(tmPtr->tm_mday);
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2856
    }
241
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2857
%}.
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2858
    year notNil ifTrue:[
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2859
	"I would love to have SELF-like inline objects ..."
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2860
	ret := Array new:6.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2861
	ret at:1 put:year.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2862
	ret at:2 put:month.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2863
	ret at:3 put:day.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2864
	ret at:4 put:hours.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2865
	ret at:5 put:minutes.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2866
	ret at:6 put:seconds.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2867
	^ ret
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2868
    ].
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2869
    ^ self primitiveFailed
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2870
!
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2871
241
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2872
computeTimePartsFromYear:y month:m day:d hour:h minute:min seconds:s
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2873
    "return an Array containing the OS-dependent time for the given
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2874
     time and day. The arguments are assumed to be in localtime including
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2875
     any daylight saving adjustings."
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2876
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2877
    |low hi|
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2878
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2879
%{
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2880
    struct tm tm;
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2881
    long t;
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2882
252
  2883
    if (__bothSmallInteger(y, m) 
  2884
     && __bothSmallInteger(d, h)
  2885
     && __bothSmallInteger(min, s)) {
  2886
	tm.tm_hour = __intVal(h);
  2887
	tm.tm_min = __intVal(min);
  2888
	tm.tm_sec = __intVal(s);
  2889
  2890
	tm.tm_year = __intVal(y) - 1900;
  2891
	tm.tm_mon = __intVal(m) - 1;
  2892
	tm.tm_mday = __intVal(d);
241
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2893
	tm.tm_isdst = -1;
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2894
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2895
	t = mktime(&tm);
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2896
	low = _MKSMALLINT(t & 0xFFFF);
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2897
	hi = _MKSMALLINT((t >> 16) & 0xFFFF);
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2898
    }
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2899
%}.
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2900
    low notNil ifTrue:[
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2901
	^ Array with:low with:hi
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2902
    ].    
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2903
    ^ self primitiveFailed
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2904
!
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  2905
275
a76029ddaa98 *** empty log message ***
claus
parents: 252
diff changeset
  2906
maximumMillisecondTimeDelta
a76029ddaa98 *** empty log message ***
claus
parents: 252
diff changeset
  2907
    "this returns the maximum delta supported by millisecondCounter
a76029ddaa98 *** empty log message ***
claus
parents: 252
diff changeset
  2908
     based methods. The returned value is half the value at which the
a76029ddaa98 *** empty log message ***
claus
parents: 252
diff changeset
  2909
     timer wraps."
a76029ddaa98 *** empty log message ***
claus
parents: 252
diff changeset
  2910
a76029ddaa98 *** empty log message ***
claus
parents: 252
diff changeset
  2911
%{  /* NOCONTEXT */
a76029ddaa98 *** empty log message ***
claus
parents: 252
diff changeset
  2912
    RETURN ( _MKSMALLINT(0x0FFFFFFF) );
a76029ddaa98 *** empty log message ***
claus
parents: 252
diff changeset
  2913
%}
a76029ddaa98 *** empty log message ***
claus
parents: 252
diff changeset
  2914
!
a76029ddaa98 *** empty log message ***
claus
parents: 252
diff changeset
  2915
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2916
getMillisecondTime
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2917
    "This returns the millisecond timers value. 
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2918
     The range is limited to 0..1fffffff (i.e. the SmallInteger range) to avoid
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2919
     LargeInteger arithmetic when doing timeouts and delays.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2920
     SInce this value is wrapping around in regular intervals, this can only be used for 
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2921
     short relative time deltas.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2922
     Use the millisecondTimeXXX:-methods to compare and add time deltas - these know about the wrap.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2923
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2924
     BAD DESIGN:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2925
	This should be changed to return some instance of RelativeTime,
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2926
	and these computations moved there.
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2927
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2928
     Dont use this method in application code since it is an internal (private)
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2929
     interface. For compatibility with ST-80, use Time millisecondClockValue.
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2930
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2931
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2932
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2933
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2934
    long t;
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2935
#if !defined(HAS_GETTIMEOFDAY) && defined(SYSV) && defined(HZ)
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2936
    /* 
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2937
     * sys5 time
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2938
     */
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2939
    long ticks;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2940
    struct tms tb;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2941
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2942
    ticks = times(&tb);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2943
    t = (ticks * 1000) / HZ;
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2944
#else /* assume HAS_GETTIMEOFDAY */
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2945
    /*
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2946
     * bsd time
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2947
     */
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2948
    struct timeval tb;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2949
    struct timezone tzb;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2950
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2951
    gettimeofday(&tb, &tzb);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2952
    t = tb.tv_sec*1000 + tb.tv_usec/1000;
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  2953
#endif
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2954
    RETURN ( _MKSMALLINT(t & 0x1FFFFFFF) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2955
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2956
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2957
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2958
millisecondTimeDeltaBetween:msTime1 and:msTime2
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2959
    "subtract two millisecond times (such as returned getMillisecondTime)
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2960
     and return the difference. Since milli-times wrap (at 16r01FFFFFFF), 
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2961
     some special handling is built-in here.
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2962
     The returned value is msTime1 - msTime2. The returned value is invalid
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2963
     if the delta is >= 0x10000000.
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2964
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  2965
     This should really be moved to some RelativeTime class."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2966
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2967
    (msTime1 > msTime2) ifTrue:[
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  2968
	^ msTime1 - msTime2
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2969
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2970
    ^ msTime1 + 16r10000000 - msTime2
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2971
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2972
    "
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2973
     OperatingSystem millisecondTimeAdd:16r0FFFFFFF and:1   
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2974
     OperatingSystem millisecondTimeAdd:16r0FFFFFFF and:(16 / 3)  
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2975
     OperatingSystem millisecondTimeAdd:16r0FFFFFFF and:1000   
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2976
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2977
     OperatingSystem millisecondTimeDeltaBetween:0 and:16r0FFFFFFF  
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2978
     OperatingSystem millisecondTimeDeltaBetween:(13/3) and:16r0FFFFFFF     
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2979
     OperatingSystem millisecondTimeDeltaBetween:999 and:16r0FFFFFFF       
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2980
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2981
     OperatingSystem millisecondTime:0 isAfter:16r0FFFFFFF    
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2982
     OperatingSystem millisecondTime:(13/3) isAfter:16r0FFFFFFF   
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2983
     OperatingSystem millisecondTime:999 isAfter:16r0FFFFFFF       
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2984
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2985
     OperatingSystem millisecondTime:0 isAfter:0          
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2986
     OperatingSystem millisecondTime:(13/3) isAfter:0  
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2987
     OperatingSystem millisecondTime:999 isAfter:0       
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2988
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2989
     OperatingSystem millisecondTime:1 isAfter:0        
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2990
     OperatingSystem millisecondTime:(13/3) isAfter:2
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2991
     OperatingSystem millisecondTime:999 isAfter:900       
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2992
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2993
     |t1 t2|
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2994
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2995
     t1 := Time millisecondClockValue.
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2996
     (Delay forMilliseconds:1) wait.   
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2997
     t2 := Time millisecondClockValue.
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2998
     OperatingSystem millisecondTimeDeltaBetween:t2 and:t1 
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  2999
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3000
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3001
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3002
millisecondTime:msTime1 isAfter:msTime2
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3003
    "return true if msTime1 is after msTime2, false if not.
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3004
     The two arguments are supposed to be millisecond times 
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3005
     (such as returned getMillisecondTime) which wrap at 16r1FFFFFFF.
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  3006
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  3007
     This should really be moved to some RelativeTime class."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3008
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3009
    (msTime1 > msTime2) ifTrue:[
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3010
	((msTime1 - msTime2) >= 16r10000000) ifTrue:[
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3011
	    ^ false
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3012
	].
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3013
	^ true
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3014
    ].
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3015
    ((msTime2 - msTime1) > 16r10000000) ifTrue:[
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3016
	^ true
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3017
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3018
    ^ false
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3019
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3020
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3021
millisecondTimeAdd:msTime1 and:msTime2
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3022
    "Add two millisecond times (such as returned getMillisecondTime).
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3023
     The returned value is msTime1 + msTime2 where a wrap occurs at:16r1FFFFFFF.
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  3024
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  3025
     This should really be moved to some RelativeTime class."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3026
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3027
    |sum|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3028
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3029
    sum := msTime1 + msTime2.
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3030
    (sum > 16r1FFFFFFF) ifTrue:[^ sum - 16r20000000].
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3031
    (sum < 0) ifTrue:[^ sum + 16r20000000].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3032
    ^ sum
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3033
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3034
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3035
millisecondDelay:millis
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3036
    "delay execution for millis milliseconds or until the next event
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3037
     arrives.
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3038
     All lower priority threads will also sleep for the duration, 
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3039
     interrupts (and therefore, higher prio processes) are
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3040
     still handled. 
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3041
     Better use a Delay, to only delay the calling thread.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3042
     (however, a delay cannot be used in the event handler or scheduler)"
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3043
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3044
    |now then delta|
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3045
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3046
    now := OperatingSystem getMillisecondTime.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3047
    then := OperatingSystem millisecondTimeAdd:now and:millis.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3048
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3049
    [OperatingSystem millisecondTime:then isAfter:now] whileTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3050
	delta := OperatingSystem millisecondTimeDeltaBetween:then and:now.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3051
	self selectOnAnyReadable:nil writable:nil exception:nil withTimeOut:delta.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3052
	now := OperatingSystem getMillisecondTime.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3053
    ]
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3054
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3055
    "
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3056
     OperatingSystem millisecondDelay:2000
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3057
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3058
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3059
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3060
sleep:numberOfSeconds
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3061
    "cease ANY action for some time. This suspends the whole smalltalk
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3062
     (unix-) process for some time.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3063
     Not really useful since not even low-prio processes and interrupt
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3064
     handling will run during the sleep.
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3065
     Use either OperatingSystem>>millisecondDelay: (which makes all
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3066
     threads sleep, but handles interrupts) or use a Delay (which makes
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3067
     only the calling thread sleep)."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3068
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3069
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3070
252
  3071
    if (__isSmallInteger(numberOfSeconds)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3072
	sleep(_intVal(numberOfSeconds));
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3073
	RETURN ( self );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3074
    }
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3075
%}.
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3076
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3077
     argument not integer
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3078
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3079
    self primitiveFailed
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3080
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3081
    "
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3082
     OperatingSystem sleep:2
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3083
    "
10
claus
parents: 5
diff changeset
  3084
! !
claus
parents: 5
diff changeset
  3085
claus
parents: 5
diff changeset
  3086
!OperatingSystem class methodsFor:'waiting for events'!
claus
parents: 5
diff changeset
  3087
claus
parents: 5
diff changeset
  3088
setBlocking:aBoolean on:fd
claus
parents: 5
diff changeset
  3089
    "set/clear the blocking attribute - if set (which is the default)
claus
parents: 5
diff changeset
  3090
     a read on the fileDescriptor will block until data is available.
claus
parents: 5
diff changeset
  3091
     If cleared, a read operation will immediately return with a value of
claus
parents: 5
diff changeset
  3092
     nil."
claus
parents: 5
diff changeset
  3093
claus
parents: 5
diff changeset
  3094
%{  /* NOCONTEXT */
claus
parents: 5
diff changeset
  3095
claus
parents: 5
diff changeset
  3096
    int ret, flags;
claus
parents: 5
diff changeset
  3097
    int savInt;
claus
parents: 5
diff changeset
  3098
claus
parents: 5
diff changeset
  3099
#if defined(F_GETFL) && defined(F_SETFL)
claus
parents: 5
diff changeset
  3100
# if defined(FNDELAY)
252
  3101
    if (__isSmallInteger(fd)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3102
	flags = fcntl(_intVal(fd), F_GETFL, 0);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3103
	if (aBoolean == true) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3104
	    ret = fcntl(_intVal(fd), F_SETFL, flags & ~FNDELAY);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3105
	} else {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3106
	    ret = fcntl(_intVal(fd), F_SETFL, flags | FNDELAY);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3107
	}
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3108
	if (ret >= 0) ret = flags;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3109
	RETURN ( _MKSMALLINT(ret) );
10
claus
parents: 5
diff changeset
  3110
    }
claus
parents: 5
diff changeset
  3111
# endif
claus
parents: 5
diff changeset
  3112
#endif
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3113
%}.
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3114
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3115
     fd argument not integer
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3116
    "
10
claus
parents: 5
diff changeset
  3117
    self primitiveFailed
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3118
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3119
10
claus
parents: 5
diff changeset
  3120
readCheck:fd
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3121
    "return true, if data is available on a filedescriptor (i.e. read
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3122
     is possible without blocking)"
10
claus
parents: 5
diff changeset
  3123
claus
parents: 5
diff changeset
  3124
    (self selectOnAnyReadable:(Array with:fd)
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3125
		     writable:nil
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3126
		    exception:nil
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3127
		  withTimeOut:0) == fd
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3128
	ifTrue:[^ true].
10
claus
parents: 5
diff changeset
  3129
    ^ false
claus
parents: 5
diff changeset
  3130
!
claus
parents: 5
diff changeset
  3131
claus
parents: 5
diff changeset
  3132
writeCheck:fd
claus
parents: 5
diff changeset
  3133
    "return true, if filedescriptor can be written without blocking"
claus
parents: 5
diff changeset
  3134
claus
parents: 5
diff changeset
  3135
    (self selectOnAnyReadable:nil
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3136
		     writable:(Array with:fd)
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3137
		    exception:nil
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3138
		  withTimeOut:0) == fd
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3139
	ifTrue:[^ true].
10
claus
parents: 5
diff changeset
  3140
    ^ false
claus
parents: 5
diff changeset
  3141
!
claus
parents: 5
diff changeset
  3142
claus
parents: 5
diff changeset
  3143
selectOn:fd withTimeOut:millis
claus
parents: 5
diff changeset
  3144
    "wait for aFileDesriptor to become ready; timeout after t milliseconds.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3145
     Return true, if i/o ok, false if timed-out or interrupted.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3146
     With 0 as timeout argument, this can be used to check for availability
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3147
     of read-data.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3148
     Experimental."
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3149
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  3150
    ^ self selectOnAnyReadable:(Array with:fd)
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3151
		      writable:(Array with:fd)
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3152
		     exception:nil
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3153
		   withTimeOut:millis
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3154
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3155
10
claus
parents: 5
diff changeset
  3156
selectOn:fd1 and:fd2 withTimeOut:millis
claus
parents: 5
diff changeset
  3157
    "wait for any fd to become ready; timeout after t milliseconds.
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3158
     A zero timeout-time will immediately return (i.e. poll).
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3159
     Return fd if i/o ok, nil if timed-out or interrupted.
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3160
     Obsolete:
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3161
	This is a leftover method and will vanish."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3162
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  3163
    ^ self selectOnAnyReadable:(Array with:fd1 with:fd2)
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3164
		      writable:(Array with:fd1 with:fd2)
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3165
		     exception:nil
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3166
		   withTimeOut:millis
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3167
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3168
10
claus
parents: 5
diff changeset
  3169
selectOnAnyReadable:fdArray withTimeOut:millis
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3170
    "wait for any fd in fdArray (an Array of integers) to become ready for 
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3171
     reading. Timeout after t milliseconds. An empty set will always wait.
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3172
     A zero timeout-time will immediately return (i.e. poll).
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  3173
     Return first ready fd if i/o ok, nil if timed-out or interrupted.
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  3174
     Experimental."
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  3175
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  3176
    ^ self selectOnAnyReadable:fdArray 
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3177
		      writable:nil 
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3178
		     exception:nil
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3179
		   withTimeOut:millis
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  3180
!
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  3181
10
claus
parents: 5
diff changeset
  3182
selectOnAny:fdArray withTimeOut:millis
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3183
    "wait for any fd in fdArray (an Array of integers) to become ready;
10
claus
parents: 5
diff changeset
  3184
     timeout after t milliseconds. An empty set will always wait.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3185
     Return first ready fd if i/o ok, nil if timed-out or interrupted.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3186
     Experimental."
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3187
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  3188
    ^ self selectOnAnyReadable:fdArray
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3189
		      writable:fdArray
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3190
		     exception:nil
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3191
		   withTimeOut:millis
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  3192
! 
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  3193
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3194
selectOnAnyReadable:readFdArray writable:writeFdArray exception:exceptFdArray withTimeOut:millis
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3195
    "wait for any fd in readFdArray (an Array of integers) to become ready for 
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3196
     reading, writeFdArray to become ready for writing, or exceptFdArray to 
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3197
     arrive exceptional data (i.e. out-of-band data).
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3198
     Timeout after t milliseconds or, if the timeout time is 0, immediately..
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3199
     Empty fd-sets will always wait. Zero time can be used to poll file-
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3200
     descriptors (i.e. to check if I/O possible without blocking).
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3201
     Return first ready fd if I/O ok, nil if timed-out or interrupted."
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  3202
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3203
%{
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3204
    fd_set rset, wset, eset;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3205
    int t, f, maxF, i, lX, bX;
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3206
    struct timeval wt, et;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3207
    OBJ fd, retFd;
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3208
    int ret;
300
fe1f742a9224 *** empty log message ***
claus
parents: 275
diff changeset
  3209
    int count;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3210
252
  3211
    if (__isSmallInteger(millis)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3212
	FD_ZERO(&rset);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3213
	FD_ZERO(&wset);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3214
	FD_ZERO(&eset);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3215
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3216
	maxF = -1;
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3217
	if (readFdArray != nil) {
300
fe1f742a9224 *** empty log message ***
claus
parents: 275
diff changeset
  3218
	    if (! __isArray(readFdArray)) {
fe1f742a9224 *** empty log message ***
claus
parents: 275
diff changeset
  3219
		goto fail;    
fe1f742a9224 *** empty log message ***
claus
parents: 275
diff changeset
  3220
	    }
fe1f742a9224 *** empty log message ***
claus
parents: 275
diff changeset
  3221
	    count = __arraySize(readFdArray);
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3222
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3223
	    for (i=0; i<count;i++) {
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3224
		fd = _ArrayInstPtr(readFdArray)->a_element[i];
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3225
		if (fd != nil) {
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3226
		    f = _intVal(fd);
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3227
		    if ((f >= 0) && (f < FD_SETSIZE)) {
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3228
			FD_SET(f, &rset);
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3229
			if (f > maxF) maxF = f;
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3230
		    }
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3231
		}
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3232
	    }
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3233
	}
300
fe1f742a9224 *** empty log message ***
claus
parents: 275
diff changeset
  3234
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3235
	if (writeFdArray != nil) {
300
fe1f742a9224 *** empty log message ***
claus
parents: 275
diff changeset
  3236
	    if (! __isArray(writeFdArray)) {
fe1f742a9224 *** empty log message ***
claus
parents: 275
diff changeset
  3237
		goto fail;    
fe1f742a9224 *** empty log message ***
claus
parents: 275
diff changeset
  3238
	    }
fe1f742a9224 *** empty log message ***
claus
parents: 275
diff changeset
  3239
	    count = __arraySize(writeFdArray);
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3240
	    for (i=0; i<count;i++) {
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3241
		fd = _ArrayInstPtr(writeFdArray)->a_element[i];
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3242
		if (fd != nil) {
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3243
		    f = _intVal(fd);
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3244
		    if ((f >= 0) && (f < FD_SETSIZE)) {
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3245
			FD_SET(f, &wset);       
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3246
			if (f > maxF) maxF = f;
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3247
		    }
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3248
		}
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3249
	    }
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3250
	}
300
fe1f742a9224 *** empty log message ***
claus
parents: 275
diff changeset
  3251
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3252
	if (exceptFdArray != nil) {
300
fe1f742a9224 *** empty log message ***
claus
parents: 275
diff changeset
  3253
	    if (! __isArray(exceptFdArray)) {
fe1f742a9224 *** empty log message ***
claus
parents: 275
diff changeset
  3254
		goto fail;    
fe1f742a9224 *** empty log message ***
claus
parents: 275
diff changeset
  3255
	    }
fe1f742a9224 *** empty log message ***
claus
parents: 275
diff changeset
  3256
	    count = __arraySize(exceptFdArray);
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3257
	    for (i=0; i<count;i++) {
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3258
		fd = _ArrayInstPtr(exceptFdArray)->a_element[i];
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3259
		if (fd != nil) {
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3260
		    f = _intVal(fd);
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3261
		    if ((f >= 0) && (f < FD_SETSIZE)) {
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3262
			FD_SET(f, &eset);       
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3263
			if (f > maxF) maxF = f;
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3264
		    }
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3265
		}
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3266
	    }
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3267
	}
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3268
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3269
	t = _intVal(millis);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3270
	wt.tv_sec = t / 1000;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3271
	wt.tv_usec = (t % 1000) * 1000;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3272
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3273
	/*
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3274
	 * make certain, that interrupt gets us out of the select
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3275
	 */
362
claus
parents: 359
diff changeset
  3276
	__BEGIN_INTERRUPTABLE__
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3277
	errno = 0;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3278
	do {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3279
	    ret = select(maxF+1, &rset, &wset, &eset, &wt);
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3280
	} while (0 /* (ret < 0) && (errno == EINTR) */ );
362
claus
parents: 359
diff changeset
  3281
	__END_INTERRUPTABLE__
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3282
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3283
	if (ret > 0) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3284
	    for (i=0; i <= maxF; i++) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3285
		if (FD_ISSET(i, &rset)
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3286
		 || FD_ISSET(i, &wset)
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3287
		 || FD_ISSET(i, &eset)) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3288
		    RETURN ( _MKSMALLINT(i) );
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3289
		}
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3290
	    }
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3291
	}
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3292
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3293
	/*
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3294
	 * return nil (means time expired)
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3295
	 */
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3296
	RETURN ( nil );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3297
    }
300
fe1f742a9224 *** empty log message ***
claus
parents: 275
diff changeset
  3298
fail: ;
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3299
%}.
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3300
    "
300
fe1f742a9224 *** empty log message ***
claus
parents: 275
diff changeset
  3301
     timeout argument not integer,
fe1f742a9224 *** empty log message ***
claus
parents: 275
diff changeset
  3302
     or any fd-array nonNil and not an array
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3303
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3304
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3305
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3306
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3307
!OperatingSystem class methodsFor:'executing commands'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3308
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3309
fork
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3310
    "fork a new (HEAVY-weight) unix process.
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3311
     Dont confuse this with Block>>fork, which creates 
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3312
     lightweight smalltalk processes. This method will return
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3313
     0 to the child process, abd a non-zero number (which is the childs
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3314
     unix-process-id) to the parent (original) process."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3315
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3316
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3317
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3318
    int pid;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3319
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3320
    pid = fork();
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3321
    RETURN ( _MKSMALLINT(pid) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3322
%}
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3323
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3324
     |id|
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3325
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3326
     id := OperatingSystem fork.
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3327
     id == 0 ifTrue:[
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3328
	OperatingSystem exit
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3329
     ]
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3330
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3331
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3332
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3333
exec:aPath withArguments:argArray
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3334
    "execute the unix command specified by the argument, aPath, with
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3335
     arguments in argArray (no arguments, if nil).
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3336
     If successful, this method does not return and smalltalk is gone.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3337
     If not sucessfull, false is returned. Normal use is with fork."
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3338
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3339
%{
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3340
    char **argv;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3341
    int nargs, i;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3342
    OBJ arg;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3343
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3344
    if (__isString(aPath) && ((argArray == nil) || __isArray(argArray))) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3345
	nargs = argArray == nil ? 0 : _arraySize(argArray);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3346
	argv = (char **) malloc(sizeof(char *) * (nargs + 1));
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  3347
	if (argv) {
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  3348
	    for (i=0; i < nargs; i++) {
241
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  3349
		arg = _ArrayInstPtr(argArray)->a_element[i];
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  3350
		if (__isString(arg)) {
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  3351
		    argv[i] = (char *) _stringVal(arg);
241
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  3352
		}
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3353
	    }
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  3354
	    argv[i] = NULL;
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  3355
	    execv(_stringVal(aPath), argv);
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  3356
	    /* should not be reached */
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  3357
	    free(argv);
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  3358
	    RETURN ( false );
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3359
	}
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3360
    }
245
  3361
%}.
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3362
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3363
     path-argument not string or
245
  3364
     argArray not an array/nil or
  3365
     malloc failed
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3366
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3367
    self primitiveFailed
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3368
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3369
    "
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3370
     |id|
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3371
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3372
     id := OperatingSystem fork.
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3373
     id == 0 ifTrue:[
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3374
	"I am the child"
375
claus
parents: 373
diff changeset
  3375
	OperatingSystem exec:'/bin/ls' withArguments:#('ls' '/tmp').
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3376
	"not reached"
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3377
     ]
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3378
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3379
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3380
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3381
executeCommand:aCommandString
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3382
    "execute the unix command specified by the argument, aCommandString.
85
claus
parents: 77
diff changeset
  3383
     Return true if successful, false otherwise. 
claus
parents: 77
diff changeset
  3384
     Smalltalk is suspended, while the command is executing.
claus
parents: 77
diff changeset
  3385
     The return value of the system()-call is available in the variable
claus
parents: 77
diff changeset
  3386
     LastExecStatus (which is zero after successful execution); this value
claus
parents: 77
diff changeset
  3387
     consists of the reason for termination (0=normal) in the upper 8bits and,
claus
parents: 77
diff changeset
  3388
     iff it was a normal return, the value passed to exit() in the low 8bits."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3389
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3390
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3391
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3392
    int status;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3393
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  3394
    if (__isString(aCommandString)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3395
	status = system((char *) _stringVal(aCommandString));
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3396
	OperatingSystem_LastExecStatus = _MKSMALLINT(status);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3397
	if (status == 0) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3398
	    RETURN ( true );
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3399
	}
354
claus
parents: 348
diff changeset
  3400
	OperatingSystem_LastErrorNumber = _MKSMALLINT(errno);
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3401
	RETURN ( false );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3402
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3403
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3404
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3405
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3406
85
claus
parents: 77
diff changeset
  3407
    "
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3408
     OperatingSystem executeCommand:'pwd'. 
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3409
     OperatingSystem lastExecStatus printNL.
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3410
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3411
     OperatingSystem executeCommand:'ls -l'. 
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3412
     OperatingSystem lastExecStatus printNL.
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3413
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3414
     OperatingSystem executeCommand:'invalidCommand'. 
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3415
     (OperatingSystem lastExecStatus printStringRadix:16) printNL.
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3416
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3417
     OperatingSystem executeCommand:'rm /tmp/foofoofoofoo'. 
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
  3418
     (OperatingSystem lastExecStatus printStringRadix:16) printNL.
85
claus
parents: 77
diff changeset
  3419
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3420
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3421
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3422
!OperatingSystem class methodsFor:'file access'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3423
10
claus
parents: 5
diff changeset
  3424
getCharacter
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3425
    "read a character from keyboard - 
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3426
     this is a blocking low-level read, provided for debugger 
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3427
     and fatal conditions. Use Stdin or (even better) the event 
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3428
     mechanisms provided."
10
claus
parents: 5
diff changeset
  3429
claus
parents: 5
diff changeset
  3430
%{  /* NOCONTEXT */
claus
parents: 5
diff changeset
  3431
claus
parents: 5
diff changeset
  3432
    RETURN ( _MKSMALLINT(getchar()) );
claus
parents: 5
diff changeset
  3433
%}
claus
parents: 5
diff changeset
  3434
!
claus
parents: 5
diff changeset
  3435
2
claus
parents: 1
diff changeset
  3436
fileSeparator
claus
parents: 1
diff changeset
  3437
    "return the character used to separate names in a path.
claus
parents: 1
diff changeset
  3438
     This character differs for MSDOS and other systems,
68
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3439
     (but those are currently not supported - so this is some
59faa75185ba *** empty log message ***
claus
parents: 63
diff changeset
  3440
      preparation for the future)"
2
claus
parents: 1
diff changeset
  3441
claus
parents: 1
diff changeset
  3442
    ^ $/
claus
parents: 1
diff changeset
  3443
!
claus
parents: 1
diff changeset
  3444
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  3445
parentDirectoryName
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  3446
    "return the name used to refer to parent directories.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  3447
     In MSDOS, Unix and other systems this is '..', but maybe different
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  3448
     for other systems.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  3449
     (but those are currently not supported - so this is some
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  3450
      preparation for the future)"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  3451
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  3452
    ^ '..'
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  3453
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  3454
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  3455
caseSensitiveFilenames
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3456
    "return true, if the OS has caseSensitive file naming.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3457
     On MSDOS, this will return false. Since this is for Unix, we
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3458
     return true."
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3459
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3460
    ^ true
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3461
!
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3462
2
claus
parents: 1
diff changeset
  3463
baseNameOf:aPathString
claus
parents: 1
diff changeset
  3464
    "return the baseName of the argument, aPathString
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3465
     - thats the file/directory name without leading parent-dirs
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3466
     (i.e. OperatingSystem baseNameOf:'/usr/lib/st/file' -> 'file'
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3467
       and OperatingSystem baseNameOf:'/usr/lib' -> lib).
2
claus
parents: 1
diff changeset
  3468
     This method does not check if the path is valid 
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3469
     (i.e. if these directories really exist & is readable)."
2
claus
parents: 1
diff changeset
  3470
claus
parents: 1
diff changeset
  3471
    |prev index sep|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3472
2
claus
parents: 1
diff changeset
  3473
    sep := self fileSeparator.
claus
parents: 1
diff changeset
  3474
    ((aPathString size == 1) and:[(aPathString at:1) == sep]) ifTrue:[
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3475
	^ aPathString
2
claus
parents: 1
diff changeset
  3476
    ].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3477
    prev := 1.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3478
    [true] whileTrue:[
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3479
	index := aPathString indexOf:sep startingAt:prev.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3480
	index == 0 ifTrue:[
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3481
	    ^ aPathString copyFrom:prev
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3482
	].
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3483
	prev := index + 1
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3484
    ]
2
claus
parents: 1
diff changeset
  3485
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3486
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3487
     OperatingSystem baseNameOf:'/fee/foo/bar'
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3488
     OperatingSystem baseNameOf:'foo/bar'
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3489
     OperatingSystem baseNameOf:'../../foo/bar'
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3490
     OperatingSystem baseNameOf:'hello'
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3491
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3492
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3493
2
claus
parents: 1
diff changeset
  3494
directoryNameOf:aPathString
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3495
    "return the directoryName of the argument, aPath
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3496
     - thats the name of the directory where aPath is
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3497
     (i.e. OperatingSystem directoryNameOf:'/usr/lib/st/file' -> '/usr/lib/st'
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3498
       and OperatingSystem directoryNameOf:'/usr/lib' -> /usr').
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3499
     This method does not check if the path is valid
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3500
     (i.e. if these directories really exist & are readable)."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3501
2
claus
parents: 1
diff changeset
  3502
    |last index sep sepString|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3503
2
claus
parents: 1
diff changeset
  3504
    sep := self fileSeparator.
claus
parents: 1
diff changeset
  3505
    sepString := sep asString.
claus
parents: 1
diff changeset
  3506
    (aPathString = sepString) ifTrue:[
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3507
	"
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3508
	 the trivial '/' case
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3509
	"
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3510
	^ aPathString
2
claus
parents: 1
diff changeset
  3511
    ].
claus
parents: 1
diff changeset
  3512
    (aPathString startsWith:sepString) ifFalse:[
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3513
	(aPathString endsWith:sepString) ifTrue:[
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3514
	    ^ aPathString copyTo:(aPathString size - 1)
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3515
	].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3516
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3517
    last := 1.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3518
    [true] whileTrue:[
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3519
	index := aPathString indexOf:sep startingAt:(last + 1).
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3520
	index == 0 ifTrue:[
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3521
	    (last == 1) ifTrue:[
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3522
		(aPathString startsWith:sepString) ifTrue:[
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3523
		    ^ sepString
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3524
		].
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3525
		^ '.'
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3526
	    ].
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3527
"
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3528
	    (aPathString startsWith:sepString) ifFalse:[
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3529
		(aPathString startsWith:('..' , sepString)) ifFalse:[
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3530
		    ^ './' , (aPathString copyTo:(last - 1))
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3531
		]
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3532
	    ].
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3533
"
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3534
	    ^ aPathString copyTo:(last - 1)
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3535
	].
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3536
	last := index.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3537
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3538
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3539
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3540
     OperatingSystem directoryNameOf:'/fee/foo/bar'
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3541
     OperatingSystem directoryNameOf:'foo/bar'
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3542
     OperatingSystem directoryNameOf:'../../foo/bar'
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3543
     OperatingSystem directoryNameOf:'bar'
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3544
     OperatingSystem directoryNameOf:'/bar'
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3545
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3546
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3547
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3548
primPathNameOf:pathName
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3549
    "return the pathName of the argument, aPathString,
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3550
     - thats the full pathname of the directory, starting at '/'.
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3551
     This method here returns nil, if the OS does not provide a
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3552
     realPath library function.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3553
     Notice: if symbolic links are involved, the result may look different
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3554
     from what you expect."
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3555
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3556
    |path|
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3557
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3558
    "some systems have a convenient function for this ..."
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3559
%{  /* STACK: 16000 */
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3560
#ifdef HAS_REALPATH
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3561
    char nameBuffer[MAXPATHLEN + 1];
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3562
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3563
    if (__isString(pathName)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3564
	if (realpath(_stringVal(pathName), nameBuffer)) {
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3565
	    RETURN ( _MKSTRING(nameBuffer COMMA_CON) );
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3566
	}
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3567
    }
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3568
#endif
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3569
%}.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3570
    ^ nil
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3571
!
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3572
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3573
compressPath:pathName
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3574
    "return the pathName compressed - that is, remove all ..-entries
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3575
     and . entries. This does not always (in case of symbolic links)
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3576
     return the true pathName and is therefore used as a fallback
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3577
     if realPath and popen failed."
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3578
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3579
    |names|
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3580
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3581
    names := pathName 
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3582
		asCollectionOfSubstringsSeparatedBy:self fileSeparator.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3583
    names := names asOrderedCollection.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3584
    "
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3585
     cut off initial double-slashes
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3586
    "
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3587
    [names startsWith:#('' '')] whileTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3588
	names removeFirst.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3589
    ].
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3590
    "
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3591
     cut off double-slashes at end
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3592
    "
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3593
    [names endsWith:#('')] whileTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3594
	names removeLast.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3595
    ].
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3596
    "
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3597
     cut off current-dir at beginning
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3598
    "
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3599
    [(names size >= 2) and:[names startsWith:#('.')]] whileTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3600
	names removeFirst.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3601
    ].
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3602
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3603
    "
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3604
     cut off parent-dirs at end
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3605
    "
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3606
    [(names size > 2) 
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3607
     and:[(names endsWith:#('..'))
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3608
     and:[((names at:(names size - 1)) startsWith:'.') not ]]] whileTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3609
	names removeLast; removeLast
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3610
    ].
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3611
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3612
    ^ names asStringWith:self fileSeparator 
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3613
		    from:1
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3614
		    to:names size
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3615
		    compressTabs:false final:nil 
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3616
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3617
    "
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3618
     OperatingSystem compressPath:'./..'    
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3619
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3620
     OperatingSystem compressPath:'/foo/bar/baz/..'  
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3621
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3622
     OperatingSystem compressPath:'foo/bar/baz/..'  
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3623
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3624
     OperatingSystem compressPath:'foo/bar/baz/../'  
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3625
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3626
     OperatingSystem compressPath:'foo/bar/baz/..///' 
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3627
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3628
     OperatingSystem compressPath:'///foo/bar/baz/..///' 
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3629
    "
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3630
!
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3631
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3632
pathNameOf:pathName
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3633
    "return the pathName of the argument, aPathString,
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3634
     - thats the full pathname of the directory, starting at '/'.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3635
     This method needs the path to be valid
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3636
     (i.e. all directories must exist, be readable and executable).
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3637
     Notice: if symbolic links are involved, the result may look different
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3638
     from what you expect."
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3639
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3640
    |p path command|
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3641
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3642
    "some systems have a convenient function for this ..."
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3643
    path := self primPathNameOf:pathName.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3644
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3645
    path isNil ifTrue:[
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3646
	(SlowFork==true or:[ForkFailed]) ifFalse:[
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3647
	    PipeStream openErrorSignal handle:[:ex |
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3648
		ForkFailed := true.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3649
		'UNIX: cannot fork/popen' errorPrintNL.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3650
		ex return.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3651
	    ] do:[
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3652
		"have to fall back ..."
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3653
		command := 'cd ' , pathName , '; pwd'.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3654
		p := PipeStream readingFrom:command.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3655
	    ].
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3656
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3657
	    (p isNil or:[p atEnd]) ifTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3658
		('UNIX: PipeStream for <' , command , '> failed') errorPrintNL.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3659
	    ] ifFalse:[
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3660
		path := p nextLine.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3661
		p close.
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3662
	    ].
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3663
	].
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3664
	path isNil ifTrue:[
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3665
	    path := pathName
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3666
	].
308
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3667
	(SlowFork==true or:[ForkFailed]) ifTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3668
	    path := self compressPath:path
f04744ef7b5d *** empty log message ***
claus
parents: 300
diff changeset
  3669
	]
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3670
    ].
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3671
    ^ path.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3672
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3673
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3674
     OperatingSystem pathNameOf:'.'
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3675
     OperatingSystem pathNameOf:'../smalltalk/../smalltalk'
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3676
     OperatingSystem pathNameOf:'../../..'
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3677
     OperatingSystem pathNameOf:'..'
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  3678
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3679
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3680
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3681
isValidPath:aPathName
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3682
    "return true, if 'aPathName' is a valid path name
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3683
     (i.e. the file or directory exists)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3684
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3685
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3686
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3687
    struct stat buf;
10
claus
parents: 5
diff changeset
  3688
    int ret;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3689
322
ac37e8e9edfb *** empty log message ***
claus
parents: 308
diff changeset
  3690
    if (__isString(aPathName) || __isSymbol(aPathName) ) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3691
	do {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3692
	    ret = stat((char *) _stringVal(aPathName), &buf);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3693
	} while (ret < 0 && errno == EINTR);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3694
	RETURN ( ret ? false : true );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3695
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3696
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3697
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3698
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3699
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3700
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3701
isDirectory:aPathName
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3702
    "return true, if 'aPathName' is a valid directory path name.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3703
     (i.e. exists and is a directory)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3704
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3705
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3706
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3707
    struct stat buf;
10
claus
parents: 5
diff changeset
  3708
    int ret;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3709
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  3710
    if (__isString(aPathName)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3711
	do {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3712
	    ret = stat((char *) _stringVal(aPathName), &buf);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3713
	} while (ret < 0 && errno == EINTR);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3714
	if ((ret < 0) || ((buf.st_mode & S_IFMT) != S_IFDIR)) {
354
claus
parents: 348
diff changeset
  3715
	    OperatingSystem_LastErrorNumber = _MKSMALLINT(errno);
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3716
	    RETURN ( false );
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3717
	}
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3718
	RETURN ( true );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3719
    }
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3720
%}.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3721
    self primitiveFailed
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3722
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3723
    "an alternative implementation would be:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3724
	^ (self infoOf:aPathName) at:#type == #directory
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3725
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3726
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3727
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3728
isReadable:aPathName
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3729
    "return true, if the file/dir 'aPathName' is readable."
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3730
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3731
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3732
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  3733
    if (__isString(aPathName)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3734
	if (access(_stringVal(aPathName), R_OK) == 0) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3735
	    RETURN ( true );
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3736
	}
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3737
	OperatingSystem_LastErrorNumber = _MKSMALLINT(errno);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3738
	RETURN ( false );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3739
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3740
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3741
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3742
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3743
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3744
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3745
isWritable:aPathName
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3746
    "return true, if the given file is writable"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3747
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3748
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3749
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  3750
    if (__isString(aPathName)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3751
	if (access(_stringVal(aPathName), W_OK) == 0) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3752
	    RETURN ( true );
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3753
	}
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3754
	OperatingSystem_LastErrorNumber = _MKSMALLINT(errno);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3755
	RETURN ( false );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3756
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3757
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3758
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3759
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3760
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3761
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3762
isExecutable:aPathName
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3763
    "return true, if the given file is executable"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3764
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3765
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3766
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  3767
    if (__isString(aPathName)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3768
	if (access(_stringVal(aPathName), X_OK) == 0) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3769
	    RETURN ( true );
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3770
	}
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3771
	OperatingSystem_LastErrorNumber = _MKSMALLINT(errno);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3772
	RETURN ( false );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3773
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3774
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3775
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3776
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3777
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3778
329
claus
parents: 322
diff changeset
  3779
isSymbolicLink:aPathName
claus
parents: 322
diff changeset
  3780
    "return true, if the given file is a symbolic link"
claus
parents: 322
diff changeset
  3781
claus
parents: 322
diff changeset
  3782
    ^ (self linkInfoOf:aPathName) notNil
356
claus
parents: 354
diff changeset
  3783
claus
parents: 354
diff changeset
  3784
    "
claus
parents: 354
diff changeset
  3785
     OperatingSystem isSymbolicLink:'Make.proto'
claus
parents: 354
diff changeset
  3786
     OperatingSystem isSymbolicLink:'Makefile' 
claus
parents: 354
diff changeset
  3787
    "
329
claus
parents: 322
diff changeset
  3788
!
claus
parents: 322
diff changeset
  3789
claus
parents: 322
diff changeset
  3790
linkInfoOf:aPathName
claus
parents: 322
diff changeset
  3791
    "return a dictionary filled with info for the file 'aPathName',
claus
parents: 322
diff changeset
  3792
     IFF aPathName is a symbolic link. If not, return nil.
claus
parents: 322
diff changeset
  3793
     The contents of the dictionary gives info about the link itself,
claus
parents: 322
diff changeset
  3794
     on contrast to #infoOf:, which returns the info of the pointed to file
claus
parents: 322
diff changeset
  3795
     in case of a symbolic link."
claus
parents: 322
diff changeset
  3796
     
claus
parents: 322
diff changeset
  3797
    |info type mode uid gid size id atimeLow atimeHi mtimeLow mtimeHi ctimeLow ctimeHi
claus
parents: 322
diff changeset
  3798
     path|
claus
parents: 322
diff changeset
  3799
claus
parents: 322
diff changeset
  3800
%{  /* STACK: 1200 */
claus
parents: 322
diff changeset
  3801
    struct stat buf;
claus
parents: 322
diff changeset
  3802
    int ret;
claus
parents: 322
diff changeset
  3803
    char pathBuffer[1024];
claus
parents: 322
diff changeset
  3804
claus
parents: 322
diff changeset
  3805
    if (__isString(aPathName)) {
claus
parents: 322
diff changeset
  3806
	do {
claus
parents: 322
diff changeset
  3807
	    ret = lstat((char *) _stringVal(aPathName), &buf);
claus
parents: 322
diff changeset
  3808
	} while (ret < 0 && errno == EINTR);
claus
parents: 322
diff changeset
  3809
	if (ret < 0) {
claus
parents: 322
diff changeset
  3810
	    OperatingSystem_LastErrorNumber = _MKSMALLINT(errno);
claus
parents: 322
diff changeset
  3811
	    RETURN ( nil );
claus
parents: 322
diff changeset
  3812
	}
claus
parents: 322
diff changeset
  3813
	switch (buf.st_mode & S_IFMT) {
claus
parents: 322
diff changeset
  3814
	    default:
claus
parents: 322
diff changeset
  3815
		RETURN ( nil ); /* not a symbolic link */
claus
parents: 322
diff changeset
  3816
claus
parents: 322
diff changeset
  3817
	    case S_IFLNK:
claus
parents: 322
diff changeset
  3818
		type = @symbol(symbolicLink);
claus
parents: 322
diff changeset
  3819
		break;
claus
parents: 322
diff changeset
  3820
	}
claus
parents: 322
diff changeset
  3821
claus
parents: 322
diff changeset
  3822
	mode = _MKSMALLINT(buf.st_mode & 0777);
claus
parents: 322
diff changeset
  3823
	uid = _MKSMALLINT(buf.st_uid);
claus
parents: 322
diff changeset
  3824
	gid = _MKSMALLINT(buf.st_gid);
claus
parents: 322
diff changeset
  3825
	size = _MKSMALLINT(buf.st_size);
claus
parents: 322
diff changeset
  3826
	id = _MKSMALLINT(buf.st_ino);
claus
parents: 322
diff changeset
  3827
	atimeLow = _MKSMALLINT(buf.st_atime & 0xFFFF);
claus
parents: 322
diff changeset
  3828
	atimeHi = _MKSMALLINT((buf.st_atime >> 16) & 0xFFFF);
claus
parents: 322
diff changeset
  3829
	mtimeLow = _MKSMALLINT(buf.st_mtime & 0xFFFF);
claus
parents: 322
diff changeset
  3830
	mtimeHi = _MKSMALLINT((buf.st_mtime >> 16) & 0xFFFF);
claus
parents: 322
diff changeset
  3831
	ctimeLow = _MKSMALLINT(buf.st_ctime & 0xFFFF);
claus
parents: 322
diff changeset
  3832
	ctimeHi = _MKSMALLINT((buf.st_ctime >> 16) & 0xFFFF);
356
claus
parents: 354
diff changeset
  3833
	if ((ret = readlink((char *) _stringVal(aPathName), pathBuffer, sizeof(pathBuffer))) < 0) {
329
claus
parents: 322
diff changeset
  3834
	    OperatingSystem_LastErrorNumber = _MKSMALLINT(errno);
claus
parents: 322
diff changeset
  3835
	    RETURN ( nil );
claus
parents: 322
diff changeset
  3836
	} 
356
claus
parents: 354
diff changeset
  3837
	pathBuffer[ret] = '\0';  /* readlink does not 0-terminate */
329
claus
parents: 322
diff changeset
  3838
	path = _MKSTRING(pathBuffer COMMA_CON);
claus
parents: 322
diff changeset
  3839
    }
claus
parents: 322
diff changeset
  3840
%}.
claus
parents: 322
diff changeset
  3841
    mode notNil ifTrue:[
claus
parents: 322
diff changeset
  3842
	info := IdentityDictionary new.
claus
parents: 322
diff changeset
  3843
	info at:#type put:type.
claus
parents: 322
diff changeset
  3844
	info at:#mode put:mode.
claus
parents: 322
diff changeset
  3845
	info at:#uid put:uid.
claus
parents: 322
diff changeset
  3846
	info at:#gid put:gid.
claus
parents: 322
diff changeset
  3847
	info at:#size put:size.
claus
parents: 322
diff changeset
  3848
	info at:#id put:id.
claus
parents: 322
diff changeset
  3849
	info at:#path put:path.
claus
parents: 322
diff changeset
  3850
	info at:#accessed      put:(AbsoluteTime fromOSTimeLow:atimeLow and:atimeHi).
claus
parents: 322
diff changeset
  3851
	info at:#modified      put:(AbsoluteTime fromOSTimeLow:mtimeLow and:mtimeHi).
claus
parents: 322
diff changeset
  3852
	info at:#statusChanged put:(AbsoluteTime fromOSTimeLow:ctimeLow and:ctimeHi).
claus
parents: 322
diff changeset
  3853
	^ info
claus
parents: 322
diff changeset
  3854
   ].
claus
parents: 322
diff changeset
  3855
   self primitiveFailed
claus
parents: 322
diff changeset
  3856
claus
parents: 322
diff changeset
  3857
   "
claus
parents: 322
diff changeset
  3858
    OperatingSystem infoOf:'Make.proto'
claus
parents: 322
diff changeset
  3859
    OperatingSystem linkInfoOf:'Make.proto'
claus
parents: 322
diff changeset
  3860
   "
claus
parents: 322
diff changeset
  3861
!
claus
parents: 322
diff changeset
  3862
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3863
infoOf:aPathName
329
claus
parents: 322
diff changeset
  3864
    "return a dictionary filled with info for the file 'aPathName';
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3865
     info is: (type->t mode->n uid->u gid->g size->s id->ino).
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3866
     return nil if such a file does not exist. A dictionary is returned,
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3867
     since we might need to add more info in the future without affecting
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3868
     existing applications."
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3869
329
claus
parents: 322
diff changeset
  3870
    |info type mode uid gid size id 
claus
parents: 322
diff changeset
  3871
     atimeLow atimeHi mtimeLow mtimeHi ctimeLow ctimeHi|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3872
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3873
%{
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3874
    struct stat buf;
10
claus
parents: 5
diff changeset
  3875
    int ret;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3876
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  3877
    if (__isString(aPathName)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3878
	do {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3879
	    ret = stat((char *) _stringVal(aPathName), &buf);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3880
	} while (ret < 0 && errno == EINTR);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3881
	if (ret < 0) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3882
	    OperatingSystem_LastErrorNumber = _MKSMALLINT(errno);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3883
	    RETURN ( nil );
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3884
	}
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3885
	switch (buf.st_mode & S_IFMT) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3886
	    case S_IFDIR:
329
claus
parents: 322
diff changeset
  3887
		type = @symbol(directory);
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3888
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3889
	    case S_IFCHR:
329
claus
parents: 322
diff changeset
  3890
		type = @symbol(characterSpecial);
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3891
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3892
	    case S_IFBLK:
329
claus
parents: 322
diff changeset
  3893
		type = @symbol(blockSpecial);
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3894
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3895
	    case S_IFREG:
329
claus
parents: 322
diff changeset
  3896
		type = @symbol(regular);
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3897
		break;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3898
#ifdef S_IFLNK
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3899
	    case S_IFLNK:
329
claus
parents: 322
diff changeset
  3900
		type = @symbol(symbolicLink);
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3901
		break;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3902
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3903
#ifdef S_IFSOCK
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3904
	    case S_IFSOCK:
329
claus
parents: 322
diff changeset
  3905
		type = @symbol(socket);
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3906
		break;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3907
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3908
#ifdef S_IFIFO
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3909
	    case S_IFIFO:
329
claus
parents: 322
diff changeset
  3910
		type = @symbol(fifo);
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3911
		break;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3912
#endif
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3913
	    default:
329
claus
parents: 322
diff changeset
  3914
		type = @symbol(unknown);
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3915
		break;
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3916
	}
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3917
	mode = _MKSMALLINT(buf.st_mode & 0777);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3918
	uid = _MKSMALLINT(buf.st_uid);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3919
	gid = _MKSMALLINT(buf.st_gid);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3920
	size = _MKSMALLINT(buf.st_size);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3921
	id = _MKSMALLINT(buf.st_ino);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3922
	atimeLow = _MKSMALLINT(buf.st_atime & 0xFFFF);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3923
	atimeHi = _MKSMALLINT((buf.st_atime >> 16) & 0xFFFF);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3924
	mtimeLow = _MKSMALLINT(buf.st_mtime & 0xFFFF);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3925
	mtimeHi = _MKSMALLINT((buf.st_mtime >> 16) & 0xFFFF);
329
claus
parents: 322
diff changeset
  3926
	ctimeLow = _MKSMALLINT(buf.st_ctime & 0xFFFF);
claus
parents: 322
diff changeset
  3927
	ctimeHi = _MKSMALLINT((buf.st_ctime >> 16) & 0xFFFF);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3928
    }
329
claus
parents: 322
diff changeset
  3929
%}.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3930
    mode notNil ifTrue:[
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3931
	info := IdentityDictionary new.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3932
	info at:#type put:type.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3933
	info at:#mode put:mode.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3934
	info at:#uid put:uid.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3935
	info at:#gid put:gid.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3936
	info at:#size put:size.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3937
	info at:#id put:id.
329
claus
parents: 322
diff changeset
  3938
	info at:#accessed      put:(AbsoluteTime fromOSTimeLow:atimeLow and:atimeHi).
claus
parents: 322
diff changeset
  3939
	info at:#modified      put:(AbsoluteTime fromOSTimeLow:mtimeLow and:mtimeHi).
claus
parents: 322
diff changeset
  3940
	info at:#statusChanged put:(AbsoluteTime fromOSTimeLow:ctimeLow and:ctimeHi).
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3941
	^ info
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3942
   ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3943
   self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3944
329
claus
parents: 322
diff changeset
  3945
   "
claus
parents: 322
diff changeset
  3946
    OperatingSystem infoOf:'/'
claus
parents: 322
diff changeset
  3947
    (OperatingSystem infoOf:'/') at:#uid
claus
parents: 322
diff changeset
  3948
    (OperatingSystem infoOf:'/') at:#accessed
claus
parents: 322
diff changeset
  3949
   "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3950
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  3951
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3952
accessMaskFor:aSymbol
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3953
    "return the access bits mask for numbers as returned by 
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3954
     OperatingSystem>>accessModeOf:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3955
     and expected by OperatingSystem>>changeAccessModeOf:to:.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3956
     Since these numbers are OS dependent, always use the mask
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3957
     (never hardcode 8rxxx into your code)."
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3958
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3959
%{  /* NOCONTEXT */
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3960
#   ifndef S_IRUSR
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3961
    /* posix systems should define these ... */
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3962
#    define S_IRUSR 0400
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3963
#    define S_IWUSR 0200
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3964
#    define S_IXUSR 0100
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3965
#    define S_IRGRP 0040
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3966
#    define S_IWGRP 0020
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3967
#    define S_IXGRP 0010
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3968
#    define S_IROTH 0004
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3969
#    define S_IWOTH 0002
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3970
#    define S_IXOTH 0001
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3971
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3972
#   endif
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3973
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3974
    if (aSymbol == @symbol(readUser)) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3975
	return _MKSMALLINT(S_IRUSR);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3976
    }
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3977
    if (aSymbol == @symbol(writeUser)) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3978
	return _MKSMALLINT(S_IWUSR);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3979
    }
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3980
    if (aSymbol == @symbol(executeUser)) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3981
	return _MKSMALLINT(S_IXUSR);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3982
    }
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3983
    if (aSymbol == @symbol(readGroup)) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3984
	return _MKSMALLINT(S_IRGRP);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3985
    }
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3986
    if (aSymbol == @symbol(writeGroup)) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3987
	return _MKSMALLINT(S_IWGRP);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3988
    }
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3989
    if (aSymbol == @symbol(executeGroup)) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3990
	return _MKSMALLINT(S_IXGRP);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3991
    }
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3992
    if (aSymbol == @symbol(readOthers)) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3993
	return _MKSMALLINT(S_IROTH);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3994
    }
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3995
    if (aSymbol == @symbol(writeOthers)) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3996
	return _MKSMALLINT(S_IWOTH);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3997
    }
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3998
    if (aSymbol == @symbol(executeOthers)) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  3999
	return _MKSMALLINT(S_IXOTH);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4000
    }
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4001
%}.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4002
    self primitiveFailed
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4003
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4004
    "
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4005
     OperatingSystem accessMaskFor:#readUser
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4006
    "
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4007
!
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4008
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4009
accessModeOf:aPathName
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4010
    "return a number representing access rights rwxrwxrwx for owner,
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4011
     group and others. Return nil if such a file does not exist.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4012
     Notice that the returned number is OS dependent - use the 
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4013
     modeMasks as returned by OperatingSystem>>accessMaskFor:"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4014
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4015
    "
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4016
     this could have been implemented as:
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4017
	(self infoOf:aPathName) at:#mode
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4018
     but for huge directory searches the code below is faster
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4019
    "
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4020
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4021
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4022
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4023
    struct stat buf;
10
claus
parents: 5
diff changeset
  4024
    int ret;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4025
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  4026
    if (__isString(aPathName)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4027
	do {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4028
	    ret = stat((char *) _stringVal(aPathName), &buf);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4029
	} while (ret < 0 && errno == EINTR);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4030
	if (ret < 0) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4031
	    OperatingSystem_LastErrorNumber = _MKSMALLINT(errno);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4032
	    RETURN ( nil );
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4033
	}
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4034
	RETURN ( _MKSMALLINT(buf.st_mode & 0777) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4035
    }
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4036
%}.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4037
   self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4038
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4039
   "
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4040
    (OperatingSystem accessModeOf:'/') printStringRadix:8
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4041
   "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4042
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4043
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4044
changeAccessModeOf:aPathName to:modeBits
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4045
    "change the access rights of aPathName to the OS dependent modeBits.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4046
     You should construct this mask using accessMaskFor, to be OS
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4047
     independent. Return true if changed, 
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4048
     false if such a file does not exist or change was not allowd."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4049
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4050
%{  /* NOCONTEXT */
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4051
    int ret;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4052
252
  4053
    if (__isString(aPathName) && __isSmallInteger(modeBits)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4054
	do {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4055
	    ret = chmod((char *)_stringVal(aPathName), _intVal(modeBits));
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4056
	} while (ret < 0 && errno == EINTR);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4057
	if (ret < 0) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4058
	    OperatingSystem_LastErrorNumber = _MKSMALLINT(errno);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4059
	    RETURN ( false );
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4060
	}
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4061
	RETURN ( true );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4062
    }
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4063
%}.
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4064
    self primitiveFailed
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4065
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4066
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4067
timeOfLastChange:aPathName
2
claus
parents: 1
diff changeset
  4068
    "return the time, when the file was last changed"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4069
329
claus
parents: 322
diff changeset
  4070
    "could be implemented as:
claus
parents: 322
diff changeset
  4071
	(self infoOf:aPathName) at:#modified
claus
parents: 322
diff changeset
  4072
    "
claus
parents: 322
diff changeset
  4073
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4074
    |timeLow timeHi|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4075
%{
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4076
    struct stat buf;
10
claus
parents: 5
diff changeset
  4077
    int ret;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4078
    time_t mtime;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4079
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  4080
    if (__isString(aPathName)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4081
	do {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4082
	    ret = stat((char *) _stringVal(aPathName), &buf);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4083
	} while (ret < 0 && errno == EINTR);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4084
	if (ret >= 0) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4085
	    timeLow = _MKSMALLINT(buf.st_mtime & 0xFFFF);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4086
	    timeHi = _MKSMALLINT((buf.st_mtime >> 16) & 0xFFFF);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4087
	}
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4088
	OperatingSystem_LastErrorNumber = _MKSMALLINT(errno);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4089
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4090
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4091
.
241
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  4092
    timeLow notNil ifTrue:[^ AbsoluteTime fromOSTimeLow:timeLow and:timeHi].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4093
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4094
241
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  4095
    "
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  4096
     OperatingSystem timeOfLastChange:'/'
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  4097
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4098
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4099
2
claus
parents: 1
diff changeset
  4100
timeOfLastAccess:aPathName
claus
parents: 1
diff changeset
  4101
    "return the time, when the file was last accessed"
claus
parents: 1
diff changeset
  4102
329
claus
parents: 322
diff changeset
  4103
    "could be implemented as:
claus
parents: 322
diff changeset
  4104
	(self infoOf:aPathName) at:#accessed 
claus
parents: 322
diff changeset
  4105
    "
2
claus
parents: 1
diff changeset
  4106
    |timeLow timeHi|
claus
parents: 1
diff changeset
  4107
%{
claus
parents: 1
diff changeset
  4108
    struct stat buf;
claus
parents: 1
diff changeset
  4109
    time_t mtime;
10
claus
parents: 5
diff changeset
  4110
    int ret;
2
claus
parents: 1
diff changeset
  4111
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  4112
    if (__isString(aPathName)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4113
	do {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4114
	    ret = stat((char *) _stringVal(aPathName), &buf);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4115
	} while (ret < 0 && errno == EINTR);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4116
	if (ret >= 0) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4117
	    timeLow = _MKSMALLINT(buf.st_atime & 0xFFFF);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4118
	    timeHi = _MKSMALLINT((buf.st_atime >> 16) & 0xFFFF);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4119
	}
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4120
	OperatingSystem_LastErrorNumber = _MKSMALLINT(errno);
2
claus
parents: 1
diff changeset
  4121
    }
claus
parents: 1
diff changeset
  4122
%}
claus
parents: 1
diff changeset
  4123
.
241
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  4124
    timeLow notNil ifTrue:[^ AbsoluteTime fromOSTimeLow:timeLow and:timeHi].
2
claus
parents: 1
diff changeset
  4125
    self primitiveFailed
claus
parents: 1
diff changeset
  4126
241
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  4127
    "
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  4128
     OperatingSystem timeOfLastAccess:'/'
6f30be88e314 *** empty log message ***
claus
parents: 234
diff changeset
  4129
    "
2
claus
parents: 1
diff changeset
  4130
!
claus
parents: 1
diff changeset
  4131
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4132
idOf:aPathName
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4133
    "return the fileNumber (i.e. inode number) of a file"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4134
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4135
    "
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4136
     this could have been implemented as:
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4137
	(self infoOf:aPathName) at:#id 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4138
     but for huge directory searches the code below is faster
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4139
    "
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4140
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4141
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4142
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4143
    struct stat buf;
10
claus
parents: 5
diff changeset
  4144
    int ret;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4145
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  4146
    if (__isString(aPathName)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4147
	do {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4148
	    ret = stat((char *) _stringVal(aPathName), &buf);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4149
	} while (ret < 0 && errno == EINTR);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4150
	if (ret >= 0) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4151
	    RETURN (_MKSMALLINT(buf.st_ino));
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4152
	}
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4153
	OperatingSystem_LastErrorNumber = _MKSMALLINT(errno);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4154
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4155
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4156
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4157
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4158
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4159
    "OperatingSystem idOf:'/'"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4160
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4161
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4162
typeOf:aPathName
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4163
    "return the type of a file as a symbol"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4164
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4165
    "
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4166
     this could have been implemented as:
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4167
	(self infoOf:aPathName) at:#type 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4168
     but for huge directory searches the code below is faster
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4169
    "
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4170
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4171
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4172
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4173
    struct stat buf;
10
claus
parents: 5
diff changeset
  4174
    int ret;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4175
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  4176
    if (__isString(aPathName)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4177
	do {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4178
	    ret = stat((char *) _stringVal(aPathName), &buf);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4179
	} while (ret < 0 && errno == EINTR);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4180
	if (ret < 0) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4181
	    OperatingSystem_LastErrorNumber = _MKSMALLINT(errno);
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4182
	    RETURN ( nil );
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4183
	}
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4184
	switch (buf.st_mode & S_IFMT) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4185
	    case S_IFDIR:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4186
		RETURN ( @symbol(directory) );
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4187
	    case S_IFCHR:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4188
		RETURN ( @symbol(characterSpecial) );
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4189
	    case S_IFBLK:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4190
		RETURN ( @symbol(blockSpecial) );
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4191
	    case S_IFREG:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4192
		RETURN ( @symbol(regular) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4193
#ifdef S_IFLNK
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4194
	    case S_IFLNK:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4195
		RETURN ( @symbol(symbolicLink) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4196
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4197
#ifdef S_IFSOCK
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4198
	    case S_IFSOCK:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4199
		RETURN ( @symbol(socket) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4200
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4201
#ifdef S_IFIFO
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4202
	    case S_IFIFO:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4203
		RETURN ( @symbol(fifo) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4204
#endif
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4205
	    default:
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4206
		RETURN ( @symbol(unknown) );
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4207
	}
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4208
    }
329
claus
parents: 322
diff changeset
  4209
%}.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4210
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4211
329
claus
parents: 322
diff changeset
  4212
    "
claus
parents: 322
diff changeset
  4213
     OperatingSystem typeOf:'/' 
claus
parents: 322
diff changeset
  4214
     OperatingSystem typeOf:'.' 
claus
parents: 322
diff changeset
  4215
     OperatingSystem typeOf:'Make.proto' 
claus
parents: 322
diff changeset
  4216
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4217
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4218
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4219
createDirectory:newPathName
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4220
    "create a new directory with name 'newPathName'.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4221
     Return true if successful, false if failed."
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4222
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4223
    "since createDirectory is not used too often,
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4224
     you'll forgive me using mkdir ..."
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4225
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4226
    ^ self executeCommand:('mkdir ' , newPathName)
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4227
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4228
    "OperatingSystem createDirectory:'foo'"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4229
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4230
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4231
recursiveCreateDirectory:dirName
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4232
    "create a directory - with all parent dirs if needed.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4233
     Return true if successful, false otherwise. If false
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4234
     is returned, a partial created tree may be left,
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4235
     which is not cleaned-up here."
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4236
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4237
    self createDirectory:dirName.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4238
    (self isDirectory:dirName) ifFalse:[
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4239
	(self recursiveCreateDirectory:(self directoryNameOf:dirName)) ifFalse:[^ false].
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4240
	^ self createDirectory:dirName
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4241
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4242
    ^ (self isDirectory:dirName)
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4243
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4244
    "OperatingSystem recursiveCreateDirectory:'foo/bar/baz'"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4245
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4246
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4247
removeFile:fullPathName
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4248
    "remove the file named 'fullPathName'; return true if successful"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4249
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4250
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4251
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  4252
    if (__isString(fullPathName)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4253
	RETURN ( (unlink((char *) _stringVal(fullPathName)) >= 0) ? true : false );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4254
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4255
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4256
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4257
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4258
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4259
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4260
removeDirectory:fullPathName
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4261
    "remove the directory named 'fullPathName'.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4262
     Return true if successful, false if directory is not empty or no permission"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4263
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4264
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4265
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  4266
    if (__isString(fullPathName)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4267
	RETURN ( (rmdir((char *) _stringVal(fullPathName)) >= 0) ? true : false );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4268
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4269
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4270
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4271
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4272
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4273
18
e0994bb28ef5 added recursive rmdir
claus
parents: 17
diff changeset
  4274
recursiveRemoveDirectory:fullPathName
e0994bb28ef5 added recursive rmdir
claus
parents: 17
diff changeset
  4275
    "remove the directory named 'fullPathName' and all contained files/directories.
e0994bb28ef5 added recursive rmdir
claus
parents: 17
diff changeset
  4276
     Return true if successful."
e0994bb28ef5 added recursive rmdir
claus
parents: 17
diff changeset
  4277
e0994bb28ef5 added recursive rmdir
claus
parents: 17
diff changeset
  4278
    ^ self executeCommand:('rm -rf ' , fullPathName)
e0994bb28ef5 added recursive rmdir
claus
parents: 17
diff changeset
  4279
!
e0994bb28ef5 added recursive rmdir
claus
parents: 17
diff changeset
  4280
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  4281
linkFile:oldPath to:newPath
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4282
    "link the file 'oldPath' to 'newPath'. The link will be a hard link.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4283
     Return true if successful, false if not."
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4284
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4285
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4286
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  4287
    if (__isString(oldPath) && __isString(newPath)) {
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4288
	RETURN ( (link((char *) _stringVal(oldPath), (char *) _stringVal(newPath)) >= 0) ?
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4289
				true : false );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4290
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4291
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4292
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4293
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4294
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  4295
    "OperatingSystem linkFile:'foo' to:'bar'"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4296
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4297
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  4298
renameFile:oldPath to:newPath
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4299
    "rename the file 'oldPath' to 'newPath'. 
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4300
     Return true if sucessfull, false if not"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4301
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4302
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4303
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  4304
    if (__isString(oldPath) && __isString(newPath)) {
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  4305
#if defined(HAS_RENAME)
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4306
	if (rename((char *) _stringVal(oldPath), (char *) _stringVal(newPath)) >= 0) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4307
	    RETURN ( true );
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4308
	}
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4309
#else
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4310
	if (link((char *) _stringVal(oldPath), (char *) _stringVal(newPath)) >= 0) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4311
	    if (unlink((char *) _stringVal(oldPath)) >= 0) {
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4312
		RETURN ( true );
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4313
	    }
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4314
	    unlink((char *) _stringVal(newPath));
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4315
	}
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4316
#endif
185
d9be85c4cfe4 more functions
claus
parents: 123
diff changeset
  4317
	RETURN ( false );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4318
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4319
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4320
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4321
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4322
63
1f0cdefb013f *** empty log message ***
claus
parents: 51
diff changeset
  4323
    "OperatingSystem renameFile:'foo' to:'bar'"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4324
! !