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