FileStream.st
author claus
Tue, 17 May 1994 12:09:46 +0200
changeset 77 6c38ca59927f
parent 68 59faa75185ba
child 85 1343af456e28
permissions -rw-r--r--
*** empty log message ***
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) 1989 by Claus Gittinger
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     3
              All Rights Reserved
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
ExternalStream subclass:#FileStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
    14
       instanceVariableNames:'pathName'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    15
       classVariableNames:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    16
       poolDictionaries:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    17
       category:'Streams-External'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    18
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
a27a279701f8 Initial revision
claus
parents:
diff changeset
    20
FileStream comment:'
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
    21
COPYRIGHT (c) 1989 by Claus Gittinger
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    22
              All Rights Reserved
a27a279701f8 Initial revision
claus
parents:
diff changeset
    23
a27a279701f8 Initial revision
claus
parents:
diff changeset
    24
This class provides access to the operating systems underlying file
a27a279701f8 Initial revision
claus
parents:
diff changeset
    25
system (i.e. its an interface to the stdio library).
a27a279701f8 Initial revision
claus
parents:
diff changeset
    26
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    27
$Header: /cvs/stx/stx/libbasic/FileStream.st,v 1.11 1994-05-17 10:07:32 claus Exp $
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    28
'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    29
a27a279701f8 Initial revision
claus
parents:
diff changeset
    30
%{
a27a279701f8 Initial revision
claus
parents:
diff changeset
    31
#include <stdio.h>
10
claus
parents: 5
diff changeset
    32
#include <errno.h>
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    33
a27a279701f8 Initial revision
claus
parents:
diff changeset
    34
#ifdef transputer
a27a279701f8 Initial revision
claus
parents:
diff changeset
    35
# include <iocntrl.h>
a27a279701f8 Initial revision
claus
parents:
diff changeset
    36
# ifndef fileno
a27a279701f8 Initial revision
claus
parents:
diff changeset
    37
   /* kludge: inmos forgot fileno */
a27a279701f8 Initial revision
claus
parents:
diff changeset
    38
#  define fileno(f)     ((f)->__file)
a27a279701f8 Initial revision
claus
parents:
diff changeset
    39
# endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
    40
#else
a27a279701f8 Initial revision
claus
parents:
diff changeset
    41
# include <sys/types.h>
a27a279701f8 Initial revision
claus
parents:
diff changeset
    42
# include <sys/stat.h>
a27a279701f8 Initial revision
claus
parents:
diff changeset
    43
#endif
10
claus
parents: 5
diff changeset
    44
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
    45
#ifdef hpux
68
59faa75185ba *** empty log message ***
claus
parents: 49
diff changeset
    46
# define fileno(f)      ((f->__fileH << 8) | (f->__fileL))
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
    47
#endif
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
    48
10
claus
parents: 5
diff changeset
    49
#ifndef SEEK_SET
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
    50
# define SEEK_SET       0
10
claus
parents: 5
diff changeset
    51
#endif
claus
parents: 5
diff changeset
    52
#ifndef SEEK_CUR
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
    53
# define SEEK_CUR       1
10
claus
parents: 5
diff changeset
    54
#endif
claus
parents: 5
diff changeset
    55
#ifndef SEEK_END
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
    56
# define SEEK_END       2
10
claus
parents: 5
diff changeset
    57
#endif
claus
parents: 5
diff changeset
    58
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    59
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
    60
a27a279701f8 Initial revision
claus
parents:
diff changeset
    61
!FileStream class methodsFor:'instance creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    62
a27a279701f8 Initial revision
claus
parents:
diff changeset
    63
newFileNamed:filename
a27a279701f8 Initial revision
claus
parents:
diff changeset
    64
    "return a FileStream for new file named filename, aString.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    65
     If the file exists, it is truncated, otherwise created.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    66
     The file is opened for write access only."
a27a279701f8 Initial revision
claus
parents:
diff changeset
    67
a27a279701f8 Initial revision
claus
parents:
diff changeset
    68
    |newStream|
2
claus
parents: 1
diff changeset
    69
    newStream := self new pathName:filename.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    70
    newStream createForReadWrite isNil ifTrue:[^nil].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    71
    ^ newStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
    72
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    73
a27a279701f8 Initial revision
claus
parents:
diff changeset
    74
newFileNamed:filename in:aDirectory
a27a279701f8 Initial revision
claus
parents:
diff changeset
    75
    "return a FileStream for new file named filename, aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
    76
     in aDirectory, a FileDirectory.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    77
     If the file exists, it is truncated, otherwise created.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    78
     The file is opened for write access only."
a27a279701f8 Initial revision
claus
parents:
diff changeset
    79
a27a279701f8 Initial revision
claus
parents:
diff changeset
    80
    |newStream|
2
claus
parents: 1
diff changeset
    81
    newStream := self new pathName:filename in:aDirectory.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    82
    newStream createForReadWrite isNil ifTrue:[^nil].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    83
    ^ newStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
    84
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    85
a27a279701f8 Initial revision
claus
parents:
diff changeset
    86
oldFileNamed:filename
a27a279701f8 Initial revision
claus
parents:
diff changeset
    87
    "return a FileStream for existing file named filename, aString.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    88
     The file is opened for read/write access."
a27a279701f8 Initial revision
claus
parents:
diff changeset
    89
a27a279701f8 Initial revision
claus
parents:
diff changeset
    90
    |newStream|
a27a279701f8 Initial revision
claus
parents:
diff changeset
    91
a27a279701f8 Initial revision
claus
parents:
diff changeset
    92
    (OperatingSystem isReadable:filename) ifFalse:[^nil].
2
claus
parents: 1
diff changeset
    93
    newStream := self new pathName:filename.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    94
    newStream readwrite.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    95
    newStream openForReadWrite isNil ifTrue:[^nil].
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
    96
"
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
    97
    this is not a good idea; someone else might be appending ...
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
    98
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    99
    newStream readLimit:(newStream size).
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   100
"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   101
    ^ newStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   102
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   103
a27a279701f8 Initial revision
claus
parents:
diff changeset
   104
oldFileNamed:filename in:aDirectory
a27a279701f8 Initial revision
claus
parents:
diff changeset
   105
    "return a FileStream for existing file named filename, aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   106
     in aDirectory, a FileDirectory.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   107
     The file is opened for read/write access."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   108
a27a279701f8 Initial revision
claus
parents:
diff changeset
   109
    |newStream|
2
claus
parents: 1
diff changeset
   110
    newStream := self new pathName:filename in:aDirectory.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   111
    newStream openForReadWrite isNil ifTrue:[^nil].
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   112
"
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   113
    this is not a good idea; someone else might be appending ...
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   114
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   115
    newStream readLimit:(newStream size).
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   116
"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   117
    ^ newStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   118
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   119
a27a279701f8 Initial revision
claus
parents:
diff changeset
   120
fileNamed:filename
a27a279701f8 Initial revision
claus
parents:
diff changeset
   121
    "return a stream on file filename - if the file does not
a27a279701f8 Initial revision
claus
parents:
diff changeset
   122
     already exist, create it."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   123
a27a279701f8 Initial revision
claus
parents:
diff changeset
   124
    |stream|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   125
a27a279701f8 Initial revision
claus
parents:
diff changeset
   126
    stream := self oldFileNamed:filename.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   127
    stream isNil ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   128
        stream := self newFileNamed:filename
a27a279701f8 Initial revision
claus
parents:
diff changeset
   129
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   130
    ^ stream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   131
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   132
a27a279701f8 Initial revision
claus
parents:
diff changeset
   133
fileNamed:filename in:aDirectory
a27a279701f8 Initial revision
claus
parents:
diff changeset
   134
    "return a stream on file filename - if the file does not
a27a279701f8 Initial revision
claus
parents:
diff changeset
   135
     already exist, create it."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   136
a27a279701f8 Initial revision
claus
parents:
diff changeset
   137
    |stream|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   138
a27a279701f8 Initial revision
claus
parents:
diff changeset
   139
    stream := self oldFileNamed:filename in:aDirectory.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   140
    stream isNil ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   141
        stream := self newFileNamed:filename in:aDirectory
a27a279701f8 Initial revision
claus
parents:
diff changeset
   142
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   143
    ^ stream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   144
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   145
a27a279701f8 Initial revision
claus
parents:
diff changeset
   146
readonlyFileNamed:filename
a27a279701f8 Initial revision
claus
parents:
diff changeset
   147
    "return a readonly FileStream for existing file named filename, aString"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   148
a27a279701f8 Initial revision
claus
parents:
diff changeset
   149
    |newStream|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   150
a27a279701f8 Initial revision
claus
parents:
diff changeset
   151
    (OperatingSystem isReadable:filename) ifFalse:[^nil].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   152
2
claus
parents: 1
diff changeset
   153
    newStream := self new pathName:filename.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   154
    newStream openForReading isNil ifTrue:[^nil].
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   155
"
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   156
    this is not a good idea; someone else might be appending ...
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   157
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   158
    newStream readLimit:(newStream size).
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   159
"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   160
    ^ newStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   161
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   162
a27a279701f8 Initial revision
claus
parents:
diff changeset
   163
readonlyFileNamed:filename in:aDirectory
a27a279701f8 Initial revision
claus
parents:
diff changeset
   164
    "return a readonly FileStream for existing file named filename, aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   165
     in aDirectory, a FileDirectory"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   166
a27a279701f8 Initial revision
claus
parents:
diff changeset
   167
    |newStream|
2
claus
parents: 1
diff changeset
   168
    newStream := self new pathName:filename in:aDirectory.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   169
    newStream openForReading isNil ifTrue:[^nil].
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   170
"
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   171
    this is not a good idea; someone else might be appending ...
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   172
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   173
    newStream readLimit:(newStream size).
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   174
"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   175
    ^ newStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   176
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   177
a27a279701f8 Initial revision
claus
parents:
diff changeset
   178
appendingOldFileNamed:filename
a27a279701f8 Initial revision
claus
parents:
diff changeset
   179
    "return a FileStream for existing file named filename, aString"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   180
a27a279701f8 Initial revision
claus
parents:
diff changeset
   181
    |newStream|
2
claus
parents: 1
diff changeset
   182
    newStream := self new pathName:filename.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   183
    newStream openForAppending isNil ifTrue:[^nil].
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   184
"
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   185
    this is not a good idea; I might like to read the written stuff ...
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   186
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   187
    newStream readLimit:(newStream size).
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   188
"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   189
    ^ newStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   190
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   191
a27a279701f8 Initial revision
claus
parents:
diff changeset
   192
appendingOldFileNamed:filename in:aDirectory
a27a279701f8 Initial revision
claus
parents:
diff changeset
   193
    "return a FileStream for existing file named filename, aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   194
     in aDirectory, a FileDirectory"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   195
a27a279701f8 Initial revision
claus
parents:
diff changeset
   196
    |newStream|
2
claus
parents: 1
diff changeset
   197
    newStream := self new pathName:filename in:aDirectory.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   198
    newStream openForAppending isNil ifTrue:[^nil].
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   199
"
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   200
    this is not a good idea; I might like to read the written stuff ...
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   201
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   202
    newStream readLimit:(newStream size).
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   203
"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   204
    ^ newStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   205
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   206
a27a279701f8 Initial revision
claus
parents:
diff changeset
   207
!FileStream methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   208
a27a279701f8 Initial revision
claus
parents:
diff changeset
   209
store:something
a27a279701f8 Initial revision
claus
parents:
diff changeset
   210
    "what really should this do"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   211
31
75f2b9f78be2 *** empty log message ***
claus
parents: 13
diff changeset
   212
    self nextPutAll:something storeString
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   213
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   214
a27a279701f8 Initial revision
claus
parents:
diff changeset
   215
directoryName
a27a279701f8 Initial revision
claus
parents:
diff changeset
   216
    "return the name of the directory I'm in"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   217
a27a279701f8 Initial revision
claus
parents:
diff changeset
   218
    |path lastIndex index|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   219
a27a279701f8 Initial revision
claus
parents:
diff changeset
   220
    path := pathName.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   221
    lastIndex := 0.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   222
    index := path indexOf:$/.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   223
    [index ~~ 0] whileTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   224
        lastIndex := index.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   225
        index := path indexOf:$/ startingAt:(index + 1)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   226
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   227
    (lastIndex == 0) ifTrue:[^ '.'].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   228
    (lastIndex == 1) ifTrue:[^ '/'].
31
75f2b9f78be2 *** empty log message ***
claus
parents: 13
diff changeset
   229
    ^ path copyTo:(lastIndex - 1)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   230
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   231
a27a279701f8 Initial revision
claus
parents:
diff changeset
   232
name
a27a279701f8 Initial revision
claus
parents:
diff changeset
   233
    "return my name without leading direcory-path"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   234
a27a279701f8 Initial revision
claus
parents:
diff changeset
   235
    |lastIndex index|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   236
a27a279701f8 Initial revision
claus
parents:
diff changeset
   237
    lastIndex := 1.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   238
    [true] whileTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   239
        index := pathName indexOf:$/ startingAt:lastIndex.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   240
        (index == 0) ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   241
            ^ pathName copyFrom:lastIndex
a27a279701f8 Initial revision
claus
parents:
diff changeset
   242
        ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   243
        lastIndex := index + 1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   244
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   245
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   246
a27a279701f8 Initial revision
claus
parents:
diff changeset
   247
pathName
a27a279701f8 Initial revision
claus
parents:
diff changeset
   248
    "return the pathname"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   249
a27a279701f8 Initial revision
claus
parents:
diff changeset
   250
    ^ pathName
a27a279701f8 Initial revision
claus
parents:
diff changeset
   251
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   252
a27a279701f8 Initial revision
claus
parents:
diff changeset
   253
!FileStream methodsFor:'private'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   254
a27a279701f8 Initial revision
claus
parents:
diff changeset
   255
pathName:filename
a27a279701f8 Initial revision
claus
parents:
diff changeset
   256
    "set the pathname"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   257
a27a279701f8 Initial revision
claus
parents:
diff changeset
   258
    pathName := filename
a27a279701f8 Initial revision
claus
parents:
diff changeset
   259
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   260
a27a279701f8 Initial revision
claus
parents:
diff changeset
   261
pathName:filename in:aDirectory
a27a279701f8 Initial revision
claus
parents:
diff changeset
   262
    "set the pathname starting at aDirectory, a FileDirectory"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   263
a27a279701f8 Initial revision
claus
parents:
diff changeset
   264
    ((filename at:1) == $/) ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   265
        "filename may not start with a '/'"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   266
        pathName := nil
a27a279701f8 Initial revision
claus
parents:
diff changeset
   267
    ] ifFalse:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   268
        pathName := aDirectory pathName.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   269
        (pathName endsWith:'/') ifFalse:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   270
            pathName := pathName , '/'
a27a279701f8 Initial revision
claus
parents:
diff changeset
   271
        ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   272
        pathName := pathName , filename
a27a279701f8 Initial revision
claus
parents:
diff changeset
   273
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   274
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   275
a27a279701f8 Initial revision
claus
parents:
diff changeset
   276
open
a27a279701f8 Initial revision
claus
parents:
diff changeset
   277
    "open the file"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   278
a27a279701f8 Initial revision
claus
parents:
diff changeset
   279
    pathName isNil ifTrue:[^nil].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   280
    (mode == #readonly) ifTrue: [
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   281
        ^ self openWithMode:'r'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   282
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   283
    (mode == #writeonly) ifTrue: [
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   284
        ^ self openWithMode:'w'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   285
    ].
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   286
    ^ self openWithMode:'r+'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   287
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   288
a27a279701f8 Initial revision
claus
parents:
diff changeset
   289
openWithMode:openmode
a27a279701f8 Initial revision
claus
parents:
diff changeset
   290
    "open the file; openmode is the string defining the way to open"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   291
a27a279701f8 Initial revision
claus
parents:
diff changeset
   292
    |retVal|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   293
%{
a27a279701f8 Initial revision
claus
parents:
diff changeset
   294
    FILE *f;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   295
    OBJ path;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   296
    extern OBJ ErrorNumber, Filename;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   297
    extern errno;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   298
a27a279701f8 Initial revision
claus
parents:
diff changeset
   299
    if (_INST(filePointer) == nil) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   300
        path = _INST(pathName);
10
claus
parents: 5
diff changeset
   301
        if (path != nil 
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   302
         && ((_qClass(path)==String) || (_qClass(path) == Filename))) {
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   303
            do {
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   304
#ifdef LINUX
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   305
                /* LINUX returns a non-NULL f even when interrupted */
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   306
                errno = 0;
49
f1c2d75f2eb6 *** empty log message ***
claus
parents: 42
diff changeset
   307
                f = (FILE *) fopen((char *) _stringVal(path), (char *) _stringVal(openmode));
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   308
                if (errno == EINTR)
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   309
                    f = NULL;
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   310
#else
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   311
49
f1c2d75f2eb6 *** empty log message ***
claus
parents: 42
diff changeset
   312
                f = (FILE *) fopen((char *) _stringVal(path), (char *) _stringVal(openmode));
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   313
#endif
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   314
            } while ((f == NULL) && (errno == EINTR));
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   315
            if (f == NULL) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   316
                ErrorNumber = _MKSMALLINT(errno);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   317
                _INST(position) = nil;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   318
            } else {
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   319
                _INST(filePointer) = MKOBJ((int)f);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   320
                _INST(position) = _MKSMALLINT(1);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   321
                retVal = self;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   322
            }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   323
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   324
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   325
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   326
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   327
    retVal notNil ifTrue:[
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   328
        buffered := true.       "default is buffered"
31
75f2b9f78be2 *** empty log message ***
claus
parents: 13
diff changeset
   329
        Lobby register:self
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   330
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   331
    ^ retVal
a27a279701f8 Initial revision
claus
parents:
diff changeset
   332
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   333
a27a279701f8 Initial revision
claus
parents:
diff changeset
   334
openForReading
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   335
    "open the file for readonly.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   336
     If the file does not exist its an error, return nil; 
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   337
     otherwise return the receiver."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   338
a27a279701f8 Initial revision
claus
parents:
diff changeset
   339
    mode := #readonly.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   340
    ^ self openWithMode:'r'
a27a279701f8 Initial revision
claus
parents:
diff changeset
   341
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   342
a27a279701f8 Initial revision
claus
parents:
diff changeset
   343
openForWriting
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   344
    "open the file writeonly.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   345
     If the file does not exist its an error, return nil; 
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   346
     otherwise return the receiver."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   347
a27a279701f8 Initial revision
claus
parents:
diff changeset
   348
    mode := #writeonly.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   349
    ^ self openWithMode:'r+'   "unix-io does not allow this; open for update here"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   350
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   351
a27a279701f8 Initial revision
claus
parents:
diff changeset
   352
openForAppending
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   353
    "open the file for writeonly appending to the end.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   354
     If the file does not exist its an error, return nil; 
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   355
     otherwise return the receiver."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   356
a27a279701f8 Initial revision
claus
parents:
diff changeset
   357
    mode := #writeonly.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   358
    ^ self openWithMode:'a+'
a27a279701f8 Initial revision
claus
parents:
diff changeset
   359
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   360
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   361
openForReadWrite
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   362
    "open the file for read/write.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   363
     If the file does not exist its an error, return nil; 
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   364
     otherwise return the receiver."
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   365
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   366
    mode := #readwrite.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   367
    ^ self openWithMode:'r+'
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   368
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   369
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   370
createForWriting
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   371
    "create/truncate the file for writeonly.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   372
     If the file existed, its truncated; otherwise its created."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   373
a27a279701f8 Initial revision
claus
parents:
diff changeset
   374
    mode := #writeonly.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   375
    ^ self openWithMode:'w'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   376
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   377
a27a279701f8 Initial revision
claus
parents:
diff changeset
   378
createForReadWrite
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   379
    "create/truncate the file for read/write.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   380
     If the file existed, its truncated; otherwise its created."
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   381
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   382
a27a279701f8 Initial revision
claus
parents:
diff changeset
   383
    mode := #readwrite.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   384
    ^ self openWithMode:'w+'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   385
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   386
a27a279701f8 Initial revision
claus
parents:
diff changeset
   387
reOpen
a27a279701f8 Initial revision
claus
parents:
diff changeset
   388
    "sent after snapin to reopen streams"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   389
a27a279701f8 Initial revision
claus
parents:
diff changeset
   390
    filePointer notNil ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   391
        "it was open, when snapped-out"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   392
        filePointer := nil.
31
75f2b9f78be2 *** empty log message ***
claus
parents: 13
diff changeset
   393
        Lobby unregister:self.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   394
        self open.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   395
        filePointer isNil ifTrue:[
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   396
            "this happens, if after a restart, the file is no longer accessable ..."
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   397
68
59faa75185ba *** empty log message ***
claus
parents: 49
diff changeset
   398
            ('could not reopen file: ', pathName) errorPrintNewline.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   399
        ] ifFalse:[
2
claus
parents: 1
diff changeset
   400
            self position:position.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   401
        ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   402
    ]
31
75f2b9f78be2 *** empty log message ***
claus
parents: 13
diff changeset
   403
! !
75f2b9f78be2 *** empty log message ***
claus
parents: 13
diff changeset
   404
75f2b9f78be2 *** empty log message ***
claus
parents: 13
diff changeset
   405
!FileStream methodsFor:'queries'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   406
a27a279701f8 Initial revision
claus
parents:
diff changeset
   407
size
a27a279701f8 Initial revision
claus
parents:
diff changeset
   408
    "return the size in bytes of the file"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   409
a27a279701f8 Initial revision
claus
parents:
diff changeset
   410
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   411
a27a279701f8 Initial revision
claus
parents:
diff changeset
   412
#ifdef transputer
a27a279701f8 Initial revision
claus
parents:
diff changeset
   413
    FILE *f;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   414
    int size;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   415
a27a279701f8 Initial revision
claus
parents:
diff changeset
   416
    if (_INST(filePointer) != nil) {
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   417
        f = (FILE *)MKFD(_INST(filePointer));
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   418
        if ((size = filesize(fileno(f))) >= 0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   419
            RETURN ( _MKSMALLINT(size) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   420
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   421
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   422
#else
a27a279701f8 Initial revision
claus
parents:
diff changeset
   423
    FILE *f;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   424
    struct stat buf;
10
claus
parents: 5
diff changeset
   425
    int ret;
claus
parents: 5
diff changeset
   426
    extern errno;
claus
parents: 5
diff changeset
   427
    extern OBJ ErrorNumber;
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   428
    int fd;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   429
a27a279701f8 Initial revision
claus
parents:
diff changeset
   430
    if (_INST(filePointer) != nil) {
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   431
        f = (FILE *)MKFD(_INST(filePointer));
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   432
        fd = fileno(f);
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   433
        do {
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   434
            ret = fstat(fd, &buf);
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   435
        } while ((ret < 0) && (errno == EINTR));
10
claus
parents: 5
diff changeset
   436
        if (ret >= 0) {
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   437
            RETURN ( _MKSMALLINT(buf.st_size) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   438
        }
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   439
        ErrorNumber = _MKSMALLINT(errno);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   440
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   441
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   442
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   443
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   444
    "could add a fall-back here:
a27a279701f8 Initial revision
claus
parents:
diff changeset
   445
a27a279701f8 Initial revision
claus
parents:
diff changeset
   446
        oldPosition := self position.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   447
        self setToEnd.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   448
        sz := self position.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   449
        self position:oldPosition.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   450
        ^ sz
a27a279701f8 Initial revision
claus
parents:
diff changeset
   451
    "
a27a279701f8 Initial revision
claus
parents:
diff changeset
   452
    filePointer isNil ifTrue:[^ self errorNotOpen].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   453
    ^ self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
   454
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   455
a27a279701f8 Initial revision
claus
parents:
diff changeset
   456
position
a27a279701f8 Initial revision
claus
parents:
diff changeset
   457
    "return the read/write position in the file -
31
75f2b9f78be2 *** empty log message ***
claus
parents: 13
diff changeset
   458
     notice, in smalltalk indices start at 1 so begin of file is 1"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   459
a27a279701f8 Initial revision
claus
parents:
diff changeset
   460
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   461
a27a279701f8 Initial revision
claus
parents:
diff changeset
   462
    FILE *f;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   463
    long currentPosition;
10
claus
parents: 5
diff changeset
   464
    extern errno;
claus
parents: 5
diff changeset
   465
    extern OBJ ErrorNumber;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   466
a27a279701f8 Initial revision
claus
parents:
diff changeset
   467
    if (_INST(filePointer) != nil) {
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   468
        f = (FILE *)MKFD(_INST(filePointer));
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   469
        do {
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   470
            if (_INST(buffered) == true) {
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   471
                currentPosition = (long) ftell(f);
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   472
            } else {
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   473
                currentPosition = (long) lseek(fileno(f), 0L, SEEK_CUR);
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   474
            }
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   475
        } while ((currentPosition < 0) && (errno == EINTR));
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   476
        if (currentPosition >= 0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   477
            /*
a27a279701f8 Initial revision
claus
parents:
diff changeset
   478
             * notice: Smalltalk index starts at 1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   479
             */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   480
            RETURN ( _MKSMALLINT(currentPosition + 1) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   481
        }
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   482
        ErrorNumber = _MKSMALLINT(errno);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   483
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   484
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   485
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   486
    filePointer isNil ifTrue:[^ self errorNotOpen].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   487
    ^ self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
   488
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   489
a27a279701f8 Initial revision
claus
parents:
diff changeset
   490
position:newPos
a27a279701f8 Initial revision
claus
parents:
diff changeset
   491
    "set the read/write position in the file"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   492
a27a279701f8 Initial revision
claus
parents:
diff changeset
   493
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   494
a27a279701f8 Initial revision
claus
parents:
diff changeset
   495
    FILE *f;
10
claus
parents: 5
diff changeset
   496
    int ret;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   497
    extern OBJ ErrorNumber;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   498
    extern errno;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   499
a27a279701f8 Initial revision
claus
parents:
diff changeset
   500
    if (_INST(filePointer) != nil) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   501
        if (_isSmallInteger(newPos)) {
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   502
            f = (FILE *)MKFD(_INST(filePointer));
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   503
            /*
a27a279701f8 Initial revision
claus
parents:
diff changeset
   504
             * notice: Smalltalk index starts at 1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   505
             */
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   506
            do {
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   507
                if (_INST(buffered) == true) {
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   508
                    ret = fseek(f, (long) (_intVal(newPos) - 1), SEEK_SET);
10
claus
parents: 5
diff changeset
   509
                } else {
42
e33491f6f260 *** empty log message ***
claus
parents: 31
diff changeset
   510
                    ret = (long) lseek(fileno(f), (long)(_intVal(newPos) - 1), SEEK_SET);
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   511
                }
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   512
            } while ((ret < 0) && (errno == EINTR));
10
claus
parents: 5
diff changeset
   513
            if (ret >= 0) {
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   514
                _INST(position) = newPos;
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   515
                /*
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   516
                 * just to make certain ...
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   517
                 */
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   518
                _INST(hitEOF) = false;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   519
                RETURN ( self );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   520
            }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   521
            ErrorNumber = _MKSMALLINT(errno);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   522
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   523
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   524
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   525
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   526
    filePointer isNil ifTrue:[^ self errorNotOpen].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   527
    ^ self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
   528
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   529
a27a279701f8 Initial revision
claus
parents:
diff changeset
   530
setToEnd
a27a279701f8 Initial revision
claus
parents:
diff changeset
   531
    "set the read/write position in the file to be at the end of the file"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   532
a27a279701f8 Initial revision
claus
parents:
diff changeset
   533
%{
a27a279701f8 Initial revision
claus
parents:
diff changeset
   534
    FILE *f;
10
claus
parents: 5
diff changeset
   535
    int ret;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   536
    extern OBJ ErrorNumber;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   537
    extern errno;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   538
49
f1c2d75f2eb6 *** empty log message ***
claus
parents: 42
diff changeset
   539
    if (_INST(filePointer) != nil) {
f1c2d75f2eb6 *** empty log message ***
claus
parents: 42
diff changeset
   540
        f = (FILE *)MKFD(_INST(filePointer));
f1c2d75f2eb6 *** empty log message ***
claus
parents: 42
diff changeset
   541
        _INST(position) = nil;
f1c2d75f2eb6 *** empty log message ***
claus
parents: 42
diff changeset
   542
        do {
f1c2d75f2eb6 *** empty log message ***
claus
parents: 42
diff changeset
   543
            if (_INST(buffered) == true) {
f1c2d75f2eb6 *** empty log message ***
claus
parents: 42
diff changeset
   544
                ret = fseek(f, 0L, SEEK_END);
f1c2d75f2eb6 *** empty log message ***
claus
parents: 42
diff changeset
   545
            } else {
f1c2d75f2eb6 *** empty log message ***
claus
parents: 42
diff changeset
   546
                ret = (long)lseek(fileno(f), 0L, SEEK_END);
f1c2d75f2eb6 *** empty log message ***
claus
parents: 42
diff changeset
   547
            }
f1c2d75f2eb6 *** empty log message ***
claus
parents: 42
diff changeset
   548
        } while ((ret < 0) && (errno == EINTR));
f1c2d75f2eb6 *** empty log message ***
claus
parents: 42
diff changeset
   549
        if (ret >= 0) {
f1c2d75f2eb6 *** empty log message ***
claus
parents: 42
diff changeset
   550
            RETURN ( self );
10
claus
parents: 5
diff changeset
   551
        }
49
f1c2d75f2eb6 *** empty log message ***
claus
parents: 42
diff changeset
   552
        ErrorNumber = _MKSMALLINT(errno);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   553
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   554
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   555
.
49
f1c2d75f2eb6 *** empty log message ***
claus
parents: 42
diff changeset
   556
    filePointer isNil ifTrue:[^ self errorNotOpen].
f1c2d75f2eb6 *** empty log message ***
claus
parents: 42
diff changeset
   557
    DemoMode ifTrue:[^ self warn:'no save in Demo mode'].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   558
    ^ self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
   559
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   560
2
claus
parents: 1
diff changeset
   561
!FileStream methodsFor:'testing'!
claus
parents: 1
diff changeset
   562
claus
parents: 1
diff changeset
   563
isFileStream
claus
parents: 1
diff changeset
   564
    "return true, if the receiver is some kind of fileStream.
claus
parents: 1
diff changeset
   565
     redefined from Object"
claus
parents: 1
diff changeset
   566
claus
parents: 1
diff changeset
   567
    ^ true
claus
parents: 1
diff changeset
   568
! !
claus
parents: 1
diff changeset
   569
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   570
!FileStream methodsFor:'printing & storing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   571
a27a279701f8 Initial revision
claus
parents:
diff changeset
   572
printOn:aStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   573
    aStream nextPutAll:'(a FileStream for:'.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   574
    aStream nextPutAll:pathName.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   575
    aStream nextPut:$)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   576
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   577
a27a279701f8 Initial revision
claus
parents:
diff changeset
   578
storeOn:aStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   579
    aStream nextPutAll:'(FileStream oldFileNamed:'.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   580
    aStream nextPutAll:pathName.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   581
    (self position ~~ 1) ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   582
        aStream nextPutAll:'; position:'.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   583
        self position storeOn:aStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   584
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   585
    aStream nextPut:$)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   586
! !