ExternalStream.st
author convert-repo
Wed, 30 Sep 2015 04:03:07 +0000
changeset 18772 7e478404f86d
parent 18652 ee5e81c67497
child 18678 a9b30d72dff9
child 18779 bf2e0fa40131
permissions -rw-r--r--
update tags
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
17608
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
     1
"{ Encoding: utf8 }"
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
     2
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     3
"
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
     4
 COPYRIGHT (c) 1988 by Claus Gittinger
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
     5
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     6
a27a279701f8 Initial revision
claus
parents:
diff changeset
     7
 This software is furnished under a license and may be used
a27a279701f8 Initial revision
claus
parents:
diff changeset
     8
 only in accordance with the terms of that license and with the
a27a279701f8 Initial revision
claus
parents:
diff changeset
     9
 inclusion of the above copyright notice.   This software may not
a27a279701f8 Initial revision
claus
parents:
diff changeset
    10
 be provided or otherwise made available to, or used by, any
a27a279701f8 Initial revision
claus
parents:
diff changeset
    11
 other person.  No title to or ownership of the software is
a27a279701f8 Initial revision
claus
parents:
diff changeset
    12
 hereby transferred.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    13
"
5414
8557e4e71e51 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 5323
diff changeset
    14
"{ Package: 'stx:libbasic' }"
8557e4e71e51 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 5323
diff changeset
    15
17418
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
    16
"{ NameSpace: Smalltalk }"
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
    17
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    18
ReadWriteStream subclass:#ExternalStream
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
    19
	instanceVariableNames:'handleType handle mode buffered binary eolMode hitEOF didWrite
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
    20
		lastErrorNumber readAhead'
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
    21
	classVariableNames:'Lobby LastErrorNumber InvalidReadSignal InvalidWriteSignal
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
    22
		InvalidModeSignal OpenErrorSignal StreamNotOpenSignal
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
    23
		InvalidOperationSignal DefaultEOLMode ReadMode ReadWriteMode
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
    24
		WriteMode AppendMode CreateReadWriteMode StreamIOErrorSignal
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
    25
		FileOpenTrace'
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
    26
	poolDictionaries:''
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
    27
	category:'Streams-External'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    28
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    29
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
    30
!ExternalStream primitiveDefinitions!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    31
%{
10328
ad731a7584a3 ensure that win32_fwrite is used for stdout and stderr
Claus Gittinger <cg@exept.de>
parents: 9053
diff changeset
    32
#undef fwrite
ad731a7584a3 ensure that win32_fwrite is used for stdout and stderr
Claus Gittinger <cg@exept.de>
parents: 9053
diff changeset
    33
17078
f3ded8a6f9d9 include os defss
Claus Gittinger <cg@exept.de>
parents: 16912
diff changeset
    34
#include "stxOSDefs.h"
f3ded8a6f9d9 include os defss
Claus Gittinger <cg@exept.de>
parents: 16912
diff changeset
    35
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    36
#include <stdio.h>
437
claus
parents: 436
diff changeset
    37
#define _STDIO_H_INCLUDED_
claus
parents: 436
diff changeset
    38
2903
e64704e86cce various VMS changes
Claus Gittinger <cg@exept.de>
parents: 2896
diff changeset
    39
#ifndef NO_FCNTL_H
e64704e86cce various VMS changes
Claus Gittinger <cg@exept.de>
parents: 2896
diff changeset
    40
# include <fcntl.h>
e64704e86cce various VMS changes
Claus Gittinger <cg@exept.de>
parents: 2896
diff changeset
    41
# define _FCNTL_H_INCLUDED_
e64704e86cce various VMS changes
Claus Gittinger <cg@exept.de>
parents: 2896
diff changeset
    42
#endif
437
claus
parents: 436
diff changeset
    43
10
claus
parents: 5
diff changeset
    44
#include <errno.h>
437
claus
parents: 436
diff changeset
    45
#define _ERRNO_H_INCLUDED_
42
e33491f6f260 *** empty log message ***
claus
parents: 38
diff changeset
    46
1141
8ea1b43f7034 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1138
diff changeset
    47
#ifdef LINUX
8ea1b43f7034 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1138
diff changeset
    48
  /* use inline string macros */
8ea1b43f7034 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1138
diff changeset
    49
# define __STRINGDEFS__
8ea1b43f7034 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1138
diff changeset
    50
# include <linuxIntern.h>
8ea1b43f7034 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1138
diff changeset
    51
#endif
8ea1b43f7034 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1138
diff changeset
    52
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
    53
#if !defined(MSDOS_LIKE) && !defined(__openVMS__)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
    54
# include <termios.h>
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
    55
#endif
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
    56
42
e33491f6f260 *** empty log message ***
claus
parents: 38
diff changeset
    57
#ifdef hpux
e33491f6f260 *** empty log message ***
claus
parents: 38
diff changeset
    58
# define fileno(f)      ((f->__fileH << 8) | (f->__fileL))
e33491f6f260 *** empty log message ***
claus
parents: 38
diff changeset
    59
#endif
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
    60
933
2eebae059045 oops - when truncating buffered streams, we must flush & seek first (stdio trouble)
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
    61
#ifndef SEEK_SET
2eebae059045 oops - when truncating buffered streams, we must flush & seek first (stdio trouble)
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
    62
# define SEEK_SET 0
2eebae059045 oops - when truncating buffered streams, we must flush & seek first (stdio trouble)
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
    63
#endif
2eebae059045 oops - when truncating buffered streams, we must flush & seek first (stdio trouble)
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
    64
#ifndef SEEK_CUR
2eebae059045 oops - when truncating buffered streams, we must flush & seek first (stdio trouble)
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
    65
# define SEEK_CUR 1
2eebae059045 oops - when truncating buffered streams, we must flush & seek first (stdio trouble)
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
    66
#endif
2eebae059045 oops - when truncating buffered streams, we must flush & seek first (stdio trouble)
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
    67
#ifndef SEEK_END
2eebae059045 oops - when truncating buffered streams, we must flush & seek first (stdio trouble)
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
    68
# define SEEK_END 2
2eebae059045 oops - when truncating buffered streams, we must flush & seek first (stdio trouble)
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
    69
#endif
2eebae059045 oops - when truncating buffered streams, we must flush & seek first (stdio trouble)
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
    70
8901
824a89d0b5c7 alpha64 vs. POINTER_SIZE cleanup
Claus Gittinger <cg@exept.de>
parents: 8881
diff changeset
    71
#if defined(__VMS__) || defined(__sparc__) || defined(WIN32)
5120
13143fbcbdf8 introduced __threadErrno (for native threads)
Claus Gittinger <cg@exept.de>
parents: 5101
diff changeset
    72
# define CLEAR_ERRNO            __threadErrno = 0;
2961
a188727d0619 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2920
diff changeset
    73
#else
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
    74
# define CLEAR_ERRNO            /* nothing */
2961
a188727d0619 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2920
diff changeset
    75
#endif
a188727d0619 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2920
diff changeset
    76
3420
4dc6667afda9 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3419
diff changeset
    77
#ifdef LATER
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
    78
# define __isFilePointer(x)      (__Class(x) == ExternalStream__FilePointer)
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
    79
# define __CHANGECLASS(o, x)     (__qClass(o) = (x), o)
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
    80
# define __MKFILEPOINTER(f)      __CHANGECLASS(__MKEXTERNALADDRESS(f), ExternalStream__FilePointer)
3420
4dc6667afda9 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3419
diff changeset
    81
#else
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
    82
# define __MKFILEPOINTER(f)      __MKEXTERNALADDRESS(f)
3420
4dc6667afda9 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3419
diff changeset
    83
#endif
4dc6667afda9 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3419
diff changeset
    84
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
    85
#ifdef WIN32
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
    86
# define NO_STDIO
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
    87
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
    88
# undef __HANDLE_INTERRUPTS__
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
    89
# define __HANDLE_INTERRUPTS__    /* nothing */
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
    90
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
    91
# undef __BEGIN_INTERRUPTABLE__
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
    92
# define __BEGIN_INTERRUPTABLE__  /* nothing */
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
    93
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
    94
# undef __END_INTERRUPTABLE__
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
    95
# define __END_INTERRUPTABLE__    /* nothing */
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
    96
#endif
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
    97
8901
824a89d0b5c7 alpha64 vs. POINTER_SIZE cleanup
Claus Gittinger <cg@exept.de>
parents: 8881
diff changeset
    98
# ifdef __i386__
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
    99
#  define _X86_
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   100
# endif
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   101
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   102
#ifdef WIN32
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   103
# undef INT
14644
e5f19ef20dcd mingw changes
Claus Gittinger <cg@exept.de>
parents: 14632
diff changeset
   104
# undef UINT
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   105
# undef Array
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   106
# undef Number
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   107
# undef Method
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   108
# undef Point
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   109
# undef Rectangle
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   110
# undef Block
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   111
# undef Time
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   112
# undef Date
7832
f8a02752ca28 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7806
diff changeset
   113
# undef Delay
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   114
# undef Set
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   115
# undef Signal
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   116
# undef Context
9023
7919c66b8fb0 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9002
diff changeset
   117
# undef Message
9024
8066b17d9ccf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9023
diff changeset
   118
# undef Process
10339
972d0164125a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10328
diff changeset
   119
# undef Processor
14632
6fe0dc1d5377 64bit mingw changes
Claus Gittinger <cg@exept.de>
parents: 14603
diff changeset
   120
# undef String
6fe0dc1d5377 64bit mingw changes
Claus Gittinger <cg@exept.de>
parents: 14603
diff changeset
   121
# undef Character
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   122
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   123
# define NOATOM
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   124
# define NOGDICAPMASKS
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   125
# define NOMETAFILE
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   126
# define NOMINMAX
14068
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
   127
//# define NOOPENFILE
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   128
# define NOSOUND
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   129
# define NOWH
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   130
//# define NOCOMM
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   131
# define NOKANJI
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   132
# define NOCRYPT
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   133
//# define NOMCX
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   134
# define WIN32_LEAN_AND_MEAN
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   135
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   136
# include <windows.h>
15435
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
   137
# include <winsock2.h>
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   138
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   139
# ifdef __DEF_Array
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   140
#  define Array __DEF_Array
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   141
# endif
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   142
# ifdef __DEF_Number
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   143
#  define Number __DEF_Number
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   144
# endif
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   145
# ifdef __DEF_Method
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   146
#  define Method __DEF_Method
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   147
# endif
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   148
# ifdef __DEF_Point
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   149
#  define Point __DEF_Point
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   150
# endif
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   151
# ifdef __DEF_Block
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   152
#  define Block __DEF_Block
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   153
# endif
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   154
# ifdef __DEF_Time
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   155
#  define Time __DEF_Time
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   156
# endif
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   157
# ifdef __DEF_Date
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   158
#  define Date __DEF_Date
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   159
# endif
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   160
# ifdef __DEF_Set
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   161
#  define Set __DEF_Set
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   162
# endif
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   163
# ifdef __DEF_Signal
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   164
#  define Signal __DEF_Signal
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   165
# endif
7832
f8a02752ca28 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7806
diff changeset
   166
# ifdef __DEF_Delay
f8a02752ca28 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7806
diff changeset
   167
#  define Delay __DEF_Delay
f8a02752ca28 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7806
diff changeset
   168
# endif
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   169
# ifdef __DEF_Context
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   170
#  define Context __DEF_Context
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   171
# endif
9023
7919c66b8fb0 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9002
diff changeset
   172
# ifdef __DEF_Message
7919c66b8fb0 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9002
diff changeset
   173
#  define Message __DEF_Message
7919c66b8fb0 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9002
diff changeset
   174
# endif
9024
8066b17d9ccf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9023
diff changeset
   175
# ifdef __DEF_Process
8066b17d9ccf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9023
diff changeset
   176
#  define Process __DEF_Process
8066b17d9ccf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9023
diff changeset
   177
# endif
10339
972d0164125a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10328
diff changeset
   178
# ifdef __DEF_Processor
972d0164125a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10328
diff changeset
   179
#  define Processor __DEF_Processor
972d0164125a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10328
diff changeset
   180
# endif
14632
6fe0dc1d5377 64bit mingw changes
Claus Gittinger <cg@exept.de>
parents: 14603
diff changeset
   181
# ifdef __DEF_String
6fe0dc1d5377 64bit mingw changes
Claus Gittinger <cg@exept.de>
parents: 14603
diff changeset
   182
#  define String __DEF_String
6fe0dc1d5377 64bit mingw changes
Claus Gittinger <cg@exept.de>
parents: 14603
diff changeset
   183
# endif
6fe0dc1d5377 64bit mingw changes
Claus Gittinger <cg@exept.de>
parents: 14603
diff changeset
   184
# ifdef __DEF_Character
6fe0dc1d5377 64bit mingw changes
Claus Gittinger <cg@exept.de>
parents: 14603
diff changeset
   185
#  define Character __DEF_Character
6fe0dc1d5377 64bit mingw changes
Claus Gittinger <cg@exept.de>
parents: 14603
diff changeset
   186
# endif
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   187
14644
e5f19ef20dcd mingw changes
Claus Gittinger <cg@exept.de>
parents: 14632
diff changeset
   188
# define INT    STX_INT
e5f19ef20dcd mingw changes
Claus Gittinger <cg@exept.de>
parents: 14632
diff changeset
   189
# define UINT   STX_UINT
e5f19ef20dcd mingw changes
Claus Gittinger <cg@exept.de>
parents: 14632
diff changeset
   190
# ifndef off_t
e5f19ef20dcd mingw changes
Claus Gittinger <cg@exept.de>
parents: 14632
diff changeset
   191
#  define off_t  long
e5f19ef20dcd mingw changes
Claus Gittinger <cg@exept.de>
parents: 14632
diff changeset
   192
# endif
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   193
#endif /* WIN32 */
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   194
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   195
#ifndef NO_STDIO /* use STDIO */
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   196
# define STDIO_NEEDS_FSEEK
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   197
# define FILEPOINTER            FILE *
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   198
# define READ(f, cp, n)         read(f, cp, n)
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   199
# define WRITE(f, cp, n)        write(f, cp, n)
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   200
# define FFLUSH(fp)             fflush(fp)
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   201
# define FILENO(f)              fileno(f)
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   202
#endif /* use STDIO */
3681
55dc17d40aab fixed nextAvail
Claus Gittinger <cg@exept.de>
parents: 3674
diff changeset
   203
3682
Claus Gittinger <cg@exept.de>
parents: 3681
diff changeset
   204
#ifdef DEBUGGING
4092
fee552eb3418 removed win32 stuff
Claus Gittinger <cg@exept.de>
parents: 3980
diff changeset
   205
  extern char *__survStartPtr, *__survEndPtr;
3682
Claus Gittinger <cg@exept.de>
parents: 3681
diff changeset
   206
# define DEBUGBUFFER(buf)  \
3681
55dc17d40aab fixed nextAvail
Claus Gittinger <cg@exept.de>
parents: 3674
diff changeset
   207
    if (((char *)(buf) >= __survStartPtr) \
55dc17d40aab fixed nextAvail
Claus Gittinger <cg@exept.de>
parents: 3674
diff changeset
   208
     && ((char *)(buf) < __survEndPtr)) { \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   209
	__fatal0("read into survivor\n"); \
3681
55dc17d40aab fixed nextAvail
Claus Gittinger <cg@exept.de>
parents: 3674
diff changeset
   210
    }
55dc17d40aab fixed nextAvail
Claus Gittinger <cg@exept.de>
parents: 3674
diff changeset
   211
3682
Claus Gittinger <cg@exept.de>
parents: 3681
diff changeset
   212
#else
Claus Gittinger <cg@exept.de>
parents: 3681
diff changeset
   213
# define DEBUGBUFFER(buf) /* nothing */
Claus Gittinger <cg@exept.de>
parents: 3681
diff changeset
   214
#endif
Claus Gittinger <cg@exept.de>
parents: 3681
diff changeset
   215
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   216
/*
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   217
 * stdio library requires an fseek before reading whenever a file
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   218
 * is open for read/write and the last operation was a write.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   219
 * (also vice-versa).
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   220
 * All code should use the following macro before doing reads:
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   221
 */
2593
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
   222
#ifdef STDIO_NEEDS_FSEEK
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
   223
# define OPT_FSEEK(f, pos, whence)      fseek(f, pos, whence)
2593
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
   224
#else
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
   225
# define OPT_FSEEK(f, pos, whence)      /* nothing */
2593
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
   226
#endif
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
   227
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   228
#ifdef WIN32
16912
2391fcb8b4a4 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16909
diff changeset
   229
// Win returns from ReadFile() with false and _threadErrno == 0 on end of pipe.
2391fcb8b4a4 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16909
diff changeset
   230
// We don't know why
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
   231
#  define READ(ret, f, cp, n, handleType) { \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   232
	if (handleType == @symbol(socketHandle)) { \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   233
	  (ret) = __STX_WSA_NOINT_CALL4("recv", recv, (f), (cp), (n), 0); \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   234
	} else { \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   235
	  HANDLE h = _get_osfhandle(fileno(f)); \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   236
	  if (handleType == @symbol(socketFilePointer)) { \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   237
	    (ret) = __STX_WSA_NOINT_CALL4("recv", recv, h, (cp), (n), 0);\
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   238
	  } else { \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   239
	    int __res; \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   240
	    (ret) = __STX_API_NOINT_CALL5("ReadFile", ReadFile, h, (cp), (n), &__res, 0);\
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   241
	    (ret) = (ret) ? __res : ((__threadErrno == EPIPE || __threadErrno == 0) ? 0 : -1); \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   242
	  } \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   243
	} \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   244
      }
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
   245
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
   246
#  define WRITE(ret, f, cp, n, handleType) { \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   247
	if (handleType == @symbol(socketHandle)) { \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   248
	  (ret) = __STX_WSA_NOINT_CALL4("send", send, (f), (cp), (n), 0); \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   249
	} else {\
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   250
	  HANDLE h = _get_osfhandle(fileno(f)); \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   251
	  if (handleType == @symbol(socketFilePointer)) { \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   252
	    (ret) = __STX_WSA_NOINT_CALL4("send", send, h, (cp), (n), 0);\
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   253
	  } else {\
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   254
	    int __res; \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   255
	    (ret) = __STX_API_NOINT_CALL5("WriteFile", WriteFile, h, (cp), (n), &__res, 0);\
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   256
	    (ret) = (ret) ? __res : -1; \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   257
	  } \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   258
	} \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   259
      }
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   260
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   261
# define FFLUSH(fp)             fflush(fp)
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   262
# undef STDIO_NEEDS_FSEEK
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   263
# define FILEPOINTER            FILE *
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   264
# define FILENO(f)              fileno(f)
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   265
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   266
# define __READING__(f)                          \
1133
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1119
diff changeset
   267
    if ((__INST(didWrite) != false)              \
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1119
diff changeset
   268
     && (__INST(mode) == @symbol(readwrite))) {  \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   269
	__INST(didWrite) = false;                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   270
	OPT_FSEEK(f, 0L, SEEK_CUR); /* needed in stdio */  \
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   271
    }
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   272
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   273
# define __WRITING__(f)                          \
1133
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1119
diff changeset
   274
    if ((__INST(didWrite) != true)               \
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1119
diff changeset
   275
     && (__INST(mode) == @symbol(readwrite))) {  \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   276
	__INST(didWrite) = true;                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   277
	OPT_FSEEK(f, 0L, SEEK_CUR); /* needed in stdio */  \
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   278
    }
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
   279
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   280
# define __UNGETC__(c, f, isBuffered)                   \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   281
    if (isBuffered) {                                   \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   282
	ungetc((c), (f));                               \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   283
    } else {                                            \
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
   284
      __INST(readAhead) = __mkSmallInteger((c));        \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   285
    }
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   286
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
   287
# define __READBYTE__(ret, f, buf, isBuffered, handleType) \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   288
    if (isBuffered) {                                   \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   289
	for (;;) {                                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   290
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   291
	    (ret) = getc(f);                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   292
	    if ((ret) >= 0) {                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   293
		*(buf) = (ret);                         \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   294
		(ret) = 1;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   295
	    } else if (ferror(f)) {                     \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   296
		if (__threadErrno == EINTR) {           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   297
		    clearerr(f);                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   298
		    continue;                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   299
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   300
	    } else {                                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   301
		(ret) = 0;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   302
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   303
	    break;                                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   304
	}                                               \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   305
    } else {                                            \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   306
	OBJ rA = __INST(readAhead);                     \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   307
	if (rA != nil) {                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   308
	    *(buf) = (char)__intVal(rA);                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   309
	    __INST(readAhead) = nil;                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   310
	    (ret) = 1;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   311
	} else {                                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   312
	    for (;;) {                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   313
		CLEAR_ERRNO;                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   314
		READ((ret), f, buf, 1, handleType);       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   315
		if ((ret) >= 0 || __threadErrno != EINTR) \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   316
		    break;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   317
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   318
	}                                               \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   319
    }
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   320
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   321
  /*
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   322
   * read_bytes into a c-buffer
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   323
   * (which may NOT move)
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   324
   */
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
   325
# define __READBYTES__(ret, f, buf, cnt, isBuffered, handleType)    \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   326
    (ret) = 0;                                          \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   327
    if (isBuffered) {                                   \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   328
	int __offs = 0;                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   329
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   330
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   331
	    (ret) = getc(f);                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   332
	    if ((ret) < 0) {                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   333
		if (ferror(f)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   334
		    if (__threadErrno == EINTR) {       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   335
			clearerr(f);                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   336
			continue;                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   337
		    }                                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   338
		} else {                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   339
		    (ret) = 0;                          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   340
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   341
		break;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   342
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   343
	    (buf)[__offs++] = (ret);                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   344
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   345
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   346
	    (ret) = __offs;                             \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   347
    } else {                                            \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   348
	int __offs = 0;                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   349
							\
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   350
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   351
	    OBJ rA = __INST(readAhead);                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   352
	    if (rA != nil) {                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   353
		(buf)[__offs] = __intVal(rA);           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   354
		__INST(readAhead) = nil;                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   355
		(ret) = 1;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   356
	    } else {                                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   357
		CLEAR_ERRNO;                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   358
		READ((ret), f, (buf)+__offs, (cnt)-__offs, handleType); \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   359
		if ((ret) <= 0) {                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   360
		    if ((ret) < 0 && __threadErrno == EINTR) {  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   361
			continue;                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   362
		    }                                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   363
		    break;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   364
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   365
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   366
	    __offs += (ret);                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   367
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   368
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   369
	    (ret) = __offs;                             \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   370
   }
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   371
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
   372
# define __READAVAILBYTES__(ret, f, buf, cnt, isBuffered, handleType) \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   373
  {                                                     \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   374
    int __offs = 0;                                     \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   375
    int oldFlags;                                       \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   376
							\
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   377
    (ret) = 0;                                          \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   378
    if (isBuffered) {                                   \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   379
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   380
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   381
	    (ret) = getc(f);                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   382
	    if ((ret) < 0) {                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   383
		if (ferror(f)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   384
		    if (__threadErrno == EINTR) {       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   385
			clearerr(f);                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   386
			continue;                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   387
		    }                                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   388
		} else {                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   389
		    (ret) = 0;                          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   390
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   391
		break;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   392
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   393
	    (buf)[__offs++] = (ret);                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   394
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   395
	(ret) = __offs;                                 \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   396
    } else {                                            \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   397
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   398
	    OBJ rA = __INST(readAhead);                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   399
	    if (rA != nil) {                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   400
		(buf)[__offs] = __intVal(rA);           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   401
		__INST(readAhead) = nil;                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   402
		(ret) = 1;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   403
		__offs ++;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   404
		continue;                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   405
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   406
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   407
	    {                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   408
	      int res = 0;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   409
	      if ((handleType == @symbol(socketFilePointer) && (ioctlsocket((SOCKET)_get_osfhandle(fileno(f)),FIONREAD,&res), 1)) \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   410
		  || (handleType == @symbol(socketHandle) && (ioctlsocket((SOCKET)(f), FIONREAD, &res), 1)) \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   411
		  || (handleType == @symbol(pipeFilePointer) && (PeekNamedPipe((HANDLE)_get_osfhandle(fileno(f)),0, 0,0,&res,0), 1))) { \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   412
		  if (res > 0) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   413
		      if (res > ((cnt)-__offs))         \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   414
			  res = (cnt)-__offs;           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   415
		      READ((ret), f, (buf)+__offs, res, handleType); \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   416
		  } else {                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   417
		      (ret) = 0;                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   418
		      break;                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   419
		  }                                     \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   420
	      } else {                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   421
		  READ((ret), f, (buf)+__offs, (cnt)-__offs, handleType); \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   422
	      }                                         \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   423
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   424
	    if ((ret) <= 0) {                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   425
		if (ret < 0 && __threadErrno == EINTR)  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   426
		    continue;                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   427
		break;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   428
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   429
	    __offs += (ret);                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   430
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   431
	(ret) = __offs;                                 \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   432
    }                                                   \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   433
  }
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   434
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   435
# define IO_BUFFER_SIZE        (8*1024)
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   436
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
   437
# define __READBYTES_OBJ__(ret, f, obj, obj_offs, cnt, isBuffered, handleType) \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   438
  {                                                     \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   439
    int __ooffs = obj_offs;                             \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   440
    int __offs = 0;                                     \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   441
    char *buf = (char *)(obj);                          \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   442
							\
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   443
    (ret) = 0;                                          \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   444
    if (isBuffered) {                                   \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   445
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   446
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   447
	    (ret) = getc(f);                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   448
	    if ((ret) < 0) {                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   449
		if (ferror(f)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   450
		    if (__threadErrno == EINTR) {       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   451
			clearerr(f);                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   452
			/* refetch */                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   453
			buf = (char *)(obj);   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   454
			continue;                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   455
		    }                                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   456
		} else {                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   457
		    (ret) = 0;                          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   458
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   459
		break;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   460
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   461
	    (buf)[__ooffs+__offs] = (ret);              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   462
	    __offs++;                                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   463
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   464
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   465
	    (ret) = __offs;                             \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   466
    } else {                                            \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   467
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   468
	    char __buf[IO_BUFFER_SIZE];                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   469
	    OBJ rA = __INST(readAhead);                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   470
	    if (rA != nil) {                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   471
		(buf)[__ooffs+__offs] = __intVal(rA);   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   472
		__INST(readAhead) = nil;                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   473
		(ret) = 1;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   474
	    } else {                                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   475
		int l;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   476
		CLEAR_ERRNO;                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   477
		l = (cnt)-__offs;                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   478
		if ( l > IO_BUFFER_SIZE)                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   479
		  l = IO_BUFFER_SIZE;                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   480
		READ((ret),f, __buf, l, handleType);                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   481
		if ((ret) <= 0) {                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   482
		    if ((ret) < 0 && __threadErrno == EINTR) {  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   483
			continue;                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   484
		    }                                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   485
		    break;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   486
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   487
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   488
	    if ((ret) > 0 ) {                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   489
		/* refetch */                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   490
		buf = (char *)(obj);               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   491
		memcpy((buf)+__ooffs+__offs,__buf,(ret));   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   492
		__offs += (ret);                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   493
	    } else {                                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   494
		(ret) = 0;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   495
	    }                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   496
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   497
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   498
	    (ret) = __offs;                             \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   499
    }                                                   \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   500
  }
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   501
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
   502
# define __READAVAILBYTES_OBJ__(ret, f, obj, obj_offs, cnt, isBuffered, handleType) \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   503
  {                                                  \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   504
    int __ooffs = obj_offs;                          \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   505
    int __offs = 0;                                  \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   506
    char *buf = (char *)(obj);                       \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   507
						     \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   508
    (ret) = 0;                                       \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   509
    if (isBuffered) {                                \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   510
	while (__offs < (cnt)) {                     \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   511
	    CLEAR_ERRNO;                             \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   512
	    (ret) = getc(f);                         \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   513
	    if ((ret) < 0) {                         \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   514
		if (ferror(f)) {                     \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   515
		    if (__threadErrno == EINTR) {    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   516
			clearerr(f);                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   517
			/* refetch */                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   518
			buf = (char *)(obj);\
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   519
			continue;                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   520
		    }                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   521
		} else {                             \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   522
		    (ret) = 0;                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   523
		}                                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   524
		break;                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   525
	    }                                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   526
	    (buf)[__ooffs+__offs] = (ret);           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   527
	    __offs++;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   528
	}                                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   529
	if (__offs > 0)                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   530
	    (ret) = __offs;                          \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   531
    } else {                                         \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   532
	while (__offs < (cnt)) {                     \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   533
	    char __buf[IO_BUFFER_SIZE];              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   534
	    OBJ rA = __INST(readAhead);              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   535
	    if (rA != nil) {                         \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   536
		(buf)[__ooffs+__offs] = __intVal(rA);\
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   537
		__INST(readAhead) = nil;             \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   538
		(ret) = 1;                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   539
		__offs++;                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   540
		continue;                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   541
	    }                                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   542
	    {                                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   543
		int res = 0;                         \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   544
		int l = (cnt)-__offs;                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   545
		CLEAR_ERRNO;                         \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   546
		if (l > IO_BUFFER_SIZE)              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   547
		    l = IO_BUFFER_SIZE;              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   548
		if ((handleType == @symbol(socketFilePointer) && (ioctlsocket((SOCKET)_get_osfhandle(fileno(f)), FIONREAD, &res), 1)) \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   549
		    || (handleType == @symbol(socketHandle) && (ioctlsocket((SOCKET)(f), FIONREAD, &res), 1)) \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   550
		    || (handleType == @symbol(pipeFilePointer) && (PeekNamedPipe((HANDLE)_get_osfhandle(fileno(f)),0,0,0,&res,0), 1))) { \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   551
		    if (res > 0) {                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   552
			if (res > l) res = l;        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   553
			READ((ret), f, __buf, res, handleType); \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   554
		    } else {                         \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   555
			(ret) = 0;                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   556
			break;                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   557
		    }                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   558
		} else {                             \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   559
		    READ((ret), f, __buf, l, handleType); \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   560
		}                                     \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   561
		if ((ret) <= 0) {                     \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   562
		    if (ret < 0 && __threadErrno == EINTR) \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   563
			continue;                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   564
		    break;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   565
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   566
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   567
	    if ((ret) > 0) {                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   568
		buf = (char *)(obj);                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   569
		memcpy((buf)+__ooffs+__offs, __buf, (ret)); \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   570
		__offs += (ret);                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   571
	    } else {                                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   572
		(ret) = 0;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   573
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   574
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   575
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   576
	    (ret) = __offs;                             \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   577
    }                                                   \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   578
  }
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   579
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
   580
# define __WRITEBYTE__(ret, f, buf, isBuffered, handleType)         \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   581
    if (isBuffered) {                                   \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   582
	for (;;) {                                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   583
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   584
	    ret = putc(*(buf), f);                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   585
	    if ((ret) >= 0) {                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   586
		(ret) = 1;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   587
	    } else if (ferror(f)) {                     \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   588
		if (__threadErrno == EINTR) {                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   589
		    clearerr(f);                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   590
		    continue;                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   591
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   592
	    } else                                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   593
		(ret) = 0;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   594
	    break;                                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   595
	}                                               \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   596
    } else {                                            \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   597
	for (;;) {                                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   598
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   599
	    WRITE(ret,f, buf, 1, handleType);                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   600
	    if ((ret) >= 0 || __threadErrno != EINTR)           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   601
		break;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   602
	}                                               \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   603
   }
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   604
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
   605
# define __WRITEBYTES__(ret, f, buf, cnt, isBuffered, handleType)   \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   606
    (ret) = 0;                                          \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   607
    if (isBuffered) {                                   \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   608
	int __offs = 0;                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   609
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   610
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   611
	    (ret) = fwrite((buf)+__offs, 1, (cnt)-__offs, f);\
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   612
	    if ((ret) <= 0) {                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   613
		if (ferror(f)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   614
		    if (__threadErrno == EINTR) {               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   615
			clearerr(f);                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   616
			continue;                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   617
		    }                                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   618
		    break;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   619
		} else {                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   620
		    (ret) = 0;                          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   621
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   622
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   623
	    __offs += (ret);                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   624
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   625
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   626
	    (ret) = __offs;                             \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   627
    } else {                                            \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   628
	int __offs = 0;                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   629
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   630
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   631
	    WRITE(ret,f, (buf)+__offs, (cnt)-__offs, handleType);   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   632
	    if (ret <= 0) {                             \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   633
		if (ret < 0 && __threadErrno == EINTR) { \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   634
		    continue;                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   635
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   636
		break;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   637
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   638
	    __offs += (ret);                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   639
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   640
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   641
	    (ret) = __offs;                             \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   642
   }
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   643
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
   644
# define __WRITEBYTES_OBJ__(ret, f, obj, obj_offs, cnt, isBuffered, handleType) \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   645
  {                                                     \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   646
    int __ooffs = obj_offs;                             \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   647
    int __offs = 0;                                     \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   648
    char *buf = (char *)(obj);                          \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   649
							\
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   650
    (ret) = 0;                                          \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   651
    if (isBuffered) {                                   \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   652
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   653
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   654
	    ret = fwrite((buf)+__ooffs+__offs, 1, (cnt)-__offs, f); \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   655
	    if ((ret) <= 0) {                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   656
		if (ferror(f)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   657
		    if (__threadErrno == EINTR) {       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   658
			/* refetch */                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   659
			buf = (char *)(obj);   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   660
			clearerr(f);                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   661
			continue;                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   662
		    }                                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   663
		    break;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   664
		} else {                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   665
		    (ret) = 0;                          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   666
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   667
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   668
	    __offs += (ret);                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   669
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   670
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   671
	    (ret) = __offs;                             \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   672
    } else {                                            \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   673
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   674
	    char __buf[IO_BUFFER_SIZE];                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   675
	    int l;                                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   676
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   677
	    l = (cnt)-__offs;                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   678
	    if ( l > IO_BUFFER_SIZE)                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   679
	      l = IO_BUFFER_SIZE;                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   680
	    /* refetch */                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   681
	    buf = (char *)(obj);               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   682
	    memcpy(__buf,(buf)+__ooffs+__offs,l);       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   683
	    WRITE(ret,f, __buf, l, handleType);                     \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   684
	    if (ret <= 0) {                             \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   685
		if (ret < 0 && __threadErrno == EINTR) {        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   686
		    continue;                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   687
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   688
		break;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   689
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   690
	    __offs += (ret);                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   691
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   692
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   693
	    (ret) = __offs;                             \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   694
    }                                                   \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   695
  }
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   696
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
   697
#else /* ! WIN32 */
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
   698
/* ========================   UNIX / LINUX ====================================================== */
16373
9b9827530bf4 Adapt previous change for linux
Stefan Vogel <sv@exept.de>
parents: 16368
diff changeset
   699
typedef int SOCKET;
9b9827530bf4 Adapt previous change for linux
Stefan Vogel <sv@exept.de>
parents: 16368
diff changeset
   700
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   701
# define __READING__(f)                          \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   702
    if ((__INST(didWrite) != false)              \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   703
     && (__INST(mode) == @symbol(readwrite))) {  \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   704
	__INST(didWrite) = false;                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   705
	OPT_FSEEK(f, 0L, SEEK_CUR); /* needed in stdio */  \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   706
    }
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   707
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   708
# define __WRITING__(f)                          \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   709
    if ((__INST(didWrite) != true)               \
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   710
     && (__INST(mode) == @symbol(readwrite))) {  \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   711
	__INST(didWrite) = true;                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   712
	OPT_FSEEK(f, 0L, SEEK_CUR); /* needed in stdio */  \
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   713
    }
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   714
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   715
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   716
# ifdef NO_STDIO
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   717
#  define __UNGETC__(c, f, isBuffered)                  \
8913
b9498d27a554 64bit; mkSmallInteger
Claus Gittinger <cg@exept.de>
parents: 8901
diff changeset
   718
    __INST(readAhead) = __mkSmallInteger((c));
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   719
# else /* use STDIO */
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   720
#  define __UNGETC__(c, f, isBuffered)                  \
2264
ac5dfc03aa26 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2262
diff changeset
   721
    if (isBuffered) {                                   \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   722
	ungetc((c), (f));                               \
2264
ac5dfc03aa26 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2262
diff changeset
   723
    } else {                                            \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   724
	__INST(readAhead) = __mkSmallInteger((c));          \
2120
71c1870df7ba implemented 1-character readAhead for unbuffered streams;
Claus Gittinger <cg@exept.de>
parents: 2045
diff changeset
   725
    }
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   726
# endif /* use STDIO */
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   727
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   728
# ifdef NO_STDIO
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
   729
#  define __READBYTE__(ret, f, buf, isBuffered, handleType)         \
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
   730
    {                                                   \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   731
	OBJ rA = __INST(readAhead);                     \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   732
	if (rA != nil) {                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   733
	    *(buf) = __intVal(rA);                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   734
	    DEBUGBUFFER(buf);                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   735
	    __INST(readAhead) = nil;                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   736
	    (ret) = 1;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   737
	} else {                                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   738
	    for (;;) {                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   739
		CLEAR_ERRNO;                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   740
		(ret) = READ(f, buf, 1, handleType);    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   741
		DEBUGBUFFER(buf);                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   742
		if ((ret) >= 0) break;                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   743
		if (errno != EINTR) {                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   744
		    break;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   745
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   746
		__HANDLE_INTERRUPTS__;                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   747
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   748
	}                                               \
2593
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
   749
    }
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   750
# else /* use STDIO */
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
   751
#  define __READBYTE__(ret, f, buf, isBuffered, handleType)         \
2264
ac5dfc03aa26 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2262
diff changeset
   752
    if (isBuffered) {                                   \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   753
	for (;;) {                                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   754
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   755
	    (ret) = getc(f);                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   756
	    if ((ret) >= 0) {                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   757
		DEBUGBUFFER(buf);                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   758
		*(buf) = (ret);                         \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   759
		(ret) = 1;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   760
	    } else if (ferror(f)) {                     \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   761
		if (errno == EINTR) {                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   762
		    __HANDLE_INTERRUPTS__;              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   763
		    clearerr(f);                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   764
		    continue;                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   765
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   766
	    } else                                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   767
		(ret) = 0;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   768
	    break;                                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   769
	}                                               \
2264
ac5dfc03aa26 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2262
diff changeset
   770
    } else {                                            \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   771
	OBJ rA = __INST(readAhead);                     \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   772
	if (rA != nil) {                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   773
	    *(buf) = __intVal(rA);                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   774
	    DEBUGBUFFER(buf);                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   775
	    __INST(readAhead) = nil;                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   776
	    (ret) = 1;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   777
	} else {                                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   778
	    for (;;) {                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   779
		CLEAR_ERRNO;                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   780
		(ret) = read(fileno(f), buf, 1);        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   781
		DEBUGBUFFER(buf);                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   782
		if ((ret) >= 0) break;                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   783
		if (errno != EINTR) {                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   784
		    break;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   785
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   786
		__HANDLE_INTERRUPTS__;                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   787
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   788
	}                                               \
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   789
   }
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   790
# endif /* use STDIO */
1463
ace6b72b6f4a Use common macros to make interruptable system calls signal proof.
Stefan Vogel <sv@exept.de>
parents: 1422
diff changeset
   791
2513
a589586a3828 big bug: READBYTES & WRITEBYTES did not care for moving objects when interrupted.
Claus Gittinger <cg@exept.de>
parents: 2331
diff changeset
   792
/*
a589586a3828 big bug: READBYTES & WRITEBYTES did not care for moving objects when interrupted.
Claus Gittinger <cg@exept.de>
parents: 2331
diff changeset
   793
 * read_bytes into a c-buffer
a589586a3828 big bug: READBYTES & WRITEBYTES did not care for moving objects when interrupted.
Claus Gittinger <cg@exept.de>
parents: 2331
diff changeset
   794
 * (which may NOT move)
a589586a3828 big bug: READBYTES & WRITEBYTES did not care for moving objects when interrupted.
Claus Gittinger <cg@exept.de>
parents: 2331
diff changeset
   795
 */
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   796
# ifdef NO_STDIO
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
   797
#  define __READBYTES__(ret, f, buf, cnt, isBuffered, handleType)   \
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
   798
    {                                                   \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   799
	int __offs = 0, __cnt;                          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   800
							\
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   801
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   802
	    OBJ rA = __INST(readAhead);                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   803
	    if (rA != nil) {                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   804
		(buf)[__offs] = __intVal(rA);           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   805
		DEBUGBUFFER(buf);                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   806
		__INST(readAhead) = nil;                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   807
		__offs++;                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   808
	    } else {                                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   809
		CLEAR_ERRNO;                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   810
		__cnt = READ(f, (buf)+__offs, (cnt)-__offs, handleType); \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   811
		DEBUGBUFFER(buf);                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   812
		if (__cnt <= 0) {                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   813
		    if (__cnt < 0 && errno == EINTR) {  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   814
			__HANDLE_INTERRUPTS__;          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   815
			continue;                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   816
		    }                                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   817
		    break;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   818
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   819
		__offs += __cnt;                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   820
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   821
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   822
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   823
	    (ret) = __offs;                             \
2593
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
   824
   }
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   825
# else /* use STDIO */
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
   826
#  define __READBYTES__(ret, f, buf, cnt, isBuffered, handleType)     \
2120
71c1870df7ba implemented 1-character readAhead for unbuffered streams;
Claus Gittinger <cg@exept.de>
parents: 2045
diff changeset
   827
    (ret) = 0;                                          \
71c1870df7ba implemented 1-character readAhead for unbuffered streams;
Claus Gittinger <cg@exept.de>
parents: 2045
diff changeset
   828
    if (isBuffered) {                                   \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   829
	int __offs = 0;                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   830
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   831
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   832
	    (ret) = getc(f);                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   833
	    if ((ret) < 0) {                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   834
		if (ferror(f)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   835
		    if (errno == EINTR) {               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   836
			__HANDLE_INTERRUPTS__;          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   837
			clearerr(f);                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   838
			continue;                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   839
		    }                                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   840
		} else {                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   841
		    (ret) = 0;                          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   842
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   843
		break;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   844
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   845
	    DEBUGBUFFER(buf);                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   846
	    (buf)[__offs++] = (ret);                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   847
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   848
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   849
	    (ret) = __offs;                             \
2120
71c1870df7ba implemented 1-character readAhead for unbuffered streams;
Claus Gittinger <cg@exept.de>
parents: 2045
diff changeset
   850
    } else {                                            \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   851
	int __offs = 0, __cnt;                          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   852
	int fd = fileno(f);                             \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   853
							\
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   854
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   855
	    OBJ rA = __INST(readAhead);                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   856
	    if (rA != nil) {                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   857
		DEBUGBUFFER(buf);                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   858
		(buf)[__offs] = __intVal(rA);           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   859
		__INST(readAhead) = nil;                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   860
		__offs++;                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   861
	    } else {                                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   862
		CLEAR_ERRNO;                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   863
		__cnt = read(fd, (buf)+__offs, (cnt)-__offs);  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   864
		DEBUGBUFFER(buf);                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   865
		if (__cnt <= 0) {                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   866
		    if (__cnt < 0 && errno == EINTR) {  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   867
			__HANDLE_INTERRUPTS__;          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   868
			continue;                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   869
		    }                                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   870
		    break;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   871
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   872
		__offs += __cnt;                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   873
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   874
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   875
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   876
	    (ret) = __offs;                             \
1463
ace6b72b6f4a Use common macros to make interruptable system calls signal proof.
Stefan Vogel <sv@exept.de>
parents: 1422
diff changeset
   877
   }
3445
2639c1e3fd0b nextAvail also for externalBytes
Claus Gittinger <cg@exept.de>
parents: 3432
diff changeset
   878
6563
f786651428c8 Support O_NONBLOCK which is the POSIX way of FNDELAY
Stefan Vogel <sv@exept.de>
parents: 6487
diff changeset
   879
f786651428c8 Support O_NONBLOCK which is the POSIX way of FNDELAY
Stefan Vogel <sv@exept.de>
parents: 6487
diff changeset
   880
/*
f786651428c8 Support O_NONBLOCK which is the POSIX way of FNDELAY
Stefan Vogel <sv@exept.de>
parents: 6487
diff changeset
   881
 * FNDELAY and O_NDELAY is deprecated, O_NONBLOCK is used in POSIX, XPG, etc...
f786651428c8 Support O_NONBLOCK which is the POSIX way of FNDELAY
Stefan Vogel <sv@exept.de>
parents: 6487
diff changeset
   882
 */
f786651428c8 Support O_NONBLOCK which is the POSIX way of FNDELAY
Stefan Vogel <sv@exept.de>
parents: 6487
diff changeset
   883
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   884
#  if defined(F_GETFL) && defined(F_SETFL) && (defined(O_NONBLOCK) || defined(O_NDELAY) || defined(FNDELAY))
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   885
#   define SETFLAGS(fd, flags) \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   886
	fcntl(fd, F_SETFL, flags)
6563
f786651428c8 Support O_NONBLOCK which is the POSIX way of FNDELAY
Stefan Vogel <sv@exept.de>
parents: 6487
diff changeset
   887
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   888
#   if defined(O_NONBLOCK)
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   889
#    define __STX_NONBLOCK_FLAG O_NONBLOCK
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   890
#   else
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   891
#    if defined(O_NDELAY)
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   892
#     define __STX_NONBLOCK_FLAG O_NDELAY
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   893
#    else
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   894
#     define __STX_NONBLOCK_FLAG FNDELAY
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   895
#    endif
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   896
#   endif
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   897
15342
d89884677c76 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15304
diff changeset
   898
#   define SETNONBLOCKING(fd, oldFlags) \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   899
	{ \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   900
	    int flags = fcntl(fd, F_GETFL, 0); \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   901
	    if (flags >= 0) { \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   902
		fcntl(fd, F_SETFL, flags | __STX_NONBLOCK_FLAG); \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   903
	    } \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   904
	    oldFlags = flags; \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   905
	}
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   906
#  else
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   907
#   define SETFLAGS(fd, flags) /* nothing */
15342
d89884677c76 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15304
diff changeset
   908
#   define SETNONBLOCKING(fd, oldFlags) /* nothing */
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   909
#  endif
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   910
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
   911
#  define __READAVAILBYTES__(ret, f, buf, cnt, isBuffered, handleType) \
3445
2639c1e3fd0b nextAvail also for externalBytes
Claus Gittinger <cg@exept.de>
parents: 3432
diff changeset
   912
  {                                                     \
15342
d89884677c76 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15304
diff changeset
   913
    int __offs = 0, __cnt;                              \
3681
55dc17d40aab fixed nextAvail
Claus Gittinger <cg@exept.de>
parents: 3674
diff changeset
   914
    int oldFlags;                                       \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   915
							\
3445
2639c1e3fd0b nextAvail also for externalBytes
Claus Gittinger <cg@exept.de>
parents: 3432
diff changeset
   916
    (ret) = 0;                                          \
15342
d89884677c76 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15304
diff changeset
   917
    SETNONBLOCKING(fileno(f), oldFlags);                \
3445
2639c1e3fd0b nextAvail also for externalBytes
Claus Gittinger <cg@exept.de>
parents: 3432
diff changeset
   918
    if (isBuffered) {                                   \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   919
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   920
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   921
	    (ret) = getc(f);                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   922
	    if ((ret) < 0) {                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   923
		if (ferror(f)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   924
		    if (errno == EINTR) {               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   925
			(ret) = 0;                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   926
			clearerr(f);                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   927
			break;                          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   928
		    }                                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   929
		} else {                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   930
		    (ret) = 0;                          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   931
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   932
		break;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   933
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   934
	    (buf)[__offs++] = (ret);                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   935
	    DEBUGBUFFER(buf);                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   936
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   937
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   938
	    (ret) = __offs;                             \
3445
2639c1e3fd0b nextAvail also for externalBytes
Claus Gittinger <cg@exept.de>
parents: 3432
diff changeset
   939
    } else {                                            \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   940
	int fd = fileno(f);                             \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   941
							\
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   942
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   943
	    OBJ rA = __INST(readAhead);                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   944
	    if (rA != nil) {                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   945
		(buf)[__offs] = __intVal(rA);           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   946
		DEBUGBUFFER(buf);                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   947
		__INST(readAhead) = nil;                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   948
		__offs++;                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   949
		continue;                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   950
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   951
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   952
	    __cnt = read(fd, (buf)+__offs, (cnt)-__offs); \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   953
	    DEBUGBUFFER(buf);                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   954
	    if (__cnt > 0) {                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   955
		__offs += __cnt;                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   956
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   957
	    break;                                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   958
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   959
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   960
	    (ret) = __offs;                             \
3445
2639c1e3fd0b nextAvail also for externalBytes
Claus Gittinger <cg@exept.de>
parents: 3432
diff changeset
   961
    }                                                   \
3681
55dc17d40aab fixed nextAvail
Claus Gittinger <cg@exept.de>
parents: 3674
diff changeset
   962
    SETFLAGS(fileno(f), oldFlags);                      \
3445
2639c1e3fd0b nextAvail also for externalBytes
Claus Gittinger <cg@exept.de>
parents: 3432
diff changeset
   963
  }
2639c1e3fd0b nextAvail also for externalBytes
Claus Gittinger <cg@exept.de>
parents: 3432
diff changeset
   964
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
   965
# endif /* use STDIO */
1463
ace6b72b6f4a Use common macros to make interruptable system calls signal proof.
Stefan Vogel <sv@exept.de>
parents: 1422
diff changeset
   966
2513
a589586a3828 big bug: READBYTES & WRITEBYTES did not care for moving objects when interrupted.
Claus Gittinger <cg@exept.de>
parents: 2331
diff changeset
   967
/*
a589586a3828 big bug: READBYTES & WRITEBYTES did not care for moving objects when interrupted.
Claus Gittinger <cg@exept.de>
parents: 2331
diff changeset
   968
 * read_bytes into an object
a589586a3828 big bug: READBYTES & WRITEBYTES did not care for moving objects when interrupted.
Claus Gittinger <cg@exept.de>
parents: 2331
diff changeset
   969
 * (which may be moved by GC)
a589586a3828 big bug: READBYTES & WRITEBYTES did not care for moving objects when interrupted.
Claus Gittinger <cg@exept.de>
parents: 2331
diff changeset
   970
 */
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
   971
# ifdef NO_STDIO
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
   972
#  define __READBYTES_OBJ__(ret, f, obj, obj_offs, cnt, isBuffered, handleType)     \
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
   973
  {                                                     \
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
   974
    int __ooffs = obj_offs;                             \
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
   975
    int __offs = 0;                                     \
7540
7cd542f29024 Fix reading when readAheadBuffer is filled and following read fails
Stefan Vogel <sv@exept.de>
parents: 7503
diff changeset
   976
    int __cnt;                                          \
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
   977
    char *buf = (char *)(obj);                          \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   978
							\
2593
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
   979
    (ret) = 0;                                          \
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
   980
    {                                                   \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   981
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   982
	    OBJ rA = __INST(readAhead);                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   983
	    if (rA != nil) {                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   984
		(buf)[__ooffs+__offs] = __intVal(rA);   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   985
		DEBUGBUFFER(buf);                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   986
		__INST(readAhead) = nil;                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   987
		__offs++;                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   988
	    } else {                                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   989
		CLEAR_ERRNO;                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   990
		__cnt = READ(f, (buf)+__ooffs+__offs, (cnt)-__offs, handleType); \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   991
		DEBUGBUFFER(buf);                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   992
		if (__cnt <= 0) {                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   993
		    if (__cnt < 0 && errno == EINTR) {  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   994
			__HANDLE_INTERRUPTS__;          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   995
			/* refetch */                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   996
			buf = (char *)(obj);            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   997
			continue;                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   998
		    }                                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
   999
		    break;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1000
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1001
		__offs += __cnt;                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1002
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1003
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1004
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1005
	    (ret) = __offs;                             \
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1006
    }                                                   \
2593
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
  1007
  }
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  1008
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1009
# else /* use STDIO */
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  1010
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  1011
#  define __READBYTES_OBJ__(ret, f, obj, obj_offs, cnt, isBuffered, handleType)     \
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1012
  {                                                     \
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1013
    int __ooffs = obj_offs;                             \
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1014
    int __offs = 0;                                     \
7540
7cd542f29024 Fix reading when readAheadBuffer is filled and following read fails
Stefan Vogel <sv@exept.de>
parents: 7503
diff changeset
  1015
    int __cnt;                                          \
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1016
    char *buf = (char *)(obj);                          \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1017
							\
2513
a589586a3828 big bug: READBYTES & WRITEBYTES did not care for moving objects when interrupted.
Claus Gittinger <cg@exept.de>
parents: 2331
diff changeset
  1018
    (ret) = 0;                                          \
a589586a3828 big bug: READBYTES & WRITEBYTES did not care for moving objects when interrupted.
Claus Gittinger <cg@exept.de>
parents: 2331
diff changeset
  1019
    if (isBuffered) {                                   \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1020
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1021
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1022
	    (ret) = getc(f);                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1023
	    if ((ret) < 0) {                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1024
		if (ferror(f)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1025
		    if (errno == EINTR) {               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1026
			__HANDLE_INTERRUPTS__;          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1027
			clearerr(f);                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1028
			/* refetch */                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1029
			buf = (char *)(obj);            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1030
			DEBUGBUFFER(buf);               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1031
			continue;                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1032
		    }                                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1033
		} else {                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1034
		    (ret) = 0;                          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1035
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1036
		break;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1037
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1038
	    (buf)[__ooffs+__offs] = (ret);              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1039
	    DEBUGBUFFER(buf);                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1040
	    __offs++;                                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1041
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1042
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1043
	    (ret) = __offs;                             \
2513
a589586a3828 big bug: READBYTES & WRITEBYTES did not care for moving objects when interrupted.
Claus Gittinger <cg@exept.de>
parents: 2331
diff changeset
  1044
    } else {                                            \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1045
	int fd = fileno(f);                             \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1046
							\
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1047
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1048
	    OBJ rA = __INST(readAhead);                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1049
	    if (rA != nil) {                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1050
		(buf)[__ooffs+__offs] = __intVal(rA);   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1051
		DEBUGBUFFER(buf);                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1052
		__INST(readAhead) = nil;                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1053
		__offs++;                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1054
	    } else {                                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1055
		CLEAR_ERRNO;                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1056
		__cnt = read(fd, (buf)+__ooffs+__offs, (cnt)-__offs); \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1057
		DEBUGBUFFER(buf);                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1058
		if (__cnt <= 0) {                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1059
		    if (__cnt < 0 && errno == EINTR) {  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1060
			__HANDLE_INTERRUPTS__;          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1061
			/* refetch */                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1062
			buf = (char *)(obj);            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1063
			continue;                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1064
		    }                                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1065
		    break;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1066
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1067
		__offs += __cnt;                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1068
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1069
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1070
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1071
	    (ret) = __offs;                             \
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1072
    }                                                   \
2513
a589586a3828 big bug: READBYTES & WRITEBYTES did not care for moving objects when interrupted.
Claus Gittinger <cg@exept.de>
parents: 2331
diff changeset
  1073
  }
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1074
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  1075
# define __READAVAILBYTES_OBJ__(ret, f, obj, obj_offs, cnt, isBuffered, handleType)     \
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1076
  {                                                     \
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1077
    int __ooffs = obj_offs;                             \
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1078
    int __offs = 0;                                     \
7540
7cd542f29024 Fix reading when readAheadBuffer is filled and following read fails
Stefan Vogel <sv@exept.de>
parents: 7503
diff changeset
  1079
    int __cnt;                                          \
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1080
    char *buf = (char *)(obj);                          \
15342
d89884677c76 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15304
diff changeset
  1081
    int oldFlags;                                       \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1082
							\
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1083
    (ret) = 0;                                          \
15342
d89884677c76 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15304
diff changeset
  1084
    SETNONBLOCKING(fileno(f), oldFlags);                \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1085
							\
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1086
    if (isBuffered) {                                   \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1087
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1088
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1089
	    (ret) = getc(f);                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1090
	    if ((ret) < 0) {                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1091
		if (ferror(f)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1092
		    if (errno == EINTR) {               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1093
			clearerr(f);                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1094
			/* refetch */                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1095
			buf = (char *)(obj);            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1096
			(ret) = 0;                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1097
			break;                          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1098
		    }                                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1099
		} else {                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1100
		    (ret) = 0;                          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1101
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1102
		break;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1103
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1104
	    (buf)[__ooffs+__offs] = (ret);              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1105
	    DEBUGBUFFER(buf);                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1106
	    __offs++;                                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1107
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1108
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1109
	    (ret) = __offs;                             \
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1110
    } else {                                            \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1111
	int fd = fileno(f);                             \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1112
							\
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1113
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1114
	    OBJ rA = __INST(readAhead);                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1115
	    if (rA != nil) {                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1116
		(buf)[__ooffs+__offs] = __intVal(rA);   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1117
		DEBUGBUFFER(buf);                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1118
		__INST(readAhead) = nil;                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1119
		__offs++;                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1120
		continue;                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1121
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1122
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1123
	    __cnt = read(fd, (buf)+__ooffs+__offs, (cnt)-__offs); \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1124
	    DEBUGBUFFER(buf);                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1125
	    if (__cnt > 0) {                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1126
		__offs += __cnt;                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1127
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1128
	    break;                                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1129
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1130
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1131
	    (ret) = __offs;                             \
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1132
    }                                                   \
15342
d89884677c76 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15304
diff changeset
  1133
    SETFLAGS(fileno(f), oldFlags);                      \
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1134
  }
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1135
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1136
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1137
# endif /* use STDIO */
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
  1138
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
  1139
# ifdef NO_STDIO
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  1140
#  define __WRITEBYTE__(ret, f, buf, isBuffered, handleType)          \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1141
	for (;;) {                                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1142
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1143
	    (ret) = WRITE(f, buf, 1, handleType);       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1144
	    if ((ret) >= 0) break;                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1145
	    if (errno != EINTR) {                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1146
		break;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1147
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1148
	    __HANDLE_INTERRUPTS__;                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1149
	}
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1150
# else /* use STDIO */
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  1151
#  define __WRITEBYTE__(ret, f, buf, isBuffered, handleType)        \
2120
71c1870df7ba implemented 1-character readAhead for unbuffered streams;
Claus Gittinger <cg@exept.de>
parents: 2045
diff changeset
  1152
    if (isBuffered) {                                   \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1153
	for (;;) {                                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1154
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1155
	    ret = putc(*(buf), f);                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1156
	    if ((ret) >= 0) {                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1157
		(ret) = 1;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1158
	    } else if (ferror(f)) {                     \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1159
		/* SOLARIS/SPARC (2.6) generates spurious errors with errno = 0 */ \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1160
		if (errno == EINTR || errno == 0) {     \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1161
		    __HANDLE_INTERRUPTS__;              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1162
		    clearerr(f);                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1163
		    continue;                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1164
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1165
	    } else                                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1166
		(ret) = 0;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1167
	    break;                                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1168
	}                                               \
2120
71c1870df7ba implemented 1-character readAhead for unbuffered streams;
Claus Gittinger <cg@exept.de>
parents: 2045
diff changeset
  1169
    } else {                                            \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1170
	for (;;) {                                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1171
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1172
	    (ret) = write(fileno(f), buf, 1);           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1173
	    if ((ret) >= 0) break;                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1174
	    if (errno != EINTR) {                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1175
		break;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1176
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1177
	    __HANDLE_INTERRUPTS__;                      \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1178
	}                                               \
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1179
   }
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1180
# endif /* use STDIO */
1463
ace6b72b6f4a Use common macros to make interruptable system calls signal proof.
Stefan Vogel <sv@exept.de>
parents: 1422
diff changeset
  1181
2513
a589586a3828 big bug: READBYTES & WRITEBYTES did not care for moving objects when interrupted.
Claus Gittinger <cg@exept.de>
parents: 2331
diff changeset
  1182
/*
a589586a3828 big bug: READBYTES & WRITEBYTES did not care for moving objects when interrupted.
Claus Gittinger <cg@exept.de>
parents: 2331
diff changeset
  1183
 * write_bytes from a c-buffer
a589586a3828 big bug: READBYTES & WRITEBYTES did not care for moving objects when interrupted.
Claus Gittinger <cg@exept.de>
parents: 2331
diff changeset
  1184
 * (which may NOT move)
a589586a3828 big bug: READBYTES & WRITEBYTES did not care for moving objects when interrupted.
Claus Gittinger <cg@exept.de>
parents: 2331
diff changeset
  1185
 */
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
  1186
# ifdef NO_STDIO
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  1187
#  define __WRITEBYTES__(ret, f, buf, cnt, isBuffered, handleType)    \
2961
a188727d0619 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2920
diff changeset
  1188
    (ret) = 0;                                          \
a188727d0619 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2920
diff changeset
  1189
    {                                                   \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1190
	int __offs = 0;                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1191
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1192
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1193
	    ret = WRITE(f, (buf)+__offs, (cnt)-__offs, handleType); \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1194
	    if (ret <= 0) {                             \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1195
		if (ret < 0 && errno == EINTR) {        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1196
		    __HANDLE_INTERRUPTS__;              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1197
		    continue;                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1198
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1199
		break;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1200
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1201
	    __offs += (ret);                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1202
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1203
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1204
	    (ret) = __offs;                             \
2593
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
  1205
   }
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1206
# else /* use STDIO */
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  1207
#  define __WRITEBYTES__(ret, f, buf, cnt, isBuffered, handleType)    \
2961
a188727d0619 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2920
diff changeset
  1208
    (ret) = 0;                                          \
a188727d0619 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2920
diff changeset
  1209
    if (isBuffered) {                                   \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1210
	int __offs = 0;                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1211
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1212
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1213
	    (ret) = fwrite((buf)+__offs, 1, (cnt)-__offs, f);\
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1214
	    if ((ret) <= 0) {                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1215
		if (ferror(f)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1216
		    if (errno == EINTR) {               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1217
			__HANDLE_INTERRUPTS__;          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1218
			clearerr(f);                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1219
			continue;                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1220
		    }                                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1221
		} else {                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1222
		    (ret) = 0;                          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1223
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1224
		break;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1225
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1226
	    __offs += (ret);                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1227
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1228
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1229
	    (ret) = __offs;                             \
2961
a188727d0619 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2920
diff changeset
  1230
    } else {                                            \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1231
	int __offs = 0;                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1232
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1233
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1234
	    (ret) = write(fileno(f), (buf)+__offs, (cnt)-__offs);\
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1235
	    if ((ret) <= 0) {                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1236
		if ((ret) < 0) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1237
		    if (errno == EINTR) {               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1238
			__HANDLE_INTERRUPTS__;          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1239
			continue;                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1240
		    }                                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1241
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1242
		break;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1243
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1244
	    __offs += (ret);                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1245
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1246
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1247
	    (ret) = __offs;                             \
1463
ace6b72b6f4a Use common macros to make interruptable system calls signal proof.
Stefan Vogel <sv@exept.de>
parents: 1422
diff changeset
  1248
   }
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1249
# endif /* use STDIO */
1463
ace6b72b6f4a Use common macros to make interruptable system calls signal proof.
Stefan Vogel <sv@exept.de>
parents: 1422
diff changeset
  1250
223
3075043790b8 immediateInterr & errno cleanup
claus
parents: 216
diff changeset
  1251
/*
2513
a589586a3828 big bug: READBYTES & WRITEBYTES did not care for moving objects when interrupted.
Claus Gittinger <cg@exept.de>
parents: 2331
diff changeset
  1252
 * write_bytes from an object
a589586a3828 big bug: READBYTES & WRITEBYTES did not care for moving objects when interrupted.
Claus Gittinger <cg@exept.de>
parents: 2331
diff changeset
  1253
 * (which may be moved around by GC)
a589586a3828 big bug: READBYTES & WRITEBYTES did not care for moving objects when interrupted.
Claus Gittinger <cg@exept.de>
parents: 2331
diff changeset
  1254
 */
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
  1255
# ifdef NO_STDIO
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  1256
#  define __WRITEBYTES_OBJ__(ret, f, obj, obj_offs, cnt, isBuffered, handleType)            \
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1257
  {                                                     \
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1258
    int __ooffs = obj_offs;                             \
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1259
    int __offs = 0;                                     \
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1260
    char *buf = (char *)(obj);                          \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1261
							\
2961
a188727d0619 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2920
diff changeset
  1262
    (ret) = 0;                                          \
a188727d0619 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2920
diff changeset
  1263
    {                                                   \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1264
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1265
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1266
	    ret = WRITE(f, (buf)+__ooffs+__offs, (cnt)-__offs, handleType); \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1267
	    if (ret <= 0) {                             \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1268
		if (ret < 0 && errno == EINTR) {        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1269
		    __HANDLE_INTERRUPTS__;              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1270
		    /* refetch */                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1271
		    buf = (char *)(obj);                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1272
		    continue;                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1273
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1274
		break;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1275
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1276
	    __offs += (ret);                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1277
	}                                               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1278
	if (__offs > 0)                                 \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1279
	    (ret) = __offs;                             \
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1280
    }                                                   \
2593
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
  1281
  }
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1282
# else /* use STDIO */
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  1283
#  define __WRITEBYTES_OBJ__(ret, f, obj, obj_offs, cnt, isBuffered, handleType)            \
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1284
  {                                                     \
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1285
    int __ooffs = obj_offs;                             \
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1286
    int __offs = 0;                                     \
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1287
    char *buf = (char *)(obj);                          \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1288
							\
2961
a188727d0619 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2920
diff changeset
  1289
    (ret) = 0;                                          \
a188727d0619 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2920
diff changeset
  1290
    if (isBuffered) {                                   \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1291
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1292
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1293
	    (ret) = fwrite((buf)+__ooffs+__offs, 1, (cnt)-__offs, f);  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1294
	    if ((ret) <= 0) {                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1295
		if (ferror(f)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1296
		    if (errno == EINTR) {               \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1297
			__HANDLE_INTERRUPTS__;          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1298
			/* refetch */                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1299
			buf = (char *)(obj);            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1300
			clearerr(f);                    \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1301
			continue;                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1302
		    }                                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1303
		    break;                              \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1304
		} else {                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1305
		    (ret) = 0;                          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1306
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1307
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1308
	    __offs += (ret);                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1309
	}                                               \
2961
a188727d0619 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2920
diff changeset
  1310
    } else {                                            \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1311
	while (__offs < (cnt)) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1312
	    CLEAR_ERRNO;                                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1313
	    (ret) = write(fileno(f), (buf)+__ooffs+__offs, (cnt)-__offs); \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1314
	    if ((ret) <= 0) {                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1315
		if ((ret) < 0) {                        \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1316
		    if (errno == EINTR){                \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1317
			__HANDLE_INTERRUPTS__;          \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1318
			/* refetch */                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1319
			buf = (char *)(obj);            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1320
			continue;                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1321
		    }                                   \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1322
		}                                       \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1323
		break;                                  \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1324
	    }                                           \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1325
	    __offs += (ret);                            \
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1326
	}                                               \
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  1327
    }                                                   \
15845
2b732fc8a4f4 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15655
diff changeset
  1328
    if (__offs > 0)                                     \
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  1329
	(ret) = __offs;                                 \
2513
a589586a3828 big bug: READBYTES & WRITEBYTES did not care for moving objects when interrupted.
Claus Gittinger <cg@exept.de>
parents: 2331
diff changeset
  1330
  }
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1331
# endif /* use STDIO */
4913
4964b2c71d31 remerged ExtSTream_win32 into ExtStream.
Claus Gittinger <cg@exept.de>
parents: 4640
diff changeset
  1332
#endif /* unix */
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1333
%}
188
454ed0ee733e EINTR problems
claus
parents: 159
diff changeset
  1334
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1335
2045
1ad17ca6520f fall back to super>>nextPutLine: if argument is not a string.
Claus Gittinger <cg@exept.de>
parents: 2044
diff changeset
  1336
!ExternalStream class methodsFor:'documentation'!
22
847106305963 *** empty log message ***
claus
parents: 12
diff changeset
  1337
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
  1338
copyright
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
  1339
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
  1340
 COPYRIGHT (c) 1988 by Claus Gittinger
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1341
	      All Rights Reserved
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
  1342
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
  1343
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
  1344
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
  1345
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
  1346
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
  1347
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
  1348
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
  1349
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
  1350
!
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
  1351
22
847106305963 *** empty log message ***
claus
parents: 12
diff changeset
  1352
documentation
847106305963 *** empty log message ***
claus
parents: 12
diff changeset
  1353
"
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1354
    ExternalStream defines protocol common to Streams which have a file-descriptor and
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1355
    represent some file or communicationChannel of the underlying OperatingSystem.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1356
    ExternalStream is abstract; concrete classes are FileStream, PipeStream etc.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1357
159
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1358
    ExternalStreams can be in two modes: text- (the default) and binary-mode.
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1359
    In text-mode, the elements read/written are characters;
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1360
    while in binary-mode the basic elements are bytes which read/write as SmallIntegers
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1361
    in the range 0..255.
22
847106305963 *** empty log message ***
claus
parents: 12
diff changeset
  1362
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1363
    Also, the stream can be either in buffered or unbuffered mode. In buffered mode,
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1364
    data is not written until either a cr is written (in text mode) or a synchronizeOutput
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1365
    is sent (in both modes).
22
847106305963 *** empty log message ***
claus
parents: 12
diff changeset
  1366
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1367
    The underlying OperatingSystem streams may either be closed explicitely (sending a close)
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1368
    or just forgotten - in this case, the garbage collector will eventually collect the
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1369
    object AND a close will be performed automatically (but you will NOT know when this
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1370
    happens - so it is recommended, that you close your files when no longer needed).
159
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1371
    Closing is also suggested, since if smalltalk is finished (be it by purpose, or due to
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1372
    some crash) the data will not be in the file, if unclosed.
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1373
    All streams understand the close message, so it never hurts to use it (it is defined as
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1374
    a noop in one of the superclasses).
22
847106305963 *** empty log message ***
claus
parents: 12
diff changeset
  1375
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1376
    Most of the methods found here redefine inherited methods for better performance,
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1377
    since I/O from/to files should be fast.
22
847106305963 *** empty log message ***
claus
parents: 12
diff changeset
  1378
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1379
    Recovering a snapshot:
1295
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  1380
      not all streams can be restored to the state they had before - see the implementation of
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  1381
      reOpen in subclasses for more information.
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  1382
      For streams sitting on some communication channel (i.e. Pipes and Sockets) you should
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  1383
      reestablish the stream upon image restart (make someone dependent on ObjectMemory).
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  1384
      FileStreams are reopened and positioned to their offset they had at snapshot time.
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  1385
      This may fail, if the file was removed or renamed - or lead to confusion
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  1386
      if the contents changed in the meantime.
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  1387
      Therefore, it is a good idea to reopen files and check for these things at restart time.
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  1388
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  1389
    [Instance variables:]
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  1390
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1391
	handleType      <Symbol>        desribes what handle is:
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1392
					    win32: #fileHandle, #socketHandle,
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1393
						   #filePointer, #socketFilePointer, #pipeFilePointer
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1394
					    unix: #filePointer, #socketFilePointer, #pipeFilePointer
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1395
					needed for win32, which uses different APIs for the different handles (sigh)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1396
	handle          <Integer>       used to be always a filePointer somehow mapped to an integer (FILE* - not the fd);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1397
					now, either a filePointer or a handle (win32)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1398
	mode            <Symbol>        #readwrite, #readonly or #writeonly
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1399
	buffered        <Boolean>       true, if buffered (i.e. collects characters - does
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1400
					not output immediately)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1401
	binary          <Boolean>       true if in binary mode (reads bytes instead of chars)
17332
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  1402
	eolMode         <Symbol>        one of nil, #nl, #cr or #crlf.
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1403
					determines how lines should be terminated.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1404
					nil -> newLine (as in Unix);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1405
					#crlf -> with cr-lf (as in MSDOS)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1406
					#cr -> with cr (as in VMS)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1407
	hitEOF          <Boolean>       true, if EOF was reached
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1408
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1409
	lastErrorNumber <Integer>       the value of errno (only valid right after the error -
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1410
					updated with next i/o operation)
1295
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  1411
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  1412
    [Class variables:]
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1413
	Lobby           <Registry>      keeps track of used ext-streams (to free up FILE*'s)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1414
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1415
	StreamErrorSignal       <Signal> parent of all stream errors (see Stream class)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1416
	InvalidReadSignal       <Signal> raised on read from writeonly stream
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1417
	InvalidWriteSignal      <Signal> raised on write to readonly stream
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1418
	InvalidModeSignal       <Signal> raised on text I/O with binary-stream
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1419
					 or binary I/O with text-stream
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1420
	OpenErrorSignal         <Signal> raised if open fails
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1421
	StreamNotOpenSignal     <Signal> raised on I/O with non-open stream
159
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1422
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1423
    Additional notes:
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1424
      This class is implemented using the underlying stdio-c library package, which
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1425
      has both advantages and disadvantages: since it is portable (posix defined), porting
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1426
      ST/X to non-Unix machines is simplified. The disadvantage is that the stdio library
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1427
      has big problems handling unbounded Streams, since the EOF handling in stdio is
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1428
      not prepared for data to arrive after EOF has been reached - time will show, if we need
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1429
      a complete rewrite for UnboundedStream ...
325
claus
parents: 308
diff changeset
  1430
188
454ed0ee733e EINTR problems
claus
parents: 159
diff changeset
  1431
      Also, depending on the system, the stdio library behaves infriendly when signals
454ed0ee733e EINTR problems
claus
parents: 159
diff changeset
  1432
      occur while reading (for example, timer interrupts) - on real unixes (i.e. BSD) the signal
454ed0ee733e EINTR problems
claus
parents: 159
diff changeset
  1433
      is handled transparently - on SYS5.3 (i.e. non unixes :-) the read operation returns
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1434
      an error and errno is set to EINTR.
1295
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  1435
      Thats what the ugly code around all getc-calls is for ...
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  1436
      Since things get more and more ugly - we will rewrite ExternalStream
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  1437
      completely, to NOT use any stdio stuff (and do its buffering itself).
325
claus
parents: 308
diff changeset
  1438
claus
parents: 308
diff changeset
  1439
      Notice that typical stdio's use a single errno global variable to return an error code,
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1440
      this was bad design in the stdio lib (right from the very beginning), since it's much
325
claus
parents: 308
diff changeset
  1441
      harder to deal with this in the presence of lightweight processes, where errno gets
claus
parents: 308
diff changeset
  1442
      overwritten by an I/O operation done in another thread. (stdio should have been written
claus
parents: 308
diff changeset
  1443
      to return errno as a negative number ...).
claus
parents: 308
diff changeset
  1444
      To deal with this, the scheduler treats errno like a per-thread private variable,
claus
parents: 308
diff changeset
  1445
      and saves/restores the errno setting when switching to another thread.
claus
parents: 308
diff changeset
  1446
      (Notice that some thread packages do this also, but ST/X's thread implementation
claus
parents: 308
diff changeset
  1447
      does not depend on those, but instead uses a portable private package).
claus
parents: 308
diff changeset
  1448
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1449
      Finally, if an stdio-stream is open for both reading and writing, we have to call
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1450
      fseek whenever we are about to read after write and vice versa.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1451
      Two macros (__READING__ and __WRITING__) have been defined to be used before every
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1452
      fread/fgetc and fwrite/putc respectively.
1295
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  1453
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  1454
    [author:]
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1455
	Claus Gittinger
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1456
	Stefan Vogel (many, many fixes ...)
1295
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  1457
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  1458
    [see also:]
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1459
	FileStream Socket PipeStream
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  1460
	Filename OperatingSystem
22
847106305963 *** empty log message ***
claus
parents: 12
diff changeset
  1461
"
3255
eb76cba071a1 example
Claus Gittinger <cg@exept.de>
parents: 3235
diff changeset
  1462
!
eb76cba071a1 example
Claus Gittinger <cg@exept.de>
parents: 3235
diff changeset
  1463
eb76cba071a1 example
Claus Gittinger <cg@exept.de>
parents: 3235
diff changeset
  1464
examples
eb76cba071a1 example
Claus Gittinger <cg@exept.de>
parents: 3235
diff changeset
  1465
"
eb76cba071a1 example
Claus Gittinger <cg@exept.de>
parents: 3235
diff changeset
  1466
    open a file, read the contents and display it in a textView:
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1467
									[exBegin]
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1468
	|topView scrollPane textView fileStream text|
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1469
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1470
	topView := StandardSystemView new.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1471
	topView label:'contents of Makefile'.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1472
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1473
	scrollPane := HVScrollableView in:topView.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1474
	scrollPane origin:0.0@0.0 corner:1.0@1.0.
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1475
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1476
	textView := EditTextView new.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1477
	scrollPane scrolledView:textView.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1478
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1479
	fileStream := 'Makefile' asFilename readStream.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1480
	text := fileStream upToEnd.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1481
	fileStream close.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1482
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1483
	textView contents:text.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1484
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1485
	topView open.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1486
									[exEnd]
3255
eb76cba071a1 example
Claus Gittinger <cg@exept.de>
parents: 3235
diff changeset
  1487
eb76cba071a1 example
Claus Gittinger <cg@exept.de>
parents: 3235
diff changeset
  1488
eb76cba071a1 example
Claus Gittinger <cg@exept.de>
parents: 3235
diff changeset
  1489
    Notice, all of the above can also be done (simply) as:
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1490
									[exBegin]
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1491
	EditTextView openOn:'Makefile'
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1492
									[exEnd]
3255
eb76cba071a1 example
Claus Gittinger <cg@exept.de>
parents: 3235
diff changeset
  1493
"
22
847106305963 *** empty log message ***
claus
parents: 12
diff changeset
  1494
! !
847106305963 *** empty log message ***
claus
parents: 12
diff changeset
  1495
2045
1ad17ca6520f fall back to super>>nextPutLine: if argument is not a string.
Claus Gittinger <cg@exept.de>
parents: 2044
diff changeset
  1496
!ExternalStream class methodsFor:'initialization'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1497
18636
16d8110eb172 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 18372
diff changeset
  1498
closeFiles
16d8110eb172 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 18372
diff changeset
  1499
    "close all files.
16d8110eb172 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 18372
diff changeset
  1500
     To be called on exit of Smalltalk."
16d8110eb172 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 18372
diff changeset
  1501
16d8110eb172 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 18372
diff changeset
  1502
    Lobby do:[:eachFileStream |
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  1503
	eachFileStream close
18636
16d8110eb172 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 18372
diff changeset
  1504
    ].
16d8110eb172 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 18372
diff changeset
  1505
!
16d8110eb172 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 18372
diff changeset
  1506
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1507
initDefaultEOLMode
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1508
    OperatingSystem isUNIXlike ifTrue:[
17426
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  1509
	"/ unix EOL conventions
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  1510
	DefaultEOLMode := #nl
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1511
    ] ifFalse:[
17426
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  1512
	OperatingSystem isVMSlike ifTrue:[
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  1513
	    "/ vms EOL conventions
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  1514
	    DefaultEOLMode := #cr
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  1515
	] ifFalse:[
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  1516
	    "/ msdos EOL conventions
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  1517
	    "/ msdos uses #crlf. but we keep #nl here,
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  1518
	    "/ otherwise sending HTTP request over sockets fails
17420
f0895ae69f69 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17418
diff changeset
  1519
"/            DefaultEOLMode := #crlf
17426
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  1520
	    DefaultEOLMode := #nl
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  1521
	]
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1522
    ]
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1523
!
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1524
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1525
initModeStrings
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1526
    "initialize modeStrings which are passed down to the underlying
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1527
     fopen/fdopen functions."
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1528
3132
037027ae20fd msdos MUST use binary mode in I/O
Claus Gittinger <cg@exept.de>
parents: 3044
diff changeset
  1529
    OperatingSystem isMSDOSlike ifTrue:[
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1530
	ReadMode := 'rb'.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1531
	ReadWriteMode := 'rb+'.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1532
	WriteMode := 'wb'.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1533
	AppendMode := 'ab+'.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1534
	CreateReadWriteMode := 'wb+'.
3132
037027ae20fd msdos MUST use binary mode in I/O
Claus Gittinger <cg@exept.de>
parents: 3044
diff changeset
  1535
    ] ifFalse:[
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1536
	ReadMode := 'r'.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1537
	ReadWriteMode := 'r+'.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1538
	WriteMode := 'w'.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1539
	AppendMode := 'a+'.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1540
	CreateReadWriteMode := 'w+'.
3132
037027ae20fd msdos MUST use binary mode in I/O
Claus Gittinger <cg@exept.de>
parents: 3044
diff changeset
  1541
    ]
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1542
!
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1543
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1544
initialize
593
19d568779cf7 moved StreamErrorSignal into Stream;
Claus Gittinger <cg@exept.de>
parents: 583
diff changeset
  1545
    OpenErrorSignal isNil ifTrue:[
18312
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1546
	OpenErrorSignal := OpenError.
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1547
	OpenErrorSignal notifierString:'open error'.
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1548
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1549
	InvalidReadSignal := InvalidReadError.
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1550
	InvalidReadSignal notifierString:'stream does not support reading'.
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1551
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1552
	InvalidWriteSignal := InvalidWriteError.
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1553
	InvalidWriteSignal notifierString:'stream does not support writing'.
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1554
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1555
	InvalidModeSignal := InvalidModeError.
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1556
	InvalidModeSignal notifierString:'binary/text mode mismatch'.
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1557
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1558
	InvalidOperationSignal := InvalidOperationError.
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1559
	InvalidOperationSignal notifierString:'unsupported file operation'.
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1560
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1561
	StreamNotOpenSignal := StreamNotOpenError.
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1562
	StreamNotOpenSignal notifierString:'stream is not open'.
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1563
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1564
	StreamIOErrorSignal := StreamIOError.
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1565
	StreamIOErrorSignal notifierString:'I/O error'.
159
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1566
    ].
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1567
31
75f2b9f78be2 *** empty log message ***
claus
parents: 25
diff changeset
  1568
    Lobby isNil ifTrue:[
18312
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1569
	Lobby := Registry new.
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1570
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1571
	"want to get informed when returning from snapshot"
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1572
	ObjectMemory addDependent:self
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1573
    ].
5442
24b88d75396d only init once
Claus Gittinger <cg@exept.de>
parents: 5441
diff changeset
  1574
    DefaultEOLMode isNil ifTrue:[
18312
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1575
	self initDefaultEOLMode.
5442
24b88d75396d only init once
Claus Gittinger <cg@exept.de>
parents: 5441
diff changeset
  1576
    ].
24b88d75396d only init once
Claus Gittinger <cg@exept.de>
parents: 5441
diff changeset
  1577
    ReadMode isNil ifTrue:[
18312
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  1578
	self initModeStrings.
5442
24b88d75396d only init once
Claus Gittinger <cg@exept.de>
parents: 5441
diff changeset
  1579
    ].
3474
1af4d150dab4 added extra streamIOError signal.
Claus Gittinger <cg@exept.de>
parents: 3467
diff changeset
  1580
    "Modified: / 21.5.1998 / 16:33:53 / cg"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1581
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1582
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1583
reOpenFiles
4108
8c4a45bc70eb perform reOpen of streams earlier (before doing the view-reinit)
Claus Gittinger <cg@exept.de>
parents: 4093
diff changeset
  1584
    "reopen all files (if possible) after a snapShot load.
8c4a45bc70eb perform reOpen of streams earlier (before doing the view-reinit)
Claus Gittinger <cg@exept.de>
parents: 4093
diff changeset
  1585
     This is invoked via the #earlyRestart change notification."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1586
18636
16d8110eb172 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 18372
diff changeset
  1587
    Lobby do:[:eachFileStream |
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  1588
	eachFileStream reOpen
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1589
    ].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1590
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1591
1469
570ef7f8667b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1464
diff changeset
  1592
update:something with:aParameter from:changedObject
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1593
    "have to reopen files when returning from snapshot"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1594
4108
8c4a45bc70eb perform reOpen of streams earlier (before doing the view-reinit)
Claus Gittinger <cg@exept.de>
parents: 4093
diff changeset
  1595
    something == #earlyRestart ifTrue:[
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1596
	self reOpenFiles.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1597
	self initDefaultEOLMode
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1598
    ]
1469
570ef7f8667b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1464
diff changeset
  1599
570ef7f8667b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1464
diff changeset
  1600
    "Created: 15.6.1996 / 15:19:59 / cg"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1601
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1602
2045
1ad17ca6520f fall back to super>>nextPutLine: if argument is not a string.
Claus Gittinger <cg@exept.de>
parents: 2044
diff changeset
  1603
!ExternalStream class methodsFor:'instance creation'!
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  1604
12706
Stefan Vogel <sv@exept.de>
parents: 12704
diff changeset
  1605
forFileDescriptor:aFileDescriptor mode:modeSymbol
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1606
    "given a fileDescriptor, create an ExternalStream object
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1607
     to operate on this fd.
12706
Stefan Vogel <sv@exept.de>
parents: 12704
diff changeset
  1608
     The modeSymbol-argument is #readonly, #readwrite, ....
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1609
     This may be used to wrap fd's as returned by user
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1610
     primitive code, or to wrap pipe-fds into externalStreams."
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1611
12706
Stefan Vogel <sv@exept.de>
parents: 12704
diff changeset
  1612
    ^ self forFileDescriptor:aFileDescriptor mode:modeSymbol buffered:true handleType:nil
7002
7a5d55f87cd7 make pseudoTTYs unbuffered (req'd for UNIXWARE)
penk
parents: 6812
diff changeset
  1613
7a5d55f87cd7 make pseudoTTYs unbuffered (req'd for UNIXWARE)
penk
parents: 6812
diff changeset
  1614
    "
7a5d55f87cd7 make pseudoTTYs unbuffered (req'd for UNIXWARE)
penk
parents: 6812
diff changeset
  1615
     the example below will probably fail (15 is a random FD):
7a5d55f87cd7 make pseudoTTYs unbuffered (req'd for UNIXWARE)
penk
parents: 6812
diff changeset
  1616
7a5d55f87cd7 make pseudoTTYs unbuffered (req'd for UNIXWARE)
penk
parents: 6812
diff changeset
  1617
     |s|
7a5d55f87cd7 make pseudoTTYs unbuffered (req'd for UNIXWARE)
penk
parents: 6812
diff changeset
  1618
7a5d55f87cd7 make pseudoTTYs unbuffered (req'd for UNIXWARE)
penk
parents: 6812
diff changeset
  1619
     s := ExternalStream forFileDescriptor:15 mode:'r'.
7a5d55f87cd7 make pseudoTTYs unbuffered (req'd for UNIXWARE)
penk
parents: 6812
diff changeset
  1620
     s next.
7a5d55f87cd7 make pseudoTTYs unbuffered (req'd for UNIXWARE)
penk
parents: 6812
diff changeset
  1621
    "
7a5d55f87cd7 make pseudoTTYs unbuffered (req'd for UNIXWARE)
penk
parents: 6812
diff changeset
  1622
7a5d55f87cd7 make pseudoTTYs unbuffered (req'd for UNIXWARE)
penk
parents: 6812
diff changeset
  1623
    "Created: 29.2.1996 / 18:05:00 / cg"
7a5d55f87cd7 make pseudoTTYs unbuffered (req'd for UNIXWARE)
penk
parents: 6812
diff changeset
  1624
    "Modified: 29.2.1996 / 18:17:07 / cg"
7a5d55f87cd7 make pseudoTTYs unbuffered (req'd for UNIXWARE)
penk
parents: 6812
diff changeset
  1625
!
7a5d55f87cd7 make pseudoTTYs unbuffered (req'd for UNIXWARE)
penk
parents: 6812
diff changeset
  1626
12706
Stefan Vogel <sv@exept.de>
parents: 12704
diff changeset
  1627
forFileDescriptor:aFileDescriptor mode:modeSymbol buffered:buffered handleType:handleTypeSymbol
7002
7a5d55f87cd7 make pseudoTTYs unbuffered (req'd for UNIXWARE)
penk
parents: 6812
diff changeset
  1628
    "given a fileDescriptor, create an ExternalStream object
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1629
     to operate on this fd.
12706
Stefan Vogel <sv@exept.de>
parents: 12704
diff changeset
  1630
     The modeSymbol-argument is #readonly, #readwrite, ....
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1631
     This may be used to wrap fd's as returned by user
7002
7a5d55f87cd7 make pseudoTTYs unbuffered (req'd for UNIXWARE)
penk
parents: 6812
diff changeset
  1632
     primitive code, or to wrap pipe-fds into externalStreams."
7a5d55f87cd7 make pseudoTTYs unbuffered (req'd for UNIXWARE)
penk
parents: 6812
diff changeset
  1633
1048
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1634
    |newStream|
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1635
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1636
    newStream := self basicNew.
7002
7a5d55f87cd7 make pseudoTTYs unbuffered (req'd for UNIXWARE)
penk
parents: 6812
diff changeset
  1637
    newStream text; buffered:buffered; eolMode:DefaultEOLMode; clearEOF.
12706
Stefan Vogel <sv@exept.de>
parents: 12704
diff changeset
  1638
    ^ newStream connectTo:aFileDescriptor withMode:modeSymbol handleType:handleTypeSymbol
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1639
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1640
    "
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1641
     the example below will probably fail (15 is a random FD):
1048
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1642
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1643
     |s|
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1644
12706
Stefan Vogel <sv@exept.de>
parents: 12704
diff changeset
  1645
     s := ExternalStream forFileDescriptor:15 mode:#radonly handleType:#filePointer.
1048
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1646
     s next.
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1647
    "
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1648
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1649
    "Created: 29.2.1996 / 18:05:00 / cg"
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1650
    "Modified: 29.2.1996 / 18:17:07 / cg"
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1651
!
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1652
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1653
forReadWriteToFileDescriptor:aFileDescriptor
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1654
    "given a fileDescriptor, create an ExternalStream object
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1655
     to read/write from/to this fd. This may be used to wrap fd's
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1656
     as returned by user primitive code, or to wrap pipe-
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1657
     filedescriptors into externalStreams."
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1658
12706
Stefan Vogel <sv@exept.de>
parents: 12704
diff changeset
  1659
    ^ self forFileDescriptor:aFileDescriptor mode:#readWrite
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1660
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1661
    "
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1662
     the example below will probably fail (15 is a random FD):
1048
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1663
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1664
     |s|
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1665
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1666
     s := ExternalStream forReadWriteToFileDescriptor:15.
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1667
     s next.
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1668
    "
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1669
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1670
    "Created: 29.2.1996 / 18:15:08 / cg"
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1671
    "Modified: 29.2.1996 / 18:16:25 / cg"
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1672
!
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1673
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1674
forReadingFromFileDescriptor:aFileDescriptor
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1675
    "given a fileDescriptor, create an ExternalStream object
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1676
     to read from this fd. This may be used to wrap fd's
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1677
     as returned by user primitive code, or to wrap pipe-
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1678
     filedescriptors into externalStreams."
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1679
12706
Stefan Vogel <sv@exept.de>
parents: 12704
diff changeset
  1680
    ^ self forFileDescriptor:aFileDescriptor mode:#readonly
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1681
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1682
    "
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1683
     the example below will probably fail (15 is a random FD):
1048
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1684
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1685
     |s|
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1686
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1687
     s := ExternalStream forReadingFromFileDescriptor:15.
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1688
     s next.
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1689
    "
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1690
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1691
    "
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1692
     |pipe readFd writeFd rs ws|
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1693
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1694
     'create OS pipe ...'.
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1695
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1696
     pipe := OperatingSystem makePipe.
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1697
     readFd := pipe at:1.
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1698
     writeFd := pipe at:2.
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1699
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1700
     'connect Smalltalk streams ...'.
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1701
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1702
     rs := ExternalStream forReadingFromFileDescriptor:readFd.
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1703
     ws := ExternalStream forWritingToFileDescriptor:writeFd.
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1704
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1705
     'read ...'.
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1706
     [
14068
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  1707
	 1 to:10 do:[:i |
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  1708
	     Transcript showCR:rs nextLine
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  1709
	 ].
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  1710
	 rs close.
1048
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1711
     ] forkAt:7.
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1712
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1713
     'write ...'.
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1714
     [
14068
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  1715
	 1 to:10 do:[:i |
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  1716
	     ws nextPutAll:'hello world '; nextPutAll:i printString; cr
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  1717
	 ].
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  1718
	 ws close.
1048
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1719
     ] fork.
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1720
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1721
    "
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1722
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1723
    "Created: 29.2.1996 / 18:14:24 / cg"
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1724
    "Modified: 29.2.1996 / 18:25:02 / cg"
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1725
!
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1726
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1727
forWritingToFileDescriptor:aFileDescriptor
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1728
    "given a fileDescriptor, create an ExternalStream object
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1729
     to write to this fd. This may be used to wrap fd's
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1730
     as returned by user primitive code, or to wrap pipe-
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1731
     filedescriptors into externalStreams."
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1732
12706
Stefan Vogel <sv@exept.de>
parents: 12704
diff changeset
  1733
    ^ self forFileDescriptor:aFileDescriptor mode:#writeonly
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1734
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1735
    "
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  1736
     the example below will probably fail (15 is a random FD):
1048
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1737
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1738
     |s|
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1739
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1740
     s := ExternalStream forWritingToFileDescriptor:15.
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1741
     s binary.
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1742
     s nextPut:1.
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1743
    "
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1744
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1745
    "Created: 29.2.1996 / 18:14:43 / cg"
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1746
    "Modified: 29.2.1996 / 18:15:54 / cg"
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1747
!
c535c5a73cba added facilities to connect to given Fd's and #makePipe
Claus Gittinger <cg@exept.de>
parents: 1044
diff changeset
  1748
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  1749
new
15918
d5fe9b9e87d3 Initialize in instance initialize method insted in #new
Stefan Vogel <sv@exept.de>
parents: 15896
diff changeset
  1750
    "re-enable new - disabled in Stream superclass"
d5fe9b9e87d3 Initialize in instance initialize method insted in #new
Stefan Vogel <sv@exept.de>
parents: 15896
diff changeset
  1751
d5fe9b9e87d3 Initialize in instance initialize method insted in #new
Stefan Vogel <sv@exept.de>
parents: 15896
diff changeset
  1752
    ^ self basicNew initialize.
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  1753
! !
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  1754
2045
1ad17ca6520f fall back to super>>nextPutLine: if argument is not a string.
Claus Gittinger <cg@exept.de>
parents: 2044
diff changeset
  1755
!ExternalStream class methodsFor:'Signal constants'!
159
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1756
1522
1d0b4bc2e563 ST-80 compatibility: #contentsOfEntireFile must return a String.
Stefan Vogel <sv@exept.de>
parents: 1515
diff changeset
  1757
inaccessibleSignal
1d0b4bc2e563 ST-80 compatibility: #contentsOfEntireFile must return a String.
Stefan Vogel <sv@exept.de>
parents: 1515
diff changeset
  1758
    "ST-80 compatibility: return openErrorSignal"
1d0b4bc2e563 ST-80 compatibility: #contentsOfEntireFile must return a String.
Stefan Vogel <sv@exept.de>
parents: 1515
diff changeset
  1759
1d0b4bc2e563 ST-80 compatibility: #contentsOfEntireFile must return a String.
Stefan Vogel <sv@exept.de>
parents: 1515
diff changeset
  1760
    ^ self openErrorSignal
1d0b4bc2e563 ST-80 compatibility: #contentsOfEntireFile must return a String.
Stefan Vogel <sv@exept.de>
parents: 1515
diff changeset
  1761
1d0b4bc2e563 ST-80 compatibility: #contentsOfEntireFile must return a String.
Stefan Vogel <sv@exept.de>
parents: 1515
diff changeset
  1762
    "Created: 2.7.1996 / 12:27:16 / stefan"
1d0b4bc2e563 ST-80 compatibility: #contentsOfEntireFile must return a String.
Stefan Vogel <sv@exept.de>
parents: 1515
diff changeset
  1763
!
1d0b4bc2e563 ST-80 compatibility: #contentsOfEntireFile must return a String.
Stefan Vogel <sv@exept.de>
parents: 1515
diff changeset
  1764
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  1765
invalidModeSignal
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  1766
    "return the signal raised when doing text-I/O with a binary stream
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  1767
     or binary-I/O with a text stream"
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  1768
8074
4dce05d6d0a1 class based exceptions
Claus Gittinger <cg@exept.de>
parents: 8070
diff changeset
  1769
    ^ InvalidModeError
159
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1770
!
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1771
932
f57ec42ceb44 added interface to truncate & ftruncate (req. by Mr. Olberding)
Claus Gittinger <cg@exept.de>
parents: 872
diff changeset
  1772
invalidOperationSignal
f57ec42ceb44 added interface to truncate & ftruncate (req. by Mr. Olberding)
Claus Gittinger <cg@exept.de>
parents: 872
diff changeset
  1773
    "return the signal raised when an unsupported or invalid
f57ec42ceb44 added interface to truncate & ftruncate (req. by Mr. Olberding)
Claus Gittinger <cg@exept.de>
parents: 872
diff changeset
  1774
     I/O operation is attempted"
f57ec42ceb44 added interface to truncate & ftruncate (req. by Mr. Olberding)
Claus Gittinger <cg@exept.de>
parents: 872
diff changeset
  1775
8074
4dce05d6d0a1 class based exceptions
Claus Gittinger <cg@exept.de>
parents: 8070
diff changeset
  1776
    ^ InvalidOperationError
932
f57ec42ceb44 added interface to truncate & ftruncate (req. by Mr. Olberding)
Claus Gittinger <cg@exept.de>
parents: 872
diff changeset
  1777
!
f57ec42ceb44 added interface to truncate & ftruncate (req. by Mr. Olberding)
Claus Gittinger <cg@exept.de>
parents: 872
diff changeset
  1778
159
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1779
invalidReadSignal
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1780
    "return the signal raised when reading from writeonly streams"
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1781
8074
4dce05d6d0a1 class based exceptions
Claus Gittinger <cg@exept.de>
parents: 8070
diff changeset
  1782
    ^ InvalidReadError
159
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1783
!
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1784
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1785
invalidWriteSignal
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1786
    "return the signal raised when writing to readonly streams"
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1787
8074
4dce05d6d0a1 class based exceptions
Claus Gittinger <cg@exept.de>
parents: 8070
diff changeset
  1788
    ^ InvalidWriteError
159
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1789
!
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1790
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  1791
openErrorSignal
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  1792
    "return the signal raised when a file open failed"
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  1793
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  1794
    ^ OpenErrorSignal
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  1795
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  1796
3474
1af4d150dab4 added extra streamIOError signal.
Claus Gittinger <cg@exept.de>
parents: 3467
diff changeset
  1797
streamIOErrorSignal
1af4d150dab4 added extra streamIOError signal.
Claus Gittinger <cg@exept.de>
parents: 3467
diff changeset
  1798
    "return the signal raised when an I/O error occurs.
1af4d150dab4 added extra streamIOError signal.
Claus Gittinger <cg@exept.de>
parents: 3467
diff changeset
  1799
     (for example, a device-IO-error, or reading an NFS-dir,
1af4d150dab4 added extra streamIOError signal.
Claus Gittinger <cg@exept.de>
parents: 3467
diff changeset
  1800
     which is no longer available and has been mounted soft)"
1af4d150dab4 added extra streamIOError signal.
Claus Gittinger <cg@exept.de>
parents: 3467
diff changeset
  1801
8074
4dce05d6d0a1 class based exceptions
Claus Gittinger <cg@exept.de>
parents: 8070
diff changeset
  1802
    ^ StreamIOError
3474
1af4d150dab4 added extra streamIOError signal.
Claus Gittinger <cg@exept.de>
parents: 3467
diff changeset
  1803
1af4d150dab4 added extra streamIOError signal.
Claus Gittinger <cg@exept.de>
parents: 3467
diff changeset
  1804
    "Created: / 21.5.1998 / 16:32:55 / cg"
1af4d150dab4 added extra streamIOError signal.
Claus Gittinger <cg@exept.de>
parents: 3467
diff changeset
  1805
!
1af4d150dab4 added extra streamIOError signal.
Claus Gittinger <cg@exept.de>
parents: 3467
diff changeset
  1806
159
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1807
streamNotOpenSignal
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1808
    "return the signal raised on I/O with closed streams"
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1809
8074
4dce05d6d0a1 class based exceptions
Claus Gittinger <cg@exept.de>
parents: 8070
diff changeset
  1810
    ^ StreamNotOpenError
2
claus
parents: 1
diff changeset
  1811
! !
claus
parents: 1
diff changeset
  1812
2045
1ad17ca6520f fall back to super>>nextPutLine: if argument is not a string.
Claus Gittinger <cg@exept.de>
parents: 2044
diff changeset
  1813
!ExternalStream class methodsFor:'error handling'!
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1814
6269
3a888523e3a6 #errorReporter and #reportOn class-methods
Stefan Vogel <sv@exept.de>
parents: 6255
diff changeset
  1815
errorReporter
3a888523e3a6 #errorReporter and #reportOn class-methods
Stefan Vogel <sv@exept.de>
parents: 6255
diff changeset
  1816
    "I know about error codes"
3a888523e3a6 #errorReporter and #reportOn class-methods
Stefan Vogel <sv@exept.de>
parents: 6255
diff changeset
  1817
3a888523e3a6 #errorReporter and #reportOn class-methods
Stefan Vogel <sv@exept.de>
parents: 6255
diff changeset
  1818
    ^ self
3a888523e3a6 #errorReporter and #reportOn class-methods
Stefan Vogel <sv@exept.de>
parents: 6255
diff changeset
  1819
!
3a888523e3a6 #errorReporter and #reportOn class-methods
Stefan Vogel <sv@exept.de>
parents: 6255
diff changeset
  1820
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1821
lastErrorNumber
159
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1822
    "return the errno of the last error"
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1823
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1824
    ^ LastErrorNumber
159
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1825
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1826
    "
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1827
     ExternalStream lastErrorNumber
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  1828
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1829
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1830
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1831
lastErrorString
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1832
    "return a message string describing the last error"
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1833
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1834
    ^ OperatingSystem errorTextForNumber:LastErrorNumber
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1835
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1836
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1837
     ExternalStream lastErrorString
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1838
    "
6269
3a888523e3a6 #errorReporter and #reportOn class-methods
Stefan Vogel <sv@exept.de>
parents: 6255
diff changeset
  1839
!
3a888523e3a6 #errorReporter and #reportOn class-methods
Stefan Vogel <sv@exept.de>
parents: 6255
diff changeset
  1840
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1841
reportOn:anErrorSymbolOrNumber
6269
3a888523e3a6 #errorReporter and #reportOn class-methods
Stefan Vogel <sv@exept.de>
parents: 6255
diff changeset
  1842
    "an error occured.
3a888523e3a6 #errorReporter and #reportOn class-methods
Stefan Vogel <sv@exept.de>
parents: 6255
diff changeset
  1843
     Report it via an Exception"
3a888523e3a6 #errorReporter and #reportOn class-methods
Stefan Vogel <sv@exept.de>
parents: 6255
diff changeset
  1844
3a888523e3a6 #errorReporter and #reportOn class-methods
Stefan Vogel <sv@exept.de>
parents: 6255
diff changeset
  1845
    anErrorSymbolOrNumber isInteger ifTrue:[
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1846
	StreamError
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1847
	    raiseRequestWith:anErrorSymbolOrNumber
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1848
	    errorString:(' - os error:' , (OperatingSystem errorTextForNumber:anErrorSymbolOrNumber))
6269
3a888523e3a6 #errorReporter and #reportOn class-methods
Stefan Vogel <sv@exept.de>
parents: 6255
diff changeset
  1849
    ].
3a888523e3a6 #errorReporter and #reportOn class-methods
Stefan Vogel <sv@exept.de>
parents: 6255
diff changeset
  1850
    (self respondsTo:anErrorSymbolOrNumber) ifTrue:[
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1851
	self perform:anErrorSymbolOrNumber
6269
3a888523e3a6 #errorReporter and #reportOn class-methods
Stefan Vogel <sv@exept.de>
parents: 6255
diff changeset
  1852
    ] ifFalse:[
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1853
	StreamError
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1854
	    raiseRequestWith:anErrorSymbolOrNumber
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1855
	    errorString:(' - ' , anErrorSymbolOrNumber printString)
6269
3a888523e3a6 #errorReporter and #reportOn class-methods
Stefan Vogel <sv@exept.de>
parents: 6255
diff changeset
  1856
    ].
3a888523e3a6 #errorReporter and #reportOn class-methods
Stefan Vogel <sv@exept.de>
parents: 6255
diff changeset
  1857
    ^ false
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1858
! !
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1859
7497
cc29afd51151 Do not block when writing to pipes
Stefan Vogel <sv@exept.de>
parents: 7261
diff changeset
  1860
!ExternalStream class methodsFor:'obsolete'!
cc29afd51151 Do not block when writing to pipes
Stefan Vogel <sv@exept.de>
parents: 7261
diff changeset
  1861
cc29afd51151 Do not block when writing to pipes
Stefan Vogel <sv@exept.de>
parents: 7261
diff changeset
  1862
makePTYPair
cc29afd51151 Do not block when writing to pipes
Stefan Vogel <sv@exept.de>
parents: 7261
diff changeset
  1863
    "obsolete since 12-07-2003"
cc29afd51151 Do not block when writing to pipes
Stefan Vogel <sv@exept.de>
parents: 7261
diff changeset
  1864
    <resource:#obsolete>
cc29afd51151 Do not block when writing to pipes
Stefan Vogel <sv@exept.de>
parents: 7261
diff changeset
  1865
cc29afd51151 Do not block when writing to pipes
Stefan Vogel <sv@exept.de>
parents: 7261
diff changeset
  1866
    self obsoleteMethodWarning:'use NonPositionableExternalStream makePTYPair'.
cc29afd51151 Do not block when writing to pipes
Stefan Vogel <sv@exept.de>
parents: 7261
diff changeset
  1867
cc29afd51151 Do not block when writing to pipes
Stefan Vogel <sv@exept.de>
parents: 7261
diff changeset
  1868
    ^ NonPositionableExternalStream makePTYPair.
cc29afd51151 Do not block when writing to pipes
Stefan Vogel <sv@exept.de>
parents: 7261
diff changeset
  1869
!
cc29afd51151 Do not block when writing to pipes
Stefan Vogel <sv@exept.de>
parents: 7261
diff changeset
  1870
cc29afd51151 Do not block when writing to pipes
Stefan Vogel <sv@exept.de>
parents: 7261
diff changeset
  1871
makePipe
cc29afd51151 Do not block when writing to pipes
Stefan Vogel <sv@exept.de>
parents: 7261
diff changeset
  1872
    "obsolete since 12-07-2003"
cc29afd51151 Do not block when writing to pipes
Stefan Vogel <sv@exept.de>
parents: 7261
diff changeset
  1873
    <resource:#obsolete>
cc29afd51151 Do not block when writing to pipes
Stefan Vogel <sv@exept.de>
parents: 7261
diff changeset
  1874
cc29afd51151 Do not block when writing to pipes
Stefan Vogel <sv@exept.de>
parents: 7261
diff changeset
  1875
    self obsoleteMethodWarning:'use NonPositionableExternalStream makePipe'.
cc29afd51151 Do not block when writing to pipes
Stefan Vogel <sv@exept.de>
parents: 7261
diff changeset
  1876
cc29afd51151 Do not block when writing to pipes
Stefan Vogel <sv@exept.de>
parents: 7261
diff changeset
  1877
    ^ NonPositionableExternalStream makePipe.
cc29afd51151 Do not block when writing to pipes
Stefan Vogel <sv@exept.de>
parents: 7261
diff changeset
  1878
! !
cc29afd51151 Do not block when writing to pipes
Stefan Vogel <sv@exept.de>
parents: 7261
diff changeset
  1879
7261
f35fc9cee675 method category rename
Claus Gittinger <cg@exept.de>
parents: 7195
diff changeset
  1880
!ExternalStream methodsFor:'Compatibility-Dolphin'!
6474
92a666c5b104 dolphin compatibility
Claus Gittinger <cg@exept.de>
parents: 6461
diff changeset
  1881
92a666c5b104 dolphin compatibility
Claus Gittinger <cg@exept.de>
parents: 6461
diff changeset
  1882
beText
92a666c5b104 dolphin compatibility
Claus Gittinger <cg@exept.de>
parents: 6461
diff changeset
  1883
    self text
92a666c5b104 dolphin compatibility
Claus Gittinger <cg@exept.de>
parents: 6461
diff changeset
  1884
! !
92a666c5b104 dolphin compatibility
Claus Gittinger <cg@exept.de>
parents: 6461
diff changeset
  1885
7261
f35fc9cee675 method category rename
Claus Gittinger <cg@exept.de>
parents: 7195
diff changeset
  1886
!ExternalStream methodsFor:'Compatibility-Squeak'!
3044
a0bbac91639b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3029
diff changeset
  1887
3872
cab901645d2a added #nextInto: and #readInto: for Squeak compatibility.
Claus Gittinger <cg@exept.de>
parents: 3863
diff changeset
  1888
nextInto:aByteArrayOrString
cab901645d2a added #nextInto: and #readInto: for Squeak compatibility.
Claus Gittinger <cg@exept.de>
parents: 3863
diff changeset
  1889
    "read elements into the argument, whose size determines the amount
cab901645d2a added #nextInto: and #readInto: for Squeak compatibility.
Claus Gittinger <cg@exept.de>
parents: 3863
diff changeset
  1890
     of bytes to read. If not enough elements could be read, return
cab901645d2a added #nextInto: and #readInto: for Squeak compatibility.
Claus Gittinger <cg@exept.de>
parents: 3863
diff changeset
  1891
     a copy of the argument; otherwise, return the filled argument."
cab901645d2a added #nextInto: and #readInto: for Squeak compatibility.
Claus Gittinger <cg@exept.de>
parents: 3863
diff changeset
  1892
cab901645d2a added #nextInto: and #readInto: for Squeak compatibility.
Claus Gittinger <cg@exept.de>
parents: 3863
diff changeset
  1893
    |n nWanted|
cab901645d2a added #nextInto: and #readInto: for Squeak compatibility.
Claus Gittinger <cg@exept.de>
parents: 3863
diff changeset
  1894
4368
d69568f9ad95 squeak compatibility fixes
Claus Gittinger <cg@exept.de>
parents: 4161
diff changeset
  1895
    nWanted := aByteArrayOrString byteSize.
3872
cab901645d2a added #nextInto: and #readInto: for Squeak compatibility.
Claus Gittinger <cg@exept.de>
parents: 3863
diff changeset
  1896
    n := self nextAvailableBytes:nWanted into:aByteArrayOrString startingAt:1.
cab901645d2a added #nextInto: and #readInto: for Squeak compatibility.
Claus Gittinger <cg@exept.de>
parents: 3863
diff changeset
  1897
    n == nWanted ifTrue:[^ aByteArrayOrString].
cab901645d2a added #nextInto: and #readInto: for Squeak compatibility.
Claus Gittinger <cg@exept.de>
parents: 3863
diff changeset
  1898
    ^ aByteArrayOrString copyTo:n
cab901645d2a added #nextInto: and #readInto: for Squeak compatibility.
Claus Gittinger <cg@exept.de>
parents: 3863
diff changeset
  1899
cab901645d2a added #nextInto: and #readInto: for Squeak compatibility.
Claus Gittinger <cg@exept.de>
parents: 3863
diff changeset
  1900
!
cab901645d2a added #nextInto: and #readInto: for Squeak compatibility.
Claus Gittinger <cg@exept.de>
parents: 3863
diff changeset
  1901
4368
d69568f9ad95 squeak compatibility fixes
Claus Gittinger <cg@exept.de>
parents: 4161
diff changeset
  1902
readInto:aContainer startingAt:index count:nElements
d69568f9ad95 squeak compatibility fixes
Claus Gittinger <cg@exept.de>
parents: 4161
diff changeset
  1903
    "same as #nextBytes:into:startingAt: for ByteArrays;
d69568f9ad95 squeak compatibility fixes
Claus Gittinger <cg@exept.de>
parents: 4161
diff changeset
  1904
     for LongArrays, nelements longs are read.
3872
cab901645d2a added #nextInto: and #readInto: for Squeak compatibility.
Claus Gittinger <cg@exept.de>
parents: 3863
diff changeset
  1905
     Squeak compatibility."
cab901645d2a added #nextInto: and #readInto: for Squeak compatibility.
Claus Gittinger <cg@exept.de>
parents: 3863
diff changeset
  1906
4368
d69568f9ad95 squeak compatibility fixes
Claus Gittinger <cg@exept.de>
parents: 4161
diff changeset
  1907
    |elementSize n|
d69568f9ad95 squeak compatibility fixes
Claus Gittinger <cg@exept.de>
parents: 4161
diff changeset
  1908
d69568f9ad95 squeak compatibility fixes
Claus Gittinger <cg@exept.de>
parents: 4161
diff changeset
  1909
    elementSize := aContainer class elementByteSize.
13940
12eb1c056d5e fixed: #readInto:startingAt:count:; offset was wrong for non-byte elements
Claus Gittinger <cg@exept.de>
parents: 13927
diff changeset
  1910
    n := self nextBytes:nElements*elementSize into:aContainer startingAt:(index-1)*elementSize+1.
4368
d69568f9ad95 squeak compatibility fixes
Claus Gittinger <cg@exept.de>
parents: 4161
diff changeset
  1911
    ^ n // elementSize
3872
cab901645d2a added #nextInto: and #readInto: for Squeak compatibility.
Claus Gittinger <cg@exept.de>
parents: 3863
diff changeset
  1912
13940
12eb1c056d5e fixed: #readInto:startingAt:count:; offset was wrong for non-byte elements
Claus Gittinger <cg@exept.de>
parents: 13927
diff changeset
  1913
    "Modified: / 14-01-2012 / 19:00:35 / cg"
3872
cab901645d2a added #nextInto: and #readInto: for Squeak compatibility.
Claus Gittinger <cg@exept.de>
parents: 3863
diff changeset
  1914
!
cab901645d2a added #nextInto: and #readInto: for Squeak compatibility.
Claus Gittinger <cg@exept.de>
parents: 3863
diff changeset
  1915
3044
a0bbac91639b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3029
diff changeset
  1916
readOnly
a0bbac91639b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3029
diff changeset
  1917
    "Squeak compatibility: make the stream readOnly"
a0bbac91639b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3029
diff changeset
  1918
a0bbac91639b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3029
diff changeset
  1919
    mode := #readonly
a0bbac91639b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3029
diff changeset
  1920
a0bbac91639b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3029
diff changeset
  1921
    "Modified: 20.10.1997 / 19:23:04 / cg"
a0bbac91639b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3029
diff changeset
  1922
    "Created: 20.10.1997 / 19:23:19 / cg"
a0bbac91639b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3029
diff changeset
  1923
! !
a0bbac91639b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3029
diff changeset
  1924
5187
4bf3787cc63a category renamining
Claus Gittinger <cg@exept.de>
parents: 5120
diff changeset
  1925
!ExternalStream methodsFor:'Signal constants'!
4bf3787cc63a category renamining
Claus Gittinger <cg@exept.de>
parents: 5120
diff changeset
  1926
4bf3787cc63a category renamining
Claus Gittinger <cg@exept.de>
parents: 5120
diff changeset
  1927
invalidReadSignal
4bf3787cc63a category renamining
Claus Gittinger <cg@exept.de>
parents: 5120
diff changeset
  1928
    ^ self class invalidReadSignal
4bf3787cc63a category renamining
Claus Gittinger <cg@exept.de>
parents: 5120
diff changeset
  1929
4bf3787cc63a category renamining
Claus Gittinger <cg@exept.de>
parents: 5120
diff changeset
  1930
    "Created: / 3.12.1998 / 15:12:06 / cg"
4bf3787cc63a category renamining
Claus Gittinger <cg@exept.de>
parents: 5120
diff changeset
  1931
!
4bf3787cc63a category renamining
Claus Gittinger <cg@exept.de>
parents: 5120
diff changeset
  1932
4bf3787cc63a category renamining
Claus Gittinger <cg@exept.de>
parents: 5120
diff changeset
  1933
invalidWriteSignal
4bf3787cc63a category renamining
Claus Gittinger <cg@exept.de>
parents: 5120
diff changeset
  1934
    ^ self class invalidWriteSignal
4bf3787cc63a category renamining
Claus Gittinger <cg@exept.de>
parents: 5120
diff changeset
  1935
4bf3787cc63a category renamining
Claus Gittinger <cg@exept.de>
parents: 5120
diff changeset
  1936
    "Created: / 3.12.1998 / 15:12:10 / cg"
4bf3787cc63a category renamining
Claus Gittinger <cg@exept.de>
parents: 5120
diff changeset
  1937
! !
4bf3787cc63a category renamining
Claus Gittinger <cg@exept.de>
parents: 5120
diff changeset
  1938
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1939
!ExternalStream methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1940
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  1941
binary
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  1942
    "switch to binary mode - default is text"
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  1943
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  1944
    binary := true
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1945
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1946
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1947
buffered:aBoolean
10
claus
parents: 5
diff changeset
  1948
    "turn buffering on or off - default is on"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1949
10
claus
parents: 5
diff changeset
  1950
    buffered := aBoolean
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1951
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1952
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1953
contents
2
claus
parents: 1
diff changeset
  1954
    "return the contents of the file from the current position up-to
claus
parents: 1
diff changeset
  1955
     the end. If the stream is in binary mode, a ByteArray containing
claus
parents: 1
diff changeset
  1956
     the byte values is returned.
claus
parents: 1
diff changeset
  1957
     In text-mode, a collection of strings, each representing one line,
claus
parents: 1
diff changeset
  1958
     is returned."
claus
parents: 1
diff changeset
  1959
claus
parents: 1
diff changeset
  1960
    |text l chunks sizes chunk byteCount cnt bytes offset|
claus
parents: 1
diff changeset
  1961
claus
parents: 1
diff changeset
  1962
    binary ifTrue:[
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1963
	"adding to a ByteArray produces quadratic time-space
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1964
	 behavior - therefore we allocate chunks, and concatenate them
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1965
	 at the end."
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1966
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1967
	chunks := OrderedCollection new.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1968
	sizes := OrderedCollection new.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1969
	byteCount := 0.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1970
	[self atEnd] whileFalse:[
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1971
	    chunk := ByteArray uninitializedNew:4096.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1972
	    cnt := self nextBytes:(chunk size) into:chunk.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1973
	    cnt notNil ifTrue:[
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1974
		chunks add:chunk.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1975
		sizes add:cnt.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1976
		byteCount := byteCount + cnt
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1977
	    ]
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1978
	].
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1979
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1980
	"now, create one big ByteArray"
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1981
	bytes := ByteArray uninitializedNew:byteCount.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1982
	offset := 1.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1983
	1 to:chunks size do:[:index |
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1984
	    chunk := chunks at:index.
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  1985
	    cnt := sizes at:index.
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1986
	    bytes replaceFrom:offset to:(offset + cnt - 1) with:chunk.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1987
	    offset := offset + cnt
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1988
	].
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1989
	^ bytes
2
claus
parents: 1
diff changeset
  1990
    ].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1991
244
9faa2da0650a Text <-> StringCollection
claus
parents: 223
diff changeset
  1992
    text := StringCollection new.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1993
    [self atEnd] whileFalse:[
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1994
	l := self nextLine.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1995
	l isNil ifTrue:[
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1996
	    ^ text
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1997
	].
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  1998
	text add:l
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1999
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2000
    ^ text
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2001
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2002
11751
1e75c54748ef added #contentsAsString for Filename compatibility
Stefan Vogel <sv@exept.de>
parents: 11651
diff changeset
  2003
contentsAsString
1e75c54748ef added #contentsAsString for Filename compatibility
Stefan Vogel <sv@exept.de>
parents: 11651
diff changeset
  2004
    "to compensate for the bad naming, use this to make things explicit.
1e75c54748ef added #contentsAsString for Filename compatibility
Stefan Vogel <sv@exept.de>
parents: 11651
diff changeset
  2005
     See also #contents, which returns the lines as stringCollection for textFiles."
1e75c54748ef added #contentsAsString for Filename compatibility
Stefan Vogel <sv@exept.de>
parents: 11651
diff changeset
  2006
1e75c54748ef added #contentsAsString for Filename compatibility
Stefan Vogel <sv@exept.de>
parents: 11651
diff changeset
  2007
    ^ self contentsOfEntireFile
1e75c54748ef added #contentsAsString for Filename compatibility
Stefan Vogel <sv@exept.de>
parents: 11651
diff changeset
  2008
!
1e75c54748ef added #contentsAsString for Filename compatibility
Stefan Vogel <sv@exept.de>
parents: 11651
diff changeset
  2009
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2010
contentsOfEntireFile
3938
4e7d1880336b oops - #contentsOfEntireFile must return a byteArray if in binaryMode.
Claus Gittinger <cg@exept.de>
parents: 3906
diff changeset
  2011
    "ST-80 compatibility: return contents as a String (or byteArray, if in binary mode).
3876
a680b41a014c comment
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  2012
     See also #contents, which returns the lines as stringCollection for text files."
1522
1d0b4bc2e563 ST-80 compatibility: #contentsOfEntireFile must return a String.
Stefan Vogel <sv@exept.de>
parents: 1515
diff changeset
  2013
6305
53b87502fc21 Fix #contentsOfEntireFile
Stefan Vogel <sv@exept.de>
parents: 6269
diff changeset
  2014
    binary ifTrue:[
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  2015
	^ self contents.
3938
4e7d1880336b oops - #contentsOfEntireFile must return a byteArray if in binaryMode.
Claus Gittinger <cg@exept.de>
parents: 3906
diff changeset
  2016
    ].
6305
53b87502fc21 Fix #contentsOfEntireFile
Stefan Vogel <sv@exept.de>
parents: 6269
diff changeset
  2017
    ^ self upToEnd
1522
1d0b4bc2e563 ST-80 compatibility: #contentsOfEntireFile must return a String.
Stefan Vogel <sv@exept.de>
parents: 1515
diff changeset
  2018
3876
a680b41a014c comment
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  2019
    "Modified: / 3.7.1996 / 13:22:16 / stefan"
3938
4e7d1880336b oops - #contentsOfEntireFile must return a byteArray if in binaryMode.
Claus Gittinger <cg@exept.de>
parents: 3906
diff changeset
  2020
    "Modified: / 27.11.1998 / 16:29:43 / cg"
2
claus
parents: 1
diff changeset
  2021
!
claus
parents: 1
diff changeset
  2022
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2023
contentsSpecies
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2024
    "return the kind of object to be returned by sub-collection builders
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2025
     (such as upTo)"
159
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  2026
5441
e88302747bbd rel5 migration
Claus Gittinger <cg@exept.de>
parents: 5431
diff changeset
  2027
    binary == true ifTrue:[
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  2028
	^ ByteArray
159
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  2029
    ].
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2030
    ^ String
2
claus
parents: 1
diff changeset
  2031
!
claus
parents: 1
diff changeset
  2032
16776
fd62ae0ff6fa class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16551
diff changeset
  2033
eolMode
fd62ae0ff6fa class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16551
diff changeset
  2034
    "return how end-of-line (EOL) is to be marked.
fd62ae0ff6fa class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16551
diff changeset
  2035
     Returns one one of:
17432
c4deddc2545a fixed lineend handling; had segfaults here
Claus Gittinger <cg@exept.de>
parents: 17430
diff changeset
  2036
	#crlf         -> add a CR-NL, as in MSDOS
c4deddc2545a fixed lineend handling; had segfaults here
Claus Gittinger <cg@exept.de>
parents: 17430
diff changeset
  2037
	#cr           -> add a CR, as in VMS
c4deddc2545a fixed lineend handling; had segfaults here
Claus Gittinger <cg@exept.de>
parents: 17430
diff changeset
  2038
	#nl           -> add a NL, as in Unix
c4deddc2545a fixed lineend handling; had segfaults here
Claus Gittinger <cg@exept.de>
parents: 17430
diff changeset
  2039
	nil           -> transparent
16776
fd62ae0ff6fa class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16551
diff changeset
  2040
    "
fd62ae0ff6fa class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16551
diff changeset
  2041
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2042
    ^ eolMode
16776
fd62ae0ff6fa class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16551
diff changeset
  2043
!
fd62ae0ff6fa class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16551
diff changeset
  2044
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2045
eolMode:aSymbolOrNil
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2046
    "specify how end-of-line (EOL) is to be marked.
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2047
     The argument may be one of:
17432
c4deddc2545a fixed lineend handling; had segfaults here
Claus Gittinger <cg@exept.de>
parents: 17430
diff changeset
  2048
	#crlf         -> add a CR-NL, as in MSDOS
c4deddc2545a fixed lineend handling; had segfaults here
Claus Gittinger <cg@exept.de>
parents: 17430
diff changeset
  2049
	#cr           -> add a CR, as in VMS
c4deddc2545a fixed lineend handling; had segfaults here
Claus Gittinger <cg@exept.de>
parents: 17430
diff changeset
  2050
	#nl           -> add a NL, as in Unix
c4deddc2545a fixed lineend handling; had segfaults here
Claus Gittinger <cg@exept.de>
parents: 17430
diff changeset
  2051
	anyOther      -> like #nl
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2052
    "
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2053
17462
6448b4559e12 ouch: eolMode
Claus Gittinger <cg@exept.de>
parents: 17432
diff changeset
  2054
    aSymbolOrNil == #crnl ifTrue:[
6448b4559e12 ouch: eolMode
Claus Gittinger <cg@exept.de>
parents: 17432
diff changeset
  2055
	eolMode := #crlf
6448b4559e12 ouch: eolMode
Claus Gittinger <cg@exept.de>
parents: 17432
diff changeset
  2056
    ] ifFalse:[
6448b4559e12 ouch: eolMode
Claus Gittinger <cg@exept.de>
parents: 17432
diff changeset
  2057
	aSymbolOrNil == #lf ifTrue:[
6448b4559e12 ouch: eolMode
Claus Gittinger <cg@exept.de>
parents: 17432
diff changeset
  2058
	    eolMode := #nl
6448b4559e12 ouch: eolMode
Claus Gittinger <cg@exept.de>
parents: 17432
diff changeset
  2059
	] ifFalse:[
6448b4559e12 ouch: eolMode
Claus Gittinger <cg@exept.de>
parents: 17432
diff changeset
  2060
	    eolMode := aSymbolOrNil
6448b4559e12 ouch: eolMode
Claus Gittinger <cg@exept.de>
parents: 17432
diff changeset
  2061
	]
6448b4559e12 ouch: eolMode
Claus Gittinger <cg@exept.de>
parents: 17432
diff changeset
  2062
    ].
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2063
!
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2064
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2065
fileDescriptor
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2066
    "return the fileDescriptor of the receiver -
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2067
     notice: this one returns the underlying OSs fileDescriptor -
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2068
     this may not be available on all platforms (i.e. non unix systems)."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2069
3971
aad506cdc5d9 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3956
diff changeset
  2070
%{
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  2071
    OBJ _handle  = __INST(handle);
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  2072
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  2073
    if (_handle != nil) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2074
	if (__INST(handleType) == @symbol(socketHandle)) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2075
	    RETURN (_handle);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2076
	} else if ((__INST(handleType) == nil)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2077
		     || (__INST(handleType) == @symbol(filePointer))
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2078
		     || (__INST(handleType) == @symbol(socketFilePointer))
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2079
		     || (__INST(handleType) == @symbol(pipeFilePointer))) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2080
	    RETURN ( __MKINT(fileno(__FILEVal(_handle))));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2081
	}
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2082
    }
1067
1e7959af0821 removed all NOCONTEXT (last version did no good - PROTECT-stack overflow ...)
Claus Gittinger <cg@exept.de>
parents: 1066
diff changeset
  2083
%}.
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2084
    handle isNil ifTrue:[^ self errorNotOpen].
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2085
    ^ self fileDescriptorOfFile:handle
5852
338c6e0cab8f rel5 migration
Claus Gittinger <cg@exept.de>
parents: 5851
diff changeset
  2086
!
338c6e0cab8f rel5 migration
Claus Gittinger <cg@exept.de>
parents: 5851
diff changeset
  2087
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2088
fileDescriptorOfFile:handle
5852
338c6e0cab8f rel5 migration
Claus Gittinger <cg@exept.de>
parents: 5851
diff changeset
  2089
    "for migration to rel5 only:
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2090
     return the fileDescriptor of the argument handle -
5852
338c6e0cab8f rel5 migration
Claus Gittinger <cg@exept.de>
parents: 5851
diff changeset
  2091
     notice: this one returns the underlying OSs fileDescriptor -
338c6e0cab8f rel5 migration
Claus Gittinger <cg@exept.de>
parents: 5851
diff changeset
  2092
     this may not be available on all platforms (i.e. non unix systems)."
338c6e0cab8f rel5 migration
Claus Gittinger <cg@exept.de>
parents: 5851
diff changeset
  2093
18312
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  2094
%{
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  2095
#ifdef __SCHTEAM__
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  2096
    return context._RETURN(handle);
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  2097
#endif
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  2098
%}.
5852
338c6e0cab8f rel5 migration
Claus Gittinger <cg@exept.de>
parents: 5851
diff changeset
  2099
    self primitiveFailed
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2100
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2101
10455
8a434bc03256 +fileHandle
Claus Gittinger <cg@exept.de>
parents: 10450
diff changeset
  2102
fileHandle
8a434bc03256 +fileHandle
Claus Gittinger <cg@exept.de>
parents: 10450
diff changeset
  2103
    "return the fileHandle of the receiver.
8a434bc03256 +fileHandle
Claus Gittinger <cg@exept.de>
parents: 10450
diff changeset
  2104
     Under unix, this is the fileDescriptor; under windows, this is the Handle."
8a434bc03256 +fileHandle
Claus Gittinger <cg@exept.de>
parents: 10450
diff changeset
  2105
8a434bc03256 +fileHandle
Claus Gittinger <cg@exept.de>
parents: 10450
diff changeset
  2106
%{
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  2107
    OBJ _handle  = __INST(handle);
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  2108
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  2109
    if (_handle != nil) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2110
	if ((__INST(handleType) == @symbol(fileHandle))
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  2111
	 || (__INST(handleType) == @symbol(socketHandle))) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2112
	    RETURN (_handle);
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  2113
	}
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  2114
	if ((__INST(handleType) == nil)
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  2115
	 || (__INST(handleType) == @symbol(filePointer))
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  2116
	 || (__INST(handleType) == @symbol(socketFilePointer))
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  2117
	 || (__INST(handleType) == @symbol(pipeFilePointer))) {
10455
8a434bc03256 +fileHandle
Claus Gittinger <cg@exept.de>
parents: 10450
diff changeset
  2118
#ifdef WIN32
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2119
	    RETURN(__MKEXTERNALADDRESS(_get_osfhandle(fileno(__FILEVal(_handle)))));
10455
8a434bc03256 +fileHandle
Claus Gittinger <cg@exept.de>
parents: 10450
diff changeset
  2120
#else
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2121
	    RETURN (__MKINT(fileno(__FILEVal(_handle))));
10455
8a434bc03256 +fileHandle
Claus Gittinger <cg@exept.de>
parents: 10450
diff changeset
  2122
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2123
	}
10455
8a434bc03256 +fileHandle
Claus Gittinger <cg@exept.de>
parents: 10450
diff changeset
  2124
    }
8a434bc03256 +fileHandle
Claus Gittinger <cg@exept.de>
parents: 10450
diff changeset
  2125
%}.
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2126
    handle isNil ifTrue:[^ self errorNotOpen].
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  2127
    ^ handle
10455
8a434bc03256 +fileHandle
Claus Gittinger <cg@exept.de>
parents: 10450
diff changeset
  2128
!
8a434bc03256 +fileHandle
Claus Gittinger <cg@exept.de>
parents: 10450
diff changeset
  2129
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2130
filePointer
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2131
    "return the filePointer of the receiver -
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2132
     notice: for portability stdio is used; this means you will get
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  2133
     a FILE * - not a fileDescriptor.
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2134
     (what you really get is a corresponding integer).
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  2135
     You cannot do much with the returned value
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2136
     - except passing it to a primitive, for example."
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2137
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2138
    (handleType isNil or:[handleType == #filePointer]) ifTrue:[
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2139
	^ handle
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2140
    ].
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2141
    ^ self error:'not a FILE*'
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2142
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2143
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  2144
handleType
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  2145
    ^ handleType
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  2146
!
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  2147
5323
f4c3a230f42f more VW compatibility
Claus Gittinger <cg@exept.de>
parents: 5204
diff changeset
  2148
lineEndCRLF
f4c3a230f42f more VW compatibility
Claus Gittinger <cg@exept.de>
parents: 5204
diff changeset
  2149
    eolMode := #crlf
f4c3a230f42f more VW compatibility
Claus Gittinger <cg@exept.de>
parents: 5204
diff changeset
  2150
!
f4c3a230f42f more VW compatibility
Claus Gittinger <cg@exept.de>
parents: 5204
diff changeset
  2151
17672
758c3ff0c9e0 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17634
diff changeset
  2152
lineEndLF
758c3ff0c9e0 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17634
diff changeset
  2153
    eolMode := #nl
758c3ff0c9e0 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17634
diff changeset
  2154
!
758c3ff0c9e0 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17634
diff changeset
  2155
3016
42466b291fae more ST80 compatibility
ca
parents: 2999
diff changeset
  2156
lineEndTransparent
17426
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  2157
    eolMode := #nl
3016
42466b291fae more ST80 compatibility
ca
parents: 2999
diff changeset
  2158
!
42466b291fae more ST80 compatibility
ca
parents: 2999
diff changeset
  2159
8069
fdf460457c96 acessing: pathName added (returns nil)
Michael Beyl <mb@exept.de>
parents: 8066
diff changeset
  2160
pathName
8511
eb02df149f42 Raise proceedable exception proceedable.
Stefan Vogel <sv@exept.de>
parents: 8472
diff changeset
  2161
    "answer the pathName of the stream.
eb02df149f42 Raise proceedable exception proceedable.
Stefan Vogel <sv@exept.de>
parents: 8472
diff changeset
  2162
     Only FileStreams know the pathName, so we return an empty string here"
eb02df149f42 Raise proceedable exception proceedable.
Stefan Vogel <sv@exept.de>
parents: 8472
diff changeset
  2163
eb02df149f42 Raise proceedable exception proceedable.
Stefan Vogel <sv@exept.de>
parents: 8472
diff changeset
  2164
    ^ ''
8069
fdf460457c96 acessing: pathName added (returns nil)
Michael Beyl <mb@exept.de>
parents: 8066
diff changeset
  2165
!
fdf460457c96 acessing: pathName added (returns nil)
Michael Beyl <mb@exept.de>
parents: 8066
diff changeset
  2166
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2167
readonly
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2168
    "set access mode to readonly"
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2169
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2170
    mode := #readonly
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2171
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2172
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2173
readwrite
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2174
    "set access mode to readwrite"
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2175
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2176
    mode := #readwrite
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2177
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2178
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2179
text
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2180
    "switch to text mode - default is text"
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2181
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2182
    binary := false
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2183
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2184
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2185
useCRLF:aBoolean
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2186
    "turn on or off CRLF sending (instead of LF only) - default is off.
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2187
     This method is provided for backward compatibility - see #eolMode:
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2188
     which offers another choice."
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2189
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2190
    aBoolean ifTrue:[
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  2191
	eolMode := #crlf
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2192
    ] ifFalse:[
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  2193
	eolMode := #nl
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2194
    ].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2195
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2196
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2197
writeonly
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2198
    "set access mode to writeonly"
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2199
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2200
    mode := #writeonly
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2201
! !
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2202
8966
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  2203
!ExternalStream methodsFor:'closing'!
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  2204
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  2205
close
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  2206
    "close the stream.
16300
277c0cb1ecbc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16296
diff changeset
  2207
     No error of the stream is not open."
8966
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  2208
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  2209
    self isOpen ifTrue:[
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  2210
	Lobby unregister:self.
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  2211
	self closeFile.
16300
277c0cb1ecbc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16296
diff changeset
  2212
    ].
8966
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  2213
!
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  2214
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  2215
shutDown
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  2216
    "close the stream - added for protocol compatibility with PipeStream.
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  2217
     see comment there"
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  2218
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  2219
    self isOpen ifTrue:[
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  2220
	Lobby unregister:self.
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  2221
	self closeFile
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  2222
    ]
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  2223
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  2224
    "Modified: 30.8.1996 / 00:39:21 / cg"
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  2225
! !
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  2226
10982
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2227
!ExternalStream methodsFor:'copying'!
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2228
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2229
copy
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2230
    "answer a copy of myself.
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2231
     Have to dup the filedescriptor"
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2232
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2233
    |copy|
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2234
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2235
    copy := super copy.
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2236
    copy dupFd.
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2237
    Lobby register:copy.
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2238
    ^ copy
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2239
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2240
    "
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2241
       |stream1 stream2|
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2242
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2243
       stream1 := Filename newTemporary writeStream.
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2244
       stream2 := stream1 copy.
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2245
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2246
       stream1 inspect.
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2247
       stream2 inspect.
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2248
    "
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2249
! !
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  2250
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2251
!ExternalStream methodsFor:'error handling'!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2252
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2253
argumentMustBeCharacter
14440
88e708da1ae1 changed:
Stefan Vogel <sv@exept.de>
parents: 14438
diff changeset
  2254
    "report an error, that the argument must be a character in 0..FF"
88e708da1ae1 changed:
Stefan Vogel <sv@exept.de>
parents: 14438
diff changeset
  2255
1119
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2256
    "{ Pragma: +optSpace }"
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2257
14440
88e708da1ae1 changed:
Stefan Vogel <sv@exept.de>
parents: 14438
diff changeset
  2258
    ArgumentError raiseErrorString:' - argument must be a single byte character'
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2259
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2260
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2261
argumentMustBeInteger
14440
88e708da1ae1 changed:
Stefan Vogel <sv@exept.de>
parents: 14438
diff changeset
  2262
    "report an error, that the argument must be an integer"
88e708da1ae1 changed:
Stefan Vogel <sv@exept.de>
parents: 14438
diff changeset
  2263
1119
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2264
    "{ Pragma: +optSpace }"
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2265
14440
88e708da1ae1 changed:
Stefan Vogel <sv@exept.de>
parents: 14438
diff changeset
  2266
    ArgumentError raiseErrorString:' - argument must be an integer'
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2267
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2268
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2269
argumentMustBeString
14440
88e708da1ae1 changed:
Stefan Vogel <sv@exept.de>
parents: 14438
diff changeset
  2270
    "report an error, that the argument must be a string"
88e708da1ae1 changed:
Stefan Vogel <sv@exept.de>
parents: 14438
diff changeset
  2271
1119
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2272
    "{ Pragma: +optSpace }"
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2273
14440
88e708da1ae1 changed:
Stefan Vogel <sv@exept.de>
parents: 14438
diff changeset
  2274
    ArgumentError raiseErrorString:' - argument must be a string'
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2275
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2276
4526
a42dc8e09586 errorOpen renamed to errorAlreadyOpen
Claus Gittinger <cg@exept.de>
parents: 4468
diff changeset
  2277
errorAlreadyOpen
a42dc8e09586 errorOpen renamed to errorAlreadyOpen
Claus Gittinger <cg@exept.de>
parents: 4468
diff changeset
  2278
    "{ Pragma: +optSpace }"
a42dc8e09586 errorOpen renamed to errorAlreadyOpen
Claus Gittinger <cg@exept.de>
parents: 4468
diff changeset
  2279
a42dc8e09586 errorOpen renamed to errorAlreadyOpen
Claus Gittinger <cg@exept.de>
parents: 4468
diff changeset
  2280
    "report an error, that the stream is already opened"
a42dc8e09586 errorOpen renamed to errorAlreadyOpen
Claus Gittinger <cg@exept.de>
parents: 4468
diff changeset
  2281
8074
4dce05d6d0a1 class based exceptions
Claus Gittinger <cg@exept.de>
parents: 8070
diff changeset
  2282
    ^ OpenError
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  2283
	raiseRequestWith:self
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  2284
	errorString:' - stream is already open'
8511
eb02df149f42 Raise proceedable exception proceedable.
Stefan Vogel <sv@exept.de>
parents: 8472
diff changeset
  2285
eb02df149f42 Raise proceedable exception proceedable.
Stefan Vogel <sv@exept.de>
parents: 8472
diff changeset
  2286
    "
eb02df149f42 Raise proceedable exception proceedable.
Stefan Vogel <sv@exept.de>
parents: 8472
diff changeset
  2287
      self new errorAlreadyOpen
eb02df149f42 Raise proceedable exception proceedable.
Stefan Vogel <sv@exept.de>
parents: 8472
diff changeset
  2288
    "
4526
a42dc8e09586 errorOpen renamed to errorAlreadyOpen
Claus Gittinger <cg@exept.de>
parents: 4468
diff changeset
  2289
a42dc8e09586 errorOpen renamed to errorAlreadyOpen
Claus Gittinger <cg@exept.de>
parents: 4468
diff changeset
  2290
    "Modified: / 8.5.1999 / 20:12:30 / cg"
a42dc8e09586 errorOpen renamed to errorAlreadyOpen
Claus Gittinger <cg@exept.de>
parents: 4468
diff changeset
  2291
!
a42dc8e09586 errorOpen renamed to errorAlreadyOpen
Claus Gittinger <cg@exept.de>
parents: 4468
diff changeset
  2292
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2293
errorBinary
1119
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2294
    "{ Pragma: +optSpace }"
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2295
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2296
    "report an error, that the stream is in binary mode"
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2297
8074
4dce05d6d0a1 class based exceptions
Claus Gittinger <cg@exept.de>
parents: 8070
diff changeset
  2298
    ^ InvalidModeError
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  2299
	raiseRequestWith:self
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  2300
	errorString:(self class name , ' is in binary mode')
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  2301
	"/ in:thisContext sender
4161
3f2758cfeff5 raise errors in thisContext (not in sender context)
Claus Gittinger <cg@exept.de>
parents: 4152
diff changeset
  2302
3f2758cfeff5 raise errors in thisContext (not in sender context)
Claus Gittinger <cg@exept.de>
parents: 4152
diff changeset
  2303
    "Modified: / 8.5.1999 / 20:12:43 / cg"
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2304
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2305
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2306
errorNotBinary
1119
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2307
    "{ Pragma: +optSpace }"
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2308
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2309
    "report an error, that the stream is not in binary mode"
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2310
8074
4dce05d6d0a1 class based exceptions
Claus Gittinger <cg@exept.de>
parents: 8070
diff changeset
  2311
    ^ InvalidModeError
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  2312
	raiseRequestWith:self
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  2313
	errorString:(self class name , ' is not in binary mode')
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  2314
	"/ in:thisContext sender
4161
3f2758cfeff5 raise errors in thisContext (not in sender context)
Claus Gittinger <cg@exept.de>
parents: 4152
diff changeset
  2315
3f2758cfeff5 raise errors in thisContext (not in sender context)
Claus Gittinger <cg@exept.de>
parents: 4152
diff changeset
  2316
    "Modified: / 8.5.1999 / 20:12:40 / cg"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2317
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2318
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2319
errorNotBuffered
1119
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2320
    "{ Pragma: +optSpace }"
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2321
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2322
    "report an error, that the stream is not in buffered mode"
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2323
8074
4dce05d6d0a1 class based exceptions
Claus Gittinger <cg@exept.de>
parents: 8070
diff changeset
  2324
    ^ StreamError
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  2325
	raiseRequestWith:self
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  2326
	errorString:(self class name , ' is unbuffered - operation not allowed')
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  2327
	"/ in:thisContext sender
4161
3f2758cfeff5 raise errors in thisContext (not in sender context)
Claus Gittinger <cg@exept.de>
parents: 4152
diff changeset
  2328
3f2758cfeff5 raise errors in thisContext (not in sender context)
Claus Gittinger <cg@exept.de>
parents: 4152
diff changeset
  2329
    "Modified: / 8.5.1999 / 20:12:36 / cg"
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2330
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2331
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2332
errorNotOpen
1119
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2333
    "{ Pragma: +optSpace }"
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2334
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2335
    "report an error, that the stream has not been opened"
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2336
8511
eb02df149f42 Raise proceedable exception proceedable.
Stefan Vogel <sv@exept.de>
parents: 8472
diff changeset
  2337
    ^ StreamNotOpenError raiseRequestWith:self  "/ in:thisContext sender
4161
3f2758cfeff5 raise errors in thisContext (not in sender context)
Claus Gittinger <cg@exept.de>
parents: 4152
diff changeset
  2338
3f2758cfeff5 raise errors in thisContext (not in sender context)
Claus Gittinger <cg@exept.de>
parents: 4152
diff changeset
  2339
    "Modified: / 8.5.1999 / 20:12:33 / cg"
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2340
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2341
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2342
errorReadOnly
1119
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2343
    "{ Pragma: +optSpace }"
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2344
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2345
    "report an error, that the stream is a readOnly stream"
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2346
8511
eb02df149f42 Raise proceedable exception proceedable.
Stefan Vogel <sv@exept.de>
parents: 8472
diff changeset
  2347
    ^ InvalidWriteSignal raiseRequestWith:self "/ in:thisContext sender
4161
3f2758cfeff5 raise errors in thisContext (not in sender context)
Claus Gittinger <cg@exept.de>
parents: 4152
diff changeset
  2348
4468
8c67b4f973d8 raise vs. raiseRequest
Claus Gittinger <cg@exept.de>
parents: 4456
diff changeset
  2349
    "Modified: / 30.7.1999 / 17:08:19 / cg"
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2350
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2351
6255
d68343dc8288 Define #errorReporter and #reportError: (ST-80 protocol)
Stefan Vogel <sv@exept.de>
parents: 6012
diff changeset
  2352
errorReporter
d68343dc8288 Define #errorReporter and #reportError: (ST-80 protocol)
Stefan Vogel <sv@exept.de>
parents: 6012
diff changeset
  2353
    "ST-80 mimicry."
d68343dc8288 Define #errorReporter and #reportError: (ST-80 protocol)
Stefan Vogel <sv@exept.de>
parents: 6012
diff changeset
  2354
6269
3a888523e3a6 #errorReporter and #reportOn class-methods
Stefan Vogel <sv@exept.de>
parents: 6255
diff changeset
  2355
    ^ self class
6255
d68343dc8288 Define #errorReporter and #reportError: (ST-80 protocol)
Stefan Vogel <sv@exept.de>
parents: 6012
diff changeset
  2356
!
d68343dc8288 Define #errorReporter and #reportError: (ST-80 protocol)
Stefan Vogel <sv@exept.de>
parents: 6012
diff changeset
  2357
932
f57ec42ceb44 added interface to truncate & ftruncate (req. by Mr. Olberding)
Claus Gittinger <cg@exept.de>
parents: 872
diff changeset
  2358
errorUnsupportedOperation
1119
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2359
    "{ Pragma: +optSpace }"
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2360
932
f57ec42ceb44 added interface to truncate & ftruncate (req. by Mr. Olberding)
Claus Gittinger <cg@exept.de>
parents: 872
diff changeset
  2361
    "report an error, that some unsupported operation was attempted"
f57ec42ceb44 added interface to truncate & ftruncate (req. by Mr. Olberding)
Claus Gittinger <cg@exept.de>
parents: 872
diff changeset
  2362
8511
eb02df149f42 Raise proceedable exception proceedable.
Stefan Vogel <sv@exept.de>
parents: 8472
diff changeset
  2363
    ^ InvalidOperationError raiseRequestWith:self  "/ in:thisContext sender
4161
3f2758cfeff5 raise errors in thisContext (not in sender context)
Claus Gittinger <cg@exept.de>
parents: 4152
diff changeset
  2364
3f2758cfeff5 raise errors in thisContext (not in sender context)
Claus Gittinger <cg@exept.de>
parents: 4152
diff changeset
  2365
    "Modified: / 8.5.1999 / 20:12:24 / cg"
932
f57ec42ceb44 added interface to truncate & ftruncate (req. by Mr. Olberding)
Claus Gittinger <cg@exept.de>
parents: 872
diff changeset
  2366
!
f57ec42ceb44 added interface to truncate & ftruncate (req. by Mr. Olberding)
Claus Gittinger <cg@exept.de>
parents: 872
diff changeset
  2367
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2368
errorWriteOnly
1119
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2369
    "{ Pragma: +optSpace }"
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2370
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2371
    "report an error, that the stream is a writeOnly stream"
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2372
8511
eb02df149f42 Raise proceedable exception proceedable.
Stefan Vogel <sv@exept.de>
parents: 8472
diff changeset
  2373
    ^ InvalidReadError raiseRequestWith:self  "/ in:thisContext sender
4161
3f2758cfeff5 raise errors in thisContext (not in sender context)
Claus Gittinger <cg@exept.de>
parents: 4152
diff changeset
  2374
3f2758cfeff5 raise errors in thisContext (not in sender context)
Claus Gittinger <cg@exept.de>
parents: 4152
diff changeset
  2375
    "Modified: / 8.5.1999 / 20:12:20 / cg"
2
claus
parents: 1
diff changeset
  2376
!
claus
parents: 1
diff changeset
  2377
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2378
ioError
3474
1af4d150dab4 added extra streamIOError signal.
Claus Gittinger <cg@exept.de>
parents: 3467
diff changeset
  2379
    "report an error, that some I/O error occured.
1af4d150dab4 added extra streamIOError signal.
Claus Gittinger <cg@exept.de>
parents: 3467
diff changeset
  2380
     (for example, a device-IO-error, or reading an NFS-dir,
1af4d150dab4 added extra streamIOError signal.
Claus Gittinger <cg@exept.de>
parents: 3467
diff changeset
  2381
     which is no longer available and has been mounted soft)"
1af4d150dab4 added extra streamIOError signal.
Claus Gittinger <cg@exept.de>
parents: 3467
diff changeset
  2382
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2383
    "{ Pragma: +optSpace }"
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2384
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2385
    self ioError:lastErrorNumber
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2386
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2387
    "Modified: / 8.5.1999 / 20:12:16 / cg"
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2388
!
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2389
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2390
ioError:errorNumber
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2391
    "report an error, that some I/O error occured.
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2392
     (for example, a device-IO-error, or reading an NFS-dir,
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2393
     which is no longer available and has been mounted soft)"
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2394
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2395
    "{ Pragma: +optSpace }"
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2396
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2397
    ^ StreamIOError newException
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2398
	errorCode:errorNumber;
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2399
	osErrorHolder:(OperatingSystem errorHolderForNumber:errorNumber);
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2400
	parameter:self;
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2401
	raiseRequest
4161
3f2758cfeff5 raise errors in thisContext (not in sender context)
Claus Gittinger <cg@exept.de>
parents: 4152
diff changeset
  2402
3f2758cfeff5 raise errors in thisContext (not in sender context)
Claus Gittinger <cg@exept.de>
parents: 4152
diff changeset
  2403
    "Modified: / 8.5.1999 / 20:12:16 / cg"
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2404
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2405
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2406
lastErrorNumber
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2407
    "return the last error"
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2408
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2409
    ^ lastErrorNumber
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2410
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2411
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2412
lastErrorString
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2413
    "return a message string describing the last error"
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2414
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2415
    (lastErrorNumber isNil or:[lastErrorNumber == 0]) ifTrue:[
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  2416
	^ 'I/O error'
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2417
    ].
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2418
    ^ OperatingSystem errorTextForNumber:lastErrorNumber
2
claus
parents: 1
diff changeset
  2419
!
claus
parents: 1
diff changeset
  2420
10932
c9148f19b2ea add #lastErrorSymbol
Stefan Vogel <sv@exept.de>
parents: 10852
diff changeset
  2421
lastErrorSymbol
c9148f19b2ea add #lastErrorSymbol
Stefan Vogel <sv@exept.de>
parents: 10852
diff changeset
  2422
    "return an error symbol describing the last error"
c9148f19b2ea add #lastErrorSymbol
Stefan Vogel <sv@exept.de>
parents: 10852
diff changeset
  2423
c9148f19b2ea add #lastErrorSymbol
Stefan Vogel <sv@exept.de>
parents: 10852
diff changeset
  2424
    ^ OperatingSystem errorSymbolForNumber:lastErrorNumber
c9148f19b2ea add #lastErrorSymbol
Stefan Vogel <sv@exept.de>
parents: 10852
diff changeset
  2425
!
c9148f19b2ea add #lastErrorSymbol
Stefan Vogel <sv@exept.de>
parents: 10852
diff changeset
  2426
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2427
openError
12688
b429dc21d6b8 added: #openError:
Stefan Vogel <sv@exept.de>
parents: 12683
diff changeset
  2428
    "report an error, that the open failed"
b429dc21d6b8 added: #openError:
Stefan Vogel <sv@exept.de>
parents: 12683
diff changeset
  2429
1119
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2430
    "{ Pragma: +optSpace }"
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2431
14438
a4280b8038c0 changed:
Stefan Vogel <sv@exept.de>
parents: 14068
diff changeset
  2432
    ^ self openError:lastErrorNumber.
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2433
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2434
12688
b429dc21d6b8 added: #openError:
Stefan Vogel <sv@exept.de>
parents: 12683
diff changeset
  2435
openError:errorNumber
b429dc21d6b8 added: #openError:
Stefan Vogel <sv@exept.de>
parents: 12683
diff changeset
  2436
    "report an error, that the open failed"
b429dc21d6b8 added: #openError:
Stefan Vogel <sv@exept.de>
parents: 12683
diff changeset
  2437
b429dc21d6b8 added: #openError:
Stefan Vogel <sv@exept.de>
parents: 12683
diff changeset
  2438
    "{ Pragma: +optSpace }"
b429dc21d6b8 added: #openError:
Stefan Vogel <sv@exept.de>
parents: 12683
diff changeset
  2439
15496
21bb54fa8521 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15494
diff changeset
  2440
    |exClass errorHolder|
21bb54fa8521 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15494
diff changeset
  2441
21bb54fa8521 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15494
diff changeset
  2442
    errorHolder := OperatingSystem errorHolderForNumber:errorNumber.
21bb54fa8521 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15494
diff changeset
  2443
21bb54fa8521 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15494
diff changeset
  2444
    exClass := (errorHolder errorCategory == #nonexistentSignal)
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2445
	ifTrue:[ FileDoesNotExistException ]
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2446
	ifFalse:[ OpenError ].
13673
744194003e48 changed:
Claus Gittinger <cg@exept.de>
parents: 13306
diff changeset
  2447
744194003e48 changed:
Claus Gittinger <cg@exept.de>
parents: 13306
diff changeset
  2448
    ^ exClass newException
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2449
	errorCode:errorNumber;
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2450
	osErrorHolder:errorHolder;
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2451
	"/ cg: initialized lazyly - see OpenError>>#description
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2452
	"/ errorString:(' : ' , errorHolder errorString);
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2453
	parameter:self;
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2454
	raiseRequest
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2455
	"/ in:thisContext sender
13673
744194003e48 changed:
Claus Gittinger <cg@exept.de>
parents: 13306
diff changeset
  2456
744194003e48 changed:
Claus Gittinger <cg@exept.de>
parents: 13306
diff changeset
  2457
    "Modified: / 09-09-2011 / 07:22:49 / cg"
12688
b429dc21d6b8 added: #openError:
Stefan Vogel <sv@exept.de>
parents: 12683
diff changeset
  2458
!
b429dc21d6b8 added: #openError:
Stefan Vogel <sv@exept.de>
parents: 12683
diff changeset
  2459
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2460
readError
15845
2b732fc8a4f4 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15655
diff changeset
  2461
    "report an error, that some read error occured"
2b732fc8a4f4 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15655
diff changeset
  2462
1119
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2463
    "{ Pragma: +optSpace }"
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2464
15845
2b732fc8a4f4 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15655
diff changeset
  2465
    ^ self readError:lastErrorNumber
2b732fc8a4f4 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15655
diff changeset
  2466
!
2b732fc8a4f4 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15655
diff changeset
  2467
2b732fc8a4f4 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15655
diff changeset
  2468
readError:errorNumber
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2469
    "report an error, that some read error occured"
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2470
15845
2b732fc8a4f4 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15655
diff changeset
  2471
    "{ Pragma: +optSpace }"
2b732fc8a4f4 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15655
diff changeset
  2472
2b732fc8a4f4 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15655
diff changeset
  2473
    ^ ReadError newException
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2474
	errorCode:errorNumber;
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2475
	osErrorHolder:(OperatingSystem errorHolderForNumber:errorNumber);
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2476
	parameter:self;
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2477
	raiseRequest
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2478
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2479
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2480
writeError
15845
2b732fc8a4f4 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15655
diff changeset
  2481
    "report an error, that some write error occured"
2b732fc8a4f4 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15655
diff changeset
  2482
1119
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2483
    "{ Pragma: +optSpace }"
956d62a5656c compile seldom used methods with optSpace (is this a good idea ?)
Claus Gittinger <cg@exept.de>
parents: 1079
diff changeset
  2484
15845
2b732fc8a4f4 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15655
diff changeset
  2485
    ^ self writeError:lastErrorNumber
2b732fc8a4f4 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15655
diff changeset
  2486
!
2b732fc8a4f4 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15655
diff changeset
  2487
2b732fc8a4f4 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15655
diff changeset
  2488
writeError:errorNumber
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2489
    "report an error, that some write error occured"
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2490
15845
2b732fc8a4f4 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15655
diff changeset
  2491
    "{ Pragma: +optSpace }"
2b732fc8a4f4 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15655
diff changeset
  2492
2b732fc8a4f4 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15655
diff changeset
  2493
    ^ WriteError newException
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2494
	errorCode:errorNumber;
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2495
	osErrorHolder:(OperatingSystem errorHolderForNumber:errorNumber);
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2496
	parameter:self;
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2497
	raiseRequest
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2498
! !
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2499
6461
f5efaff3457b Allow #registerForFinalization for classes defining their own Lobby.
Stefan Vogel <sv@exept.de>
parents: 6441
diff changeset
  2500
!ExternalStream methodsFor:'finalization'!
f5efaff3457b Allow #registerForFinalization for classes defining their own Lobby.
Stefan Vogel <sv@exept.de>
parents: 6441
diff changeset
  2501
15468
816f9e81a546 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15452
diff changeset
  2502
executor
816f9e81a546 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15452
diff changeset
  2503
    "return a copy for finalization-registration;
816f9e81a546 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15452
diff changeset
  2504
     since all we need at finalization time is the fileDescriptor,
816f9e81a546 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15452
diff changeset
  2505
     a cheaper copy is possible."
816f9e81a546 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15452
diff changeset
  2506
816f9e81a546 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15452
diff changeset
  2507
    ^ self class basicNew setAccessor:handleType to:handle
816f9e81a546 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15452
diff changeset
  2508
!
816f9e81a546 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15452
diff changeset
  2509
6461
f5efaff3457b Allow #registerForFinalization for classes defining their own Lobby.
Stefan Vogel <sv@exept.de>
parents: 6441
diff changeset
  2510
finalizationLobby
f5efaff3457b Allow #registerForFinalization for classes defining their own Lobby.
Stefan Vogel <sv@exept.de>
parents: 6441
diff changeset
  2511
    "answer the registry used for finalization.
f5efaff3457b Allow #registerForFinalization for classes defining their own Lobby.
Stefan Vogel <sv@exept.de>
parents: 6441
diff changeset
  2512
     ExternalStreams have their own Registry"
f5efaff3457b Allow #registerForFinalization for classes defining their own Lobby.
Stefan Vogel <sv@exept.de>
parents: 6441
diff changeset
  2513
f5efaff3457b Allow #registerForFinalization for classes defining their own Lobby.
Stefan Vogel <sv@exept.de>
parents: 6441
diff changeset
  2514
    ^ Lobby
f5efaff3457b Allow #registerForFinalization for classes defining their own Lobby.
Stefan Vogel <sv@exept.de>
parents: 6441
diff changeset
  2515
!
f5efaff3457b Allow #registerForFinalization for classes defining their own Lobby.
Stefan Vogel <sv@exept.de>
parents: 6441
diff changeset
  2516
f5efaff3457b Allow #registerForFinalization for classes defining their own Lobby.
Stefan Vogel <sv@exept.de>
parents: 6441
diff changeset
  2517
finalize
f5efaff3457b Allow #registerForFinalization for classes defining their own Lobby.
Stefan Vogel <sv@exept.de>
parents: 6441
diff changeset
  2518
    "some Stream has been collected - close the file if not already done"
f5efaff3457b Allow #registerForFinalization for classes defining their own Lobby.
Stefan Vogel <sv@exept.de>
parents: 6441
diff changeset
  2519
16551
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  2520
    "/ with timeout to avoid blocking in a bad pty/socket
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  2521
    [
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2522
	self closeFile
16551
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  2523
    ] valueWithTimeout:30 seconds.
6461
f5efaff3457b Allow #registerForFinalization for classes defining their own Lobby.
Stefan Vogel <sv@exept.de>
parents: 6441
diff changeset
  2524
! !
f5efaff3457b Allow #registerForFinalization for classes defining their own Lobby.
Stefan Vogel <sv@exept.de>
parents: 6441
diff changeset
  2525
15918
d5fe9b9e87d3 Initialize in instance initialize method insted in #new
Stefan Vogel <sv@exept.de>
parents: 15896
diff changeset
  2526
!ExternalStream methodsFor:'initialization'!
d5fe9b9e87d3 Initialize in instance initialize method insted in #new
Stefan Vogel <sv@exept.de>
parents: 15896
diff changeset
  2527
d5fe9b9e87d3 Initialize in instance initialize method insted in #new
Stefan Vogel <sv@exept.de>
parents: 15896
diff changeset
  2528
initialize
15921
9941c0e5132a initialize methods
Stefan Vogel <sv@exept.de>
parents: 15920
diff changeset
  2529
    position := 0.
9941c0e5132a initialize methods
Stefan Vogel <sv@exept.de>
parents: 15920
diff changeset
  2530
    binary := false.
9941c0e5132a initialize methods
Stefan Vogel <sv@exept.de>
parents: 15920
diff changeset
  2531
    buffered := true.
9941c0e5132a initialize methods
Stefan Vogel <sv@exept.de>
parents: 15920
diff changeset
  2532
    eolMode := DefaultEOLMode.
9941c0e5132a initialize methods
Stefan Vogel <sv@exept.de>
parents: 15920
diff changeset
  2533
    hitEOF := false.
15918
d5fe9b9e87d3 Initialize in instance initialize method insted in #new
Stefan Vogel <sv@exept.de>
parents: 15896
diff changeset
  2534
! !
d5fe9b9e87d3 Initialize in instance initialize method insted in #new
Stefan Vogel <sv@exept.de>
parents: 15896
diff changeset
  2535
2
claus
parents: 1
diff changeset
  2536
!ExternalStream methodsFor:'line reading/writing'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2537
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2538
nextLine
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2539
    "read the next line (characters up to newline).
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2540
     Return a string containing those characters excluding the newline.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2541
     If the previous-to-last character is a cr, this is also removed,
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2542
     so it's possible to read alien (i.e. ms-dos) text as well.
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2543
     The line must be shorter than 32K characters - otherwise an error is signalled."
2120
71c1870df7ba implemented 1-character readAhead for unbuffered streams;
Claus Gittinger <cg@exept.de>
parents: 2045
diff changeset
  2544
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2545
    |line error|
971
eb70f5674303 max lineLength (in nextLine) increased to 16k
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  2546
12873
f6b24aa46bb1 changed: #nextLine
Stefan Vogel <sv@exept.de>
parents: 12710
diff changeset
  2547
%{  /* STACK:100000 */
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2548
2593
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
  2549
    FILEPOINTER f;
1463
ace6b72b6f4a Use common macros to make interruptable system calls signal proof.
Stefan Vogel <sv@exept.de>
parents: 1422
diff changeset
  2550
    int len, ret;
3029
aa14768e0e6a larger lineBuffer in #nextLine
Claus Gittinger <cg@exept.de>
parents: 3016
diff changeset
  2551
    char buffer[32*1024];
521
70533ec40482 use new MKSTRING_L if length is known (avoids a useless strlen)
Claus Gittinger <cg@exept.de>
parents: 481
diff changeset
  2552
    char *rslt, *nextPtr, *limit;
22
847106305963 *** empty log message ***
claus
parents: 12
diff changeset
  2553
    int fd, ch;
1068
92fdcccf12a3 alles MIST - zurueck zu 1.89 und NOCONTEXT entfernt
Claus Gittinger <cg@exept.de>
parents: 1067
diff changeset
  2554
    int _buffered;
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2555
    OBJ fp;
2120
71c1870df7ba implemented 1-character readAhead for unbuffered streams;
Claus Gittinger <cg@exept.de>
parents: 2045
diff changeset
  2556
    int lineTooLong = 0;
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2557
    int cutOff = 0;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2558
1133
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1119
diff changeset
  2559
    __INST(lastErrorNumber) = nil;
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  2560
    if ((__INST(handleType) == nil)
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  2561
     || (__INST(handleType) == @symbol(filePointer))
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  2562
     || (__INST(handleType) == @symbol(socketFilePointer))
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  2563
     || (__INST(handleType) == @symbol(socketHandle))
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  2564
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2565
	if (((fp = __INST(handle)) != nil)
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2566
	    && (__INST(mode) != @symbol(writeonly))
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2567
	    && (__INST(binary) != true)
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2568
	) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2569
	    f = __FILEVal(fp);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2570
	    buffer[0] = '\0';
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2571
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2572
	    _buffered = (__INST(buffered) == true);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2573
	    if (_buffered) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2574
		__READING__(f);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2575
	    }
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2576
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2577
	    rslt = nextPtr = buffer;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2578
	    limit = buffer + sizeof(buffer) - 2;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2579
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2580
	    for (;;) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2581
		__READBYTE__(ret, f, nextPtr, _buffered, __INST(handleType));
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2582
		if (ret <= 0) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2583
		    if (nextPtr == buffer)
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2584
			rslt = NULL;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2585
		    if (ret == 0) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2586
			__INST(hitEOF) = true;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2587
			break;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2588
		    } else {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2589
			error = __mkSmallInteger(__threadErrno);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2590
			goto err;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2591
		    }
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2592
		}
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2593
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2594
		if (*nextPtr == '\n') {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2595
		    cutOff = 1;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2596
		    *nextPtr = '\0';
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2597
		    break;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2598
		}
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2599
		if (*nextPtr == '\r') {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2600
		    char peekChar;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2601
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2602
		    /*
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2603
		     * peek ahead for a newLine ...
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2604
		     */
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2605
		    __READBYTE__(ret, f, &peekChar, _buffered, __INST(handleType));
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2606
		    if (ret <= 0) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2607
			cutOff = 1;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2608
			*nextPtr = '\0';
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2609
			if (ret == 0) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2610
			    __INST(hitEOF) = true;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2611
			    break;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2612
			}
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2613
			error = __mkSmallInteger(__threadErrno);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2614
			goto err;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2615
		    }
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2616
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2617
		    if (peekChar == '\n') {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2618
			cutOff = 2;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2619
			*nextPtr = '\0';
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2620
			break;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2621
		    }
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2622
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2623
		    __UNGETC__(peekChar, f, _buffered);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2624
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2625
		    cutOff = 1;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2626
		    *nextPtr = '\0';
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2627
		    break;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2628
		}
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2629
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2630
		nextPtr++;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2631
		if (nextPtr >= limit) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2632
		    *nextPtr = '\0';
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2633
		    lineTooLong = 1;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2634
		    if (@global(InfoPrinting) == true) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2635
			fprintf(stderr, "ExtStream [warning]: line truncated in nextLine\n");
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2636
		    }
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2637
		    break;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2638
		}
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2639
	    }
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2640
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2641
	    if (rslt != NULL) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2642
		len = nextPtr-buffer;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2643
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2644
		if (__isSmallInteger(__INST(position))) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2645
		    INT np = __intVal(__INST(position)) + len + cutOff;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2646
		    OBJ t;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2647
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2648
		    t = __MKINT(np); __INST(position) = t; __STORE(self, t);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2649
		} else {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2650
		    __INST(position) = nil; /* i.e. do not know */
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2651
		}
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2652
		/* remove any EOL character */
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2653
		if (len != 0) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2654
		    if (buffer[len-1] == '\n') {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2655
			buffer[--len] = '\0';
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2656
		    }
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2657
		    if ((len != 0) && (buffer[len-1] == '\r')) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2658
			buffer[--len] = '\0';
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2659
		    }
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2660
		}
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2661
		line = __MKSTRING_L(buffer, len);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2662
		if (! lineTooLong) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2663
		    RETURN ( line );
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2664
		}
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2665
	    }
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2666
	}
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2667
    }
1478
aae07192b7d1 labels in empty statements need a semi
Claus Gittinger <cg@exept.de>
parents: 1469
diff changeset
  2668
err: ;
159
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  2669
%}.
2120
71c1870df7ba implemented 1-character readAhead for unbuffered streams;
Claus Gittinger <cg@exept.de>
parents: 2045
diff changeset
  2670
    line notNil ifTrue:[
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2671
	"/ the line as read is longer than 32k characters (boy - what a line)
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2672
	"/ The exception could be handled by reading more and returning the
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2673
	"/ concatenation in your exception handler (the receiver and the partial
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2674
	"/ line are passed as parameter)
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2675
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2676
	LineTooLongErrorSignal isHandled ifTrue:[
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2677
	    ^ LineTooLongErrorSignal
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2678
		raiseRequestWith:(Array with:self with:line)
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2679
		     errorString:('line too long read error')
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2680
	].
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2681
	^ line , self nextLine
2120
71c1870df7ba implemented 1-character readAhead for unbuffered streams;
Claus Gittinger <cg@exept.de>
parents: 2045
diff changeset
  2682
    ].
71c1870df7ba implemented 1-character readAhead for unbuffered streams;
Claus Gittinger <cg@exept.de>
parents: 2045
diff changeset
  2683
8614
88421fbd4ab6 pastEnd -> pastEndRead
Claus Gittinger <cg@exept.de>
parents: 8604
diff changeset
  2684
    (hitEOF == true) ifTrue:[^ self pastEndRead].
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2685
    error notNil ifTrue:[
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2686
	lastErrorNumber := error.
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  2687
	^ self readError:error
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2688
    ].
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2689
    handle isNil ifTrue:[^ self errorNotOpen].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2690
    (mode == #writeonly) ifTrue:[^ self errorWriteOnly].
5431
24ce291c71f2 migration support
Claus Gittinger <cg@exept.de>
parents: 5430
diff changeset
  2691
    (binary == true) ifTrue:[^ self errorBinary].
24ce291c71f2 migration support
Claus Gittinger <cg@exept.de>
parents: 5430
diff changeset
  2692
    ^ super nextLine
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2693
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2694
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2695
nextPutLine:aString
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2696
    "write the characters in aString and append an end-of-Line marker
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2697
     (LF, CR or CRLF - depending in the setting of eolMode)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2698
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2699
    |error|
1067
1e7959af0821 removed all NOCONTEXT (last version did no good - PROTECT-stack overflow ...)
Claus Gittinger <cg@exept.de>
parents: 1066
diff changeset
  2700
%{
7875
eb7d48b0425d made all position-handling code 32bit save
Claus Gittinger <cg@exept.de>
parents: 7832
diff changeset
  2701
    OBJ fp;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2702
1133
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1119
diff changeset
  2703
    __INST(lastErrorNumber) = nil;
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  2704
    if ((__INST(handleType) == nil)
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  2705
     || (__INST(handleType) == @symbol(filePointer))
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  2706
     || (__INST(handleType) == @symbol(socketFilePointer))
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  2707
     || (__INST(handleType) == @symbol(socketHandle))
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  2708
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2709
	if (((fp = __INST(handle)) != nil)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2710
	    && (__INST(mode) != @symbol(readonly))
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2711
	    && (__INST(binary) != true)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2712
	    && __isStringLike(aString)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2713
	) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  2714
	    int _buffered = (__INST(buffered) == true);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  2715
	    int len = __stringSize(aString);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  2716
	    int cnt, len1;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  2717
	    FILEPOINTER f = __FILEVal(fp);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  2718
	    char *cp;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  2719
	    int o_offs;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  2720
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  2721
	    if (_buffered) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2722
		__WRITING__(f)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2723
	    }
9053
f3f3d48d6f44 fix writing to stdout/stderr for winstx non-console operation
Claus Gittinger <cg@exept.de>
parents: 9024
diff changeset
  2724
#ifdef WIN32
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2725
	    if ((f == __win32_stdout()) || (f == __win32_stderr())) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2726
		cnt = __win32_fwrite(__stringVal(aString), 1, len, f);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2727
	    } else
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2728
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2729
	    {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2730
		o_offs = (char *)__stringVal(aString)-(char *)aString;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2731
		__WRITEBYTES_OBJ__(cnt, f, aString, o_offs, len, _buffered, __INST(handleType));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2732
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2733
	    if (cnt == len) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2734
		OBJ mode = __INST(eolMode);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2735
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2736
		len1 = len;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2737
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2738
		if (mode == @symbol(cr)) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2739
		    cp = "\r"; len = 1;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2740
		} else if (mode == @symbol(crlf)) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2741
		    cp = "\r\n"; len = 2;
17430
c8749e1c02ad class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17426
diff changeset
  2742
		} else if (mode == @symbol(eot)) {
c8749e1c02ad class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17426
diff changeset
  2743
		    cp = "\004"; len = 1;
c8749e1c02ad class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17426
diff changeset
  2744
		} else if (mode == @symbol(etx)) {
c8749e1c02ad class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17426
diff changeset
  2745
		    cp = "\003"; len = 1;
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2746
		} else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2747
		    cp = "\n"; len = 1;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2748
		}
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2749
#ifdef WIN32
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2750
		if ((f == __win32_stdout()) || (f == __win32_stderr())) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2751
		    cnt = __win32_fwrite(cp, 1, len, f);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2752
		} else
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2753
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2754
		{
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2755
		    __WRITEBYTES__(cnt, f, cp, len, _buffered, __INST(handleType));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2756
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2757
		if (cnt > 0) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2758
		    if (__isSmallInteger(__INST(position))) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2759
			INT np = __intVal(__INST(position)) + cnt;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2760
			OBJ t;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2761
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2762
			t = __MKINT(np); __INST(position) = t; __STORE(self, t);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2763
		    } else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2764
			__INST(position) = nil; /* i.e. do not know */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2765
		    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2766
		    RETURN ( self );
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2767
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2768
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2769
	    error = __mkSmallInteger(__threadErrno);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2770
	}
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2771
    }
159
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  2772
%}.
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2773
    error notNil ifTrue:[
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2774
	lastErrorNumber := error.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2775
	self writeError:error.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2776
	^ self
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2777
    ].
2045
1ad17ca6520f fall back to super>>nextPutLine: if argument is not a string.
Claus Gittinger <cg@exept.de>
parents: 2044
diff changeset
  2778
    super nextPutLine:aString.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2779
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2780
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2781
nextPutLinesFrom:aStream upToLineStartingWith:aStringOrNil
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2782
    "read from aStream up to and including a line starting with aStringOrNil
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  2783
     and append all lines to self.
159
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  2784
     Can be used to copy/create large files or copy from a pipe/socket.
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2785
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2786
     If aStringOrNil is nil or not matched, copy proceeds to the end."
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2787
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2788
    |line|
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2789
2593
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
  2790
    [aStream atEnd] whileFalse:[
8070
2fec8e67e119 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 8069
diff changeset
  2791
	line := aStream nextLine.
2fec8e67e119 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 8069
diff changeset
  2792
	line isNil ifTrue:[
2fec8e67e119 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 8069
diff changeset
  2793
	    ^ self.
2fec8e67e119 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 8069
diff changeset
  2794
	].
2fec8e67e119 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 8069
diff changeset
  2795
	self nextPutLine:line.
2fec8e67e119 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 8069
diff changeset
  2796
	(aStringOrNil notNil and:[line startsWith:aStringOrNil]) ifTrue:[
2fec8e67e119 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 8069
diff changeset
  2797
	    ^ self
2fec8e67e119 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 8069
diff changeset
  2798
	]
2593
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
  2799
    ].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2800
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2801
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2802
peekForLineStartingWith:aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2803
    "read ahead for next line starting with aString;
159
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  2804
     return the line-string if found, or nil if EOF is encountered.
7118
10b067555add *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7054
diff changeset
  2805
     If matched, do not advance position beyond that line
159
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  2806
     i.e. nextLine will read the matched line.
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  2807
     If not matched, reposition to original position for further reading."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2808
2593
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
  2809
    |firstPos lastPos line|
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
  2810
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2811
    (mode == #writeonly) ifTrue:[^ self errorWriteOnly].
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2812
    handle isNil ifTrue:[^ self errorNotOpen].
2
claus
parents: 1
diff changeset
  2813
    binary ifTrue:[^ self errorBinary].
1463
ace6b72b6f4a Use common macros to make interruptable system calls signal proof.
Stefan Vogel <sv@exept.de>
parents: 1422
diff changeset
  2814
    buffered ifFalse:[^ self errorNotBuffered].
12
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
  2815
2593
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
  2816
    firstPos := self position.
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
  2817
    [self atEnd] whileFalse:[
8070
2fec8e67e119 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 8069
diff changeset
  2818
	lastPos := self position.
2fec8e67e119 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 8069
diff changeset
  2819
	line := self nextLine.
2fec8e67e119 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 8069
diff changeset
  2820
	line isNil ifTrue:[
2fec8e67e119 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 8069
diff changeset
  2821
	    self position:firstPos.
2fec8e67e119 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 8069
diff changeset
  2822
	    ^ nil
2fec8e67e119 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 8069
diff changeset
  2823
	].
2fec8e67e119 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 8069
diff changeset
  2824
	(line startsWith:aString) ifTrue:[
2fec8e67e119 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 8069
diff changeset
  2825
	    self position:lastPos.
2fec8e67e119 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 8069
diff changeset
  2826
	    ^ line
2fec8e67e119 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 8069
diff changeset
  2827
	]
2593
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
  2828
    ].
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
  2829
    self position:firstPos.
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
  2830
    ^ nil
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2831
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2832
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2833
peekForLineStartingWithAny:aCollectionOfStrings
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2834
    "read ahead for next line starting with any of aCollectionOfStrings;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2835
     return the index in aCollection if found, nil otherwise..
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2836
     If no match, do not change position; otherwise advance right before the
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2837
     matched line so that nextLine will return this line."
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2838
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2839
    |line startPos linePos index|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2840
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2841
    (mode == #writeonly) ifTrue:[^ self errorWriteOnly].
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2842
    handle isNil ifTrue:[^ self errorNotOpen].
2
claus
parents: 1
diff changeset
  2843
    binary ifTrue:[^ self errorBinary].
claus
parents: 1
diff changeset
  2844
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2845
    startPos := self position.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2846
    [self atEnd] whileFalse:[
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  2847
	linePos := self position.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  2848
	line := self nextLine.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  2849
	line notNil ifTrue:[
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  2850
	    index := 1.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  2851
	    aCollectionOfStrings do:[:prefix |
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  2852
		(line startsWith:prefix) ifTrue:[
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  2853
		    self position:linePos.
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  2854
		    ^ index
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  2855
		].
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  2856
		index := index + 1
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  2857
	    ]
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  2858
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2859
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2860
    self position:startPos.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2861
    ^ nil
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2862
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2863
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2864
!ExternalStream methodsFor:'misc functions'!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2865
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2866
async:aBoolean
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  2867
    "set/clear the async attribute - if set, the availability of data on
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2868
     the receiver will trigger an ioInterrupt.
779
0e41a665038a commentary
Claus Gittinger <cg@exept.de>
parents: 730
diff changeset
  2869
     If cleared (which is the default) no special notification is made.
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  2870
     Notice:
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  2871
	not every OS supports this
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  2872
	- check with OS>>supportsIOInterrupts before using"
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2873
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2874
    |fd|
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2875
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2876
    handle isNil ifTrue:[^ self errorNotOpen].
2151
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  2877
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  2878
    OperatingSystem supportsIOInterrupts ifFalse:[
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  2879
	^ self errorUnsupportedOperation
2151
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  2880
    ].
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  2881
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2882
    fd := self fileDescriptor.
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2883
    aBoolean ifTrue:[
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  2884
	^ OperatingSystem enableIOInterruptsOn:fd
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2885
    ].
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2886
    ^ OperatingSystem disableIOInterruptsOn:fd
2151
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  2887
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  2888
    "Modified: 11.1.1997 / 17:50:21 / cg"
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2889
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2890
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2891
blocking:aBoolean
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2892
    "set/clear the blocking attribute - if set (which is the default)
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2893
     a read (using next) on the receiver will block until data is available.
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2894
     If cleared, a read operation will immediately return with a value of
2151
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  2895
     nil.
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  2896
     Turning off blocking is useful when reading from PipeStreams
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  2897
     or Sockets, and the amount of data to be read is not known
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  2898
     in advance. However, the data must then be read using #nextBytes:
8616
6014ed5c67f9 pastEnd -> pastEndRead
Claus Gittinger <cg@exept.de>
parents: 8614
diff changeset
  2899
     methods, in order to avoid other (pastEndRead) exceptions."
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2900
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2901
    handle isNil ifTrue:[^ self errorNotOpen].
7499
53b7a86e1f0b ExternalStream>>blocking: returns previous blocking status
Stefan Vogel <sv@exept.de>
parents: 7497
diff changeset
  2902
    ^ OperatingSystem setBlocking:aBoolean on:self fileDescriptor.
2151
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  2903
3174
668414a73de9 Typo in comment
Stefan Vogel <sv@exept.de>
parents: 3132
diff changeset
  2904
    "Modified: / 11.1.1997 / 17:48:01 / cg"
668414a73de9 Typo in comment
Stefan Vogel <sv@exept.de>
parents: 3132
diff changeset
  2905
    "Modified: / 15.1.1998 / 11:49:48 / stefan"
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2906
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2907
17618
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2908
copyToEndFrom:inStream
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2909
    "read from inStream, and write all data up to the end to the receiver.
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2910
     Return the number of bytes which have been transferred.
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2911
     Same functionality as copyToEnd:, but reversed arg and receiver
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2912
     (useful in a cascade message of the writeStream)"
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2913
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2914
    |bufferSize|
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2915
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2916
    OperatingSystem isMSDOSlike ifTrue:[
18312
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  2917
	"/ mhmh - NT hangs, when copying bigger blocks to a network drive - why ?
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  2918
	bufferSize := 1 * 1024.
17618
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2919
    ] ifFalse:[
18312
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  2920
	bufferSize := 8 * 1024.
17618
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2921
    ].
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2922
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2923
    ^ inStream copyToEndInto:self bufferSize:bufferSize
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2924
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2925
    "
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2926
     |in out|
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2927
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2928
     in := 'Makefile' asFilename readStream.
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2929
     out := Stdout.
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2930
     in copyToEndInto:out.
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2931
     in close.
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2932
    "
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2933
!
c6ee18f841cc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17609
diff changeset
  2934
6804
caf6a4521d4c added utility: ExternalStream >> copyToEndInto:
Claus Gittinger <cg@exept.de>
parents: 6758
diff changeset
  2935
copyToEndInto:outStream
7017
03f1bd57c001 no one cares about the signal in copyToEndInto:
Claus Gittinger <cg@exept.de>
parents: 7013
diff changeset
  2936
    "copy the data into another stream."
03f1bd57c001 no one cares about the signal in copyToEndInto:
Claus Gittinger <cg@exept.de>
parents: 7013
diff changeset
  2937
8362
e17d9ffb6fa8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 8339
diff changeset
  2938
    |bufferSize|
7700
767e11efc326 use sendfile if supported by OS
Claus Gittinger <cg@exept.de>
parents: 7685
diff changeset
  2939
6804
caf6a4521d4c added utility: ExternalStream >> copyToEndInto:
Claus Gittinger <cg@exept.de>
parents: 6758
diff changeset
  2940
    OperatingSystem isMSDOSlike ifTrue:[
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2941
	"/ mhmh - NT hangs, when copying bigger blocks to a network drive - why ?
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2942
	bufferSize := 1 * 1024.
6804
caf6a4521d4c added utility: ExternalStream >> copyToEndInto:
Claus Gittinger <cg@exept.de>
parents: 6758
diff changeset
  2943
    ] ifFalse:[
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  2944
	bufferSize := 8 * 1024.
6804
caf6a4521d4c added utility: ExternalStream >> copyToEndInto:
Claus Gittinger <cg@exept.de>
parents: 6758
diff changeset
  2945
    ].
caf6a4521d4c added utility: ExternalStream >> copyToEndInto:
Claus Gittinger <cg@exept.de>
parents: 6758
diff changeset
  2946
7017
03f1bd57c001 no one cares about the signal in copyToEndInto:
Claus Gittinger <cg@exept.de>
parents: 7013
diff changeset
  2947
    ^ self copyToEndInto:outStream bufferSize:bufferSize
7700
767e11efc326 use sendfile if supported by OS
Claus Gittinger <cg@exept.de>
parents: 7685
diff changeset
  2948
767e11efc326 use sendfile if supported by OS
Claus Gittinger <cg@exept.de>
parents: 7685
diff changeset
  2949
    "
767e11efc326 use sendfile if supported by OS
Claus Gittinger <cg@exept.de>
parents: 7685
diff changeset
  2950
     |in out|
767e11efc326 use sendfile if supported by OS
Claus Gittinger <cg@exept.de>
parents: 7685
diff changeset
  2951
767e11efc326 use sendfile if supported by OS
Claus Gittinger <cg@exept.de>
parents: 7685
diff changeset
  2952
     in := 'Makefile' asFilename readStream.
767e11efc326 use sendfile if supported by OS
Claus Gittinger <cg@exept.de>
parents: 7685
diff changeset
  2953
     out := Stdout.
767e11efc326 use sendfile if supported by OS
Claus Gittinger <cg@exept.de>
parents: 7685
diff changeset
  2954
     in copyToEndInto:out.
767e11efc326 use sendfile if supported by OS
Claus Gittinger <cg@exept.de>
parents: 7685
diff changeset
  2955
     in close.
767e11efc326 use sendfile if supported by OS
Claus Gittinger <cg@exept.de>
parents: 7685
diff changeset
  2956
    "
6804
caf6a4521d4c added utility: ExternalStream >> copyToEndInto:
Claus Gittinger <cg@exept.de>
parents: 6758
diff changeset
  2957
!
caf6a4521d4c added utility: ExternalStream >> copyToEndInto:
Claus Gittinger <cg@exept.de>
parents: 6758
diff changeset
  2958
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2959
create
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2960
    "create the stream
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2961
     - this must be redefined in subclass"
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2962
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2963
    ^ self subclassResponsibility
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2964
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2965
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2966
ioctl:ioctlNumber
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2967
    "to provide a simple ioctl facility - an ioctl is performed
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2968
     on the underlying file; no arguments are passed."
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  2969
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2970
    ^ self ioctl:ioctlNumber with:nil
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2971
!
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2972
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2973
ioctl:ioctlNumber with:arg
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2974
    "to provide a simple ioctl facility - an ioctl is performed
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2975
     on the underlying file; the argument is passed as argument.
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  2976
     This is not used by ST/X, but provided for special situations
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2977
     - for example, to control proprietrary I/O devices.
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2978
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2979
     Since the type of the argument depends on the ioctl being
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2980
     performed, different arg types are allowed here.
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2981
     If the argument is nil, an ioctl without argument is performed.
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2982
     If the argument is an integral number, it's directly passed;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  2983
     if it's a kind of ByteArray (ByteArray, String or Structure),
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2984
     or external data (ExternalBytes or ExternalAddress),
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  2985
     a pointer to the data is passed.
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  2986
     This allows performing most ioctls
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2987
     - however, it might be tricky to setup the buffer.
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2988
     Be careful in what you pass - ST/X cannot validate its correctness."
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2989
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  2990
    |error|
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  2991
1067
1e7959af0821 removed all NOCONTEXT (last version did no good - PROTECT-stack overflow ...)
Claus Gittinger <cg@exept.de>
parents: 1066
diff changeset
  2992
%{
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  2993
#if !defined(MSDOS_LIKE) && !defined(__openVMS__)
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  2994
    int fd;
10552
d52aa8e066e5 #ioctl:with: accept 32-bit integers as arguments
Stefan Vogel <sv@exept.de>
parents: 10469
diff changeset
  2995
    int ret;
d52aa8e066e5 #ioctl:with: accept 32-bit integers as arguments
Stefan Vogel <sv@exept.de>
parents: 10469
diff changeset
  2996
    unsigned int ioNum;
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  2997
    INT ioArg;
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  2998
    OBJ fp = __INST(handle);
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  2999
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3000
    if (fp == nil)
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3001
	goto out;
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3002
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3003
    if (!__isInteger(ioctlNumber)
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3004
	 || (!__isInteger(arg)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3005
	     && (arg != nil)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3006
	     && !__isBytes(arg)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3007
	     && !__isExternalBytesLike(arg)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3008
	     && !__isExternalAddress(arg))) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3009
	error = @symbol(badArgument);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3010
	goto out;
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3011
    }
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3012
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3013
    if (__INST(handleType) == @symbol(socketHandle)) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3014
	fd = __FILEVal(fp);
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3015
    } else
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3016
	if ((__INST(handleType) == nil)
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3017
	 || (__INST(handleType) == @symbol(filePointer))
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3018
	 || (__INST(handleType) == @symbol(socketFilePointer))
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3019
	 || (__INST(handleType) == @symbol(pipeFilePointer))) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3020
	fd = fileno(__FILEVal(fp));
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3021
    } else {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3022
	error = @symbol(badHandleType);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3023
	goto out;
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3024
    }
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3025
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3026
    ioNum = __unsignedLongIntVal(ioctlNumber);
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3027
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3028
    __BEGIN_INTERRUPTABLE__
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3029
    do {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3030
	__threadErrno = 0;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3031
	if (arg == nil) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3032
	    ioArg = 0;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3033
	} else if (__isSmallInteger(arg)) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3034
	    ioArg = __intVal(arg);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3035
	} else if (__isInteger(arg)) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3036
	    ioArg = __unsignedLongIntVal(arg);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3037
	} else if (__isExternalBytesLike(arg)) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3038
	    ioArg = (INT)(__externalBytesAddress(arg));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3039
	} else if (__isExternalAddress(arg)) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3040
	    ioArg = (INT)(__externalAddressVal(arg));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3041
	} else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3042
	    ioArg = (INT)(__ByteArrayInstPtr(arg)->ba_element);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3043
	}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3044
	ret = ioctl(fd, ioNum, ioArg);
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3045
    } while (ret < 0 && __threadErrno == EINTR);
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3046
    __END_INTERRUPTABLE__
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3047
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3048
    if (ret >= 0) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3049
	RETURN ( __mkSmallInteger(ret) );
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3050
    }
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3051
    error = __mkSmallInteger(__threadErrno);
791
b1c153b1c719 WIN32 has no ioctl
Claus Gittinger <cg@exept.de>
parents: 779
diff changeset
  3052
#endif
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3053
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3054
out:;
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3055
%}.
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3056
    error notNil ifTrue:[
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3057
	lastErrorNumber := error.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3058
	^ self ioError:error.
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3059
    ].
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  3060
    handle isNil ifTrue:[^ self errorNotOpen].
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3061
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3062
    "/ the system does not support ioctl (MSDOS or VMS)
2920
9c10b66e1ba8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2903
diff changeset
  3063
    ^ self errorUnsupportedOperation
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3064
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3065
16551
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3066
reset
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3067
    "set the read position to the beginning of the collection"
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3068
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3069
    self position:0
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3070
!
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3071
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3072
setToEnd
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3073
    "redefined since it must be implemented differently"
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3074
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3075
    ^ self subclassResponsibility
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3076
!
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3077
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3078
sync
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3079
    "make sure, that the OS writes cached data to the disk"
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3080
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3081
    |error|
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3082
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3083
    self flush.
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3084
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3085
%{
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3086
#if !defined(__openVMS__)
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3087
    int fd;
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3088
    int ret;
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3089
    OBJ fp = __INST(handle);
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3090
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3091
    if (fp == nil)
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3092
	goto out;
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3093
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3094
    if (__INST(handleType) == @symbol(socketHandle)) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3095
	// syncing a socket to disk ?
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3096
	error = @symbol(badHandleType);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3097
	goto out;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3098
	// fd = __FILEVal(fp);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3099
    } else
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3100
	if ((__INST(handleType) == nil)
16551
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3101
	       || (__INST(handleType) == @symbol(filePointer))
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3102
	       || (__INST(handleType) == @symbol(socketFilePointer))
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3103
	       || (__INST(handleType) == @symbol(pipeFilePointer))) {
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3104
	fd = fileno(__FILEVal(fp));
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3105
    } else {
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3106
	error = @symbol(badHandleType);
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3107
	goto out;
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3108
    }
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3109
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3110
#ifdef WIN32
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3111
     __threadErrno = 0;
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3112
     ret = __STX_API_NOINT_CALL1( "FlushFileBuffers", FlushFileBuffers, _get_osfhandle(fd));
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3113
     if (ret) {
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3114
	 RETURN (self);
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3115
     }
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3116
#else
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3117
     __BEGIN_INTERRUPTABLE__
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3118
     do {
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3119
	 ret = fsync(fd);
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3120
     } while ((ret < 0) && (__threadErrno == EINTR));
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3121
     __END_INTERRUPTABLE__
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3122
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3123
     if (ret >= 0) {
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3124
	 RETURN (self);
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3125
     }
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3126
#endif /* ! WIN32 */
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3127
     error = __mkSmallInteger(__threadErrno);
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3128
#endif /* ! __openVMS__ */
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3129
out:;
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3130
%}.
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3131
    error notNil ifTrue:[
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3132
	lastErrorNumber := error.
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3133
	self ioError:error.
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3134
	^ self.
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3135
    ].
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3136
    handle isNil ifTrue:[self errorNotOpen].
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3137
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3138
    "
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3139
	|f|
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3140
	f := 'x' asFilename writeStream.
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3141
	f nextPutAll:'hallo'; sync; syncData; close
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3142
    "
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3143
!
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3144
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3145
syncData
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3146
    "make sure, that the OS writes cached data to the disk.
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3147
     In this case, metadata is only written, if it is
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3148
     required to read the file's data (so metadata will not be written,
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3149
     if only access/modification time has changed)."
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3150
    |error|
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3151
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3152
    self flush.
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3153
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3154
%{
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3155
#if !defined(__openVMS__)
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3156
    int fd;
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3157
    int ret;
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3158
    OBJ fp = __INST(handle);
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3159
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3160
    if (fp == nil)
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3161
	goto out;
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3162
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3163
    if (__INST(handleType) == @symbol(socketHandle)) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3164
	// syncing a socket to disk ?
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3165
	error = @symbol(badHandleType);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3166
	goto out;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3167
	// fd = __FILEVal(fp);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3168
    } else
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3169
	if ((__INST(handleType) == nil)
16551
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3170
	       || (__INST(handleType) == @symbol(filePointer))
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3171
	       || (__INST(handleType) == @symbol(socketFilePointer))
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3172
	       || (__INST(handleType) == @symbol(pipeFilePointer))) {
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3173
	fd = fileno(__FILEVal(fp));
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3174
    } else {
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3175
	error = @symbol(badHandleType);
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3176
	goto out;
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3177
    }
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3178
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3179
#ifdef WIN32
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3180
     __threadErrno = 0;
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3181
     ret = __STX_API_NOINT_CALL1( "FlushFileBuffers", FlushFileBuffers, _get_osfhandle(fd));
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3182
     if (ret) {
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3183
	 RETURN (self);
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3184
     }
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3185
#else
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3186
     __BEGIN_INTERRUPTABLE__
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3187
     do {
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3188
	 ret = fdatasync(fd);
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3189
     } while ((ret < 0) && (__threadErrno == EINTR));
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3190
     __END_INTERRUPTABLE__
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3191
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3192
     if (ret >= 0) {
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3193
	 RETURN (self);
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3194
     }
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3195
#endif /* ! WIN32 */
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3196
     error = __mkSmallInteger(__threadErrno);
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3197
#endif /* ! __openVMS__ */
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3198
out:;
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3199
%}.
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3200
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3201
    error notNil ifTrue:[
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3202
	lastErrorNumber := error.
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3203
	self ioError:error.
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3204
	^ self.
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3205
    ].
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3206
    handle isNil ifTrue:[^ self errorNotOpen].
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3207
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3208
    "if notdef HAS_DATASYNC, fall back"
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3209
    self sync.
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3210
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3211
    "
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3212
	|f|
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3213
	f := 'x' asFilename writeStream.
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3214
	f nextPutAll:'hallo'; sync; syncData; close
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3215
    "
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3216
!
352de37575d7 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 16509
diff changeset
  3217
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3218
tcgetattr
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3219
    "unix only:
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3220
     provide the information of a tcgetattr call as a dictionary.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3221
     This provides terminal setting values of a tty or pty.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3222
     Used by terminal emulators.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3223
     On non-unix systems, an unsupported operation error is raised"
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3224
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3225
    |error ret
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3226
     iflags "/ input flags
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3227
     ignbrk brkint ignpar parmrk inpck istrip inlcr igncr
16509
2cf139885242 Fixed ExternalStream>>tcgetattr
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 16508
diff changeset
  3228
     icrnl iuclc ixon ixoff ixany imaxbel iutf8
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3229
     oflags "/ output flags
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3230
     opost onlcr ocrnl olcuc onocr onlret oxtabs onoteot
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3231
     cflags "/ control flags
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3232
     csize cstopb cread parenb parodd hupcl clocal
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3233
     lflags "/ local flags
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3234
     echoke echoe echok echo echonl echoprt echoctl
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3235
     isig icanon altwerase iexten extproc tostop
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3236
     |
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3237
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3238
%{
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3239
#if !defined(MSDOS_LIKE) && !defined(__openVMS__)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3240
    int fd;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3241
    int _ret;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3242
    OBJ fp = __INST(handle);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3243
    struct termios t;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3244
    int sz;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3245
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3246
    if (fp == nil)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3247
	goto out;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3248
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3249
    if (__INST(handleType) == @symbol(socketHandle)) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3250
	// cg: termina attributes of a socket?
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3251
	error = @symbol(badHandleType);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3252
	goto out;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3253
	// fd = __FILEVal(fp);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3254
    } else
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3255
	if ((__INST(handleType) == nil)
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3256
	 || (__INST(handleType) == @symbol(filePointer))
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3257
	 || (__INST(handleType) == @symbol(socketFilePointer))
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3258
	 || (__INST(handleType) == @symbol(pipeFilePointer))) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3259
	fd = fileno(__FILEVal(fp));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3260
    } else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3261
	error = @symbol(badHandleType);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3262
	goto out;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3263
    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3264
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3265
    __BEGIN_INTERRUPTABLE__
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3266
    do {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3267
	__threadErrno = 0;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3268
	_ret = tcgetattr(fd, &t);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3269
    } while (_ret < 0 && __threadErrno == EINTR);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3270
    __END_INTERRUPTABLE__
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3271
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3272
    if (_ret < 0) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3273
	error = __mkSmallInteger(__threadErrno);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3274
    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3275
    ignbrk = t.c_iflag & IGNBRK ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3276
    brkint = t.c_iflag & BRKINT ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3277
    ignpar = t.c_iflag & IGNPAR ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3278
    parmrk = t.c_iflag & PARMRK ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3279
    inpck = t.c_iflag & INPCK ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3280
    istrip = t.c_iflag & ISTRIP ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3281
    inlcr = t.c_iflag & INLCR ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3282
    ixon = t.c_iflag & IXON ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3283
    ixoff = t.c_iflag & IXOFF ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3284
    ixany = t.c_iflag & IXANY ? true : false;
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3285
# ifdef IMAXBEL
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3286
    imaxbel = t.c_iflag & IMAXBEL ? true : false;
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3287
# endif
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3288
# ifdef IUCLC
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3289
    iuclc = t.c_iflag & IUCLC ? true : false;
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3290
# endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3291
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3292
    opost = t.c_oflag & OPOST ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3293
    onlcr = t.c_oflag & ONLCR ? true : false;
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3294
# ifdef OXTABS
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3295
    oxtabs = t.c_oflag & OXTABS ? true : false;
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3296
# endif
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3297
# ifdef ONOTEOT
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3298
    onoteot = t.c_oflag & ONOTEOT ? true : false;
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3299
# endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3300
    ocrnl = t.c_oflag & OCRNL ? true : false;
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3301
# ifdef OLCUC
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3302
    olcuc = t.c_oflag & OLCUC ? true : false;
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3303
# endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3304
    onocr = t.c_oflag & ONOCR ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3305
    onlret = t.c_oflag & ONLRET ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3306
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3307
    sz = t.c_cflag & CSIZE;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3308
    switch (sz) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3309
	case CS5:
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3310
	    csize = @symbol(cs5);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3311
	    break;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3312
	case CS6:
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3313
	    csize = @symbol(cs6);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3314
	    break;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3315
	case CS7:
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3316
	    csize = @symbol(cs7);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3317
	    break;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3318
	case CS8:
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3319
	    csize = @symbol(cs8);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3320
	    break;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3321
    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3322
    cstopb = t.c_cflag & CSTOPB ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3323
    cread = t.c_cflag & CREAD ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3324
    parenb = t.c_cflag & PARENB ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3325
    parodd = t.c_cflag & PARODD ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3326
    hupcl = t.c_cflag & HUPCL ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3327
    clocal = t.c_cflag & CLOCAL ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3328
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3329
    echoke = t.c_lflag & ECHOKE ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3330
    echoe = t.c_lflag & ECHOE ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3331
    echo = t.c_lflag & ECHO ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3332
    echonl = t.c_lflag & ECHONL ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3333
    echoctl = t.c_lflag & ECHOCTL ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3334
    isig = t.c_lflag & ISIG ? true : false;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3335
    icanon = t.c_lflag & ICANON ? true : false;
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3336
# ifdef ALTWERASE
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3337
    altwerase = t.c_lflag & ALTWERASE ? true : false;
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3338
# endif
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3339
# ifdef IEXTEN
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3340
    iexten = t.c_lflag & IEXTEN ? true : false;
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3341
# endif
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3342
# ifdef EXTPROC
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3343
    extproc = t.c_lflag & EXTPROC ? true : false;
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3344
# endif
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3345
# ifdef TOSTOP
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3346
    tostop = t.c_lflag & TOSTOP ? true : false;
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  3347
# endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3348
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3349
#else
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3350
    error = @symbol(unsupportedOperation);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3351
#endif
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3352
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3353
out:;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3354
%}.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3355
    error notNil ifTrue:[
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3356
	error == #unsupportedOperation ifTrue:[
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3357
	    "/ the system does not support tcgetattr
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3358
	    ^ self errorUnsupportedOperation
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3359
	].
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3360
	lastErrorNumber := error.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3361
	^ self ioError:error.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3362
    ].
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3363
    handle isNil ifTrue:[^ self errorNotOpen].
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3364
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3365
    "/ construct a dictionary...
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3366
    ret := Dictionary new.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3367
    ret at:#iflags put:(iflags := Dictionary new).
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3368
    ret at:#oflags put:(oflags := Dictionary new).
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3369
    ret at:#cflags put:(cflags := Dictionary new).
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3370
    ret at:#lflags put:(lflags := Dictionary new).
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3371
    iflags at:#ignbrk put:ignbrk.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3372
    iflags at:#brkint put:brkint.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3373
    iflags at:#ignpar put:ignpar.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3374
    iflags at:#parmrk put:parmrk.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3375
    iflags at:#inpck put:inpck.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3376
    iflags at:#istrip put:istrip.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3377
    iflags at:#inlcr put:inlcr.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3378
    iflags at:#igncr put:igncr.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3379
    iflags at:#icrnl put:icrnl.
16509
2cf139885242 Fixed ExternalStream>>tcgetattr
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 16508
diff changeset
  3380
    iflags at:#uiclc put:iuclc.
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3381
    iflags at:#ixon put:ixon.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3382
    iflags at:#ixoff put:ixoff.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3383
    iflags at:#ixany put:ixany.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3384
    iflags at:#imaxbel put:imaxbel.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3385
    iflags at:#iutf8 put:iutf8.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3386
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3387
    oflags at:#opost put:opost.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3388
    oflags at:#onlcr put:onlcr.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3389
    oflags at:#oxtabs put:oxtabs.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3390
    oflags at:#onoteot put:onoteot.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3391
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3392
    cflags at:#csize put:csize.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3393
    cflags at:#cstopb put:cstopb.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3394
    cflags at:#cread put:cread.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3395
    cflags at:#parenb put:parenb.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3396
    cflags at:#parodd put:parodd.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3397
    cflags at:#hupcl put:hupcl.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3398
    cflags at:#clocal put:clocal.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3399
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3400
    lflags at:#echoke put:echoke.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3401
    lflags at:#echoe put:echoe.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3402
    lflags at:#echok put:echok.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3403
    lflags at:#echo put:echo.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3404
    lflags at:#echonl put:echonl.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3405
    lflags at:#echoprt put:echoprt.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3406
    lflags at:#echoctl put:echoctl.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3407
    lflags at:#isig put:isig.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3408
    lflags at:#icanon put:icanon.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3409
    lflags at:#altwerase put:altwerase.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3410
    lflags at:#iexten put:iexten.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3411
    lflags at:#extproc put:extproc.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3412
    lflags at:#tostop put:tostop.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3413
    ^ ret
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3414
! !
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3415
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3416
!ExternalStream methodsFor:'non homogenous reading'!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3417
17609
b06cbfcc4a11 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17608
diff changeset
  3418
next:count into:aCollection startingAt:start
b06cbfcc4a11 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17608
diff changeset
  3419
    |readCount|
b06cbfcc4a11 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17608
diff changeset
  3420
b06cbfcc4a11 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17608
diff changeset
  3421
    readCount := self nextBytes:count into:aCollection startingAt:start.
b06cbfcc4a11 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17608
diff changeset
  3422
    readCount = count ifTrue:[
18312
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  3423
	^ aCollection.
17609
b06cbfcc4a11 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17608
diff changeset
  3424
    ].
b06cbfcc4a11 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17608
diff changeset
  3425
    ^ aCollection copyFrom:1 to:start+readCount-1.
15254
1d0a262c1743 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 14847
diff changeset
  3426
!
1d0a262c1743 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 14847
diff changeset
  3427
3674
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3428
nextAvailable:count
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3429
    "return the next count elements of the stream as aCollection.
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3430
     If the stream reaches the end before count elements have been read,
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3431
     return what is available. (i.e. a shorter collection).
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3432
     The type of collection is specified in #contentsSpecies."
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3433
3956
51f1a9a4d63f changes for egcs (stdio uses __new / utsname)
Claus Gittinger <cg@exept.de>
parents: 3949
diff changeset
  3434
    |buffer n|
3674
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3435
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3436
    binary ifTrue:[
7832
f8a02752ca28 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7806
diff changeset
  3437
	buffer := ByteArray uninitializedNew:count
3674
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3438
    ] ifFalse:[
7832
f8a02752ca28 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7806
diff changeset
  3439
	buffer := String uninitializedNew:count
3674
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3440
    ].
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3441
    n := self nextAvailableBytes:count into:buffer startingAt:1.
5202
e8130049b18f #nextAvailableBytes:into:startingAt: may NOT set EOF flag,
Claus Gittinger <cg@exept.de>
parents: 5187
diff changeset
  3442
    n == 0 ifTrue:[
7832
f8a02752ca28 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7806
diff changeset
  3443
	binary ifTrue:[
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  3444
	    ^ #[]
7832
f8a02752ca28 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7806
diff changeset
  3445
	].
f8a02752ca28 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7806
diff changeset
  3446
	^ ''
5202
e8130049b18f #nextAvailableBytes:into:startingAt: may NOT set EOF flag,
Claus Gittinger <cg@exept.de>
parents: 5187
diff changeset
  3447
    ].
3674
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3448
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3449
    n ~~ count ifTrue:[
7832
f8a02752ca28 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7806
diff changeset
  3450
	^ buffer copyTo:n
3674
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3451
    ].
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3452
    ^ buffer.
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3453
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3454
    "
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  3455
     (ReadStream on:#(1 2 3 4 5)) nextAvailable:3
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  3456
     (ReadStream on:#(1 2 3 4 5)) nextAvailable:10
3674
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3457
     (ReadStream on:'hello') nextAvailable:3
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  3458
     (ReadStream on:'hello') nextAvailable:10
3674
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3459
    "
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3460
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3461
    "Modified: / 16.6.1998 / 15:52:41 / cg"
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3462
!
c51550d1df17 added #nextAvailable:
Claus Gittinger <cg@exept.de>
parents: 3672
diff changeset
  3463
17608
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  3464
nextAvailable:count into:aCollection startingAt:pos
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  3465
    "return the next count elements of the stream into aCollection at position pos."
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  3466
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  3467
    ^ self nextAvailableBytes:count into:aCollection startingAt:pos.
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  3468
!
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  3469
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3470
nextAvailableBytes:count into:anObject startingAt:start
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3471
    "read the next count bytes into an object and return the number of
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3472
     bytes read or the number of bytes read, if EOF is encountered before,
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3473
     or no more bytes are available for reading (from the pipe/socket).
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3474
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3475
     If the receiver is some socket/pipe-like stream, an exception
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3476
     is raised if the connection is broken.
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3477
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3478
     Notice, that in contrast to other methods,
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3479
     this does NOT return nil on EOF, but the actual count.
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3480
     Thus allowing read of partial blocks.
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3481
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  3482
     The object must have non-pointer indexed instvars
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3483
     (i.e. it must be a ByteArray, String, Float- or DoubleArray).
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3484
     If anObject is a string or byteArray and reused, this provides the
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3485
     fastest possible physical I/O (since no new objects are allocated).
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3486
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3487
     Use with care - non object oriented I/O.
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  3488
     Warning: in general, you cannot use this method to pass data from other
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3489
     architectures since it does not care for byte order or float representation."
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3490
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  3491
    |error|
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3492
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3493
%{
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3494
    FILEPOINTER f;
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3495
    int cnt, offs, ret, _buffered;
15987
0fbfbdf4a0a5 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15921
diff changeset
  3496
    int objSize, nInstBytes;
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3497
    char *cp;
3445
2639c1e3fd0b nextAvail also for externalBytes
Claus Gittinger <cg@exept.de>
parents: 3432
diff changeset
  3498
    char *extPtr;
7195
755c46f9b774 also handle subclasses of ExternalBytes (Mapped..)
Claus Gittinger <cg@exept.de>
parents: 7118
diff changeset
  3499
    OBJ fp;
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3500
    int o_offs;
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3501
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3502
    __INST(lastErrorNumber) = nil;
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  3503
    if ((__INST(handleType) == nil)
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  3504
     || (__INST(handleType) == @symbol(filePointer))
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  3505
     || (__INST(handleType) == @symbol(socketFilePointer))
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3506
     || (__INST(handleType) == @symbol(socketHandle))
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  3507
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3508
	if (((fp = __INST(handle)) != nil)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3509
	    && (__INST(mode) != @symbol(writeonly))
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3510
	    && __bothSmallInteger(count, start)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3511
	) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3512
	    f = __FILEVal(fp);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3513
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3514
	    cnt = __intVal(count);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3515
	    offs = __intVal(start) - 1;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3516
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3517
	    if (__isExternalBytesLike(anObject)) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3518
		OBJ sz;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3519
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3520
		nInstBytes = 0;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3521
		extPtr = (char *)(__externalBytesAddress(anObject));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3522
		if (extPtr == NULL) goto bad;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3523
		sz = __externalBytesSize(anObject);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3524
		if (__isSmallInteger(sz)) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3525
		    objSize = __intVal(sz);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3526
		} else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3527
		    objSize = 0; /* unknown */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3528
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3529
	    } else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3530
		OBJ oClass = __Class(anObject);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3531
		int nInstVars = __intVal(__ClassInstPtr(oClass)->c_ninstvars);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3532
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3533
		nInstBytes = OHDR_SIZE + __OBJS2BYTES__(nInstVars);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3534
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3535
		switch (__intVal(__ClassInstPtr(oClass)->c_flags) & ARRAYMASK) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3536
		    case BYTEARRAY:
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3537
		    case WORDARRAY:
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3538
		    case LONGARRAY:
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3539
		    case SWORDARRAY:
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3540
		    case SLONGARRAY:
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3541
		    case FLOATARRAY:
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3542
			break;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3543
		    case DOUBLEARRAY:
15987
0fbfbdf4a0a5 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15921
diff changeset
  3544
#ifdef __NEED_DOUBLE_ALIGN
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3545
			nInstBytes = (nInstBytes-1+__DOUBLE_ALIGN) &~ (__DOUBLE_ALIGN-1);
15987
0fbfbdf4a0a5 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15921
diff changeset
  3546
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3547
			break;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3548
		    case LONGLONGARRAY:
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3549
		    case SLONGLONGARRAY:
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  3550
#ifdef __NEED_LONGLONG_ALIGN
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3551
			nInstBytes = (nInstBytes-1+__LONGLONG_ALIGN) &~ (__LONGLONG_ALIGN-1);
5202
e8130049b18f #nextAvailableBytes:into:startingAt: may NOT set EOF flag,
Claus Gittinger <cg@exept.de>
parents: 5187
diff changeset
  3552
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3553
			break;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3554
		    default:
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3555
			goto bad;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3556
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3557
		extPtr = (char *)0;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3558
		objSize = __Size(anObject) - nInstBytes;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3559
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3560
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3561
	    if ((offs >= 0) && (cnt >= 0) && (objSize >= (cnt + offs))) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3562
		_buffered = (__INST(buffered) == true);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3563
		if (_buffered) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3564
		    __READING__(f);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3565
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3566
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3567
		if (extPtr) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3568
		    __READAVAILBYTES__(ret, f, extPtr+offs, cnt, _buffered, __INST(handleType));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3569
		} else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3570
		    /*
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3571
		     * on interrupt, anObject may be moved to another location.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3572
		     * So we pass (char *)__InstPtr(anObject) + nInstBytes + offs to the macro __READ_BYTES__,
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3573
		     * to get a new address.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3574
		     */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3575
		    offs += nInstBytes;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3576
		    __READAVAILBYTES_OBJ__(ret, f, anObject, offs, cnt, _buffered, __INST(handleType));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3577
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3578
		/* 0 is NOT an EOF condition here ... */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3579
		if (ret >= 0) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3580
		    if (__isSmallInteger(__INST(position))) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3581
			INT np = __intVal(__INST(position)) + ret;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3582
			OBJ t;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3583
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3584
			t = __MKINT(np); __INST(position) = t; __STORE(self, t);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3585
		    } else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3586
			__INST(position) = nil; /* i.e. do not know */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3587
		    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3588
		    RETURN (__mkSmallInteger(ret));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3589
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3590
		__INST(position) = nil;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3591
		error = __mkSmallInteger(__threadErrno);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3592
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3593
	}
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3594
    }
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3595
bad: ;
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3596
%}.
8614
88421fbd4ab6 pastEnd -> pastEndRead
Claus Gittinger <cg@exept.de>
parents: 8604
diff changeset
  3597
    (hitEOF and:[self pastEndRead isNil]) ifTrue:[^ 0].
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  3598
    error notNil ifTrue:[
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3599
	lastErrorNumber := error.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3600
	^ self readError:error
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  3601
    ].
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  3602
    handle isNil ifTrue:[^ self errorNotOpen].
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3603
    (mode == #writeonly) ifTrue:[^ self errorWriteOnly].
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3604
    "
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3605
     count not integer or arg not bit-like (String, ByteArray etc)
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3606
    "
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3607
    ^ self primitiveFailed
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3608
!
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3609
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3610
nextByte
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3611
    "read the next byte and return it as an Integer; return nil on error.
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3612
     This is allowed in both text and binary modes, always returning the
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3613
     bytes binary value as an integer in 0..255."
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3614
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  3615
    |error|
1067
1e7959af0821 removed all NOCONTEXT (last version did no good - PROTECT-stack overflow ...)
Claus Gittinger <cg@exept.de>
parents: 1066
diff changeset
  3616
%{
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  3617
#ifdef __SCHTEAM__
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  3618
    STObject handle = self.instVarAt(I_handle);
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  3619
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  3620
    if (handle != STObject.Nil) {
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  3621
	STObject next;
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  3622
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  3623
	next = handle.nextByte();
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  3624
	if (next != STObject.EOF) {
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  3625
	    self.instVarAt_put(I_position, STObject.Nil);
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  3626
	    return __c__._RETURN( next );
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  3627
	}
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  3628
	self.instVarAt_put(I_hitEOF, STObject.True);
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  3629
    }
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  3630
#else
2593
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
  3631
    FILEPOINTER f;
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3632
    unsigned char byte;
1463
ace6b72b6f4a Use common macros to make interruptable system calls signal proof.
Stefan Vogel <sv@exept.de>
parents: 1422
diff changeset
  3633
    int ret, _buffered;
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3634
    OBJ fp;
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3635
1133
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1119
diff changeset
  3636
    __INST(lastErrorNumber) = nil;
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  3637
    if ((__INST(handleType) == nil)
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  3638
     || (__INST(handleType) == @symbol(filePointer))
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  3639
     || (__INST(handleType) == @symbol(socketFilePointer))
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3640
     || (__INST(handleType) == @symbol(socketHandle))
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  3641
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3642
	if (((fp = __INST(handle)) != nil)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3643
	 && (__INST(mode) != @symbol(writeonly))) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3644
	    f = __FILEVal(fp);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3645
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3646
	    _buffered = (__INST(buffered) == true);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3647
	    if (_buffered) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3648
		__READING__(f)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3649
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3650
	    __READBYTE__(ret, f, &byte, _buffered, __INST(handleType));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3651
	    if (ret > 0) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3652
		if (__isSmallInteger(__INST(position))) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3653
		    INT np = __intVal(__INST(position)) + 1;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3654
		    OBJ t;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3655
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3656
		    t = __MKINT(np); __INST(position) = t; __STORE(self, t);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3657
		} else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3658
		    __INST(position) = nil; /* i.e. do not know */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3659
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3660
		RETURN (__mkSmallInteger(byte));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3661
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3662
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3663
	    if (ret == 0) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3664
		__INST(hitEOF) = true;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3665
	    } else /* ret < 0 */ {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3666
		__INST(position) = nil;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3667
		error = __mkSmallInteger(__threadErrno);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3668
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3669
	}
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3670
    }
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  3671
#endif /* not SCHTEAM */
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3672
%}.
8614
88421fbd4ab6 pastEnd -> pastEndRead
Claus Gittinger <cg@exept.de>
parents: 8604
diff changeset
  3673
    hitEOF ifTrue:[^ self pastEndRead].
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  3674
    error notNil ifTrue:[
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3675
	lastErrorNumber := error.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3676
	^ self readError:error
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  3677
    ].
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  3678
    handle isNil ifTrue:[^ self errorNotOpen].
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3679
    ^ self errorWriteOnly
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3680
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3681
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3682
nextBytes:count into:anObject startingAt:start
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3683
    "read the next count bytes into an object and return the number of
2151
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  3684
     bytes read or the number of bytes read, if EOF is encountered before.
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3685
     If the receiver is some socket/pipe-like stream, an exception
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3686
     is raised if the connection is broken.
2151
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  3687
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3688
     Warning: if used with a pipe/socket, this blocks until the requested number
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3689
     of bytes have been read. See #nextAvailableBytes:into:startingAt:
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3690
     to only read whats there.
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  3691
2151
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  3692
     Notice, that in contrast to other methods,
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  3693
     this does NOT return nil on EOF, but the actual count.
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3694
     Thus allowing read of partial blocks.
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3695
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  3696
     The object must have non-pointer indexed instvars
3432
1228d4ba9518 allow reading/writing from/to ExternalBytes
Claus Gittinger <cg@exept.de>
parents: 3420
diff changeset
  3697
     (i.e. it must be a ByteArray, String, Float- or DoubleArray),
1228d4ba9518 allow reading/writing from/to ExternalBytes
Claus Gittinger <cg@exept.de>
parents: 3420
diff changeset
  3698
     or an externalBytes object (with known size).
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3699
     If anObject is a string or byteArray and reused, this provides the
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3700
     fastest possible physical I/O (since no new objects are allocated).
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3701
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3702
     Use with care - non object oriented I/O.
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  3703
     Warning: in general, you cannot use this method to pass data from other
3432
1228d4ba9518 allow reading/writing from/to ExternalBytes
Claus Gittinger <cg@exept.de>
parents: 3420
diff changeset
  3704
     architectures (unless you prepared the buffer with care),
1228d4ba9518 allow reading/writing from/to ExternalBytes
Claus Gittinger <cg@exept.de>
parents: 3420
diff changeset
  3705
     since it does not care for byte order or float representation."
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3706
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  3707
    |error|
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3708
%{
2593
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
  3709
    FILEPOINTER f;
1463
ace6b72b6f4a Use common macros to make interruptable system calls signal proof.
Stefan Vogel <sv@exept.de>
parents: 1422
diff changeset
  3710
    int cnt, offs, ret, _buffered;
15987
0fbfbdf4a0a5 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15921
diff changeset
  3711
    int objSize, nInstBytes;
3432
1228d4ba9518 allow reading/writing from/to ExternalBytes
Claus Gittinger <cg@exept.de>
parents: 3420
diff changeset
  3712
    char *extPtr;
7195
755c46f9b774 also handle subclasses of ExternalBytes (Mapped..)
Claus Gittinger <cg@exept.de>
parents: 7118
diff changeset
  3713
    OBJ fp;
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3714
1133
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1119
diff changeset
  3715
    __INST(lastErrorNumber) = nil;
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  3716
    if ((__INST(handleType) == nil)
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  3717
     || (__INST(handleType) == @symbol(filePointer))
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  3718
     || (__INST(handleType) == @symbol(socketFilePointer))
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3719
     || (__INST(handleType) == @symbol(socketHandle))
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  3720
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3721
	if (((fp = __INST(handle)) != nil)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3722
	    && (__INST(mode) != @symbol(writeonly))
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3723
	    && __bothSmallInteger(count, start)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3724
	) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3725
	    f = __FILEVal(fp);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3726
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3727
	    cnt = __intVal(count);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3728
	    offs = __intVal(start) - 1;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3729
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3730
	    if (__isExternalBytesLike(anObject)) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3731
		OBJ sz;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3732
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3733
		nInstBytes = 0;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3734
		extPtr = (char *)(__externalBytesAddress(anObject));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3735
		if (extPtr == NULL) goto bad;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3736
		sz = __externalBytesSize(anObject);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3737
		if (__isSmallInteger(sz)) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3738
		    objSize = __intVal(sz);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3739
		} else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3740
		    objSize = 0; /* unknown */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3741
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3742
	    } else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3743
		OBJ oClass = __Class(anObject);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3744
		int nInstVars = __intVal(__ClassInstPtr(oClass)->c_ninstvars);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3745
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3746
		nInstBytes = OHDR_SIZE + __OBJS2BYTES__(nInstVars);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3747
		switch (__intVal(__ClassInstPtr(oClass)->c_flags) & ARRAYMASK) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3748
		    case BYTEARRAY:
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3749
		    case WORDARRAY:
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3750
		    case LONGARRAY:
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3751
		    case SWORDARRAY:
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3752
		    case SLONGARRAY:
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3753
		    case FLOATARRAY:
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3754
			break;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3755
		    case DOUBLEARRAY:
15987
0fbfbdf4a0a5 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15921
diff changeset
  3756
#ifdef __NEED_DOUBLE_ALIGN
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3757
			nInstBytes = (nInstBytes-1+__DOUBLE_ALIGN) &~ (__DOUBLE_ALIGN-1);
15987
0fbfbdf4a0a5 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15921
diff changeset
  3758
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3759
			break;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3760
		    case LONGLONGARRAY:
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3761
		    case SLONGLONGARRAY:
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  3762
#ifdef __NEED_LONGLONG_ALIGN
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3763
			nInstBytes = (nInstBytes-1+__LONGLONG_ALIGN) &~ (__LONGLONG_ALIGN-1);
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  3764
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3765
			break;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3766
		    default:
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3767
			goto bad;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3768
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3769
		extPtr = (char *)0;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3770
		objSize = __Size(anObject) - nInstBytes;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3771
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3772
	    if ((offs >= 0) && (cnt >= 0) && (objSize >= (cnt + offs))) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3773
		_buffered = (__INST(buffered) == true);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3774
		if (_buffered) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3775
		    __READING__(f);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3776
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3777
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3778
		if (extPtr) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3779
		    __READBYTES__(ret, f, extPtr+offs, cnt, _buffered, __INST(handleType));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3780
		} else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3781
		    /*
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3782
		     * on interrupt, anObject may be moved to another location.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3783
		     * So we pass anObject, and the offset to the __READBYTES_OBJ__ macro.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3784
		     */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3785
		    offs += nInstBytes;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3786
		    __READBYTES_OBJ__(ret, f, anObject, offs, cnt, _buffered, __INST(handleType));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3787
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3788
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3789
		if (ret > 0) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3790
		    if (__isSmallInteger(__INST(position))) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3791
			INT np = __intVal(__INST(position)) + ret;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3792
			OBJ t = __MKINT(np); __INST(position) = t; __STORE(self, t);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3793
		    } else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3794
			__INST(position) = nil; /* i.e. do not know */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3795
		    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3796
		    RETURN (__mkSmallInteger(ret));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3797
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3798
		if (ret == 0) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3799
		    __INST(hitEOF) = true;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3800
		} else /* ret < 0 */ {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3801
		    __INST(position) = nil;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3802
		    error = __mkSmallInteger(__threadErrno);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3803
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3804
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3805
	}
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3806
    }
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3807
bad: ;
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3808
%}.
8614
88421fbd4ab6 pastEnd -> pastEndRead
Claus Gittinger <cg@exept.de>
parents: 8604
diff changeset
  3809
    (hitEOF and:[self pastEndRead isNil]) ifTrue:[^ 0].
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  3810
    error notNil ifTrue:[
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3811
	lastErrorNumber := error.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3812
	^ self readError:error
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  3813
    ].
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  3814
    handle isNil ifTrue:[^ self errorNotOpen].
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3815
    (mode == #writeonly) ifTrue:[^ self errorWriteOnly].
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3816
    "
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3817
     count not integer or arg not bit-like (String, ByteArray etc)
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3818
    "
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3819
    ^ self primitiveFailed
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  3820
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  3821
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3822
nextLong
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3823
    "Read four bytes (msb-first) and return the value as a 32-bit signed Integer.
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3824
     The returned value may be a LargeInteger.
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3825
     (msb-first for compatibility with other smalltalks)"
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3826
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3827
    ^ self nextUnsignedLongMSB:true
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3828
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3829
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3830
nextLongMSB:msbFlag
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  3831
    "Read four bytes and return the value as a 32-bit signed Integer,
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3832
     which may be a LargeInteger.
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  3833
     If msbFlag is true, value is read with most-significant byte first,
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3834
     otherwise least-significant byte comes first.
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3835
     A nil is returned, if EOF is hit before all 4 bytes have been read.
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3836
     Works in both binary and text modes."
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3837
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  3838
    |error|
1067
1e7959af0821 removed all NOCONTEXT (last version did no good - PROTECT-stack overflow ...)
Claus Gittinger <cg@exept.de>
parents: 1066
diff changeset
  3839
%{
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3840
    OBJ fp;
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3841
1133
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1119
diff changeset
  3842
    __INST(lastErrorNumber) = nil;
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  3843
    if ((__INST(handleType) == nil)
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  3844
     || (__INST(handleType) == @symbol(filePointer))
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  3845
     || (__INST(handleType) == @symbol(socketFilePointer))
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3846
     || (__INST(handleType) == @symbol(socketHandle))
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  3847
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3848
	if (((fp = __INST(handle)) != nil)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3849
	    && (__INST(mode) != @symbol(writeonly))
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3850
	) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3851
	    FILEPOINTER f;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3852
	    int ret, _buffered;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3853
	    int value;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3854
	    union {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3855
		unsigned char buffer[4];
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3856
		int intVal;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3857
	    } u;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3858
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3859
	    f = __FILEVal(fp);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3860
	    _buffered = (__INST(buffered) == true);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3861
	    if (_buffered) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3862
		__READING__(f)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3863
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3864
	    __READBYTES__(ret, f, u.buffer, 4, _buffered, __INST(handleType));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3865
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3866
	    if (ret == 4) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3867
		if (__isSmallInteger(__INST(position))) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3868
		    INT np = __intVal(__INST(position)) + 4;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3869
		    OBJ t;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3870
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3871
		    t = __MKINT(np); __INST(position) = t; __STORE(self, t);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3872
		} else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3873
		    __INST(position) = nil; /* i.e. do not know */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3874
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3875
		if (msbFlag == true) {
8901
824a89d0b5c7 alpha64 vs. POINTER_SIZE cleanup
Claus Gittinger <cg@exept.de>
parents: 8881
diff changeset
  3876
#if defined(__MSBFIRST__)
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3877
		    value = u.intVal;
4383
7a5abc09fb39 slightly tuned nextXXXLongMSB: and nextUnsignedXXXMSB:
Claus Gittinger <cg@exept.de>
parents: 4368
diff changeset
  3878
#else
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3879
		    value = (u.buffer[0] & 0xFF);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3880
		    value = (value << 8) | (u.buffer[1] & 0xFF);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3881
		    value = (value << 8) | (u.buffer[2] & 0xFF);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3882
		    value = (value << 8) | (u.buffer[3] & 0xFF);
4383
7a5abc09fb39 slightly tuned nextXXXLongMSB: and nextUnsignedXXXMSB:
Claus Gittinger <cg@exept.de>
parents: 4368
diff changeset
  3883
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3884
		} else {
8901
824a89d0b5c7 alpha64 vs. POINTER_SIZE cleanup
Claus Gittinger <cg@exept.de>
parents: 8881
diff changeset
  3885
#if defined(__LSBFIRST__)
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3886
		    value = u.intVal;
4383
7a5abc09fb39 slightly tuned nextXXXLongMSB: and nextUnsignedXXXMSB:
Claus Gittinger <cg@exept.de>
parents: 4368
diff changeset
  3887
#else
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3888
		    value = (u.buffer[3] & 0xFF);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3889
		    value = (value << 8) | (u.buffer[2] & 0xFF);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3890
		    value = (value << 8) | (u.buffer[1] & 0xFF);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3891
		    value = (value << 8) | (u.buffer[0] & 0xFF);
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  3892
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3893
		}
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  3894
#if __POINTER_SIZE__ == 8
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3895
		RETURN ( __mkSmallInteger(value));
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  3896
#else
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3897
		if ((value >= _MIN_INT) && (value <= _MAX_INT)) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3898
		    RETURN ( __mkSmallInteger(value));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3899
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3900
		RETURN ( __MKLARGEINT(value) );
4383
7a5abc09fb39 slightly tuned nextXXXLongMSB: and nextUnsignedXXXMSB:
Claus Gittinger <cg@exept.de>
parents: 4368
diff changeset
  3901
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3902
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3903
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3904
	    if (ret < 0) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3905
		__INST(position) = nil;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3906
		error = __mkSmallInteger(__threadErrno);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3907
	    } else /* ret == 0 */ {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3908
		__INST(hitEOF) = true;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3909
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3910
	}
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3911
    }
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3912
%}.
8614
88421fbd4ab6 pastEnd -> pastEndRead
Claus Gittinger <cg@exept.de>
parents: 8604
diff changeset
  3913
    hitEOF ifTrue:[^ self pastEndRead].
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  3914
    handle isNil ifTrue:[^ self errorNotOpen].
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3915
    (mode == #writeonly) ifTrue:[^ self errorWriteOnly].
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  3916
    lastErrorNumber := error.
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  3917
    ^ self readError:error.
362
claus
parents: 360
diff changeset
  3918
!
claus
parents: 360
diff changeset
  3919
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3920
nextShortMSB:msbFlag
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3921
    "Read two bytes and return the value as a 16-bit signed Integer.
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  3922
     If msbFlag is true, value is read with most-significant byte first,
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3923
     otherwise least-significant byte comes first.
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3924
     A nil is returned if EOF is reached (also when EOF is hit after the first byte).
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3925
     Works in both binary and text modes."
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3926
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  3927
    |error|
1067
1e7959af0821 removed all NOCONTEXT (last version did no good - PROTECT-stack overflow ...)
Claus Gittinger <cg@exept.de>
parents: 1066
diff changeset
  3928
%{
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3929
    OBJ fp;
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3930
1133
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1119
diff changeset
  3931
    __INST(lastErrorNumber) = nil;
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  3932
    if ((__INST(handleType) == nil)
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  3933
     || (__INST(handleType) == @symbol(filePointer))
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  3934
     || (__INST(handleType) == @symbol(socketFilePointer))
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  3935
     || (__INST(handleType) == @symbol(socketHandle))
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  3936
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3937
	if (((fp = __INST(handle)) != nil)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3938
	    && (__INST(mode) != @symbol(writeonly))
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3939
	) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3940
	    FILEPOINTER f;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3941
	    int ret, _buffered;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3942
	    short value;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3943
	    union {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3944
		unsigned char buffer[2];
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3945
		short shortVal;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3946
	    } u;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3947
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3948
	    f = __FILEVal(fp);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3949
	    _buffered = (__INST(buffered) == true);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3950
	    if (_buffered) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3951
		__READING__(f)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3952
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3953
	    __READBYTES__(ret, f, u.buffer, 2, _buffered, __INST(handleType));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3954
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3955
	    if (ret == 2) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3956
		if (__isSmallInteger(__INST(position))) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3957
		    INT np = __intVal(__INST(position)) + 2;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3958
		    OBJ t;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3959
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3960
		    t = __MKINT(np); __INST(position) = t; __STORE(self, t);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3961
		} else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3962
		    __INST(position) = nil; /* i.e. do not know */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3963
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3964
		if (msbFlag == true) {
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  3965
#if defined(__MSBFIRST__)
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3966
		    value = u.shortVal;
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  3967
#else
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3968
		    value = ((u.buffer[0] & 0xFF) << 8) | (u.buffer[1] & 0xFF);
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  3969
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3970
		} else {
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  3971
#if defined(__LSBFIRST__)
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3972
		    value = u.shortVal;
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  3973
#else
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3974
		    value = ((u.buffer[1] & 0xFF) << 8) | (u.buffer[0] & 0xFF);
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  3975
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3976
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3977
		RETURN (__mkSmallInteger(value));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3978
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3979
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3980
	    if (ret < 0) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3981
		__INST(position) = nil; /* i.e. do not know */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3982
		error = __mkSmallInteger(__threadErrno);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3983
	    } else /* ret == 0 */ {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3984
		__INST(hitEOF) = true;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3985
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  3986
	}
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3987
    }
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3988
%}.
8614
88421fbd4ab6 pastEnd -> pastEndRead
Claus Gittinger <cg@exept.de>
parents: 8604
diff changeset
  3989
    hitEOF ifTrue:[^ self pastEndRead].
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  3990
    handle isNil ifTrue:[^ self errorNotOpen].
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3991
    (mode == #writeonly) ifTrue:[^ self errorWriteOnly].
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  3992
    lastErrorNumber := error.
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  3993
    ^ self readError:error.
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3994
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3995
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3996
nextUnsignedLongMSB:msbFlag
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3997
    "Read four bytes and return the value as a 32-bit unsigned Integer, which may be
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3998
     a LargeInteger.
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  3999
     If msbFlag is true, value is read with most-significant byte first, otherwise
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4000
     least-significant byte comes first.
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4001
     A nil is returned, if endOfFile occurs before all 4 bytes have been read.
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4002
     Works in both binary and text modes."
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4003
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4004
    |error|
1067
1e7959af0821 removed all NOCONTEXT (last version did no good - PROTECT-stack overflow ...)
Claus Gittinger <cg@exept.de>
parents: 1066
diff changeset
  4005
%{
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4006
    OBJ fp;
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4007
1133
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1119
diff changeset
  4008
    __INST(lastErrorNumber) = nil;
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4009
    if ((__INST(handleType) == nil)
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4010
     || (__INST(handleType) == @symbol(filePointer))
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4011
     || (__INST(handleType) == @symbol(socketFilePointer))
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4012
     || (__INST(handleType) == @symbol(socketHandle))
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4013
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4014
	if (((fp = __INST(handle)) != nil)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4015
	    && (__INST(mode) != @symbol(writeonly))
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4016
	) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4017
	    FILEPOINTER f;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4018
	    int ret, _buffered;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4019
	    unsigned INT value;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4020
	    union {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4021
		unsigned char buffer[4];
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4022
		unsigned int intVal;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4023
	    } u;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4024
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4025
	    f = __FILEVal(fp);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4026
	    _buffered = (__INST(buffered) == true);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4027
	    if (_buffered) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4028
		__READING__(f)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4029
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4030
	    __READBYTES__(ret, f, u.buffer, 4, _buffered, __INST(handleType));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4031
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4032
	    if (ret == 4) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4033
		if (__isSmallInteger(__INST(position))) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4034
		    INT np = __intVal(__INST(position)) + 4;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4035
		    OBJ t;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4036
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4037
		    t = __MKINT(np); __INST(position) = t; __STORE(self, t);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4038
		} else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4039
		    __INST(position) = nil; /* i.e. do not know */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4040
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4041
		if (msbFlag == true) {
8901
824a89d0b5c7 alpha64 vs. POINTER_SIZE cleanup
Claus Gittinger <cg@exept.de>
parents: 8881
diff changeset
  4042
#if defined(__MSBFIRST__)
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4043
		    value = u.intVal;
4383
7a5abc09fb39 slightly tuned nextXXXLongMSB: and nextUnsignedXXXMSB:
Claus Gittinger <cg@exept.de>
parents: 4368
diff changeset
  4044
#else
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4045
		    value = u.buffer[0];
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4046
		    value = (value << 8) | u.buffer[1];
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4047
		    value = (value << 8) | u.buffer[2];
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4048
		    value = (value << 8) | u.buffer[3];
4383
7a5abc09fb39 slightly tuned nextXXXLongMSB: and nextUnsignedXXXMSB:
Claus Gittinger <cg@exept.de>
parents: 4368
diff changeset
  4049
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4050
		} else {
8901
824a89d0b5c7 alpha64 vs. POINTER_SIZE cleanup
Claus Gittinger <cg@exept.de>
parents: 8881
diff changeset
  4051
#if defined(__LSBFIRST__)
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4052
		    value = u.intVal;
4383
7a5abc09fb39 slightly tuned nextXXXLongMSB: and nextUnsignedXXXMSB:
Claus Gittinger <cg@exept.de>
parents: 4368
diff changeset
  4053
#else
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4054
		    value = u.buffer[3];
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4055
		    value = (value << 8) | u.buffer[2];
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4056
		    value = (value << 8) | u.buffer[1];
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4057
		    value = (value << 8) | u.buffer[0];
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4058
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4059
		}
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4060
#if __POINTER_SIZE__ == 8
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4061
		value &= 0xFFFFFFFF;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4062
		RETURN (__mkSmallInteger(value));
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4063
#else
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4064
		if (value <= _MAX_INT) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4065
		    RETURN (__mkSmallInteger(value));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4066
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4067
		RETURN (__MKULARGEINT(value) );
4383
7a5abc09fb39 slightly tuned nextXXXLongMSB: and nextUnsignedXXXMSB:
Claus Gittinger <cg@exept.de>
parents: 4368
diff changeset
  4068
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4069
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4070
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4071
	    if (ret < 0) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4072
		__INST(position) = nil; /* i.e. do not know */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4073
		error = __mkSmallInteger(__threadErrno);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4074
	    } else /* ret == 0 */ {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4075
		__INST(hitEOF) = true;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4076
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4077
	}
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4078
    }
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4079
%}.
8614
88421fbd4ab6 pastEnd -> pastEndRead
Claus Gittinger <cg@exept.de>
parents: 8604
diff changeset
  4080
    hitEOF ifTrue:[^ self pastEndRead].
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4081
    handle isNil ifTrue:[^ self errorNotOpen].
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4082
    (mode == #writeonly) ifTrue:[^ self errorWriteOnly].
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4083
    lastErrorNumber := error.
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4084
    ^ self readError:error.
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4085
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4086
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4087
nextUnsignedShortMSB:msbFlag
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4088
    "Read two bytes and return the value as a 16-bit unsigned Integer.
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  4089
     If msbFlag is true, value is read with most-significant byte first,
1079
d47cd86b487b Make methods signal-proof.
Stefan Vogel <sv@exept.de>
parents: 1068
diff changeset
  4090
     otherwise least-significant byte comes first.
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4091
     A nil is returned if EOF is reached (also when EOF is hit after the first byte).
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4092
     Works in both binary and text modes."
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4093
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4094
    |error|
1067
1e7959af0821 removed all NOCONTEXT (last version did no good - PROTECT-stack overflow ...)
Claus Gittinger <cg@exept.de>
parents: 1066
diff changeset
  4095
%{
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4096
    OBJ fp;
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4097
1133
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1119
diff changeset
  4098
    __INST(lastErrorNumber) = nil;
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4099
    if ((__INST(handleType) == nil)
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4100
     || (__INST(handleType) == @symbol(filePointer))
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4101
     || (__INST(handleType) == @symbol(socketFilePointer))
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4102
     || (__INST(handleType) == @symbol(socketHandle))
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4103
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4104
	if (((fp = __INST(handle)) != nil)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4105
	    && (__INST(mode) != @symbol(writeonly))
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4106
	) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4107
	    FILEPOINTER f;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4108
	    int ret, _buffered;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4109
	    unsigned int value;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4110
	    union {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4111
		unsigned char buffer[2];
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4112
		unsigned short shortVal;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4113
	    } u;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4114
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4115
	    f = __FILEVal(fp);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4116
	    _buffered = (__INST(buffered) == true);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4117
	    if (_buffered) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4118
		__READING__(f)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4119
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4120
	    __READBYTES__(ret, f, u.buffer, 2, _buffered, __INST(handleType));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4121
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4122
	    if (ret == 2) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4123
		if (__isSmallInteger(__INST(position))) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4124
		    INT np = __intVal(__INST(position)) + 2;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4125
		    OBJ t;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4126
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4127
		    t = __MKINT(np); __INST(position) = t; __STORE(self, t);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4128
		} else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4129
		    __INST(position) = nil; /* i.e. do not know */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4130
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4131
		if (msbFlag == true) {
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4132
#if defined(__MSBFIRST__)
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4133
		    value = u.shortVal;
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4134
#else
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4135
		    value = (u.buffer[0] << 8) | u.buffer[1];
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4136
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4137
		} else {
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4138
#if defined(__LSBFIRST__)
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4139
		    value = u.shortVal;
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4140
#else
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4141
		    value = (u.buffer[1] << 8) | u.buffer[0];
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4142
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4143
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4144
		RETURN (__mkSmallInteger(value));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4145
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4146
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4147
	    if (ret < 0) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4148
		__INST(position) = nil; /* i.e. do not know */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4149
		error = __mkSmallInteger(__threadErrno);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4150
	    } else /* ret == 0 */ {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4151
		__INST(hitEOF) = true;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4152
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4153
	}
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4154
    }
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4155
%}.
8614
88421fbd4ab6 pastEnd -> pastEndRead
Claus Gittinger <cg@exept.de>
parents: 8604
diff changeset
  4156
    hitEOF ifTrue:[^ self pastEndRead].
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4157
    handle isNil ifTrue:[^ self errorNotOpen].
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4158
    (mode == #writeonly) ifTrue:[^ self errorWriteOnly].
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4159
    lastErrorNumber := error.
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4160
    ^ self readError:error.
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4161
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4162
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4163
nextWord
15452
e2a3b2dc064b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15435
diff changeset
  4164
    <resource: #obsolete>
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4165
    "in text-mode:
14632
6fe0dc1d5377 64bit mingw changes
Claus Gittinger <cg@exept.de>
parents: 14603
diff changeset
  4166
	 read the alphaNumeric next word (i.e. up to non letter-or-digit).
6fe0dc1d5377 64bit mingw changes
Claus Gittinger <cg@exept.de>
parents: 14603
diff changeset
  4167
	 return a string containing those characters.
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4168
     in binary-mode:
14632
6fe0dc1d5377 64bit mingw changes
Claus Gittinger <cg@exept.de>
parents: 14603
diff changeset
  4169
	 read two bytes (msb-first) and return the value as a 16-bit
6fe0dc1d5377 64bit mingw changes
Claus Gittinger <cg@exept.de>
parents: 14603
diff changeset
  4170
	 unsigned Integer (for compatibility with other smalltalks)"
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4171
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4172
    binary ifTrue:[
14632
6fe0dc1d5377 64bit mingw changes
Claus Gittinger <cg@exept.de>
parents: 14603
diff changeset
  4173
	^ self nextUnsignedShortMSB:true
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  4174
    ].
14518
7dad78183779 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 14440
diff changeset
  4175
    self obsoleteMethodWarning:'use #nextAlphaNumericWord'.
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4176
    ^ self nextAlphaNumericWord
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4177
! !
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4178
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4179
!ExternalStream methodsFor:'non homogenous writing'!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4180
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4181
nextPutByte:aByteValue
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4182
    "write a byte.
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4183
     Works in both binary and text modes."
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4184
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4185
    |error|
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4186
1067
1e7959af0821 removed all NOCONTEXT (last version did no good - PROTECT-stack overflow ...)
Claus Gittinger <cg@exept.de>
parents: 1066
diff changeset
  4187
%{
7875
eb7d48b0425d made all position-handling code 32bit save
Claus Gittinger <cg@exept.de>
parents: 7832
diff changeset
  4188
    OBJ fp;
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4189
1133
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1119
diff changeset
  4190
    __INST(lastErrorNumber) = nil;
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4191
    if ((__INST(handleType) == nil)
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4192
     || (__INST(handleType) == @symbol(filePointer))
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4193
     || (__INST(handleType) == @symbol(socketFilePointer))
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4194
     || (__INST(handleType) == @symbol(socketHandle))
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4195
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4196
	if (((fp = __INST(handle)) != nil)
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  4197
	 && (__INST(mode) != @symbol(readonly))
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  4198
	 && __isSmallInteger(aByteValue)
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4199
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4200
	) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  4201
	    int _buffered = (__INST(buffered) == true);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  4202
	    FILEPOINTER f = __FILEVal(fp);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  4203
	    char c = __intVal(aByteValue);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  4204
	    int cnt;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  4205
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  4206
	    if (_buffered) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4207
		__WRITING__(f)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4208
	    }
9053
f3f3d48d6f44 fix writing to stdout/stderr for winstx non-console operation
Claus Gittinger <cg@exept.de>
parents: 9024
diff changeset
  4209
#ifdef WIN32
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4210
	    if ((f == __win32_stdout()) || (f == __win32_stderr())) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4211
		cnt = __win32_fwrite(&c, 1, 1, f);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4212
	    } else
9053
f3f3d48d6f44 fix writing to stdout/stderr for winstx non-console operation
Claus Gittinger <cg@exept.de>
parents: 9024
diff changeset
  4213
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4214
	    {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4215
		__WRITEBYTE__(cnt, f, &c, _buffered, __INST(handleType));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4216
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4217
	    if (cnt == 1) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4218
		if (__isSmallInteger(__INST(position))) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4219
		    INT np = __intVal(__INST(position)) + 1;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4220
		    OBJ t;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4221
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4222
		    t = __MKINT(np); __INST(position) = t; __STORE(self, t);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4223
		} else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4224
		    __INST(position) = nil; /* i.e. do not know */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4225
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4226
		RETURN (self);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4227
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4228
	    if (cnt < 0) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4229
		__INST(position) = nil; /* i.e. do not know */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4230
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4231
	    error = __mkSmallInteger(__threadErrno);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4232
	}
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4233
    }
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4234
%}.
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4235
    handle isNil ifTrue:[self errorNotOpen. ^ self].
7801
d930c353588d writeError: care for EWOULDBLOCK in nonBlocking case.
penk
parents: 7737
diff changeset
  4236
    (mode == #readonly) ifTrue:[self errorReadOnly. ^ self].
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4237
    lastErrorNumber := error.
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4238
    self writeError:error.
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4239
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4240
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4241
nextPutLong:aNumber MSB:msbFlag
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4242
    "Write the argument, aNumber as a long (four bytes). If msbFlag is
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4243
     true, data is written most-significant byte first; otherwise least
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4244
     first.
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4245
     Works in both binary and text modes."
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4246
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4247
    |error|
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4248
1067
1e7959af0821 removed all NOCONTEXT (last version did no good - PROTECT-stack overflow ...)
Claus Gittinger <cg@exept.de>
parents: 1066
diff changeset
  4249
%{
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4250
    int num;
4384
f8e779b99b14 slightly tuned nextPutLongMSB: and nextPutShortMSB:
Claus Gittinger <cg@exept.de>
parents: 4383
diff changeset
  4251
    union {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4252
	char bytes[4];
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4253
	int intVal;
4384
f8e779b99b14 slightly tuned nextPutLongMSB: and nextPutShortMSB:
Claus Gittinger <cg@exept.de>
parents: 4383
diff changeset
  4254
    } u;
f8e779b99b14 slightly tuned nextPutLongMSB: and nextPutShortMSB:
Claus Gittinger <cg@exept.de>
parents: 4383
diff changeset
  4255
    OBJ fp;
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4256
1133
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1119
diff changeset
  4257
    __INST(lastErrorNumber) = nil;
4384
f8e779b99b14 slightly tuned nextPutLongMSB: and nextPutShortMSB:
Claus Gittinger <cg@exept.de>
parents: 4383
diff changeset
  4258
    if (__isSmallInteger(aNumber)) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4259
	num = __intVal(aNumber);
4384
f8e779b99b14 slightly tuned nextPutLongMSB: and nextPutShortMSB:
Claus Gittinger <cg@exept.de>
parents: 4383
diff changeset
  4260
    } else {
8901
824a89d0b5c7 alpha64 vs. POINTER_SIZE cleanup
Claus Gittinger <cg@exept.de>
parents: 8881
diff changeset
  4261
#if __POINTER_SIZE__ == 8
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  4262
	// always more than 4-bytes
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4263
	goto badArg;
4384
f8e779b99b14 slightly tuned nextPutLongMSB: and nextPutShortMSB:
Claus Gittinger <cg@exept.de>
parents: 4383
diff changeset
  4264
#else
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4265
	num = __longIntVal(aNumber);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4266
	if (num == 0) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4267
	    num = __signedLongIntVal(aNumber);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4268
	    if (num == 0) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4269
		/* bad arg or out-of-range integer
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4270
		 * (handled by the fallBack code)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4271
		 */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4272
		goto badArg;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4273
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4274
	}
4384
f8e779b99b14 slightly tuned nextPutLongMSB: and nextPutShortMSB:
Claus Gittinger <cg@exept.de>
parents: 4383
diff changeset
  4275
#endif
f8e779b99b14 slightly tuned nextPutLongMSB: and nextPutShortMSB:
Claus Gittinger <cg@exept.de>
parents: 4383
diff changeset
  4276
    }
f8e779b99b14 slightly tuned nextPutLongMSB: and nextPutShortMSB:
Claus Gittinger <cg@exept.de>
parents: 4383
diff changeset
  4277
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4278
    if ((__INST(handleType) == nil)
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4279
     || (__INST(handleType) == @symbol(filePointer))
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4280
     || (__INST(handleType) == @symbol(socketFilePointer))
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4281
     || (__INST(handleType) == @symbol(socketHandle))
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4282
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4283
	if (((fp = __INST(handle)) != nil)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4284
	 && (__INST(mode) != @symbol(readonly))
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4285
	) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  4286
	    int _buffered = (__INST(buffered) == true);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  4287
	    FILEPOINTER f = __FILEVal(fp);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  4288
	    int cnt;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  4289
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4290
	    if (msbFlag == true) {
8901
824a89d0b5c7 alpha64 vs. POINTER_SIZE cleanup
Claus Gittinger <cg@exept.de>
parents: 8881
diff changeset
  4291
#if defined(__MSBFIRST__)
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4292
		u.intVal = num;
4384
f8e779b99b14 slightly tuned nextPutLongMSB: and nextPutShortMSB:
Claus Gittinger <cg@exept.de>
parents: 4383
diff changeset
  4293
#else
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4294
		u.bytes[0] = (num >> 24) & 0xFF;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4295
		u.bytes[1] = (num >> 16) & 0xFF;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4296
		u.bytes[2] = (num >> 8) & 0xFF;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4297
		u.bytes[3] = num & 0xFF;
4384
f8e779b99b14 slightly tuned nextPutLongMSB: and nextPutShortMSB:
Claus Gittinger <cg@exept.de>
parents: 4383
diff changeset
  4298
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4299
	    } else {
8901
824a89d0b5c7 alpha64 vs. POINTER_SIZE cleanup
Claus Gittinger <cg@exept.de>
parents: 8881
diff changeset
  4300
#if defined(__LSBFIRST__)
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4301
		u.intVal = num;
4384
f8e779b99b14 slightly tuned nextPutLongMSB: and nextPutShortMSB:
Claus Gittinger <cg@exept.de>
parents: 4383
diff changeset
  4302
#else
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4303
		u.bytes[3] = (num >> 24) & 0xFF;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4304
		u.bytes[2] = (num >> 16) & 0xFF;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4305
		u.bytes[1] = (num >> 8) & 0xFF;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4306
		u.bytes[0] = num & 0xFF;
4384
f8e779b99b14 slightly tuned nextPutLongMSB: and nextPutShortMSB:
Claus Gittinger <cg@exept.de>
parents: 4383
diff changeset
  4307
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4308
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4309
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  4310
	    if (_buffered) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4311
		__WRITING__(f)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4312
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4313
	    __WRITEBYTES__(cnt, f, u.bytes, 4, _buffered, __INST(handleType));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4314
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4315
	    if (cnt == 4) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4316
		if (__isSmallInteger(__INST(position))) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4317
		    INT np = __intVal(__INST(position)) + 4;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4318
		    OBJ t;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4319
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4320
		    t = __MKINT(np); __INST(position) = t; __STORE(self, t);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4321
		} else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4322
		    __INST(position) = nil; /* i.e. do not know */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4323
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4324
		RETURN ( self );
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4325
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4326
	    __INST(position) = nil; /* i.e. do not know */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4327
	    error = __mkSmallInteger(__threadErrno);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4328
	}
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4329
    }
4384
f8e779b99b14 slightly tuned nextPutLongMSB: and nextPutShortMSB:
Claus Gittinger <cg@exept.de>
parents: 4383
diff changeset
  4330
badArg: ;
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4331
%}.
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4332
    handle isNil ifTrue:[self errorNotOpen. ^ self].
7801
d930c353588d writeError: care for EWOULDBLOCK in nonBlocking case.
penk
parents: 7737
diff changeset
  4333
    (mode == #readonly) ifTrue:[self errorReadOnly. ^ self].
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4334
    error notNil ifTrue:[
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4335
	lastErrorNumber := error.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4336
	self writeError:error.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4337
	^ self
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4338
    ].
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4339
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4340
    aNumber isInteger ifTrue:[
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4341
	^ super nextPutLong:aNumber MSB:msbFlag
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  4342
    ].
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4343
    self argumentMustBeInteger
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4344
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4345
15655
a044910b6f38 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15619
diff changeset
  4346
nextPutShort:anIntegerOrCharacter MSB:msbFlag
a044910b6f38 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15619
diff changeset
  4347
    "Write the argument, anIntegerOrCharacter as a short (two bytes). If msbFlag is
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4348
     true, data is written most-significant byte first; otherwise least
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4349
     first.
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4350
     Works in both binary and text modes."
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4351
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4352
    |error|
1067
1e7959af0821 removed all NOCONTEXT (last version did no good - PROTECT-stack overflow ...)
Claus Gittinger <cg@exept.de>
parents: 1066
diff changeset
  4353
%{
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4354
    int num;
4384
f8e779b99b14 slightly tuned nextPutLongMSB: and nextPutShortMSB:
Claus Gittinger <cg@exept.de>
parents: 4383
diff changeset
  4355
    union {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4356
	char bytes[2];
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4357
	short shortVal;
4384
f8e779b99b14 slightly tuned nextPutLongMSB: and nextPutShortMSB:
Claus Gittinger <cg@exept.de>
parents: 4383
diff changeset
  4358
    } u;
f8e779b99b14 slightly tuned nextPutLongMSB: and nextPutShortMSB:
Claus Gittinger <cg@exept.de>
parents: 4383
diff changeset
  4359
    OBJ fp;
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4360
1133
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1119
diff changeset
  4361
    __INST(lastErrorNumber) = nil;
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4362
    if ((__INST(handleType) == nil)
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4363
     || (__INST(handleType) == @symbol(filePointer))
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4364
     || (__INST(handleType) == @symbol(socketFilePointer))
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4365
     || (__INST(handleType) == @symbol(socketHandle))
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4366
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4367
	if (((fp = __INST(handle)) != nil)
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  4368
	 && (__INST(mode) != @symbol(readonly))
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4369
	) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  4370
	    FILEPOINTER f = __FILEVal(fp);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  4371
	    int _buffered = (__INST(buffered) == true);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  4372
	    int cnt;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  4373
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4374
	    if (__isSmallInteger(anIntegerOrCharacter)) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4375
		num = __intVal(anIntegerOrCharacter);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4376
	    } else if (__isCharacter(anIntegerOrCharacter)) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4377
		num = __smallIntegerVal(__characterVal(anIntegerOrCharacter));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4378
	    } else
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4379
		goto out;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4380
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4381
	    if (msbFlag == true) {
8901
824a89d0b5c7 alpha64 vs. POINTER_SIZE cleanup
Claus Gittinger <cg@exept.de>
parents: 8881
diff changeset
  4382
#if defined(__MSBFIRST__)
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4383
		u.shortVal = num;
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4384
#else
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4385
		u.bytes[0] = (num >> 8) & 0xFF;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4386
		u.bytes[1] = num & 0xFF;
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4387
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4388
	    } else {
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4389
#if defined(__LSBFIRST__)
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4390
		u.shortVal = num;
4384
f8e779b99b14 slightly tuned nextPutLongMSB: and nextPutShortMSB:
Claus Gittinger <cg@exept.de>
parents: 4383
diff changeset
  4391
#else
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4392
		u.bytes[1] = (num >> 8) & 0xFF;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4393
		u.bytes[0] = num & 0xFF;
4384
f8e779b99b14 slightly tuned nextPutLongMSB: and nextPutShortMSB:
Claus Gittinger <cg@exept.de>
parents: 4383
diff changeset
  4394
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4395
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4396
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  4397
	    if (_buffered) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4398
		__WRITING__(f)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4399
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4400
	    __WRITEBYTES__(cnt, f, u.bytes, 2, _buffered, __INST(handleType));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4401
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4402
	    if (cnt == 2) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4403
		if (__isSmallInteger(__INST(position))) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4404
		    INT np = __intVal(__INST(position)) + 2;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4405
		    OBJ t;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4406
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4407
		    t = __MKINT(np); __INST(position) = t; __STORE(self, t);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4408
		} else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4409
		    __INST(position) = nil; /* i.e. do not know */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4410
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4411
		RETURN ( self );
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4412
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4413
	    __INST(position) = nil; /* i.e. do not know */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4414
	    error = __mkSmallInteger(__threadErrno);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4415
	}
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4416
    }
15655
a044910b6f38 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15619
diff changeset
  4417
out:;
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4418
%}.
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4419
    error notNil ifTrue:[
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4420
	lastErrorNumber := error.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4421
	self writeError:error.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4422
	^ self
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4423
    ].
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4424
    handle isNil ifTrue:[self errorNotOpen. ^ self].
7801
d930c353588d writeError: care for EWOULDBLOCK in nonBlocking case.
penk
parents: 7737
diff changeset
  4425
    (mode == #readonly) ifTrue:[self errorReadOnly. ^ self].
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4426
    self argumentMustBeInteger
10
claus
parents: 5
diff changeset
  4427
! !
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4428
7053
13e04c48e23c prep for 0-based stream position
Claus Gittinger <cg@exept.de>
parents: 7051
diff changeset
  4429
!ExternalStream methodsFor:'positioning'!
13e04c48e23c prep for 0-based stream position
Claus Gittinger <cg@exept.de>
parents: 7051
diff changeset
  4430
15619
3f2e6f5fab12 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15496
diff changeset
  4431
position
7053
13e04c48e23c prep for 0-based stream position
Claus Gittinger <cg@exept.de>
parents: 7051
diff changeset
  4432
    self subclassResponsibility
13e04c48e23c prep for 0-based stream position
Claus Gittinger <cg@exept.de>
parents: 7051
diff changeset
  4433
!
13e04c48e23c prep for 0-based stream position
Claus Gittinger <cg@exept.de>
parents: 7051
diff changeset
  4434
15619
3f2e6f5fab12 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 15496
diff changeset
  4435
position:index0Based
7053
13e04c48e23c prep for 0-based stream position
Claus Gittinger <cg@exept.de>
parents: 7051
diff changeset
  4436
    self subclassResponsibility
13e04c48e23c prep for 0-based stream position
Claus Gittinger <cg@exept.de>
parents: 7051
diff changeset
  4437
! !
13e04c48e23c prep for 0-based stream position
Claus Gittinger <cg@exept.de>
parents: 7051
diff changeset
  4438
12631
9e55d449f787 added: #printOn:
Stefan Vogel <sv@exept.de>
parents: 12553
diff changeset
  4439
!ExternalStream methodsFor:'printing & storing'!
9e55d449f787 added: #printOn:
Stefan Vogel <sv@exept.de>
parents: 12553
diff changeset
  4440
9e55d449f787 added: #printOn:
Stefan Vogel <sv@exept.de>
parents: 12553
diff changeset
  4441
printOn:aStream
14068
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  4442
    aStream
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  4443
	nextPutAll:self className;
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  4444
	nextPutAll:'(handle:('.
12631
9e55d449f787 added: #printOn:
Stefan Vogel <sv@exept.de>
parents: 12553
diff changeset
  4445
    handle printOn:aStream.
9e55d449f787 added: #printOn:
Stefan Vogel <sv@exept.de>
parents: 12553
diff changeset
  4446
    aStream nextPutAll:'))'
9e55d449f787 added: #printOn:
Stefan Vogel <sv@exept.de>
parents: 12553
diff changeset
  4447
! !
9e55d449f787 added: #printOn:
Stefan Vogel <sv@exept.de>
parents: 12553
diff changeset
  4448
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4449
!ExternalStream methodsFor:'private'!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4450
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4451
clearEOF
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4452
    hitEOF := false
16300
277c0cb1ecbc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16296
diff changeset
  4453
! !
277c0cb1ecbc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16296
diff changeset
  4454
277c0cb1ecbc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16296
diff changeset
  4455
!ExternalStream protectedMethodsFor:'private'!
8471
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4456
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4457
closeFile
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4458
    "low level close - may be redefined in subclasses
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4459
     Don't send this message, send #close instead"
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4460
12674
80fbcc4be1d6 changed: #closeFile
Stefan Vogel <sv@exept.de>
parents: 12631
diff changeset
  4461
    |fp error|
8471
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4462
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4463
    fp := handle.
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4464
8471
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4465
%{
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4466
    int rslt;
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4467
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4468
    if (fp == nil) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4469
	error = @symbol(errorNotOpen);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4470
	goto out;
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4471
    }
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4472
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4473
    if (__INST(handleType) == @symbol(socketHandle)) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4474
	SOCKET sock = __FILEVal(fp);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4475
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4476
	if (@global(FileOpenTrace) == true) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4477
	    fprintf(stderr, "close socket [ExternalStream] %"_lx_"\n", (INT)sock);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4478
	}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4479
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4480
	// whether the close() will be successful or not - the handle is invalid now!
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4481
	__INST(handle) = nil;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4482
	do {
8471
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4483
#ifdef WIN32
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4484
	    rslt = __STX_WSA_NOINT_CALL1("closesocket", closesocket, sock);
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4485
#else
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4486
	    rslt = close(sock);
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4487
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4488
	} while((rslt < 0) && (__threadErrno == EINTR));
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4489
    } else if ((__INST(handleType) == nil)
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4490
	       || (__INST(handleType) == @symbol(filePointer))
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4491
	       || (__INST(handleType) == @symbol(socketFilePointer))
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4492
	       || (__INST(handleType) == @symbol(pipeFilePointer)))
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4493
    {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4494
	FILEPOINTER f = __FILEVal(fp);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4495
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4496
	if (@global(FileOpenTrace) == true) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4497
	    fprintf(stderr, "fclose [ExternalStream] %"_lx_"\n", (INT)f);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4498
	}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4499
	// whether the close() will be successful or not - the handle is invalid now!
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4500
	__INST(handle) = nil;
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4501
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4502
#ifdef WIN32
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4503
	if (__INST(mode) != @symbol(readonly) && __INST(buffered) != false) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4504
	    // do a fflush() first, so that fclose() doesn't block
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4505
	    // we suspect, that EINTR causes problems in fclose()
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4506
	    do {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4507
		__threadErrno = 0;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4508
		rslt = __STX_C_CALL1("fflush", fflush, f);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4509
	    } while((rslt < 0) && (__threadErrno == EINTR));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4510
	}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4511
	do {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4512
	    __threadErrno = 0;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4513
	    rslt = __STX_C_NOINT_CALL1("fclose", fclose, f);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4514
	} while((rslt < 0) && (__threadErrno == EINTR));
8471
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4515
#else
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4516
	// cg: the pre Nov2014 code always did the fclose interruptable;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4517
	// I am not sure, if fclose is actually prepared to do this;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4518
	// at least when only reading, this should not block, and we
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4519
	// should be ableto do it without being interruptable.
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4520
	// Must watch this - if it leads to blockings, change and think about it.
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4521
	if (__INST(mode) != @symbol(readonly)) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4522
	    __BEGIN_INTERRUPTABLE__
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4523
	    rslt = fclose(f);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4524
	    __END_INTERRUPTABLE__
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4525
	} else {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4526
	    rslt = fclose(f);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4527
	}
8471
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4528
#endif
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4529
    } else {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4530
	error = @symbol(badHandleType);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4531
	goto out;
8471
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4532
    }
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4533
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4534
    if (rslt < 0) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4535
	error = __mkSmallInteger(__threadErrno);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4536
	goto out;
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4537
    }
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4538
    RETURN (self);
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4539
12674
80fbcc4be1d6 changed: #closeFile
Stefan Vogel <sv@exept.de>
parents: 12631
diff changeset
  4540
out:;
8471
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4541
%}.
12674
80fbcc4be1d6 changed: #closeFile
Stefan Vogel <sv@exept.de>
parents: 12631
diff changeset
  4542
80fbcc4be1d6 changed: #closeFile
Stefan Vogel <sv@exept.de>
parents: 12631
diff changeset
  4543
    error notNil ifTrue:[
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4544
	error == #errorNotOpen ifTrue:[
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4545
	    self errorNotOpen.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4546
	].
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4547
	error isInteger ifTrue:[
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4548
	    lastErrorNumber := error.
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4549
	    mode == #readonly ifTrue:[
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4550
		self ioError:error.
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4551
	    ] ifFalse:[
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4552
		self writeError:error.
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4553
	    ].
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4554
	    ^ self.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4555
	].
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4556
	self primitiveFailed:error.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4557
	^ self.
12674
80fbcc4be1d6 changed: #closeFile
Stefan Vogel <sv@exept.de>
parents: 12631
diff changeset
  4558
    ].
80fbcc4be1d6 changed: #closeFile
Stefan Vogel <sv@exept.de>
parents: 12631
diff changeset
  4559
8471
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4560
    "/ fallback for rel5
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4561
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4562
    fp := handle.
8471
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4563
    fp notNil ifTrue:[
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4564
	handle := nil.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4565
	self closeFile:fp
8471
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4566
    ]
16300
277c0cb1ecbc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16296
diff changeset
  4567
! !
277c0cb1ecbc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16296
diff changeset
  4568
277c0cb1ecbc class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16296
diff changeset
  4569
!ExternalStream methodsFor:'private'!
8471
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4570
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4571
closeFile:handle
8471
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4572
    "for rel5 only"
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4573
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4574
    self primitiveFailed
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4575
!
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4576
12706
Stefan Vogel <sv@exept.de>
parents: 12704
diff changeset
  4577
connectTo:aFileDescriptor withMode:modeSymbol handleType:handleTypeSymbol
8966
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4578
    "connect a fileDescriptor; openmode is the string defining the way to open.
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4579
     This can be used to connect an externally provided fileDescriptor (from
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4580
     primitive code) or a pipeFileDescriptor (as returned by makePipe) to
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4581
     a Stream object.
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4582
     The openMode ('r', 'w' etc.) must match the mode in which
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4583
     the fileDescriptor was originally opened (otherwise i/o errors will be reported later)."
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4584
12706
Stefan Vogel <sv@exept.de>
parents: 12704
diff changeset
  4585
    |retVal error openmode|
8966
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4586
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4587
    handle notNil ifTrue:[^ self errorAlreadyOpen].
12706
Stefan Vogel <sv@exept.de>
parents: 12704
diff changeset
  4588
    mode := modeSymbol.
Stefan Vogel <sv@exept.de>
parents: 12704
diff changeset
  4589
    openmode := self fopenMode.
8966
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4590
%{
12683
40b0a5cd3fd3 changed:
Stefan Vogel <sv@exept.de>
parents: 12678
diff changeset
  4591
    FILEPOINTER f = 0;
8966
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4592
    OBJ fp;
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4593
    FILE *fdopen();
12683
40b0a5cd3fd3 changed:
Stefan Vogel <sv@exept.de>
parents: 12678
diff changeset
  4594
    int fd = -2;
40b0a5cd3fd3 changed:
Stefan Vogel <sv@exept.de>
parents: 12678
diff changeset
  4595
40b0a5cd3fd3 changed:
Stefan Vogel <sv@exept.de>
parents: 12678
diff changeset
  4596
    if (__isStringLike(openmode)) {
12688
b429dc21d6b8 added: #openError:
Stefan Vogel <sv@exept.de>
parents: 12683
diff changeset
  4597
#ifdef WIN32
15435
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4598
	__stxWrapApiEnterCritical();
12688
b429dc21d6b8 added: #openError:
Stefan Vogel <sv@exept.de>
parents: 12683
diff changeset
  4599
#endif
15435
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4600
	if (__isSmallInteger(aFileDescriptor)) {
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4601
	    fd = __intVal(aFileDescriptor);
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4602
	}
12683
40b0a5cd3fd3 changed:
Stefan Vogel <sv@exept.de>
parents: 12678
diff changeset
  4603
#ifdef WIN32
15435
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4604
	else if (__isExternalAddressLike(aFileDescriptor)) {
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4605
	    fd = _open_osfhandle((long)__externalAddressVal(aFileDescriptor), O_BINARY);
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4606
	    if (fd < 0) {
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4607
		if (__threadErrno == 0) {
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4608
		    // no more file descriptors
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4609
		    __threadErrno = EMFILE;
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4610
		}
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4611
		error = __mkSmallInteger(__threadErrno);
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4612
		__stxWrapApiLeaveCritical();
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4613
		goto out;
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4614
	    }
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4615
	}
12683
40b0a5cd3fd3 changed:
Stefan Vogel <sv@exept.de>
parents: 12678
diff changeset
  4616
#endif
15435
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4617
	f = (FILEPOINTER) fdopen(fd, (char *)__stringVal(openmode));
12688
b429dc21d6b8 added: #openError:
Stefan Vogel <sv@exept.de>
parents: 12683
diff changeset
  4618
#ifdef WIN32
15435
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4619
	__stxWrapApiLeaveCritical();
12688
b429dc21d6b8 added: #openError:
Stefan Vogel <sv@exept.de>
parents: 12683
diff changeset
  4620
#endif
15435
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4621
	if (f == NULL) {
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4622
	    error =__mkSmallInteger(__threadErrno);
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4623
	} else {
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4624
	    if (@global(FileOpenTrace) == true) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4625
		fprintf(stderr, "fdopen [ExternalStream] %"_ld_" (%"_lx_") -> %"_lx_"\n", (INT)fd, (INT)fd, (INT)f);
15435
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4626
	    }
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4627
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4628
	    fp = __MKFILEPOINTER(f); __INST(handle) = fp; __STORE(self, fp);
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4629
	    retVal = self;
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4630
	}
8966
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4631
    }
12688
b429dc21d6b8 added: #openError:
Stefan Vogel <sv@exept.de>
parents: 12683
diff changeset
  4632
out:;
8966
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4633
%}.
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4634
    retVal notNil ifTrue:[
15435
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4635
	position := 0.
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4636
	buffered isNil ifTrue:[
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4637
	    buffered := true.       "default is buffered"
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4638
	].
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4639
	handleType := handleTypeSymbol.
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4640
	Lobby register:self.
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4641
	^ retVal
8966
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4642
    ].
12688
b429dc21d6b8 added: #openError:
Stefan Vogel <sv@exept.de>
parents: 12683
diff changeset
  4643
    error notNil ifTrue:[
15435
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4644
	OperatingSystem closeFd:aFileDescriptor.
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4645
	lastErrorNumber := error.
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4646
	position := nil.
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4647
	"
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4648
	 the open failed for some reason ...
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4649
	"
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4650
	^ self openError:error
8966
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4651
    ].
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4652
!
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4653
10982
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4654
dupFd
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4655
    "duplicate my file descriptor"
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4656
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4657
    |fd dupFd|
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4658
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4659
    fd := self fileHandle.
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4660
    dupFd := OperatingSystem dup:fd.
10989
f7d1de91344b fix #setFileHandle:mode:
Stefan Vogel <sv@exept.de>
parents: 10988
diff changeset
  4661
    self setFileHandle:dupFd mode:self fopenMode.
10995
94ed80f3bfc7 changed #gotErrorOrEOF
sr
parents: 10989
diff changeset
  4662
!
10989
f7d1de91344b fix #setFileHandle:mode:
Stefan Vogel <sv@exept.de>
parents: 10988
diff changeset
  4663
f7d1de91344b fix #setFileHandle:mode:
Stefan Vogel <sv@exept.de>
parents: 10988
diff changeset
  4664
fopenMode
f7d1de91344b fix #setFileHandle:mode:
Stefan Vogel <sv@exept.de>
parents: 10988
diff changeset
  4665
   "answer the mode for fopen.
f7d1de91344b fix #setFileHandle:mode:
Stefan Vogel <sv@exept.de>
parents: 10988
diff changeset
  4666
    Only used internally"
f7d1de91344b fix #setFileHandle:mode:
Stefan Vogel <sv@exept.de>
parents: 10988
diff changeset
  4667
f7d1de91344b fix #setFileHandle:mode:
Stefan Vogel <sv@exept.de>
parents: 10988
diff changeset
  4668
   mode == #readonly ifTrue:[
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4669
	^ ReadMode
10989
f7d1de91344b fix #setFileHandle:mode:
Stefan Vogel <sv@exept.de>
parents: 10988
diff changeset
  4670
   ].
f7d1de91344b fix #setFileHandle:mode:
Stefan Vogel <sv@exept.de>
parents: 10988
diff changeset
  4671
   mode == #writeonly ifTrue:[
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4672
	^ WriteMode
10989
f7d1de91344b fix #setFileHandle:mode:
Stefan Vogel <sv@exept.de>
parents: 10988
diff changeset
  4673
   ].
f7d1de91344b fix #setFileHandle:mode:
Stefan Vogel <sv@exept.de>
parents: 10988
diff changeset
  4674
   mode == #readWrite ifTrue:[
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4675
	^ ReadWriteMode
10989
f7d1de91344b fix #setFileHandle:mode:
Stefan Vogel <sv@exept.de>
parents: 10988
diff changeset
  4676
   ].
f7d1de91344b fix #setFileHandle:mode:
Stefan Vogel <sv@exept.de>
parents: 10988
diff changeset
  4677
   mode == #append ifTrue:[
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4678
	^ AppendMode
10989
f7d1de91344b fix #setFileHandle:mode:
Stefan Vogel <sv@exept.de>
parents: 10988
diff changeset
  4679
   ].
f7d1de91344b fix #setFileHandle:mode:
Stefan Vogel <sv@exept.de>
parents: 10988
diff changeset
  4680
   ^ ReadWriteMode
10995
94ed80f3bfc7 changed #gotErrorOrEOF
sr
parents: 10989
diff changeset
  4681
!
10982
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4682
8966
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4683
open:aPath withMode:openModeString
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4684
    "low level open; opens the file/device and sets the handle instance
8966
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4685
     variable. Careful: this does not care for any other state."
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4686
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4687
    |ok error|
8966
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4688
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4689
    ok := false.
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4690
%{
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4691
    FILE *f;
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4692
    OBJ fp;
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4693
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4694
    if (__isStringLike(aPath) && __isStringLike(openModeString)) {
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4695
#ifdef WIN32
10339
972d0164125a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10328
diff changeset
  4696
# if 1
8966
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4697
       f = fopen((char *) __stringVal(aPath), (char *) __stringVal(openModeString));
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4698
# else
15435
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4699
	__BEGIN_INTERRUPTABLE__
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4700
	do {
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4701
	    f = fopen((char *) __stringVal(aPath), (char *) __stringVal(openModeString));
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4702
	} while ((f == NULL) && (__threadErrno == EINTR));
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4703
	__END_INTERRUPTABLE__
8966
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4704
# endif
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4705
#else /* UNIX */
15435
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4706
	__BEGIN_INTERRUPTABLE__
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4707
	do {
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4708
	    f = fopen((char *) __stringVal(aPath), (char *) __stringVal(openModeString));
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4709
	} while ((f == NULL) && (__threadErrno == EINTR));
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4710
	__END_INTERRUPTABLE__
8966
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4711
#endif /* UNIX */
15435
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4712
	if (f == NULL) {
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4713
	    error = __mkSmallInteger(__threadErrno);
15435
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4714
	} else {
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4715
	    if (@global(FileOpenTrace) == true) {
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4716
		fprintf(stderr, "fopen %s [ExternalStream] -> %"_lx_"\n", __stringVal(aPath), (INT)f);
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4717
	    }
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4718
	    fp = __MKFILEPOINTER(f); __INST(handle) = fp; __STORE(self, fp);
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4719
	    __INST(handleType) = @symbol(filePointer);
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4720
	    ok = true;
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4721
	}
8966
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4722
    }
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4723
%}.
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4724
    ok ifTrue:[
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4725
	position := 0.
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4726
	Lobby register:self.
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4727
	^ self.
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4728
    ].
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4729
    error notNil ifTrue:[
15435
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4730
	"
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4731
	 the open failed for some reason ...
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4732
	"
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4733
	lastErrorNumber := error.
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4734
	self openError:error.
8966
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4735
    ].
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4736
    self primitiveFailed.
8966
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4737
!
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4738
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4739
reOpen
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4740
    "USERS WILL NEVER INVOKE THIS METHOD
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4741
     sent after snapin to reopen streams.
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4742
     cannot reopen here since I am abstract and have no device knowledge"
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4743
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4744
    self class name errorPrint. ' [warning]: automatic reOpen not supported - stream closed' errorPrintCR.
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4745
    handle := nil.
8966
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4746
    Lobby unregister:self.
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4747
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4748
    "Modified: 10.1.1997 / 17:50:44 / cg"
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4749
!
0b299dd8759c Allow Symbols as pathname and openMode
Stefan Vogel <sv@exept.de>
parents: 8913
diff changeset
  4750
12398
7243f8014d98 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12395
diff changeset
  4751
setAccessor:what to:something
7243f8014d98 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12395
diff changeset
  4752
    "set the filePointer/fileHandle to the given one;
7243f8014d98 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12395
diff changeset
  4753
     low level private & friend interface; may also be used to connect to some
7243f8014d98 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12395
diff changeset
  4754
     externally provided handle."
7243f8014d98 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12395
diff changeset
  4755
7243f8014d98 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12395
diff changeset
  4756
    handle := something.
7243f8014d98 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12395
diff changeset
  4757
    handleType := what.
7243f8014d98 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12395
diff changeset
  4758
!
7243f8014d98 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12395
diff changeset
  4759
8471
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4760
setFileDescriptor:anInteger mode:openMode
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4761
    "set the handle based upon a given fileDescriptor -
8471
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4762
     notice: this one is based on the underlying OSs fileDescriptor -
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4763
     this may not be available on all platforms (i.e. non unix systems)."
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4764
10982
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4765
    self setFileHandle:anInteger mode:openMode
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4766
!
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4767
12398
7243f8014d98 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12395
diff changeset
  4768
setFileHandle:something
7243f8014d98 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12395
diff changeset
  4769
    "set the fileHandle to the given one;
7243f8014d98 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12395
diff changeset
  4770
     low level private & friend interface; may also be used to connect to some
7243f8014d98 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12395
diff changeset
  4771
     externally provided file handle."
7243f8014d98 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12395
diff changeset
  4772
7243f8014d98 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12395
diff changeset
  4773
    self setAccessor:#fileHandle to:something
7243f8014d98 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12395
diff changeset
  4774
!
7243f8014d98 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12395
diff changeset
  4775
10982
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4776
setFileHandle:anIntegerOrExternalAddress mode:openMode
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4777
    "set the handle based upon a given fileHandle -
10982
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4778
     notice: this one is based on the underlying OSs fileDescriptor -
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4779
     this is a fileDescriptor (Integer) on Unix and Windows, or an Handle (ExternalAddres) on Windows only.
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4780
     It may not be available on all platforms."
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4781
8471
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4782
%{
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4783
    FILEPOINTER f;
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4784
    OBJ fp;
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4785
    FILE *fdopen();
10982
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4786
    int fd;
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4787
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4788
    if (!__isStringLike(openMode))
14068
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  4789
	goto err;
10982
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4790
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4791
#ifdef WIN32
12688
b429dc21d6b8 added: #openError:
Stefan Vogel <sv@exept.de>
parents: 12683
diff changeset
  4792
    __stxWrapApiEnterCritical();
10982
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4793
    if (__isExternalAddressLike(anIntegerOrExternalAddress) ) {
14068
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  4794
	HANDLE __fileHandle = (HANDLE)__externalAddressVal(anIntegerOrExternalAddress);
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  4795
	fd = _open_osfhandle((long)__fileHandle, O_BINARY);      /* should we handle readonly, append or text mode? */
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  4796
	if (fd < 0) {
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  4797
	    __stxWrapApiLeaveCritical();
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  4798
	    CloseHandle(__fileHandle);
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  4799
	    goto err;
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  4800
	}
10982
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4801
    } else
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4802
#endif
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4803
    if (__isSmallInteger(anIntegerOrExternalAddress)) {
14068
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  4804
	fd = __smallIntegerVal(anIntegerOrExternalAddress);
10982
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4805
    } else {
12688
b429dc21d6b8 added: #openError:
Stefan Vogel <sv@exept.de>
parents: 12683
diff changeset
  4806
#ifdef WIN32
14068
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  4807
	__stxWrapApiLeaveCritical();
12688
b429dc21d6b8 added: #openError:
Stefan Vogel <sv@exept.de>
parents: 12683
diff changeset
  4808
#endif
14068
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  4809
	goto err;
8471
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4810
    }
10997
8ec53332c725 _fdopen -> fdopen()
Stefan Vogel <sv@exept.de>
parents: 10995
diff changeset
  4811
    f = fdopen(fd, __stringVal(openMode));
12688
b429dc21d6b8 added: #openError:
Stefan Vogel <sv@exept.de>
parents: 12683
diff changeset
  4812
#ifdef WIN32
b429dc21d6b8 added: #openError:
Stefan Vogel <sv@exept.de>
parents: 12683
diff changeset
  4813
    __stxWrapApiLeaveCritical();
b429dc21d6b8 added: #openError:
Stefan Vogel <sv@exept.de>
parents: 12683
diff changeset
  4814
#endif
10982
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4815
    if (f != NULL) {
14068
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  4816
	if (@global(FileOpenTrace) == true) {
15435
fc902ce16af0 typecasts in printf for 64bit
Claus Gittinger <cg@exept.de>
parents: 15361
diff changeset
  4817
	    fprintf(stderr, "fdopen [ExternalStream] %d -> %"_lx_"\n", fd, (INT)f);
14068
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  4818
	}
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  4819
	fp = __MKFILEPOINTER(f); __INST(handle) = fp; __STORE(self, fp);
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  4820
	__INST(handleType) = @symbol(filePointer);
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  4821
	RETURN (self);
10982
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4822
    }
11fd48c1276d New: #copy duplicates the underlying file descriptor resp. file handle
Stefan Vogel <sv@exept.de>
parents: 10932
diff changeset
  4823
err:;
8471
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4824
%}.
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4825
    ^ self primitiveFailed
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4826
!
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4827
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4828
setFilePointer:something
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4829
    "set the filePointer to the given one;
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4830
     low level private & friend interface; may also be used to connect to some
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4831
     externally provided file."
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4832
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4833
    self setAccessor:#filePointer to:something
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4834
!
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4835
12398
7243f8014d98 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12395
diff changeset
  4836
setLastError:aNumber
7243f8014d98 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12395
diff changeset
  4837
    lastErrorNumber := aNumber
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4838
!
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4839
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4840
setSocketHandle:something
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4841
    "set the socketHandle to the given one;
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4842
     low level private & friend interface; may also be used to connect to some
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4843
     externally provided socket handle."
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4844
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4845
    self setAccessor:#socketHandle to:something
8471
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4846
! !
e061e503bf03 Documentation: users shold never send #closeFile
Stefan Vogel <sv@exept.de>
parents: 8362
diff changeset
  4847
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4848
!ExternalStream methodsFor:'queries'!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4849
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4850
nextError
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4851
    "return the error by trying to read something.
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4852
     Should only be used, when we know, that a read operation
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4853
     will return an error (otherwise a character may be lost).
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4854
     Return an integer (error number), 0 (EOF) or nil (no error)"
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4855
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4856
%{ /*NOCONTEXT*/
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4857
    FILEPOINTER f;
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4858
    int ret, _buffered;
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4859
    OBJ fp;
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4860
    unsigned char ch;
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4861
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4862
    if ((__INST(handleType) == nil)
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4863
     || (__INST(handleType) == @symbol(filePointer))
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4864
     || (__INST(handleType) == @symbol(socketFilePointer))
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4865
     || (__INST(handleType) == @symbol(socketHandle))
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4866
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4867
	if (((fp = __INST(handle)) != nil)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4868
	    && (__INST(mode) != @symbol(writeonly))
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4869
	) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4870
	    f = __FILEVal(fp);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4871
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4872
	    _buffered = (__INST(buffered) == true);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4873
	    if (_buffered) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4874
		__READING__(f)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4875
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4876
	    __READBYTE__(ret, f, &ch, _buffered, __INST(handleType));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4877
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4878
	    if (ret > 0) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4879
		RETURN(nil)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4880
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4881
	    if (ret < 0) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4882
		RETURN(__mkSmallInteger(__threadErrno));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4883
	    } else /* ret == 0 */ {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4884
		RETURN(__mkSmallInteger(0)); /* EOF */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4885
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4886
	}
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4887
    }
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4888
%}.
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4889
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4890
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4891
numAvailable
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4892
    "return the number of bytes available for reading"
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4893
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4894
    |fd|
7804
7128efd3b504 isNonBlocking -> isBlocking
Claus Gittinger <cg@exept.de>
parents: 7801
diff changeset
  4895
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  4896
    handle isNil ifTrue:[^ self errorNotOpen].
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4897
    mode == #writeonly ifTrue:[^ self errorWriteOnly].
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4898
    fd := self fileDescriptor.
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4899
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4900
%{
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4901
#ifdef WIN32
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4902
    int res = 1;
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4903
    int success = 0;
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4904
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4905
    if (__INST(handleType) == @symbol(socketHandle)) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4906
	success = ioctlsocket((SOCKET)__externalAddressVal(fd), FIONREAD, &res) == 0;
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4907
    } else if (__INST(handleType) == @symbol(socketFilePointer)) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4908
	success = ioctlsocket((SOCKET)_get_osfhandle(__intVal(fd)), FIONREAD, &res) == 0;
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4909
    } else if (__INST(handleType) == @symbol(pipeFilePointer)) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4910
	success = PeekNamedPipe((HANDLE)_get_osfhandle(__intVal(fd)),0,0,0,&res,0);
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4911
    }
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4912
    if (success) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4913
	if (__INST(readAhead) != nil) res++;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  4914
	RETURN(__mkSmallInteger(res));
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4915
    }
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4916
#endif
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4917
%}.
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4918
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4919
    ^ (readAhead notNil or:[OperatingSystem readCheck:fd]) ifTrue:[1] ifFalse:[0].
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4920
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4921
    "Created: / 4.2.1998 / 16:56:01 / cg"
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4922
    "Modified: / 4.2.1998 / 17:31:11 / cg"
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4923
! !
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4924
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4925
!ExternalStream methodsFor:'reading'!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4926
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4927
next
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4928
    "return the next element; advance read position.
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4929
     In binary mode, an integer is returned, otherwise a character.
10348
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  4930
     If there are no more elements, either an exception is thrown or nil is returned
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  4931
     - see #pastEndRead."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  4932
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  4933
    |c error|
1067
1e7959af0821 removed all NOCONTEXT (last version did no good - PROTECT-stack overflow ...)
Claus Gittinger <cg@exept.de>
parents: 1066
diff changeset
  4934
%{
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  4935
#ifdef __SCHTEAM__
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  4936
    STObject handle = self.instVarAt(I_handle);
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  4937
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  4938
    if (handle != STObject.Nil) {
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  4939
	STObject next;
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  4940
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  4941
	if (self.instVarAt(I_binary) == STObject.True) {
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  4942
	    next = handle.nextByte();
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  4943
	} else {
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  4944
	    next = handle.nextChar();
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  4945
	}
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  4946
	if (next != STObject.EOF) {
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  4947
	    self.instVarAt_put(I_position, STObject.Nil);
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  4948
	    return __c__._RETURN( next );
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  4949
	}
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  4950
	self.instVarAt_put(I_hitEOF, STObject.True);
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  4951
    }
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  4952
#else
2593
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
  4953
    FILEPOINTER f;
1463
ace6b72b6f4a Use common macros to make interruptable system calls signal proof.
Stefan Vogel <sv@exept.de>
parents: 1422
diff changeset
  4954
    int ret, _buffered;
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4955
    OBJ pos, fp;
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4956
    unsigned char ch;
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  4957
1133
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1119
diff changeset
  4958
    __INST(lastErrorNumber) = nil;
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4959
    if ((__INST(handleType) == nil)
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4960
     || (__INST(handleType) == @symbol(filePointer))
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4961
     || (__INST(handleType) == @symbol(socketFilePointer))
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  4962
     || (__INST(handleType) == @symbol(socketHandle))
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  4963
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4964
	if (((fp = __INST(handle)) != nil)
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4965
	    && (__INST(mode) != @symbol(writeonly))
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4966
	) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4967
	    f = __FILEVal(fp);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4968
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4969
	    _buffered = (__INST(buffered) == true);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4970
	    if (_buffered) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4971
		__READING__(f)
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4972
	    }
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4973
	    __READBYTE__(ret, f, &ch, _buffered, __INST(handleType));
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4974
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4975
	    if (ret > 0) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4976
		pos = __INST(position);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4977
		if (__isSmallInteger(pos)) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4978
		    OBJ t;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4979
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4980
		    t = __MKINT(__intVal(pos) + 1); __INST(position) = t; __STORE(self, t);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4981
		} else {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4982
		    __INST(position) = nil; /* i.e. do not know */
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4983
		}
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4984
		if (__INST(binary) == true) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4985
		    RETURN ( __mkSmallInteger(ch) );
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4986
		}
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4987
		RETURN ( __MKCHARACTER(ch) );
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4988
	    }
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4989
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4990
	    __INST(position) = nil;
17360
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  4991
	    if ((ret < 0)
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  4992
# ifdef ECONNRESET
17360
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  4993
		&& (__threadErrno != ECONNRESET)
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  4994
# endif
17360
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  4995
	    ){
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4996
		error = __mkSmallInteger(__threadErrno);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4997
	    } else /* ret == 0 */ {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4998
		__INST(hitEOF) = true;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  4999
	    }
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5000
	}
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5001
    }
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5002
#endif /* not SCHTEAM */
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5003
%}.
8614
88421fbd4ab6 pastEnd -> pastEndRead
Claus Gittinger <cg@exept.de>
parents: 8604
diff changeset
  5004
    hitEOF == true ifTrue:[^ self pastEndRead].
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  5005
    error notNil ifTrue:[
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5006
	lastErrorNumber := error.
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5007
	^ self readError:error
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  5008
    ].
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  5009
    handle isNil ifTrue:[^ self errorNotOpen].
5420
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5010
    (mode == #writeonly) ifTrue:[^ self errorWriteOnly].
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5011
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5012
    readAhead notNil ifTrue:[
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5013
	c := readAhead.
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5014
	readAhead := nil.
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5015
	^ c.
5420
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5016
    ].
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  5017
    c := self nextByteFromFile:handle.
5430
7d0aa5fc6c22 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 5420
diff changeset
  5018
    c isNil ifTrue:[
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5019
	^ self pastEndRead.
5430
7d0aa5fc6c22 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 5420
diff changeset
  5020
    ].
5420
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5021
    binary == true ifTrue:[
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5022
	^ c
5420
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5023
    ].
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5024
    ^ Character value:c
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5025
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5026
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5027
next:count
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5028
    "return the next count elements of the stream as a collection.
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5029
     Redefined to return a String or ByteArray instead of the default: Array."
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5030
2151
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  5031
    |coll nRead|
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5032
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5033
    binary ifTrue:[
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5034
	coll := ByteArray uninitializedNew:count
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5035
    ] ifFalse:[
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5036
	coll := String new:count
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5037
    ].
2151
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  5038
    nRead := self nextBytes:count into:coll startingAt:1.
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  5039
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  5040
    "/ for readStream protocol compatibility,
2151
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  5041
    "/ we must raise an exception here.
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  5042
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  5043
    nRead < count ifTrue:[
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5044
	^ self pastEndRead
2151
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  5045
    ].
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5046
    ^ coll
2151
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  5047
5f1fd65f8c3b next: must raise pastEnd, if EOF is hit;
Claus Gittinger <cg@exept.de>
parents: 2134
diff changeset
  5048
    "Modified: 11.1.1997 / 17:44:17 / cg"
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5049
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5050
10348
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5051
nextOrNil
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5052
    "return the next element; advance read position.
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5053
     In binary mode, an integer is returned, otherwise a character.
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5054
     If there are no more elements, nil is returned.
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5055
     This is #atEnd and #next in a single operation - to speed up some code"
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5056
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  5057
    |c error|
10348
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5058
%{
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5059
    FILEPOINTER f;
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5060
    int ret, _buffered;
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5061
    OBJ pos, fp;
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5062
    unsigned char ch;
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5063
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5064
    __INST(lastErrorNumber) = nil;
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5065
    if ((__INST(handleType) == nil)
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5066
     || (__INST(handleType) == @symbol(filePointer))
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5067
     || (__INST(handleType) == @symbol(socketFilePointer))
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5068
     || (__INST(handleType) == @symbol(socketHandle))
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5069
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5070
	if (((fp = __INST(handle)) != nil)
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5071
	    && (__INST(mode) != @symbol(writeonly))
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5072
	) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5073
	    f = __FILEVal(fp);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5074
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5075
	    _buffered = (__INST(buffered) == true);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5076
	    if (_buffered) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5077
		__READING__(f)
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5078
	    }
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5079
	    __READBYTE__(ret, f, &ch, _buffered, __INST(handleType));
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5080
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5081
	    if (ret > 0) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5082
		pos = __INST(position);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5083
		if (__isSmallInteger(pos)) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5084
		    OBJ t;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5085
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5086
		    t = __MKINT(__intVal(pos) + 1); __INST(position) = t; __STORE(self, t);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5087
		} else {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5088
		    __INST(position) = nil; /* i.e. do not know */
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5089
		}
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5090
		if (__INST(binary) == true) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5091
		    RETURN ( __mkSmallInteger(ch) );
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5092
		}
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5093
		RETURN ( __MKCHARACTER(ch) );
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5094
	    }
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5095
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5096
	    __INST(position) = nil;
17360
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  5097
	    if ((ret < 0)
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  5098
#ifdef ECONNRESET
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  5099
		&& (__threadErrno != ECONNRESET)
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  5100
#endif
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  5101
	    ){
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5102
		error = __mkSmallInteger(__threadErrno);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5103
	    } else /* ret == 0 */ {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5104
		__INST(hitEOF) = true;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5105
	    }
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5106
	}
10348
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5107
    }
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5108
%}.
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5109
    hitEOF == true ifTrue:[^ nil].
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  5110
    error notNil ifTrue:[
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5111
	lastErrorNumber := error.
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5112
	^ self readError:error.
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  5113
    ].
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  5114
    handle isNil ifTrue:[^ self errorNotOpen].
10348
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5115
    (mode == #writeonly) ifTrue:[^ self errorWriteOnly].
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5116
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5117
    readAhead notNil ifTrue:[
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5118
	c := readAhead.
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5119
	readAhead := nil.
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5120
	^ c.
10348
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5121
    ].
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  5122
    c := self nextByteFromFile:handle.
10348
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5123
    c isNil ifTrue:[
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5124
	^ nil.
10348
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5125
    ].
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5126
    binary == true ifTrue:[
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5127
	^ c
10348
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5128
    ].
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5129
    ^ Character value:c
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5130
!
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5131
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5132
peek
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5133
    "return the element to be read next without advancing read position.
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5134
     In binary mode, an integer is returned, otherwise a character.
10348
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5135
     If there are no more elements, either an exception is thrown or nil is returned
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5136
     - see #pastEndRead."
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5137
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  5138
    |error|
1067
1e7959af0821 removed all NOCONTEXT (last version did no good - PROTECT-stack overflow ...)
Claus Gittinger <cg@exept.de>
parents: 1066
diff changeset
  5139
%{
2593
d678527ef34e changes for NT; prepare to use HANDLES instead of FILES (NT)
Claus Gittinger <cg@exept.de>
parents: 2591
diff changeset
  5140
    FILEPOINTER f;
1463
ace6b72b6f4a Use common macros to make interruptable system calls signal proof.
Stefan Vogel <sv@exept.de>
parents: 1422
diff changeset
  5141
    unsigned char c;
2120
71c1870df7ba implemented 1-character readAhead for unbuffered streams;
Claus Gittinger <cg@exept.de>
parents: 2045
diff changeset
  5142
    int ret, _buffered;
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  5143
    OBJ fp;
3672
49dff0652a2c fixed readAhead in peek with non-binary mode
Claus Gittinger <cg@exept.de>
parents: 3569
diff changeset
  5144
    OBJ ra;
49dff0652a2c fixed readAhead in peek with non-binary mode
Claus Gittinger <cg@exept.de>
parents: 3569
diff changeset
  5145
49dff0652a2c fixed readAhead in peek with non-binary mode
Claus Gittinger <cg@exept.de>
parents: 3569
diff changeset
  5146
    if ((ra = __INST(readAhead)) != nil) {
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5147
	if (__INST(binary) == true) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5148
	    RETURN ( ra );
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5149
	}
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5150
	c = __intVal(ra);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5151
	RETURN ( __MKCHARACTER(c) );
3029
aa14768e0e6a larger lineBuffer in #nextLine
Claus Gittinger <cg@exept.de>
parents: 3016
diff changeset
  5152
    }
aa14768e0e6a larger lineBuffer in #nextLine
Claus Gittinger <cg@exept.de>
parents: 3016
diff changeset
  5153
1133
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1119
diff changeset
  5154
    __INST(lastErrorNumber) = nil;
2120
71c1870df7ba implemented 1-character readAhead for unbuffered streams;
Claus Gittinger <cg@exept.de>
parents: 2045
diff changeset
  5155
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5156
    if ((__INST(handleType) == nil)
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5157
     || (__INST(handleType) == @symbol(filePointer))
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5158
     || (__INST(handleType) == @symbol(socketFilePointer))
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5159
     || (__INST(handleType) == @symbol(socketHandle))
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5160
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5161
	if (((fp = __INST(handle)) != nil)
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5162
	    && (__INST(mode) != @symbol(writeonly))
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5163
	) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5164
	    f = __FILEVal(fp);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5165
	    _buffered = (__INST(buffered) == true);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5166
	    if (_buffered) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5167
		__READING__(f)
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5168
	    }
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5169
	    __READBYTE__(ret, f, &c, _buffered, __INST(handleType));
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5170
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5171
	    if (ret > 0) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5172
		__UNGETC__(c, f, _buffered);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5173
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5174
		if (__INST(binary) == true) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5175
		    RETURN ( __mkSmallInteger(c) );
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5176
		}
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5177
		RETURN ( __MKCHARACTER(c) );
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5178
	    }
17360
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  5179
	    if ((ret < 0)
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  5180
#ifdef ECONNRESET
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  5181
		&& (__threadErrno != ECONNRESET)
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  5182
#endif
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  5183
	    ){
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5184
		error = __mkSmallInteger(__threadErrno);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5185
	    } else /* ret == 0 */ {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5186
		__INST(hitEOF) = true;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5187
	    }
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5188
	}
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  5189
    }
159
514c749165c3 *** empty log message ***
claus
parents: 108
diff changeset
  5190
%}.
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  5191
    hitEOF == true ifTrue:[^ self pastEndRead].
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  5192
    error notNil ifTrue:[
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5193
	lastErrorNumber := error.
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5194
	^ self readError:error.
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  5195
    ].
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  5196
    handle isNil ifTrue:[^ self errorNotOpen].
5420
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5197
    (mode == #writeonly) ifTrue:[^ self errorWriteOnly].
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5198
10348
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5199
    readAhead isNil ifTrue:[
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5200
	readAhead := self nextOrNil.
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5201
	readAhead isNil ifTrue:[
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5202
	    ^ self pastEndRead.
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5203
	].
5420
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5204
    ].
10348
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5205
    ^ readAhead
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5206
!
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5207
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5208
peekOrNil
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5209
    "return the element to be read next without advancing read position.
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5210
     In binary mode, an integer is returned, otherwise a character.
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5211
     If there are no more elements, nil is returned.
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5212
     Same as #atEnd and #peek in a single operation - speeding up some code"
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5213
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  5214
    |error|
10348
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5215
%{
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5216
    FILEPOINTER f;
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5217
    unsigned char c;
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5218
    int ret, _buffered;
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5219
    OBJ fp;
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5220
    OBJ ra;
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5221
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5222
    if ((ra = __INST(readAhead)) != nil) {
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5223
	if (__INST(binary) == true) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5224
	    RETURN ( ra );
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5225
	}
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5226
	c = __intVal(ra);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5227
	RETURN ( __MKCHARACTER(c) );
10348
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5228
    }
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5229
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5230
    __INST(lastErrorNumber) = nil;
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5231
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5232
    if ((__INST(handleType) == nil)
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5233
     || (__INST(handleType) == @symbol(filePointer))
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5234
     || (__INST(handleType) == @symbol(socketFilePointer))
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5235
     || (__INST(handleType) == @symbol(socketHandle))
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5236
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5237
	if (((fp = __INST(handle)) != nil)
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5238
	    && (__INST(mode) != @symbol(writeonly))
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5239
	) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5240
	    f = __FILEVal(fp);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5241
	    _buffered = (__INST(buffered) == true);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5242
	    if (_buffered) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5243
		__READING__(f)
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5244
	    }
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5245
	    __READBYTE__(ret, f, &c, _buffered, __INST(handleType));
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5246
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5247
	    if (ret > 0) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5248
		__UNGETC__(c, f, _buffered);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5249
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5250
		if (__INST(binary) == true) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5251
		    RETURN ( __mkSmallInteger(c) );
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5252
		}
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5253
		RETURN ( __MKCHARACTER(c) );
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5254
	    }
17360
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  5255
	    if ((ret < 0)
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  5256
#ifdef ECONNRESET
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  5257
		&& (__threadErrno != ECONNRESET)
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  5258
#endif
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  5259
	    ){
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5260
		error = __mkSmallInteger(__threadErrno);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5261
	    } else /* ret == 0 */ {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5262
		__INST(hitEOF) = true;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5263
	    }
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5264
	}
10348
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5265
    }
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5266
%}.
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5267
    hitEOF == true ifTrue:[^ nil].
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  5268
    error notNil ifTrue:[
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5269
	lastErrorNumber := error.
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5270
	^ self readError:error.
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  5271
    ].
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  5272
    handle isNil ifTrue:[^ self errorNotOpen].
10348
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5273
    (mode == #writeonly) ifTrue:[^ self errorWriteOnly].
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5274
7ed317f7f2be Speedup ExternalStream>>#nextOrNil and ExternalStream>>#peekOrNil.
Stefan Vogel <sv@exept.de>
parents: 10339
diff changeset
  5275
    readAhead isNil ifTrue:[
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5276
	readAhead := self nextOrNil.
5420
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5277
    ].
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5278
    ^ readAhead
1295
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  5279
!
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  5280
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  5281
upToEnd
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  5282
    "return a collection of the elements up-to the end.
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  5283
     Return nil if the stream-end is reached before."
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  5284
6569
f8336e46ec9f Speedup #upToEnd
Stefan Vogel <sv@exept.de>
parents: 6563
diff changeset
  5285
    |answerStream buffer count|
f8336e46ec9f Speedup #upToEnd
Stefan Vogel <sv@exept.de>
parents: 6563
diff changeset
  5286
f8336e46ec9f Speedup #upToEnd
Stefan Vogel <sv@exept.de>
parents: 6563
diff changeset
  5287
    buffer := self contentsSpecies new:4096.
1295
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  5288
    [self atEnd] whileFalse:[
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  5289
	count := self nextAvailableBytes:4096 into:buffer startingAt:1.
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  5290
	count ~~ 0 ifTrue:[
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  5291
	    answerStream isNil ifTrue:[
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  5292
		answerStream := WriteStream with:buffer.
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  5293
		answerStream position:count.
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  5294
		buffer := self contentsSpecies new:4096.
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  5295
	    ] ifFalse:[
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  5296
		answerStream nextPutAll:buffer startingAt:1 to:count.
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  5297
	    ].
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  5298
	].
1295
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  5299
    ].
6758
bc933037a1dc oops - upToEnd failed if already at the end
Claus Gittinger <cg@exept.de>
parents: 6661
diff changeset
  5300
    answerStream isNil ifTrue:[^ self contentsSpecies new].
1295
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  5301
    ^ answerStream contents
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
  5302
7054
685d359f9847 code rewritten to be independent of stream zero-base
Claus Gittinger <cg@exept.de>
parents: 7053
diff changeset
  5303
    "
685d359f9847 code rewritten to be independent of stream zero-base
Claus Gittinger <cg@exept.de>
parents: 7053
diff changeset
  5304
     ('smalltalk.rc' asFilename readStream upToEnd)
685d359f9847 code rewritten to be independent of stream zero-base
Claus Gittinger <cg@exept.de>
parents: 7053
diff changeset
  5305
     =
685d359f9847 code rewritten to be independent of stream zero-base
Claus Gittinger <cg@exept.de>
parents: 7053
diff changeset
  5306
     ('smalltalk.rc' asFilename readStream contentsOfEntireFile)
685d359f9847 code rewritten to be independent of stream zero-base
Claus Gittinger <cg@exept.de>
parents: 7053
diff changeset
  5307
    "
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5308
! !
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5309
5420
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5310
!ExternalStream methodsFor:'rel5 protocol'!
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5311
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  5312
atEndFile:handle
5420
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5313
    "for migration to rel5 only"
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5314
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5315
    self primitiveFailed
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5316
!
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5317
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  5318
nextByteFromFile:handle
5420
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5319
    "for migration to rel5 only"
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5320
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5321
    self primitiveFailed
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5322
!
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5323
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  5324
nextPutByte:aByte toFile:handle
5420
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5325
    "for migration to rel5 only"
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5326
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5327
    self primitiveFailed
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5328
! !
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5329
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5330
!ExternalStream methodsFor:'testing'!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5331
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5332
atEnd
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5333
    "return true, if position is at end"
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5334
1067
1e7959af0821 removed all NOCONTEXT (last version did no good - PROTECT-stack overflow ...)
Claus Gittinger <cg@exept.de>
parents: 1066
diff changeset
  5335
%{
7875
eb7d48b0425d made all position-handling code 32bit save
Claus Gittinger <cg@exept.de>
parents: 7832
diff changeset
  5336
    OBJ fp, pos, lim;
1463
ace6b72b6f4a Use common macros to make interruptable system calls signal proof.
Stefan Vogel <sv@exept.de>
parents: 1422
diff changeset
  5337
    char c;
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5338
1133
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1119
diff changeset
  5339
    if (__INST(hitEOF) == true) {
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5340
	RETURN (true);
3906
7f2d4a3b63e2 oops - readLimit was not handled in #atEnd
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  5341
    }
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  5342
    pos = __INST(position);
7875
eb7d48b0425d made all position-handling code 32bit save
Claus Gittinger <cg@exept.de>
parents: 7832
diff changeset
  5343
    lim = __INST(readLimit);
eb7d48b0425d made all position-handling code 32bit save
Claus Gittinger <cg@exept.de>
parents: 7832
diff changeset
  5344
    if (lim != nil) {
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5345
	off_t _pos, _readLimit;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5346
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5347
	_pos = __signedLongIntVal(pos);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5348
	_pos = _pos - __intVal( @global(PositionableStream:ZeroPosition)) + 1;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5349
	_readLimit = __signedLongIntVal(lim);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5350
	if (_pos > _readLimit) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5351
	    RETURN (true);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5352
	}
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5353
    }
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5354
1133
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1119
diff changeset
  5355
    __INST(lastErrorNumber) = nil;
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1119
diff changeset
  5356
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5357
    if ((__INST(handleType) == nil)
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5358
     || (__INST(handleType) == @symbol(filePointer))
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5359
     || (__INST(handleType) == @symbol(socketFilePointer))
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5360
     || (__INST(handleType) == @symbol(socketHandle))
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5361
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5362
	if ((fp = __INST(handle)) != nil) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5363
	    int _buffered = (__INST(buffered) == true);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5364
	    int ret;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5365
	    FILEPOINTER f = __FILEVal(fp);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5366
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5367
	    if (_buffered) {
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5368
		__READING__(f);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5369
	    } else {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5370
		if (__INST(readAhead) != nil) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5371
		    RETURN (false);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5372
		}
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5373
	    }
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5374
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5375
	    /*
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5376
	     * read ahead ...
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5377
	     */
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5378
	    do {
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  5379
#ifdef WIN32
10339
972d0164125a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10328
diff changeset
  5380
# if 1
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5381
		__READBYTE__(ret, f, &c, _buffered, __INST(handleType));
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  5382
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  5383
# else
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5384
		__BEGIN_INTERRUPTABLE__
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5385
		__READBYTE__(ret, f, &c, _buffered, __INST(handleType));
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5386
		__END_INTERRUPTABLE__
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  5387
# endif
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  5388
#else /* not WIN32 */
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5389
		__BEGIN_INTERRUPTABLE__
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5390
		__READBYTE__(ret, f, &c, _buffered, __INST(handleType));
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5391
		__END_INTERRUPTABLE__
4914
Claus Gittinger <cg@exept.de>
parents: 4913
diff changeset
  5392
#endif
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5393
	    } while ((ret < 0) && (__threadErrno == EINTR));
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5394
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5395
	    if (ret > 0) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5396
		__UNGETC__(c&0xff, f, _buffered);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5397
		RETURN (false);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5398
	    }
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5399
	    if (ret == 0) {
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5400
		__INST(hitEOF) = true;
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5401
		RETURN (true);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5402
	    }
17360
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  5403
#ifdef ECONNRESET
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  5404
	    // connection reset by peer is also an EOF
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  5405
	    if (__threadErrno == ECONNRESET) {
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  5406
		__INST(hitEOF) = true;
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  5407
		RETURN (true);
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  5408
	    }
24b114ab935a ECONNRESET must be treated like EOF; not like an error.
Claus Gittinger <cg@exept.de>
parents: 17332
diff changeset
  5409
#endif
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5410
	    /* ret < 0 */
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5411
	    __INST(lastErrorNumber) = __mkSmallInteger(__threadErrno);
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5412
	}
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5413
    }
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5414
%}.
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5415
    lastErrorNumber notNil ifTrue:[^ self readError].
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  5416
    handle isNil ifTrue:[^ self errorNotOpen].
5420
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5417
    mode == #writeonly ifTrue:[^ self errorWriteOnly].
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5418
    readAhead notNil ifTrue:[^ false].
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5419
cec8306dff39 migration
Claus Gittinger <cg@exept.de>
parents: 5417
diff changeset
  5420
    "/ migration support
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  5421
    ^ self
17115
2ef08a902c34 did report error in close always as writeError - although it could also happen on a readonly stream
Claus Gittinger <cg@exept.de>
parents: 17078
diff changeset
  5422
	atEndFile:handle
3906
7f2d4a3b63e2 oops - readLimit was not handled in #atEnd
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  5423
7f2d4a3b63e2 oops - readLimit was not handled in #atEnd
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  5424
    "Modified: / 30.10.1998 / 20:16:06 / cg"
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5425
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5426
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5427
canReadWithoutBlocking
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5428
    "return true, if any data is available for reading (i.e.
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5429
     a read operation will not block the smalltalk process), false otherwise.
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5430
     We know, that error conditions do not block, so return true for errors."
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5431
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5432
    ^ readAhead notNil
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5433
	or:[handle isNil]
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5434
	or:[mode == #writeonly
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5435
	or:[OperatingSystem readCheck:self fileDescriptor]]
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5436
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5437
    "
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5438
     |pipe|
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5439
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5440
     pipe := PipeStream readingFrom:'(sleep 10; echo hello)'.
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5441
     pipe canReadWithoutBlocking ifTrue:[
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  5442
	 Transcript showCR:'data available'
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5443
     ] ifFalse:[
7051
984d8271d06b preps for 0-based stream positions
Claus Gittinger <cg@exept.de>
parents: 7017
diff changeset
  5444
	 Transcript showCR:'no data available'
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5445
     ].
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5446
     pipe close
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5447
    "
2986
c6957cf6128f Handle readAhead in #canReadWithoutBlocking
Stefan Vogel <sv@exept.de>
parents: 2963
diff changeset
  5448
c6957cf6128f Handle readAhead in #canReadWithoutBlocking
Stefan Vogel <sv@exept.de>
parents: 2963
diff changeset
  5449
    "Modified: 25.9.1997 / 13:08:45 / stefan"
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5450
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5451
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5452
canWriteWithoutBlocking
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  5453
    "return true, if data can be written into the stream
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5454
     (i.e. a write operation will not block the smalltalk process).
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5455
     We know, that error conditions do not block, so return true for errors."
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5456
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5457
    ^ handle isNil
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5458
	or:[mode == #readonly
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5459
	or:[OperatingSystem writeCheck:self fileDescriptor]]
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  5460
!
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  5461
10995
94ed80f3bfc7 changed #gotErrorOrEOF
sr
parents: 10989
diff changeset
  5462
gotErrorOrEOF
94ed80f3bfc7 changed #gotErrorOrEOF
sr
parents: 10989
diff changeset
  5463
    "answerv true, if amn error or eof has been occured on the stream"
94ed80f3bfc7 changed #gotErrorOrEOF
sr
parents: 10989
diff changeset
  5464
94ed80f3bfc7 changed #gotErrorOrEOF
sr
parents: 10989
diff changeset
  5465
    ^ hitEOF == true or:[lastErrorNumber notNil]
94ed80f3bfc7 changed #gotErrorOrEOF
sr
parents: 10989
diff changeset
  5466
!
94ed80f3bfc7 changed #gotErrorOrEOF
sr
parents: 10989
diff changeset
  5467
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5468
isBinary
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5469
    "return true, if the stream is in binary (as opposed to text-) mode.
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5470
     The default when created is false."
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5471
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5472
    ^ binary
6269
3a888523e3a6 #errorReporter and #reportOn class-methods
Stefan Vogel <sv@exept.de>
parents: 6255
diff changeset
  5473
!
3a888523e3a6 #errorReporter and #reportOn class-methods
Stefan Vogel <sv@exept.de>
parents: 6255
diff changeset
  5474
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5475
isBlocking
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5476
    "return true, if O_NONBLOCK is NOT set in the fileDescriptor (probably UNIX specific)"
3274
92a24829f14a added #nextAvailableBytes - very useful for pipes & sockets.
Claus Gittinger <cg@exept.de>
parents: 3255
diff changeset
  5477
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  5478
    handle isNil ifTrue:[^ self errorNotOpen].
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5479
    ^ OperatingSystem isBlockingOn:self fileDescriptor
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5480
!
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5481
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5482
isExternalStream
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5483
    "return true, if the receiver is some kind of externalStream;
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5484
     true is returned here - the method redefined from Object."
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5485
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5486
    ^ true
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5487
!
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5488
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5489
isOpen
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5490
    "return true, if this stream is open"
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5491
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5492
    ^ handle notNil
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5493
!
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5494
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5495
isReadable
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5496
    "return true, if this stream can be read from"
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5497
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5498
    ^ (mode ~~ #writeonly)
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5499
!
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5500
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5501
isWritable
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5502
    "return true, if this stream can be written to"
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5503
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5504
    ^ (mode ~~ #readonly)
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5505
! !
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5506
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5507
!ExternalStream methodsFor:'waiting for I/O'!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5508
5101
901c91d6dd50 support to poll write-fds
Claus Gittinger <cg@exept.de>
parents: 4968
diff changeset
  5509
canBeSelected
901c91d6dd50 support to poll write-fds
Claus Gittinger <cg@exept.de>
parents: 4968
diff changeset
  5510
    "return true, if this stream can be selected upon"
901c91d6dd50 support to poll write-fds
Claus Gittinger <cg@exept.de>
parents: 4968
diff changeset
  5511
901c91d6dd50 support to poll write-fds
Claus Gittinger <cg@exept.de>
parents: 4968
diff changeset
  5512
    ^ OperatingSystem supportsSelect
901c91d6dd50 support to poll write-fds
Claus Gittinger <cg@exept.de>
parents: 4968
diff changeset
  5513
!
901c91d6dd50 support to poll write-fds
Claus Gittinger <cg@exept.de>
parents: 4968
diff changeset
  5514
18327
57a095b55d92 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 18312
diff changeset
  5515
readWaitWithTimeoutMs:timeoutOrNil
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5516
    "suspend the current process, until the receiver
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  5517
     becomes ready for reading or a timeout (in milliseconds) expired.
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  5518
     If data is already available, return immediate.
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5519
     Return true if a timeout occured (i.e. false, if data is available).
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5520
     The other threads are not affected by the wait."
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5521
16480
2b0c4915f31d class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16463
diff changeset
  5522
    |fd inputSema hasTimedout wasBlocked|
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5523
2120
71c1870df7ba implemented 1-character readAhead for unbuffered streams;
Claus Gittinger <cg@exept.de>
parents: 2045
diff changeset
  5524
    readAhead notNil ifTrue:[^ false].
71c1870df7ba implemented 1-character readAhead for unbuffered streams;
Claus Gittinger <cg@exept.de>
parents: 2045
diff changeset
  5525
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  5526
    handle isNil ifTrue:[^ self errorNotOpen].
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5527
    mode == #writeonly ifTrue:[^ self errorWriteOnly].
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5528
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5529
    fd := self fileDescriptor.
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5530
    (OperatingSystem readCheck:fd) ifTrue:[^ false].
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5531
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5532
    wasBlocked := OperatingSystem blockInterrupts.
16463
2b3728727f5e class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16373
diff changeset
  5533
    inputSema := Semaphore new name:'readWait'.
2b3728727f5e class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16373
diff changeset
  5534
    [
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5535
	timeoutOrNil notNil ifTrue:[
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5536
	    Processor signal:inputSema afterMilliseconds:timeoutOrNil.
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5537
	].
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5538
	Processor signal:inputSema onInput:fd.
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5539
	Processor activeProcess state:#ioWait.
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5540
	inputSema wait.
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5541
	hasTimedout := timeoutOrNil notNil and:[(OperatingSystem readCheck:fd) not].
16463
2b3728727f5e class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16373
diff changeset
  5542
    ] ifCurtailed:[
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5543
	Processor disableSemaphore:inputSema.
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5544
	wasBlocked ifFalse:[OperatingSystem unblockInterrupts].
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5545
    ].
18327
57a095b55d92 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 18312
diff changeset
  5546
    timeoutOrNil notNil ifTrue:[
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5547
	Processor disableSemaphore:inputSema.
16480
2b0c4915f31d class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16463
diff changeset
  5548
    ].
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5549
    wasBlocked ifFalse:[OperatingSystem unblockInterrupts].
16480
2b0c4915f31d class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16463
diff changeset
  5550
    ^ hasTimedout
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5551
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5552
3490
6a87c2b37fd4 added #readWriteWait methods.
Claus Gittinger <cg@exept.de>
parents: 3474
diff changeset
  5553
readWriteWaitWithTimeoutMs:timeout
6a87c2b37fd4 added #readWriteWait methods.
Claus Gittinger <cg@exept.de>
parents: 3474
diff changeset
  5554
    "suspend the current process, until the receiver
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  5555
     becomes ready for reading or writing or a timeout (in milliseconds) expired.
3490
6a87c2b37fd4 added #readWriteWait methods.
Claus Gittinger <cg@exept.de>
parents: 3474
diff changeset
  5556
     Return true if a timeout occured (i.e. false, if data is available).
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  5557
     Return immediate if the receiver is already ready.
5506
ffa0d32f4a51 Comment
Stefan Vogel <sv@exept.de>
parents: 5494
diff changeset
  5558
     The other threads are not affected by the wait."
3490
6a87c2b37fd4 added #readWriteWait methods.
Claus Gittinger <cg@exept.de>
parents: 3474
diff changeset
  5559
16480
2b0c4915f31d class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16463
diff changeset
  5560
    |fd sema hasTimedout wasBlocked|
3490
6a87c2b37fd4 added #readWriteWait methods.
Claus Gittinger <cg@exept.de>
parents: 3474
diff changeset
  5561
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  5562
    handle isNil ifTrue:[
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5563
	^ self errorNotOpen
3490
6a87c2b37fd4 added #readWriteWait methods.
Claus Gittinger <cg@exept.de>
parents: 3474
diff changeset
  5564
    ].
6a87c2b37fd4 added #readWriteWait methods.
Claus Gittinger <cg@exept.de>
parents: 3474
diff changeset
  5565
6a87c2b37fd4 added #readWriteWait methods.
Claus Gittinger <cg@exept.de>
parents: 3474
diff changeset
  5566
    fd := self fileDescriptor.
6a87c2b37fd4 added #readWriteWait methods.
Claus Gittinger <cg@exept.de>
parents: 3474
diff changeset
  5567
    (OperatingSystem readWriteCheck:fd) ifTrue:[^ false].
6a87c2b37fd4 added #readWriteWait methods.
Claus Gittinger <cg@exept.de>
parents: 3474
diff changeset
  5568
6a87c2b37fd4 added #readWriteWait methods.
Claus Gittinger <cg@exept.de>
parents: 3474
diff changeset
  5569
    wasBlocked := OperatingSystem blockInterrupts.
16463
2b3728727f5e class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16373
diff changeset
  5570
    sema := Semaphore new name:'readWriteWait'.
2b3728727f5e class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16373
diff changeset
  5571
    [
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5572
	timeout notNil ifTrue:[
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5573
	    Processor signal:sema afterMilliseconds:timeout
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5574
	].
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5575
	Processor signal:sema onOutput:fd.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5576
	Processor signal:sema onInput:fd.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5577
	Processor activeProcess state:#ioWait.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5578
	sema wait.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5579
	hasTimedout := timeout notNil and:[(OperatingSystem readWriteCheck:fd) not].
16463
2b3728727f5e class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16373
diff changeset
  5580
    ] ifCurtailed:[
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5581
	Processor disableSemaphore:sema.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5582
	wasBlocked ifFalse:[OperatingSystem unblockInterrupts].
3490
6a87c2b37fd4 added #readWriteWait methods.
Claus Gittinger <cg@exept.de>
parents: 3474
diff changeset
  5583
    ].
16480
2b0c4915f31d class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16463
diff changeset
  5584
    timeout notNil ifTrue:[
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5585
	Processor disableSemaphore:sema.
16480
2b0c4915f31d class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16463
diff changeset
  5586
    ].
3490
6a87c2b37fd4 added #readWriteWait methods.
Claus Gittinger <cg@exept.de>
parents: 3474
diff changeset
  5587
    wasBlocked ifFalse:[OperatingSystem unblockInterrupts].
16480
2b0c4915f31d class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16463
diff changeset
  5588
    ^ hasTimedout
3490
6a87c2b37fd4 added #readWriteWait methods.
Claus Gittinger <cg@exept.de>
parents: 3474
diff changeset
  5589
!
6a87c2b37fd4 added #readWriteWait methods.
Claus Gittinger <cg@exept.de>
parents: 3474
diff changeset
  5590
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5591
writeWaitWithTimeoutMs:timeout
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5592
    "suspend the current process, until the receiver
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  5593
     becomes ready for writing or a timeout (in milliseconds) expired.
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5594
     Return true if a timeout occured (i.e. false, if data is available).
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  5595
     Return immediate if the receiver is already ready.
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5596
     The other threads are not affected by the wait."
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5597
16480
2b0c4915f31d class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16463
diff changeset
  5598
    |fd outputSema hasTimedout wasBlocked|
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5599
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  5600
    handle isNil ifTrue:[
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5601
	^ self errorNotOpen
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5602
    ].
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5603
    mode == #readonly ifTrue:[
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5604
	^ self errorReadOnly
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5605
    ].
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5606
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5607
    fd := self fileDescriptor.
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5608
    (OperatingSystem writeCheck:fd) ifTrue:[^ false].
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5609
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5610
    wasBlocked := OperatingSystem blockInterrupts.
16463
2b3728727f5e class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16373
diff changeset
  5611
    outputSema := Semaphore new name:'writeWait'.
2b3728727f5e class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16373
diff changeset
  5612
    [
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5613
	timeout notNil ifTrue:[
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5614
	    Processor signal:outputSema afterMilliseconds:timeout
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5615
	].
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5616
	Processor signal:outputSema onOutput:fd.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5617
	Processor activeProcess state:#ioWait.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5618
	outputSema wait.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5619
	hasTimedout := timeout notNil and:[(OperatingSystem writeCheck:fd) not].
16463
2b3728727f5e class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16373
diff changeset
  5620
    ] ifCurtailed:[
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5621
	Processor disableSemaphore:outputSema.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5622
	wasBlocked ifFalse:[OperatingSystem unblockInterrupts].
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5623
    ].
16480
2b0c4915f31d class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16463
diff changeset
  5624
    timeout notNil ifTrue:[
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5625
	Processor disableSemaphore:outputSema.
16480
2b0c4915f31d class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16463
diff changeset
  5626
    ].
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5627
    wasBlocked ifFalse:[OperatingSystem unblockInterrupts].
16480
2b0c4915f31d class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 16463
diff changeset
  5628
    ^ hasTimedout
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5629
! !
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5630
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5631
!ExternalStream methodsFor:'writing'!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5632
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5633
cr
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5634
    "append an end-of-line character (or CRLF if in crlf mode).
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5635
     reimplemented for speed"
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5636
1067
1e7959af0821 removed all NOCONTEXT (last version did no good - PROTECT-stack overflow ...)
Claus Gittinger <cg@exept.de>
parents: 1066
diff changeset
  5637
%{
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5638
    if ((__INST(handleType) == nil)
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5639
     || (__INST(handleType) == @symbol(filePointer))
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  5640
     || (__INST(handleType) == @symbol(socketHandle))
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5641
     || (__INST(handleType) == @symbol(socketFilePointer))
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5642
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5643
	OBJ fp;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5644
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5645
	__INST(lastErrorNumber) = nil;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5646
	if (((fp = __INST(handle)) != nil)
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5647
	 && (__INST(mode) != @symbol(readonly))
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5648
	 && (__INST(binary) != true)
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5649
	) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5650
	    FILEPOINTER f = __FILEVal(fp);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5651
	    int _buffered = (__INST(buffered) == true);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5652
	    int len, cnt;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5653
	    char *cp;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5654
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5655
	    if (_buffered) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5656
		__WRITING__(f)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5657
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5658
	    {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5659
		OBJ mode = __INST(eolMode);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5660
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5661
		if (mode == @symbol(cr)) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5662
		    cp = "\r"; len = 1;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5663
		} else if (mode == @symbol(crlf)) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5664
		    cp = "\r\n"; len = 2;
17430
c8749e1c02ad class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17426
diff changeset
  5665
		} else if (mode == @symbol(eot)) {
c8749e1c02ad class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17426
diff changeset
  5666
		    cp = "\004"; len = 1;
c8749e1c02ad class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17426
diff changeset
  5667
		} else if (mode == @symbol(etx)) {
c8749e1c02ad class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17426
diff changeset
  5668
		    cp = "\003"; len = 1;
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5669
		} else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5670
		    cp = "\n"; len = 1;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5671
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5672
	    }
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  5673
#ifdef WIN32
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5674
	    if ((f == __win32_stdout()) || (f == __win32_stderr())) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5675
		cnt = __win32_fwrite(cp, 1, len, f);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5676
	    } else
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  5677
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5678
	    {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5679
		__WRITEBYTES__(cnt, f, cp, len, _buffered, __INST(handleType));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5680
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5681
	    if (cnt == len) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5682
		if (__isSmallInteger(__INST(position))) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5683
		    INT np = __intVal(__INST(position)) + len;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5684
		    OBJ t;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5685
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5686
		    t = __MKINT(np); __INST(position) = t; __STORE(self, t);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5687
		} else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5688
		    __INST(position) = nil; /* i.e: dont know */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5689
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5690
		RETURN ( self );
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5691
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5692
	    __INST(lastErrorNumber) = __mkSmallInteger(__threadErrno);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  5693
	}
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5694
    }
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5695
%}.
2326
01fa309e48d9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 2325
diff changeset
  5696
    lastErrorNumber notNil ifTrue:[self writeError. ^ self].
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  5697
    handle isNil ifTrue:[self errorNotOpen. ^ self].
2326
01fa309e48d9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 2325
diff changeset
  5698
    (mode == #readonly) ifTrue:[self errorReadOnly. ^ self].
5414
8557e4e71e51 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 5323
diff changeset
  5699
    (binary==true) ifTrue:[self errorBinary. ^ self].
8557e4e71e51 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 5323
diff changeset
  5700
17426
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  5701
    (eolMode == #cr) ifTrue:[
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  5702
	self nextPut:(Character return).
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  5703
	^ self
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  5704
    ].
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  5705
    (eolMode == #crlf) ifTrue:[
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  5706
	self nextPut:(Character return).
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  5707
    ].
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  5708
    self nextPut:(Character nl).
5414
8557e4e71e51 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 5323
diff changeset
  5709
    ^ self
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5710
!
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5711
1463
ace6b72b6f4a Use common macros to make interruptable system calls signal proof.
Stefan Vogel <sv@exept.de>
parents: 1422
diff changeset
  5712
flush
ace6b72b6f4a Use common macros to make interruptable system calls signal proof.
Stefan Vogel <sv@exept.de>
parents: 1422
diff changeset
  5713
    "write all buffered data - ignored if unbuffered"
ace6b72b6f4a Use common macros to make interruptable system calls signal proof.
Stefan Vogel <sv@exept.de>
parents: 1422
diff changeset
  5714
ace6b72b6f4a Use common macros to make interruptable system calls signal proof.
Stefan Vogel <sv@exept.de>
parents: 1422
diff changeset
  5715
%{
ace6b72b6f4a Use common macros to make interruptable system calls signal proof.
Stefan Vogel <sv@exept.de>
parents: 1422
diff changeset
  5716
    __INST(lastErrorNumber) = nil;
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5717
    if ((__INST(handleType) == nil)
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5718
     || (__INST(handleType) == @symbol(filePointer))
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5719
     || (__INST(handleType) == @symbol(socketFilePointer))
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  5720
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5721
	OBJ fp;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5722
	int _buffered = (__INST(buffered) == true);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5723
14068
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  5724
	if ((fp = __INST(handle)) != nil) {
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  5725
	    if (__INST(mode) != @symbol(readonly)) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5726
		if (_buffered) {
14068
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  5727
		    FILEPOINTER f = __FILEVal(fp);
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  5728
#ifdef WIN32
14068
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  5729
		    if ((f == __win32_stdout()) || (f == __win32_stderr())) {
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  5730
			__win32_fflush(f);
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  5731
		    } else {
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  5732
			int rslt;
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  5733
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  5734
			do {
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  5735
			    __threadErrno = 0;
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  5736
			    rslt = __STX_C_CALL1("fflush", fflush, f);
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  5737
			} while((rslt < 0) && (__threadErrno == EINTR));
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  5738
		    }
12678
662465401b77 changed:
Stefan Vogel <sv@exept.de>
parents: 12674
diff changeset
  5739
#else /* ! WIN32 */
14068
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  5740
		    __BEGIN_INTERRUPTABLE__
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  5741
		    FFLUSH(f);
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  5742
		    __END_INTERRUPTABLE__
12678
662465401b77 changed:
Stefan Vogel <sv@exept.de>
parents: 12674
diff changeset
  5743
#endif /* ! WIN32 */
14068
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  5744
		}
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  5745
	    }
46a8289bf92a pass linenr to dumpObject
Claus Gittinger <cg@exept.de>
parents: 13940
diff changeset
  5746
	}
1463
ace6b72b6f4a Use common macros to make interruptable system calls signal proof.
Stefan Vogel <sv@exept.de>
parents: 1422
diff changeset
  5747
    }
ace6b72b6f4a Use common macros to make interruptable system calls signal proof.
Stefan Vogel <sv@exept.de>
parents: 1422
diff changeset
  5748
%}
ace6b72b6f4a Use common macros to make interruptable system calls signal proof.
Stefan Vogel <sv@exept.de>
parents: 1422
diff changeset
  5749
!
ace6b72b6f4a Use common macros to make interruptable system calls signal proof.
Stefan Vogel <sv@exept.de>
parents: 1422
diff changeset
  5750
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5751
nextPut:aCharacter
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5752
    "write the argument, aCharacter - return nil if failed, self if ok.
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5753
     Only single-byte characters are currently supported"
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  5754
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  5755
    |error|
1067
1e7959af0821 removed all NOCONTEXT (last version did no good - PROTECT-stack overflow ...)
Claus Gittinger <cg@exept.de>
parents: 1066
diff changeset
  5756
%{
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5757
#ifdef __SCHTEAM__
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5758
    STObject handle = self.instVarAt(I_handle);
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5759
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5760
    if ((handle != STObject.Nil)
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5761
     && (aCharacter.isSTCharacter())) {
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5762
	handle.writeChar( aCharacter );
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5763
	self.instVarAt_put(I_position, STObject.Nil);
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5764
	return __c__._RETURN_self();
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5765
    }
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5766
#else
17332
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5767
    __INST(lastErrorNumber) = nil;
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5768
    if ((__INST(handleType) == nil)
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5769
     || (__INST(handleType) == @symbol(filePointer))
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5770
     || (__INST(handleType) == @symbol(socketFilePointer))
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5771
     || (__INST(handleType) == @symbol(socketHandle))
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5772
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5773
	OBJ fp;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5774
17332
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5775
	if (((fp = __INST(handle)) != nil)
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5776
	 && (__INST(mode) != @symbol(readonly))
17332
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5777
	) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5778
	    FILEPOINTER f = __FILEVal(fp);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5779
	    int _buffered = (__INST(buffered) == true);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5780
	    unsigned codePoint;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5781
	    unsigned char c;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5782
	    int cnt;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5783
	    char buff[2];
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5784
	    int nBytes = 1;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5785
17332
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5786
	    if (__INST(binary) != true) {
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5787
		if (__isCharacter(aCharacter)) {
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5788
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5789
		    codePoint = __intVal(__characterVal(aCharacter));
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5790
		    if (codePoint <= 0xFF) {
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5791
			c = codePoint;
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5792
			buff[0] = c; nBytes = 1;
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5793
17426
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  5794
			if (c == '\n') {
17430
c8749e1c02ad class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17426
diff changeset
  5795
			    OBJ mode = __INST(eolMode);
c8749e1c02ad class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17426
diff changeset
  5796
			    if (mode == @symbol(nl)) {
c8749e1c02ad class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17426
diff changeset
  5797
				// no EOL translation
c8749e1c02ad class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17426
diff changeset
  5798
			    } else if (mode == nil) {
c8749e1c02ad class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17426
diff changeset
  5799
				// no EOL translation
c8749e1c02ad class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17426
diff changeset
  5800
			    } else if (mode == @symbol(cr)) {
17332
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5801
				buff[0] = '\r';
17430
c8749e1c02ad class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17426
diff changeset
  5802
			    } else if (mode == @symbol(eot)) {
c8749e1c02ad class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17426
diff changeset
  5803
				buff[0] = '\004';
c8749e1c02ad class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17426
diff changeset
  5804
			    } else if (mode == @symbol(etx)) {
c8749e1c02ad class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17426
diff changeset
  5805
				buff[0] = '\003';
c8749e1c02ad class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 17426
diff changeset
  5806
			    } else if (mode == @symbol(crlf)) {
17426
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  5807
				buff[0] = '\r';
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  5808
				buff[1] = '\n';
6e49243ce4e0 fix: code treated everything but nl,cr,crnl symbols als cr (by accident).
Claus Gittinger <cg@exept.de>
parents: 17420
diff changeset
  5809
				nBytes = 2;
17332
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5810
			    }
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5811
			}
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5812
    doWrite:
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5813
			if (! f) {
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5814
			    fprintf(stderr, "oops - fileHandle is NULL in nextPut:\n");
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5815
			    __INST(handle) = nil;
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5816
			    goto out;
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5817
			}
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5818
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5819
			if (_buffered) {
17332
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5820
			    __WRITING__(f)
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5821
			}
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5822
# ifdef WIN32
17332
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5823
			if ((f == __win32_stdout()) || (f == __win32_stderr())) {
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5824
			    cnt = __win32_fwrite(buff, 1, nBytes, f);
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5825
			} else
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5826
# endif
17332
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5827
			{
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5828
			    __WRITEBYTES__(cnt, f, buff, nBytes, _buffered, __INST(handleType));
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5829
			}
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5830
			if (cnt == nBytes) {
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5831
			    if (__isSmallInteger(__INST(position))) {
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5832
				INT np = __intVal(__INST(position)) + nBytes;
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5833
				OBJ t;
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5834
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5835
				t = __MKINT(np); __INST(position) = t; __STORE(self, t);
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5836
			    } else {
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5837
				__INST(position) = nil; /* i.e. do not know */
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5838
			    }
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5839
			    RETURN ( self );
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5840
			}
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5841
			error = __mkSmallInteger(__threadErrno);
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5842
		    }
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5843
		}
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5844
	    } else {
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5845
		if (__isSmallInteger(aCharacter)) {
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5846
		    c = __intVal(aCharacter);
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5847
		    buff[0] = c; nBytes = 1;
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5848
		    goto doWrite;
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5849
		}
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5850
	    }
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5851
	}
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5852
    }
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5853
out: ;
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5854
#endif /* not SCHTEAM */
17332
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5855
%}.
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5856
    error notNil ifTrue:[
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5857
	lastErrorNumber := error.
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5858
	self writeError:error.
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5859
	^ self
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5860
    ].
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5861
    handle isNil ifTrue:[self errorNotOpen. ^ self].
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5862
    (mode == #readonly) ifTrue:[self errorReadOnly. ^ self].
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5863
    binary == true ifFalse:[
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5864
	(aCharacter isCharacter not
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5865
	or:[aCharacter codePoint > 16rFF]) ifTrue:[
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5866
	    self argumentMustBeCharacter.
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5867
	    ^ self.
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5868
	].
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5869
    ] ifTrue:[
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5870
	aCharacter isInteger ifFalse:[
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5871
	    self argumentMustBeInteger.
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5872
	    ^ self.
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5873
	].
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5874
    ].
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5875
    "/ migration support
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5876
    self
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5877
	nextPutByte:aCharacter asInteger
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5878
	toFile:handle
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5879
!
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  5880
17418
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  5881
nextPutAll:aCollection
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  5882
    "write all elements of the argument, aCollection.
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  5883
     Reimplemented for speed when writing strings or byteArrays.
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  5884
     For others, falls back to general method in superclass."
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  5885
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  5886
    |error|
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  5887
%{
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5888
#ifdef __SCHTEAM__
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5889
    STObject handle = self.instVarAt(I_handle);
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5890
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5891
    if ((handle != STObject.Nil)
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5892
     && (aCollection.isSTString())) {
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5893
	handle.writeCharacters( aCollection.asSTString().characters );
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5894
	self.instVarAt_put(I_position, STObject.Nil);
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5895
	return __c__._RETURN_self();
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5896
    }
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5897
#else
17418
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  5898
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  5899
    __INST(lastErrorNumber) = nil;
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  5900
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  5901
    if ((__INST(handleType) == nil)
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  5902
     || (__INST(handleType) == @symbol(filePointer))
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  5903
     || (__INST(handleType) == @symbol(socketFilePointer))
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  5904
     || (__INST(handleType) == @symbol(socketHandle))
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  5905
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5906
	OBJ fp;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5907
17474
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5908
	if (((fp = __INST(handle)) != nil)
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5909
	    && (__INST(mode) != @symbol(readonly))
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5910
	) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5911
	    INT len, cnt;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5912
	    INT o_offs;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5913
	    FILEPOINTER f = __FILEVal(fp);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5914
	    int _buffered = (__INST(buffered) == true);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5915
17474
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5916
	    if (! f) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5917
		fprintf(stderr, "oops - fileHandle is NULL in nextPutAll:\n");
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5918
		__INST(handle) = nil;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5919
		goto out;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5920
	    }
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  5921
	    if (_buffered) {
17474
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5922
		__WRITING__(f)
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5923
	    }
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5924
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5925
	    if (__isStringLike(aCollection)) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5926
		OBJ mode = __INST(eolMode);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5927
		char *stringP = __stringVal(aCollection);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5928
		len = __stringSize(aCollection);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5929
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5930
		if (__INST(binary) != true
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5931
		    && ((mode == @symbol(cr))
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5932
			|| (mode == @symbol(etx))
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5933
			|| (mode == @symbol(eot))
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5934
			|| (mode == @symbol(crlf)))
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5935
		    && memchr(stringP, '\n', len) != NULL)
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5936
		{
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5937
		    // there is a '\n' to be translated, replace it into a buffer
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5938
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5939
		    char *end;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5940
		    char sep[2];
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5941
		    int sepLen = 1;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5942
		    int bufLen;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5943
		    char *buf, *endBuf, *sp, *dp;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5944
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5945
		    sep[0] = '\n';
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5946
		    if (mode == @symbol(crlf)) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5947
			 sep[0] = '\r'; sep[1] = '\n'; sepLen = 2;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5948
		    } else if (mode == @symbol(cr)) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5949
			 sep[0] = '\r';
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5950
		    } else if (mode == @symbol(eot)) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5951
			 sep[0] = '\004';
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5952
		    } else if (mode == @symbol(etx)) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5953
			 sep[0] = '\003';
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5954
		    }
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5955
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5956
		    // estimate size of buffer - assume every 4th char is a separator
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5957
		    bufLen = (sepLen == 1) ? len : (len + ((len/4) + 1) * sepLen);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5958
		    buf = (char *)malloc(bufLen);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5959
		    if (buf == NULL) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5960
			error = __mkSmallInteger(ENOMEM);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5961
			goto out;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5962
		    }
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5963
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5964
		    endBuf = buf + bufLen;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5965
		    end = stringP + len;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5966
		    for (sp = stringP, dp = buf; sp < end; sp++) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5967
			char c;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5968
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5969
			if ((dp+sepLen) >= endBuf) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5970
			    char *newBuf;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5971
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5972
			    bufLen = bufLen * 2;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5973
			    newBuf = (char *)realloc(buf, bufLen);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5974
			    if (newBuf == NULL) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5975
				free(buf);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5976
				error = __mkSmallInteger(ENOMEM);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5977
				goto out;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5978
			    }
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5979
			    endBuf = newBuf + bufLen;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5980
			    dp = newBuf + (dp-buf);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5981
			    buf = newBuf;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5982
			}
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5983
17475
a31762a088b7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17474
diff changeset
  5984
			if ((c = *sp) != '\n') {
a31762a088b7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17474
diff changeset
  5985
			    *dp++ = c;
a31762a088b7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17474
diff changeset
  5986
			} else {
17474
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5987
			    *dp++ = sep[0];
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5988
			    if (sepLen == 2) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5989
				*dp++ = sep[1];
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5990
			    };
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5991
			}
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5992
		    }
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5993
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5994
		    len = dp - buf;
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5995
# ifdef WIN32
17474
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5996
		    if ((f == __win32_stdout()) || (f == __win32_stderr())) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5997
			cnt = __win32_fwrite(buf, 1, len, f);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  5998
		    } else
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  5999
# endif
17474
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6000
		    {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6001
			__WRITEBYTES__(cnt, f, buf, len, _buffered, __INST(handleType));
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6002
		    }
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6003
		    free(buf);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6004
		} else  {  // No EOL conversion needed
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  6005
# ifdef WIN32
17474
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6006
		    if ((f == __win32_stdout()) || (f == __win32_stderr())) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6007
			cnt = __win32_fwrite(stringP, 1, len, f);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6008
		    } else
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  6009
# endif
17474
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6010
		    {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6011
			o_offs = stringP - (char *)__InstPtr(aCollection);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6012
			__WRITEBYTES_OBJ__(cnt, f, aCollection, o_offs, len, _buffered, __INST(handleType));
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6013
		    }
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6014
		}
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6015
	    } else {   // Not a String
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6016
		if (__INST(binary) == true) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6017
		    INT offs;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6018
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6019
		    if (__isByteArrayLike(aCollection)) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6020
			offs = 0;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6021
			len = __byteArraySize(aCollection);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6022
		    } else if (__isBytes(aCollection)) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6023
			offs = __OBJS2BYTES__(__intVal(__ClassInstPtr(__qClass(aCollection))->c_ninstvars));
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6024
			len = __byteArraySize(aCollection) - offs;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6025
		    } else
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6026
			goto out;
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  6027
# ifdef WIN32
17474
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6028
		    if ((f == __win32_stdout()) || (f == __win32_stderr())) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6029
			cnt = __win32_fwrite(__stringVal(aCollection), 1, len, f);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6030
		    } else
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  6031
# endif
17474
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6032
		    {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6033
			o_offs = (char *)(__ByteArrayInstPtr(aCollection)->ba_element) - (char *)__InstPtr(aCollection);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6034
			o_offs += offs;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6035
			__WRITEBYTES_OBJ__(cnt, f, aCollection, o_offs, len, _buffered, __INST(handleType));
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6036
		    }
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6037
		} else  // Not binary mode
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6038
		    goto out;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6039
	    }
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6040
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6041
	    // Now check for errors
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6042
	    if (cnt == len) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6043
		if (__isSmallInteger(__INST(position))) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6044
		    INT np = __intVal(__INST(position)) + len;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6045
		    OBJ t;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6046
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6047
		    t = __MKINT(np); __INST(position) = t; __STORE(self, t);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6048
		} else {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6049
		    __INST(position) = nil; /* i.e. do not know */
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6050
		}
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6051
		RETURN (self);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6052
	    }
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6053
	    fprintf(stderr, "cnt=%d len=%d\n", cnt, len);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6054
	    error = __mkSmallInteger(__threadErrno);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6055
	}
17418
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6056
    }
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6057
out: ;
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  6058
#endif /* not SCHTEAM */
17418
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6059
%}.
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6060
    error notNil ifTrue:[
17474
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6061
	lastErrorNumber := error.
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6062
	self writeError:error.
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6063
	^ self
17418
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6064
    ].
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6065
    handle isNil ifTrue:[self errorNotOpen. ^ self].
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6066
    (mode == #readonly) ifTrue:[self errorReadOnly. ^ self].
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6067
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6068
    ^ super nextPutAll:aCollection
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6069
!
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6070
17608
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6071
nextPutAll:initialWriteCount from:buffer startingAt:initialOffset
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6072
    "redefined, to wait until stream is writable, to avoid blocking in a write.
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6073
     I don't know how to write non-bytes to a external stream, but let superclass handle this."
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6074
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6075
    buffer isByteCollection ifTrue:[
18312
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6076
	^ self nextPutBytes:initialWriteCount from:buffer startingAt:initialOffset.
17608
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6077
    ].
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6078
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6079
    ^ super nextPutAll:initialWriteCount from:buffer startingAt:initialOffset
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6080
!
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6081
17418
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6082
nextPutAll:aCollection startingAt:start to:stop
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6083
    "write a range of elements of the argument, aCollection.
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6084
     Reimplemented for speed when writing strings or byteArrays.
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6085
     For others, falls back to general method in superclass."
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6086
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6087
     |error|
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6088
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6089
%{
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6090
    __INST(lastErrorNumber) = nil;
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6091
    if ((__INST(handleType) == nil)
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6092
     || (__INST(handleType) == @symbol(filePointer))
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6093
     || (__INST(handleType) == @symbol(socketFilePointer))
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6094
     || (__INST(handleType) == @symbol(socketHandle))
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6095
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6096
	OBJ fp = __INST(handle);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6097
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6098
	if ((fp != nil)
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6099
	 && (__INST(mode) != @symbol(readonly))
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6100
	 && __bothSmallInteger(start, stop)
17474
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6101
	) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6102
	    int _buffered = (__INST(buffered) == true);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6103
	    FILEPOINTER f = __FILEVal(fp);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6104
	    int offs, len, cnt;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6105
	    int iStart = __intVal(start);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6106
	    int iStop = __intVal(stop);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6107
	    int o_offs;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6108
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6109
	    if (_buffered ) {
17474
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6110
		__WRITING__(f)
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6111
	    }
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6112
17474
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6113
	    if ((iStart < 1) || (iStop < iStart)) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6114
		RETURN(self);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6115
	    }
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6116
	    if (__isStringLike(aCollection)) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6117
		char *stringP;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6118
		OBJ mode = __INST(eolMode);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6119
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6120
		len = __stringSize(aCollection);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6121
		if (iStop > len) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6122
		    RETURN(self);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6123
		}
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6124
		if (iStop > len)
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6125
		    iStop = len;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6126
		len = iStop - iStart + 1;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6127
		stringP = __stringVal(aCollection) + iStart - 1;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6128
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6129
		if (__INST(binary) != true
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6130
		    && ((mode == @symbol(cr))
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6131
			|| (mode == @symbol(etx))
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6132
			|| (mode == @symbol(eot))
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6133
			|| (mode == @symbol(crlf)))
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6134
		    && memchr(stringP, '\n', len) != NULL)
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6135
		{
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6136
		    // see if there is a \n which needs to be translated, replace it
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6137
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6138
		    char *end = stringP + len;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6139
		    char sep[2];
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6140
		    int sepLen = 1;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6141
		    int bufLen;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6142
		    char *buf, *endBuf, *sp, *dp;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6143
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6144
		    sep[0] = '\n';
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6145
		    if (mode == @symbol(crlf)) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6146
			 sep[0] = '\r'; sep[1] = '\n'; sepLen = 2;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6147
		    } else if (mode == @symbol(cr)) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6148
			 sep[0] = '\r';
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6149
		    } else if (mode == @symbol(eot)) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6150
			 sep[0] = '\004';
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6151
		    } else if (mode == @symbol(etx)) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6152
			 sep[0] = '\003';
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6153
		    }
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6154
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6155
		    // estimate size of buffer - assume every 4th char is a separator
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6156
		    bufLen = (sepLen == 1) ? len : (len + ((len/4) + 1) * sepLen);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6157
		    buf = (char *)malloc(bufLen);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6158
		    if (buf == NULL) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6159
			error = __mkSmallInteger(ENOMEM);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6160
			goto out;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6161
		    }
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6162
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6163
		    endBuf = buf + bufLen;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6164
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6165
		    for (sp = stringP, dp = buf; sp < end; sp++) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6166
			char c;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6167
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6168
			if ((dp+sepLen) >= endBuf) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6169
			    char *newBuf;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6170
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6171
			    bufLen = bufLen * 2;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6172
			    newBuf = (char *)realloc(buf, bufLen);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6173
			    if (newBuf == NULL) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6174
				free(buf);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6175
				error = __mkSmallInteger(ENOMEM);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6176
				goto out;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6177
			    }
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6178
			    endBuf = newBuf + bufLen;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6179
			    dp = newBuf + (dp-buf);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6180
			    buf = newBuf;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6181
			}
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6182
17475
a31762a088b7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17474
diff changeset
  6183
			if ((c = *sp) == '\n') {
17474
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6184
			    *dp++ = sep[0];
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6185
			    if (sepLen == 2) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6186
				*dp++ = sep[1];
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6187
			    };
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6188
			} else {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6189
			    *dp++ = c;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6190
			}
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6191
		    }
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6192
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6193
		    len = dp - buf;
17420
f0895ae69f69 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17418
diff changeset
  6194
#ifdef WIN32
17474
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6195
		    if ((f == __win32_stdout()) || (f == __win32_stderr())) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6196
			cnt = __win32_fwrite(buf, 1, len, f);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6197
		    } else
17420
f0895ae69f69 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17418
diff changeset
  6198
#endif
17474
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6199
		    {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6200
			__WRITEBYTES__(cnt, f, buf, len, _buffered, __INST(handleType));
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6201
		    }
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6202
		    free(buf);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6203
		} else  {  // No EOL conversion needed
17420
f0895ae69f69 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17418
diff changeset
  6204
#ifdef WIN32
17474
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6205
		    if ((f == __win32_stdout()) || (f == __win32_stderr())) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6206
			cnt = __win32_fwrite(stringP, 1, len, f);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6207
		    } else
17420
f0895ae69f69 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17418
diff changeset
  6208
#endif
17474
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6209
		    {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6210
			o_offs = (char *)__stringVal(aCollection)-(char *)__InstPtr(aCollection);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6211
			__WRITEBYTES_OBJ__(cnt, f, aCollection, o_offs+iStart-1, len, _buffered, __INST(handleType));
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6212
		    }
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6213
		}
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6214
	    } else {  // Not a string
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6215
		if (__INST(binary) == true) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6216
		    int offs;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6217
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6218
		    if (__isByteArrayLike(aCollection)) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6219
			offs = 0;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6220
			len = __byteArraySize(aCollection);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6221
		    } else if (__isBytes(aCollection)) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6222
			offs = __OBJS2BYTES__(__intVal(__ClassInstPtr(__qClass(aCollection))->c_ninstvars));
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6223
			len = __byteArraySize(aCollection) - offs;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6224
		    } else
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6225
			goto out;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6226
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6227
		    if (iStop > len) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6228
			RETURN(self);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6229
		    }
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6230
		    if (iStop > len)
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6231
			iStop = len;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6232
		    len = iStop - iStart + 1;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6233
		    offs += iStart - 1;
17418
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6234
#ifdef WIN32
17474
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6235
		    if ((f == __win32_stdout()) || (f == __win32_stderr())) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6236
			cnt = __win32_fwrite(__stringVal(aCollection)+iStart-1, 1, len, f);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6237
		    } else
17418
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6238
#endif
17474
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6239
		    {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6240
			o_offs = (char *)(__ByteArrayInstPtr(aCollection)->ba_element)-(char *)__InstPtr(aCollection);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6241
			__WRITEBYTES_OBJ__(cnt, f,  aCollection, o_offs+offs, len, _buffered, __INST(handleType));
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6242
		    }
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6243
		} else
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6244
		    goto out;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6245
	    }
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6246
	    if (cnt == len) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6247
		if (__isSmallInteger(__INST(position))) {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6248
		    INT np = __intVal(__INST(position)) + len;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6249
		    OBJ t;
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6250
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6251
		    t = __MKINT(np); __INST(position) = t; __STORE(self, t);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6252
		} else {
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6253
		    __INST(position) = nil; /* i.e. do not know */
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6254
		}
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6255
		RETURN (self);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6256
	    }
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6257
	    error = __mkSmallInteger(__threadErrno);
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6258
	}
17418
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6259
    }
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6260
out: ;
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6261
%}.
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6262
    error notNil ifTrue:[
17474
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6263
	lastErrorNumber := error.
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6264
	self writeError:error.
18c7b1b817b4 oops - strcpy was wrong here (not 0 terminated)
Claus Gittinger <cg@exept.de>
parents: 17473
diff changeset
  6265
	^ self
17418
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6266
    ].
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6267
    ^ super nextPutAll:aCollection startingAt:start to:stop
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6268
!
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6269
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6270
nextPutAllUnicode:aString
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6271
    "normal streams can not handle multi-byte characters, so convert them to utf8.
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6272
     This is needed, so that you can do ('something' asUnicode16String errorPrintCR)"
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6273
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6274
    aString do:[:eachCharacter|
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6275
	self nextPutUtf8:eachCharacter.
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6276
    ].
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6277
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6278
    "
17608
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6279
	'Bönnigheim' asUnicode16String errorPrintCR
17418
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6280
    "
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6281
!
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6282
17608
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6283
nextPutBytes:count from:anObject startingAt:start
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6284
    "write count bytes from an object starting at index start.
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6285
     return the number of bytes written - which could be 0.
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6286
     The object must have non-pointer indexed instvars
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6287
     (i.e. be a ByteArray, String, Float- or DoubleArray),
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6288
     or an externalBytes object (with known size).
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6289
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6290
     Use with care - non object oriented i/o.
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6291
     Warning:
18312
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6292
	in general, you cannot use this method to pass non-byte data to other
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6293
	architectures (unless you prepared the buffer with care),
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6294
	since it does not care for byte order or float representation."
17608
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6295
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6296
    |error|
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6297
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6298
%{
18312
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6299
#ifdef __SCHTEAM__
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6300
    byte[] bytes;
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6301
    STObject handle = self.instVarAt(I_handle);
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6302
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6303
    if (anObject.isSTString()) {
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  6304
	char[] chars = anObject.asSTString().characters;
18372
d1f38f6a96d8 comments only
Claus Gittinger <cg@exept.de>
parents: 18364
diff changeset
  6305
	handle.writeCharacters(chars, start.intValue()-1, count.intValue());
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  6306
	self.instVarAt_put(I_position, STObject.Nil);
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  6307
	return context._RETURN(count);
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  6308
    }
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  6309
    if (anObject.isSymbol()) {
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  6310
	java.lang.String chars = anObject.asSTSymbol().characters;
18372
d1f38f6a96d8 comments only
Claus Gittinger <cg@exept.de>
parents: 18364
diff changeset
  6311
	handle.writeString(chars, start.intValue()-1, count.intValue());
18364
a693511a7c46 commnts only
Claus Gittinger <cg@exept.de>
parents: 18327
diff changeset
  6312
	self.instVarAt_put(I_position, STObject.Nil);
18312
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6313
	return context._RETURN(count);
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6314
    }
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6315
#else
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6316
    int ret;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6317
    int objSize, nInstBytes;
17608
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6318
    char *extPtr;
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6319
    OBJ fp;
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6320
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6321
    __INST(lastErrorNumber) = nil;
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6322
    if ((__INST(handleType) == nil)
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6323
     || (__INST(handleType) == @symbol(filePointer))
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6324
     || (__INST(handleType) == @symbol(socketFilePointer))
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6325
     || (__INST(handleType) == @symbol(socketHandle))
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6326
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
18312
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6327
	if (((fp = __INST(handle)) != nil)
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6328
	    && (__INST(mode) != @symbol(readonly))
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6329
	    && __bothSmallInteger(count, start)
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6330
	) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6331
	    int _buffered = (__INST(buffered) == true);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6332
	    FILEPOINTER f = __FILEVal(fp);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6333
	    int len = __intVal(count);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6334
	    int offs = __intVal(start) - 1;
18312
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6335
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6336
	    if (__isExternalBytesLike(anObject)) {
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6337
		OBJ sz;
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6338
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6339
		nInstBytes = 0;
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6340
		extPtr = (char *)__externalBytesAddress(anObject);
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6341
		if (extPtr == NULL) goto bad;
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6342
		sz = __externalBytesSize(anObject);
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6343
		if (__isSmallInteger(sz)) {
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6344
		    objSize = __intVal(sz);
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6345
		} else {
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6346
		    objSize = 0; /* unknown */
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6347
		}
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6348
	    } else {
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6349
		OBJ oClass = __Class(anObject);
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6350
		int nInstVars = __intVal(__ClassInstPtr(oClass)->c_ninstvars);
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6351
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6352
		nInstBytes = OHDR_SIZE + __OBJS2BYTES__(nInstVars);
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6353
		switch (__intVal(__ClassInstPtr(oClass)->c_flags) & ARRAYMASK) {
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6354
		    case BYTEARRAY:
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6355
		    case WORDARRAY:
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6356
		    case LONGARRAY:
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6357
		    case SWORDARRAY:
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6358
		    case SLONGARRAY:
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6359
		    case FLOATARRAY:
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6360
			break;
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6361
		    case DOUBLEARRAY:
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6362
# ifdef __NEED_DOUBLE_ALIGN
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6363
			nInstBytes = (nInstBytes-1+__DOUBLE_ALIGN) &~ (__DOUBLE_ALIGN-1);
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6364
# endif
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6365
			break;
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6366
		    case LONGLONGARRAY:
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6367
		    case SLONGLONGARRAY:
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6368
# ifdef __NEED_LONGLONG_ALIGN
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6369
			nInstBytes = (nInstBytes-1+__LONGLONG_ALIGN) &~ (__LONGLONG_ALIGN-1);
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6370
# endif
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6371
			break;
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6372
		    default:
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6373
			goto bad;
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6374
		}
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6375
		extPtr = (char *)0;
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6376
		objSize = __Size(anObject) - nInstBytes;
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6377
	    }
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6378
	    if ( (offs >= 0) && (len >= 0) && (objSize >= (len + offs)) ) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6379
		int cnt;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6380
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6381
		if (_buffered) {
18312
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6382
		    __WRITING__(f)
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6383
		}
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6384
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6385
		if (extPtr) {
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6386
# ifdef WIN32
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6387
		    if ((f == __win32_stdout()) || (f == __win32_stderr())) {
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6388
			cnt = __win32_fwrite(extPtr+offs, 1, len, f);
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6389
		    } else
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6390
# endif
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6391
		    {
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6392
			__WRITEBYTES__(cnt, f, extPtr+offs, len, _buffered, __INST(handleType));
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6393
		    }
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6394
		} else {
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6395
		    /*
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6396
		     * on interrupt, anObject may be moved to another location.
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6397
		     * So we pass anObject, and the offset to the __WRITEBYTES_OBJ__ macro.
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6398
		     */
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6399
		    offs += nInstBytes;
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6400
# ifdef WIN32
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6401
		    if ((f == __win32_stdout()) || (f == __win32_stderr())) {
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6402
			cnt = __win32_fwrite((char *)anObject+offs, 1, len, f);
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6403
		    } else
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6404
# endif
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6405
		    {
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6406
			 __WRITEBYTES_OBJ__(cnt, f, anObject, offs, len, _buffered, __INST(handleType));
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6407
		    }
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6408
		}
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6409
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6410
		if (cnt >= 0) {
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6411
		    if (__isSmallInteger(__INST(position))) {
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6412
			INT np = __intVal(__INST(position)) + cnt;
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6413
			OBJ t;
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6414
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6415
			t = __MKINT(np); __INST(position) = t; __STORE(self, t);
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6416
		    } else {
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6417
			__INST(position) = nil; /* i.e. do not know */
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6418
		    }
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6419
		    RETURN ( __mkSmallInteger(cnt) );
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6420
		} else /* cnt < 0 */ {
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6421
		    if (
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6422
# ifdef EWOULDBLOCK
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6423
			(__threadErrno == EWOULDBLOCK) ||
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6424
# endif
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6425
			(__threadErrno == EAGAIN)
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6426
		    ) {
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6427
			RETURN ( __mkSmallInteger(0) );
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6428
		    }
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6429
		    __INST(position) = nil; /* i.e. do not know */
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6430
		    error = __mkSmallInteger(__threadErrno);
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6431
		}
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6432
	    }
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6433
	}
17608
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6434
    }
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6435
bad: ;
18312
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6436
#endif /* not SCHTEAM */
17608
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6437
%}.
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6438
    error notNil ifTrue:[
18312
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6439
	lastErrorNumber := error.
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6440
	self writeError:error.
b414c7a96a1e comment sonly
Claus Gittinger <cg@exept.de>
parents: 18218
diff changeset
  6441
	^ 0
17608
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6442
    ].
17634
76a10ce9c870 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17618
diff changeset
  6443
    handle isNil ifTrue:[self errorNotOpen. ^ 0].
76a10ce9c870 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17618
diff changeset
  6444
    (mode == #readonly) ifTrue:[self errorReadOnly. ^ 0].
76a10ce9c870 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17618
diff changeset
  6445
    self primitiveFailed.
76a10ce9c870 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17618
diff changeset
  6446
    ^ 0.
17608
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6447
!
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6448
17418
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6449
nextPutUnicode:aCharacter
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6450
    "normal streams can not handle multi-byte characters, so convert them to utf8"
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6451
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6452
    self nextPutUtf8:aCharacter.
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6453
!
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6454
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6455
nextPutUtf16:aCharacter
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6456
    "append my UTF-16 representation to the argument, aStream.
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6457
     UTF-16 can encode only characters with code points between 0 to 16r10FFFF."
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6458
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6459
    |codePoint|
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6460
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6461
    codePoint := aCharacter codePoint.
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6462
    (codePoint <= 16rD7FF
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6463
      or:[codePoint >= 16rE000 and:[codePoint <= 16rFFFF]]) ifTrue:[
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6464
	self nextPutShort:codePoint MSB:true.
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6465
    ] ifFalse:[codePoint <= 16r10FFFF ifTrue:[
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6466
	|highBits lowBits|
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6467
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6468
	codePoint := codePoint - 16r100000.
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6469
	highBits := codePoint bitShift:-10.
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6470
	lowBits := codePoint bitAnd:16r3FF.
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6471
	self nextPutShort:highBits+16rD800 MSB:true.
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6472
	self nextPutShort:lowBits+16rDC00 MSB:true.
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6473
    ] ifFalse:[
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6474
	EncodingError raiseWith:aCharacter errorString:'Character cannot be encoded as UTF-16'.
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6475
    ]].
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6476
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6477
    "
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6478
	(FileStream newTemporary
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6479
	    nextPutUtf16:$B;
17608
03f28a6ee650 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17533
diff changeset
  6480
	    nextPutUtf16:$Ä;
17418
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6481
	    nextPutUtf16:(Character codePoint:16r10CCCC);
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6482
	    reset;
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6483
	    binary;
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6484
	    contents)
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6485
    "
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6486
!
e574f4adb86b class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 17360
diff changeset
  6487
17332
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  6488
old_nextPut:aCharacter
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  6489
    "write the argument, aCharacter - return nil if failed, self if ok.
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  6490
     Only single-byte characters are currently supported"
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  6491
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  6492
    |error|
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  6493
%{
f223abac93ca *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 17115
diff changeset
  6494
    OBJ fp;
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  6495
1133
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1119
diff changeset
  6496
    __INST(lastErrorNumber) = nil;
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  6497
    if ((__INST(handleType) == nil)
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  6498
     || (__INST(handleType) == @symbol(filePointer))
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  6499
     || (__INST(handleType) == @symbol(socketFilePointer))
16368
1efe4d36fd3f Win32 sockets use handles instead of file pointers
Stefan Vogel <sv@exept.de>
parents: 16308
diff changeset
  6500
     || (__INST(handleType) == @symbol(socketHandle))
12548
6a2abe88a7a2 handleTypes
Claus Gittinger <cg@exept.de>
parents: 12460
diff changeset
  6501
     || (__INST(handleType) == @symbol(pipeFilePointer))) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6502
	if (((fp = __INST(handle)) != nil)
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6503
	 && (__INST(mode) != @symbol(readonly))
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6504
	) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6505
	    unsigned char c;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6506
	    int _buffered = (__INST(buffered) == true);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6507
	    FILEPOINTER f = __FILEVal(fp);
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6508
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6509
	    if (__INST(binary) != true) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6510
		if (__isCharacter(aCharacter)) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6511
		    unsigned codePoint = __intVal(__characterVal(aCharacter));
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6512
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6513
		    if (codePoint <= 0xFF) {
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6514
			int cnt;
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6515
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6516
			c = codePoint;
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  6517
    doWrite:
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6518
			if (! f) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6519
			    fprintf(stderr, "oops - fileHandle is NULL in nextPut:\n");
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6520
			    __INST(handle) = nil;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6521
			    goto out;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6522
			}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6523
18652
ee5e81c67497 moved local C variables down into their blcoks
Claus Gittinger <cg@exept.de>
parents: 18636
diff changeset
  6524
			if (_buffered) {
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6525
			    __WRITING__(f)
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6526
			}
9053
f3f3d48d6f44 fix writing to stdout/stderr for winstx non-console operation
Claus Gittinger <cg@exept.de>
parents: 9024
diff changeset
  6527
#ifdef WIN32
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6528
			if ((f == __win32_stdout()) || (f == __win32_stderr())) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6529
			    cnt = __win32_fwrite(&c, 1, 1, f);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6530
			} else
9053
f3f3d48d6f44 fix writing to stdout/stderr for winstx non-console operation
Claus Gittinger <cg@exept.de>
parents: 9024
diff changeset
  6531
#endif
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6532
			__WRITEBYTE__(cnt, f, &c, _buffered, __INST(handleType));
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6533
			if (cnt == 1) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6534
			    if (__isSmallInteger(__INST(position))) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6535
				INT np = __intVal(__INST(position)) + 1;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6536
				OBJ t;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6537
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6538
				t = __MKINT(np); __INST(position) = t; __STORE(self, t);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6539
			    } else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6540
				__INST(position) = nil; /* i.e. do not know */
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6541
			    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6542
			    RETURN ( self );
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6543
			}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6544
			error = __mkSmallInteger(__threadErrno);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6545
		    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6546
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6547
	    } else {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6548
		if (__isSmallInteger(aCharacter)) {
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6549
		    c = __intVal(aCharacter);
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6550
		    goto doWrite;
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6551
		}
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6552
	    }
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6553
	}
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  6554
    }
7737
616d849b7838 fileHandle check
Claus Gittinger <cg@exept.de>
parents: 7700
diff changeset
  6555
out: ;
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  6556
%}.
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  6557
    error notNil ifTrue:[
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6558
	lastErrorNumber := error.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6559
	self writeError:error.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6560
	^ self
16296
f8548919e174 Fix error handling.
Stefan Vogel <sv@exept.de>
parents: 15994
diff changeset
  6561
    ].
12395
1db7ea277c93 filePointer -> handle migration
Claus Gittinger <cg@exept.de>
parents: 11751
diff changeset
  6562
    handle isNil ifTrue:[self errorNotOpen. ^ self].
2331
d6ddf452adc9 return codes in error cases
Claus Gittinger <cg@exept.de>
parents: 2326
diff changeset
  6563
    (mode == #readonly) ifTrue:[self errorReadOnly. ^ self].
5417
0478ac31e042 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5414
diff changeset
  6564
    binary == true ifFalse:[
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6565
	(aCharacter isCharacter not
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6566
	or:[aCharacter codePoint > 16rFF]) ifTrue:[
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6567
	    self argumentMustBeCharacter.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6568
	    ^ self.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6569
	].
5417
0478ac31e042 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5414
diff changeset
  6570
    ] ifTrue:[
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6571
	aCharacter isInteger ifFalse:[
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6572
	    self argumentMustBeInteger.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6573
	    ^ self.
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6574
	].
5417
0478ac31e042 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5414
diff changeset
  6575
    ].
0478ac31e042 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5414
diff changeset
  6576
    "/ migration support
8818
4b1ffc19e3ce remerged WIN32 and Unix versions into common source
Claus Gittinger <cg@exept.de>
parents: 8616
diff changeset
  6577
    self
16508
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6578
	nextPutByte:aCharacter asInteger
f2d6afb19d35 added tcgetattr
Claus Gittinger <cg@exept.de>
parents: 16493
diff changeset
  6579
	toFile:handle
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  6580
! !
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  6581
2045
1ad17ca6520f fall back to super>>nextPutLine: if argument is not a string.
Claus Gittinger <cg@exept.de>
parents: 2044
diff changeset
  6582
!ExternalStream class methodsFor:'documentation'!
730
62643519bf68 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
  6583
62643519bf68 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
  6584
version
18636
16d8110eb172 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 18372
diff changeset
  6585
    ^ '$Header$'
12398
7243f8014d98 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12395
diff changeset
  6586
!
7243f8014d98 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12395
diff changeset
  6587
7243f8014d98 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12395
diff changeset
  6588
version_CVS
18636
16d8110eb172 class: ExternalStream
Stefan Vogel <sv@exept.de>
parents: 18372
diff changeset
  6589
    ^ '$Header$'
730
62643519bf68 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 711
diff changeset
  6590
! !
6804
caf6a4521d4c added utility: ExternalStream >> copyToEndInto:
Claus Gittinger <cg@exept.de>
parents: 6758
diff changeset
  6591
14603
f73f90e25023 class: ExternalStream
Claus Gittinger <cg@exept.de>
parents: 14518
diff changeset
  6592
612
e640bef6170e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 593
diff changeset
  6593
ExternalStream initialize!