DirectoryStream.st
author Claus Gittinger <cg@exept.de>
Fri, 15 Jan 1999 21:53:59 +0100
changeset 3956 51f1a9a4d63f
parent 3825 262f33c41418
child 3980 8f9443e37693
permissions -rw-r--r--
changes for egcs (stdio uses __new / utsname)
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     1
"
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
     2
 COPYRIGHT (c) 1989 by Claus Gittinger
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
     3
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     4
a27a279701f8 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
a27a279701f8 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
a27a279701f8 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
a27a279701f8 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
a27a279701f8 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
a27a279701f8 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    11
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    12
a27a279701f8 Initial revision
claus
parents:
diff changeset
    13
FileStream subclass:#DirectoryStream
1664
82793bcf229c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1631
diff changeset
    14
	instanceVariableNames:'dirPointer readAheadEntry'
1281
b4b3abffdf32 Support optional signal generation on end of stream.
Stefan Vogel <sv@exept.de>
parents: 1133
diff changeset
    15
	classVariableNames:''
b4b3abffdf32 Support optional signal generation on end of stream.
Stefan Vogel <sv@exept.de>
parents: 1133
diff changeset
    16
	poolDictionaries:''
b4b3abffdf32 Support optional signal generation on end of stream.
Stefan Vogel <sv@exept.de>
parents: 1133
diff changeset
    17
	category:'Streams-External'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    18
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
217
a0400fdbc933 *** empty log message ***
claus
parents: 206
diff changeset
    20
!DirectoryStream primitiveDefinitions!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    21
%{
437
claus
parents: 384
diff changeset
    22
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    23
#define UNIX_LIKE
2609
68abf045b637 stat call emulation
Claus Gittinger <cg@exept.de>
parents: 1989
diff changeset
    24
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    25
#if defined(WIN32)
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    26
# undef UNIX_LIKE
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    27
#endif
437
claus
parents: 384
diff changeset
    28
2896
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
    29
#if defined(transputer)
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
    30
# undef UNIX_LIKE
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
    31
#endif
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
    32
3956
51f1a9a4d63f changes for egcs (stdio uses __new / utsname)
Claus Gittinger <cg@exept.de>
parents: 3825
diff changeset
    33
#if defined(__openVMS__) || defined(LINUX)
51f1a9a4d63f changes for egcs (stdio uses __new / utsname)
Claus Gittinger <cg@exept.de>
parents: 3825
diff changeset
    34
  /*
51f1a9a4d63f changes for egcs (stdio uses __new / utsname)
Claus Gittinger <cg@exept.de>
parents: 3825
diff changeset
    35
   * mhmh - used in stdio ...
51f1a9a4d63f changes for egcs (stdio uses __new / utsname)
Claus Gittinger <cg@exept.de>
parents: 3825
diff changeset
    36
   * (new linuxes)
51f1a9a4d63f changes for egcs (stdio uses __new / utsname)
Claus Gittinger <cg@exept.de>
parents: 3825
diff changeset
    37
   */
2896
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
    38
# undef __new
3956
51f1a9a4d63f changes for egcs (stdio uses __new / utsname)
Claus Gittinger <cg@exept.de>
parents: 3825
diff changeset
    39
# define __NEED_REDEF_new__
2896
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
    40
#endif
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
    41
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    42
#ifdef UNIX_LIKE
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    43
# include <stdio.h>
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    44
# define _STDIO_H_INCLUDED_
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    45
3956
51f1a9a4d63f changes for egcs (stdio uses __new / utsname)
Claus Gittinger <cg@exept.de>
parents: 3825
diff changeset
    46
#ifdef __NEED_REDEF_new__
51f1a9a4d63f changes for egcs (stdio uses __new / utsname)
Claus Gittinger <cg@exept.de>
parents: 3825
diff changeset
    47
# define __new  __STX___new
51f1a9a4d63f changes for egcs (stdio uses __new / utsname)
Claus Gittinger <cg@exept.de>
parents: 3825
diff changeset
    48
#endif
51f1a9a4d63f changes for egcs (stdio uses __new / utsname)
Claus Gittinger <cg@exept.de>
parents: 3825
diff changeset
    49
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    50
# include <errno.h>
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    51
# define _ERRNO_H_INCLUDED_
10
claus
parents: 5
diff changeset
    52
2896
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
    53
# include <sys/types.h>
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
    54
# include <sys/stat.h>
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    55
2896
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
    56
# ifdef HAS_OPENDIR
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
    57
#  include <sys/types.h>
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
    58
#  ifdef NEXT
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
    59
#   include <sys/dir.h>
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
    60
#  else
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
    61
#   include <dirent.h>
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    62
#  endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
    63
# endif
223
3075043790b8 immediateInterr & errno cleanup
claus
parents: 217
diff changeset
    64
3075043790b8 immediateInterr & errno cleanup
claus
parents: 217
diff changeset
    65
/*
3075043790b8 immediateInterr & errno cleanup
claus
parents: 217
diff changeset
    66
 * on some systems errno is a macro ... check for it here
3075043790b8 immediateInterr & errno cleanup
claus
parents: 217
diff changeset
    67
 */
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    68
# ifndef errno
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    69
  extern errno;
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    70
# endif
2896
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
    71
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    72
#endif /* UNIX_LIKE */
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    73
2896
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
    74
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    75
#ifdef WIN32
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    76
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    77
# ifdef i386
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    78
#  define _X86_
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    79
# endif
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    80
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    81
# undef INT
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    82
# undef Array
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    83
# undef Number
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    84
# undef Method
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    85
# undef Point
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    86
# undef Context
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    87
# undef Rectangle
1989
92b10a0e8a51 win32 changes
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
    88
# undef Block
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    89
2685
6576fb7af338 nt stuff
Claus Gittinger <cg@exept.de>
parents: 2609
diff changeset
    90
/* # include <types.h> /* */
1989
92b10a0e8a51 win32 changes
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
    91
# include <stdarg.h> /* */
92b10a0e8a51 win32 changes
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
    92
# include <windef.h> /* */
92b10a0e8a51 win32 changes
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
    93
# include <winbase.h> /* */
92b10a0e8a51 win32 changes
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
    94
# include <wingdi.h> /* */
92b10a0e8a51 win32 changes
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
    95
# include <winuser.h> /* */
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    96
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    97
# ifdef __DEF_Array
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    98
#  define Array __DEF_Array
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
    99
# endif
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   100
# ifdef __DEF_Number
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   101
#  define Number __DEF_Number
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   102
# endif
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   103
# ifdef __DEF_Method
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   104
#  define Method __DEF_Method
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   105
# endif
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   106
# ifdef __DEF_Point
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   107
#  define Point __DEF_Point
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   108
# endif
1989
92b10a0e8a51 win32 changes
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   109
# ifdef __DEF_Block
92b10a0e8a51 win32 changes
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   110
#  define Block __DEF_Block
92b10a0e8a51 win32 changes
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   111
# endif
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   112
# ifdef __DEF_Context
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   113
#  define Context __DEF_Context
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   114
# endif
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   115
2999
b0e55440cf12 eliminate MKOBJ & MKCP (use MKEXTERNALADDRESS & externalAddressVal)
Claus Gittinger <cg@exept.de>
parents: 2982
diff changeset
   116
# define __HANDLEVal(o)  (HANDLE)__externalAddressVal(o)
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   117
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   118
#endif /* WIN32 */
223
3075043790b8 immediateInterr & errno cleanup
claus
parents: 217
diff changeset
   119
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   120
%}
206
5858b2c9d0c6 fixed close
claus
parents: 155
diff changeset
   121
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   122
438
claus
parents: 437
diff changeset
   123
!DirectoryStream primitiveFunctions!
claus
parents: 437
diff changeset
   124
%{
2896
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   125
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   126
#ifndef HAS_OPENDIR
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   127
# if defined(__VMS__)
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   128
3816
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   129
#  define lib$find_file LIB$FIND_FILE
438
claus
parents: 437
diff changeset
   130
claus
parents: 437
diff changeset
   131
/*
claus
parents: 437
diff changeset
   132
**  VMS readdir() routines.
claus
parents: 437
diff changeset
   133
**  Written by Rich $alz, <rsalz@bbn.com> in August, 1990.
claus
parents: 437
diff changeset
   134
**  This code has no copyright.
claus
parents: 437
diff changeset
   135
*/
claus
parents: 437
diff changeset
   136
claus
parents: 437
diff changeset
   137
/* 12-NOV-1990 added d_namlen field and special case "." name -GJC@MITECH.COM 
claus
parents: 437
diff changeset
   138
 */
claus
parents: 437
diff changeset
   139
2896
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   140
#   ifndef _STDIO_H_INCLUDED_
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   141
#    include <stdio.h>
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   142
#    define _STDIO_H_INCLUDED_
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   143
#   endif
438
claus
parents: 437
diff changeset
   144
2896
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   145
#   ifndef _CTYPE_H_INCLUDED_
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   146
#    include <ctype.h>
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   147
#    define _CTYPE_H_INCLUDED_
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   148
#   endif
438
claus
parents: 437
diff changeset
   149
2896
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   150
#   ifndef _ERRNO_H_INCLUDED_
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   151
#    include <errno.h>
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   152
#    define _ERRNO_H_INCLUDED_
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   153
#   endif
438
claus
parents: 437
diff changeset
   154
2896
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   155
#   ifndef _DESCRIP_H_INCLUDED_
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   156
#    include <descrip.h>
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   157
#    define _DESCRIP_H_INCLUDED_
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   158
#   endif
438
claus
parents: 437
diff changeset
   159
2896
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   160
#   ifndef _RMSDEF_H_INCLUDED_
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   161
#    include <rmsdef.h>
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   162
#    define _RMSDEF_H_INCLUDED_
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   163
#   endif
438
claus
parents: 437
diff changeset
   164
claus
parents: 437
diff changeset
   165
/*
claus
parents: 437
diff changeset
   166
 * actually, the following has to go into dirent.h ...
claus
parents: 437
diff changeset
   167
 */
2896
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   168
/* BEGIN included dirent.h
438
claus
parents: 437
diff changeset
   169
 *
claus
parents: 437
diff changeset
   170
**  Header file for VMS readdir() routines.
claus
parents: 437
diff changeset
   171
**  Written by Rich $alz, <rsalz@bbn.com> in August, 1990.
claus
parents: 437
diff changeset
   172
**  This code has no copyright.
claus
parents: 437
diff changeset
   173
**
claus
parents: 437
diff changeset
   174
**  You must #include <descrip.h> before this file.
claus
parents: 437
diff changeset
   175
*/
claus
parents: 437
diff changeset
   176
claus
parents: 437
diff changeset
   177
/* 12-NOV-1990 added d_namlen field -GJC@MITECH.COM */
claus
parents: 437
diff changeset
   178
claus
parents: 437
diff changeset
   179
    /* Data structure returned by READDIR(). */
claus
parents: 437
diff changeset
   180
struct dirent {
claus
parents: 437
diff changeset
   181
    char        d_name[100];            /* File name            */
claus
parents: 437
diff changeset
   182
    int         d_namlen;
2957
46015145c398 comments
Claus Gittinger <cg@exept.de>
parents: 2945
diff changeset
   183
    int         vms_verscount;          /* Number of versions   */
46015145c398 comments
Claus Gittinger <cg@exept.de>
parents: 2945
diff changeset
   184
    int         vms_versions[20];       /* Version numbers      */
438
claus
parents: 437
diff changeset
   185
};
claus
parents: 437
diff changeset
   186
claus
parents: 437
diff changeset
   187
    /* Handle returned by opendir(), used by the other routines.  You
claus
parents: 437
diff changeset
   188
     * are not supposed to care what's inside this structure. */
claus
parents: 437
diff changeset
   189
typedef struct _dirdesc {
claus
parents: 437
diff changeset
   190
    long                        context;
2957
46015145c398 comments
Claus Gittinger <cg@exept.de>
parents: 2945
diff changeset
   191
    int                         vms_wantversions;
438
claus
parents: 437
diff changeset
   192
    char                        *pattern;
claus
parents: 437
diff changeset
   193
    struct dirent               entry;
claus
parents: 437
diff changeset
   194
    struct dsc$descriptor_s     pat;
claus
parents: 437
diff changeset
   195
} DIR;
claus
parents: 437
diff changeset
   196
claus
parents: 437
diff changeset
   197
claus
parents: 437
diff changeset
   198
#define rewinddir(dirp)                 seekdir((dirp), 0L)
claus
parents: 437
diff changeset
   199
claus
parents: 437
diff changeset
   200
claus
parents: 437
diff changeset
   201
extern DIR              *opendir();
claus
parents: 437
diff changeset
   202
extern struct dirent    *readdir();
claus
parents: 437
diff changeset
   203
extern long             telldir();
claus
parents: 437
diff changeset
   204
extern void             seekdir();
claus
parents: 437
diff changeset
   205
extern void             closedir();
claus
parents: 437
diff changeset
   206
extern void             vmsreaddirversions();
claus
parents: 437
diff changeset
   207
/*
claus
parents: 437
diff changeset
   208
 * END dirent.h
claus
parents: 437
diff changeset
   209
 */
2896
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   210
#define _DIRENT_H_INCLUDED_
438
claus
parents: 437
diff changeset
   211
claus
parents: 437
diff changeset
   212
claus
parents: 437
diff changeset
   213
    /* Number of elements in vms_versions array */
claus
parents: 437
diff changeset
   214
#define VERSIZE(e)      (sizeof e->vms_versions / sizeof e->vms_versions[0])
claus
parents: 437
diff changeset
   215
claus
parents: 437
diff changeset
   216
    /* Linked in later. */
claus
parents: 437
diff changeset
   217
extern char     *strrchr();
claus
parents: 437
diff changeset
   218
extern char     *strcpy();
claus
parents: 437
diff changeset
   219
/*  Don't need this when all these programs are lumped together.    RLD
claus
parents: 437
diff changeset
   220
extern char     *malloc();
claus
parents: 437
diff changeset
   221
*/
claus
parents: 437
diff changeset
   222
claus
parents: 437
diff changeset
   223
/*
claus
parents: 437
diff changeset
   224
**  Open a directory, return a handle for later use.
claus
parents: 437
diff changeset
   225
*/
claus
parents: 437
diff changeset
   226
DIR *
claus
parents: 437
diff changeset
   227
opendir(name)
claus
parents: 437
diff changeset
   228
    char        *name;
claus
parents: 437
diff changeset
   229
{
claus
parents: 437
diff changeset
   230
    DIR                 *dd;
claus
parents: 437
diff changeset
   231
claus
parents: 437
diff changeset
   232
    /* Get memory for the handle, and the pattern. */
claus
parents: 437
diff changeset
   233
    if ((dd = (DIR *)malloc(sizeof *dd)) == NULL) {
claus
parents: 437
diff changeset
   234
	errno = ENOMEM;
claus
parents: 437
diff changeset
   235
	return NULL;
claus
parents: 437
diff changeset
   236
    }
claus
parents: 437
diff changeset
   237
claus
parents: 437
diff changeset
   238
    if (strcmp(".",name) == 0) name = "";
claus
parents: 437
diff changeset
   239
claus
parents: 437
diff changeset
   240
    dd->pattern = malloc((unsigned int)(strlen(name) + sizeof "*.*" + 1));
claus
parents: 437
diff changeset
   241
    if (dd->pattern == NULL) {
claus
parents: 437
diff changeset
   242
	free((char *)dd);
claus
parents: 437
diff changeset
   243
	errno = ENOMEM;
claus
parents: 437
diff changeset
   244
	return NULL;
claus
parents: 437
diff changeset
   245
    }
claus
parents: 437
diff changeset
   246
claus
parents: 437
diff changeset
   247
    /* Fill in the fields; mainly playing with the descriptor. */
claus
parents: 437
diff changeset
   248
    (void)sprintf(dd->pattern, "%s*.*", name);
claus
parents: 437
diff changeset
   249
    dd->context = 0;
claus
parents: 437
diff changeset
   250
    dd->vms_wantversions = 0;
claus
parents: 437
diff changeset
   251
    dd->pat.dsc$a_pointer = dd->pattern;
claus
parents: 437
diff changeset
   252
    dd->pat.dsc$w_length = strlen(dd->pattern);
claus
parents: 437
diff changeset
   253
    dd->pat.dsc$b_dtype = DSC$K_DTYPE_T;
claus
parents: 437
diff changeset
   254
    dd->pat.dsc$b_class = DSC$K_CLASS_S;
claus
parents: 437
diff changeset
   255
claus
parents: 437
diff changeset
   256
    return dd;
claus
parents: 437
diff changeset
   257
}
claus
parents: 437
diff changeset
   258
claus
parents: 437
diff changeset
   259
/*
claus
parents: 437
diff changeset
   260
**  Set the flag to indicate we want versions or not.
claus
parents: 437
diff changeset
   261
*/
claus
parents: 437
diff changeset
   262
void
claus
parents: 437
diff changeset
   263
vmsreaddirversions(dd, flag)
claus
parents: 437
diff changeset
   264
    DIR                 *dd;
claus
parents: 437
diff changeset
   265
    int                 flag;
claus
parents: 437
diff changeset
   266
{
claus
parents: 437
diff changeset
   267
    dd->vms_wantversions = flag;
claus
parents: 437
diff changeset
   268
}
claus
parents: 437
diff changeset
   269
claus
parents: 437
diff changeset
   270
/*
claus
parents: 437
diff changeset
   271
**  Free up an opened directory.
claus
parents: 437
diff changeset
   272
*/
claus
parents: 437
diff changeset
   273
void
claus
parents: 437
diff changeset
   274
closedir(dd)
claus
parents: 437
diff changeset
   275
    DIR                 *dd;
claus
parents: 437
diff changeset
   276
{
claus
parents: 437
diff changeset
   277
    free(dd->pattern);
claus
parents: 437
diff changeset
   278
    free((char *)dd);
claus
parents: 437
diff changeset
   279
}
claus
parents: 437
diff changeset
   280
claus
parents: 437
diff changeset
   281
/*
claus
parents: 437
diff changeset
   282
**  Collect all the version numbers for the current file.
claus
parents: 437
diff changeset
   283
*/
claus
parents: 437
diff changeset
   284
static void
claus
parents: 437
diff changeset
   285
collectversions(dd)
claus
parents: 437
diff changeset
   286
    DIR                                 *dd;
claus
parents: 437
diff changeset
   287
{
claus
parents: 437
diff changeset
   288
    struct dsc$descriptor_s     pat;
claus
parents: 437
diff changeset
   289
    struct dsc$descriptor_s     res;
claus
parents: 437
diff changeset
   290
    struct dirent               *e;
claus
parents: 437
diff changeset
   291
    char                        *p;
claus
parents: 437
diff changeset
   292
    char                        buff[sizeof dd->entry.d_name];
claus
parents: 437
diff changeset
   293
    int                                 i;
claus
parents: 437
diff changeset
   294
    char                        *text;
claus
parents: 437
diff changeset
   295
    long                        context;
claus
parents: 437
diff changeset
   296
claus
parents: 437
diff changeset
   297
    /* Convenient shorthand. */
claus
parents: 437
diff changeset
   298
    e = &dd->entry;
claus
parents: 437
diff changeset
   299
claus
parents: 437
diff changeset
   300
    /* Add the version wildcard, ignoring the "*.*" put on before */
claus
parents: 437
diff changeset
   301
    i = strlen(dd->pattern);
claus
parents: 437
diff changeset
   302
    text = malloc((unsigned int)(i + strlen(e->d_name)+ 2 + 1));
claus
parents: 437
diff changeset
   303
    if (text == NULL)
claus
parents: 437
diff changeset
   304
	return;
claus
parents: 437
diff changeset
   305
    (void)strcpy(text, dd->pattern);
claus
parents: 437
diff changeset
   306
    (void)sprintf(&text[i - 3], "%s;*", e->d_name);
claus
parents: 437
diff changeset
   307
claus
parents: 437
diff changeset
   308
    /* Set up the pattern descriptor. */
claus
parents: 437
diff changeset
   309
    pat.dsc$a_pointer = text;
claus
parents: 437
diff changeset
   310
    pat.dsc$w_length = strlen(text);
claus
parents: 437
diff changeset
   311
    pat.dsc$b_dtype = DSC$K_DTYPE_T;
claus
parents: 437
diff changeset
   312
    pat.dsc$b_class = DSC$K_CLASS_S;
claus
parents: 437
diff changeset
   313
claus
parents: 437
diff changeset
   314
    /* Set up result descriptor. */
claus
parents: 437
diff changeset
   315
    res.dsc$a_pointer = buff;
claus
parents: 437
diff changeset
   316
    res.dsc$w_length = sizeof buff - 2;
claus
parents: 437
diff changeset
   317
    res.dsc$b_dtype = DSC$K_DTYPE_T;
claus
parents: 437
diff changeset
   318
    res.dsc$b_class = DSC$K_CLASS_S;
claus
parents: 437
diff changeset
   319
claus
parents: 437
diff changeset
   320
    /* Read files, collecting versions. */
claus
parents: 437
diff changeset
   321
    for (context = 0; e->vms_verscount < VERSIZE(e); e->vms_verscount++) {
claus
parents: 437
diff changeset
   322
	if (lib$find_file(&pat, &res, &context) == RMS$_NMF || context == 0)
claus
parents: 437
diff changeset
   323
	    break;
claus
parents: 437
diff changeset
   324
	buff[sizeof buff - 1] = '\0';
claus
parents: 437
diff changeset
   325
	if (p = strchr(buff, ';'))
claus
parents: 437
diff changeset
   326
	    e->vms_versions[e->vms_verscount] = atoi(p + 1);
claus
parents: 437
diff changeset
   327
	else
claus
parents: 437
diff changeset
   328
	    e->vms_versions[e->vms_verscount] = -1;
claus
parents: 437
diff changeset
   329
    }
claus
parents: 437
diff changeset
   330
claus
parents: 437
diff changeset
   331
    free(text);
claus
parents: 437
diff changeset
   332
}
claus
parents: 437
diff changeset
   333
claus
parents: 437
diff changeset
   334
/*
claus
parents: 437
diff changeset
   335
**  Read the next entry from the directory.
claus
parents: 437
diff changeset
   336
*/
claus
parents: 437
diff changeset
   337
struct dirent *
claus
parents: 437
diff changeset
   338
readdir(dd)
2957
46015145c398 comments
Claus Gittinger <cg@exept.de>
parents: 2945
diff changeset
   339
    DIR *dd;
438
claus
parents: 437
diff changeset
   340
{
2957
46015145c398 comments
Claus Gittinger <cg@exept.de>
parents: 2945
diff changeset
   341
    struct dsc$descriptor_s res;
46015145c398 comments
Claus Gittinger <cg@exept.de>
parents: 2945
diff changeset
   342
    char                    *p;
2982
3032a3a7e17a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2957
diff changeset
   343
    char                    buff[sizeof dd->entry.d_name + 10];
2957
46015145c398 comments
Claus Gittinger <cg@exept.de>
parents: 2945
diff changeset
   344
    int                     i;
438
claus
parents: 437
diff changeset
   345
claus
parents: 437
diff changeset
   346
    /* Set up result descriptor, and get next file. */
claus
parents: 437
diff changeset
   347
    res.dsc$a_pointer = buff;
claus
parents: 437
diff changeset
   348
    res.dsc$w_length = sizeof buff - 2;
claus
parents: 437
diff changeset
   349
    res.dsc$b_dtype = DSC$K_DTYPE_T;
claus
parents: 437
diff changeset
   350
    res.dsc$b_class = DSC$K_CLASS_S;
claus
parents: 437
diff changeset
   351
    if (lib$find_file(&dd->pat, &res, &dd->context) == RMS$_NMF
claus
parents: 437
diff changeset
   352
     || dd->context == 0L)
claus
parents: 437
diff changeset
   353
	/* None left... */
claus
parents: 437
diff changeset
   354
	return NULL;
claus
parents: 437
diff changeset
   355
claus
parents: 437
diff changeset
   356
    /* Force the buffer to end with a NUL. */
claus
parents: 437
diff changeset
   357
    buff[sizeof buff - 1] = '\0';
claus
parents: 437
diff changeset
   358
    for (p = buff; !isspace(*p); p++)
claus
parents: 437
diff changeset
   359
	;
claus
parents: 437
diff changeset
   360
    *p = '\0';
claus
parents: 437
diff changeset
   361
claus
parents: 437
diff changeset
   362
    /* Skip any directory component and just copy the name. */
claus
parents: 437
diff changeset
   363
    if (p = strchr(buff, ']'))
claus
parents: 437
diff changeset
   364
	(void)strcpy(dd->entry.d_name, p + 1);
claus
parents: 437
diff changeset
   365
    else
claus
parents: 437
diff changeset
   366
	(void)strcpy(dd->entry.d_name, buff);
claus
parents: 437
diff changeset
   367
claus
parents: 437
diff changeset
   368
    /* Clobber the version. */
claus
parents: 437
diff changeset
   369
    if (p = strchr(dd->entry.d_name, ';'))
claus
parents: 437
diff changeset
   370
	*p = '\0';
claus
parents: 437
diff changeset
   371
2982
3032a3a7e17a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2957
diff changeset
   372
    /* claus: empty dirs seems to leave *.* in the buffer ... */
3032a3a7e17a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2957
diff changeset
   373
    if (strcmp(dd->entry.d_name, "*.*") == 0) {
3032a3a7e17a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2957
diff changeset
   374
	return NULL;
3032a3a7e17a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2957
diff changeset
   375
    }
3032a3a7e17a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2957
diff changeset
   376
438
claus
parents: 437
diff changeset
   377
    dd->entry.d_namlen = strlen(dd->entry.d_name);
claus
parents: 437
diff changeset
   378
claus
parents: 437
diff changeset
   379
    dd->entry.vms_verscount = 0;
claus
parents: 437
diff changeset
   380
    if (dd->vms_wantversions)
claus
parents: 437
diff changeset
   381
	collectversions(dd);
claus
parents: 437
diff changeset
   382
    return &dd->entry;
claus
parents: 437
diff changeset
   383
}
claus
parents: 437
diff changeset
   384
claus
parents: 437
diff changeset
   385
/*
claus
parents: 437
diff changeset
   386
**  Return something that can be used in a seekdir later.
claus
parents: 437
diff changeset
   387
*/
claus
parents: 437
diff changeset
   388
long
claus
parents: 437
diff changeset
   389
telldir(dd)
2957
46015145c398 comments
Claus Gittinger <cg@exept.de>
parents: 2945
diff changeset
   390
    DIR  *dd;
438
claus
parents: 437
diff changeset
   391
{
claus
parents: 437
diff changeset
   392
    return dd->context;
claus
parents: 437
diff changeset
   393
}
claus
parents: 437
diff changeset
   394
claus
parents: 437
diff changeset
   395
/*
claus
parents: 437
diff changeset
   396
**  Return to a spot where we used to be.
claus
parents: 437
diff changeset
   397
*/
claus
parents: 437
diff changeset
   398
void
claus
parents: 437
diff changeset
   399
seekdir(dd, pos)
2957
46015145c398 comments
Claus Gittinger <cg@exept.de>
parents: 2945
diff changeset
   400
    DIR  *dd;
46015145c398 comments
Claus Gittinger <cg@exept.de>
parents: 2945
diff changeset
   401
    long pos;
438
claus
parents: 437
diff changeset
   402
{
claus
parents: 437
diff changeset
   403
    dd->context = pos;
claus
parents: 437
diff changeset
   404
}
claus
parents: 437
diff changeset
   405
2896
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   406
#  define HAS_OPENDIR
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   407
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   408
# endif /* __VMS__ */
be30640b9012 VMS stuff
Claus Gittinger <cg@exept.de>
parents: 2685
diff changeset
   409
#endif /* not HAS_OPENDIR */
438
claus
parents: 437
diff changeset
   410
%}
claus
parents: 437
diff changeset
   411
! !
claus
parents: 437
diff changeset
   412
613
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   413
!DirectoryStream class methodsFor:'documentation'!
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   414
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   415
copyright
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   416
"
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   417
 COPYRIGHT (c) 1989 by Claus Gittinger
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   418
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   419
613
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   420
 This software is furnished under a license and may be used
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   421
 only in accordance with the terms of that license and with the
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   422
 inclusion of the above copyright notice.   This software may not
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   423
 be provided or otherwise made available to, or used by, any
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   424
 other person.  No title to or ownership of the software is
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   425
 hereby transferred.
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   426
"
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   427
!
360
claus
parents: 249
diff changeset
   428
613
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   429
documentation
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   430
"
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   431
    Instances of DirectoryStream allow reading a file-directory,
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   432
    as if it was a stream of filenames.
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   433
    Basically, its an interface to opendir, readdir and closedir.
2957
46015145c398 comments
Claus Gittinger <cg@exept.de>
parents: 2945
diff changeset
   434
    Notice: 
46015145c398 comments
Claus Gittinger <cg@exept.de>
parents: 2945
diff changeset
   435
	DirectoryStream is an ST/X special; 
46015145c398 comments
Claus Gittinger <cg@exept.de>
parents: 2945
diff changeset
   436
	for portability, we recommend the use of Filename protocol.
1295
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
   437
83f594f05c52 documentation
Claus Gittinger <cg@exept.de>
parents: 1281
diff changeset
   438
    [author:]
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   439
	Claus Gittinger
2957
46015145c398 comments
Claus Gittinger <cg@exept.de>
parents: 2945
diff changeset
   440
46015145c398 comments
Claus Gittinger <cg@exept.de>
parents: 2945
diff changeset
   441
    [see also:]
46015145c398 comments
Claus Gittinger <cg@exept.de>
parents: 2945
diff changeset
   442
	Filename
613
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   443
"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   444
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   445
a27a279701f8 Initial revision
claus
parents:
diff changeset
   446
!DirectoryStream class methodsFor:'instance creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   447
a27a279701f8 Initial revision
claus
parents:
diff changeset
   448
directoryNamed:dirName
a27a279701f8 Initial revision
claus
parents:
diff changeset
   449
    "return a DirectoryStream for directory named dirName, aString"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   450
a27a279701f8 Initial revision
claus
parents:
diff changeset
   451
    |newStream|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   452
a27a279701f8 Initial revision
claus
parents:
diff changeset
   453
    newStream := (self basicNew) pathName:dirName.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   454
    newStream openForReading isNil ifTrue:[^nil].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   455
    ^ newStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   456
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   457
a27a279701f8 Initial revision
claus
parents:
diff changeset
   458
!DirectoryStream methodsFor:'access reading'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   459
a27a279701f8 Initial revision
claus
parents:
diff changeset
   460
nextLine
a27a279701f8 Initial revision
claus
parents:
diff changeset
   461
    "return the next filename as a string"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   462
a27a279701f8 Initial revision
claus
parents:
diff changeset
   463
    |prevEntry nextEntry|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   464
%{
77
6c38ca59927f *** empty log message ***
claus
parents: 54
diff changeset
   465
#ifdef HAS_OPENDIR
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   466
    DIR *d;
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   467
# ifdef NEXT
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   468
    struct direct *dp;
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   469
# else
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   470
    struct dirent *dp;
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   471
# endif
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   472
    OBJ dirP;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   473
1281
b4b3abffdf32 Support optional signal generation on end of stream.
Stefan Vogel <sv@exept.de>
parents: 1133
diff changeset
   474
    if (__INST(hitEOF) != true && (dirP = __INST(dirPointer)) != nil) {
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   475
	__INST(lastErrorNumber) = nil;
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   476
	d = (DIR *)__FILEVal(dirP);
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   477
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   478
	__BEGIN_INTERRUPTABLE__
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   479
	do {
2957
46015145c398 comments
Claus Gittinger <cg@exept.de>
parents: 2945
diff changeset
   480
	    do {
3816
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   481
		errno = 0;
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   482
		dp = readdir(d);
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   483
		/*
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   484
		 * for compatibility with ST-80,
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   485
		 * skip entries for '.' and '..'.
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   486
		 * If wanted, these must be added synthetically.
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   487
		 */
2957
46015145c398 comments
Claus Gittinger <cg@exept.de>
parents: 2945
diff changeset
   488
	    } while (dp && ((strcmp(dp->d_name, ".")==0) || (strcmp(dp->d_name, "..")==0)));
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   489
	} while ((dp == NULL) && (errno == EINTR));
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   490
	__END_INTERRUPTABLE__
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   491
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   492
	if (dp != NULL) {
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1664
diff changeset
   493
	    nextEntry = __MKSTRING((char *)(dp->d_name));
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   494
	} else {
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   495
	    if (errno) {
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   496
		__INST(lastErrorNumber) = __MKSMALLINT(errno);
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   497
	    } else {
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   498
	       __INST(hitEOF) = true;
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   499
	    }
1281
b4b3abffdf32 Support optional signal generation on end of stream.
Stefan Vogel <sv@exept.de>
parents: 1133
diff changeset
   500
       }
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   501
    }
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   502
#else /* no HAS_OPENDIR */
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   503
# ifdef WIN32
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   504
    HANDLE d;
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   505
    WIN32_FIND_DATA data;
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   506
    OBJ dirP;
3816
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   507
    int rslt;
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   508
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   509
    if (__INST(hitEOF) != true && (dirP = __INST(dirPointer)) != nil) {
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   510
	__INST(lastErrorNumber) = nil;
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   511
	d = __HANDLEVal(dirP);
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   512
3816
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   513
#  ifdef DO_WRAP_CALLS
3825
262f33c41418 new wrap-call macros
Claus Gittinger <cg@exept.de>
parents: 3816
diff changeset
   514
	rslt = __STX_API_CALL2( (void*)FindNextFile, (void *)d, (void *)&data );
3816
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   515
#  else
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   516
	rslt = FindNextFile(d, &data);
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   517
#  endif
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   518
	if (rslt) {
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   519
	    nextEntry = __MKSTRING( data.cFileName );
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   520
	} else {
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   521
	   __INST(hitEOF) = true;
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   522
	}
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   523
    }
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   524
# endif /* WIN32 */
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   525
#endif /* HAS_OPENDIR */
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   526
%}.
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   527
    lastErrorNumber notNil ifTrue:[^ self ioError].
1664
82793bcf229c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1631
diff changeset
   528
    prevEntry := readAheadEntry.
82793bcf229c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1631
diff changeset
   529
    readAheadEntry := nextEntry.
1281
b4b3abffdf32 Support optional signal generation on end of stream.
Stefan Vogel <sv@exept.de>
parents: 1133
diff changeset
   530
    prevEntry isNil ifTrue:[^ self pastEnd].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   531
    ^ prevEntry
a27a279701f8 Initial revision
claus
parents:
diff changeset
   532
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   533
613
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   534
!DirectoryStream methodsFor:'closing'!
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   535
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   536
close
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   537
    "close the stream - tell operating system"
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   538
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   539
    dirPointer notNil ifTrue:[
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   540
	Lobby unregister:self.
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   541
	self closeFile.
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   542
	dirPointer := nil
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   543
    ]
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   544
! !
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   545
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   546
!DirectoryStream methodsFor:'instance release'!
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   547
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   548
closeFile
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   549
    "low level close of a directoryStream"
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   550
%{
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   551
#ifdef HAS_OPENDIR
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   552
    OBJ dp;
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   553
1133
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 613
diff changeset
   554
    if ((dp = __INST(dirPointer)) != nil) {
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 613
diff changeset
   555
	__INST(dirPointer) = nil;
613
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   556
	closedir( (DIR *)(__FILEVal(dp)) );
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   557
    }
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   558
#else
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   559
# ifdef WIN32
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   560
    OBJ dp;
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   561
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   562
    if ((dp = __INST(dirPointer)) != nil) {
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   563
	__INST(dirPointer) = nil;
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   564
	FindClose( __HANDLEVal(dp) );
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   565
    }
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   566
# endif
613
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   567
#endif
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   568
%}
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   569
! !
0af19c3594fc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   570
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   571
!DirectoryStream methodsFor:'private'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   572
a27a279701f8 Initial revision
claus
parents:
diff changeset
   573
openForReading
a27a279701f8 Initial revision
claus
parents:
diff changeset
   574
    "open the file for readonly"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   575
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   576
    |ok entry|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   577
a27a279701f8 Initial revision
claus
parents:
diff changeset
   578
    mode := #readonly.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   579
%{
77
6c38ca59927f *** empty log message ***
claus
parents: 54
diff changeset
   580
#ifdef HAS_OPENDIR
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   581
    DIR *d;
477
8710aba7876b oops - making id's real objects requires a store macro
Claus Gittinger <cg@exept.de>
parents: 475
diff changeset
   582
    OBJ path, dp;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   583
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   584
    ok = false;
1133
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 613
diff changeset
   585
    if (__INST(dirPointer) == nil) {
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 613
diff changeset
   586
	path = __INST(pathName);
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   587
	if (__isString(path)) {
362
claus
parents: 360
diff changeset
   588
	    __BEGIN_INTERRUPTABLE__
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   589
	    errno = 0;
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   590
	    do {
1133
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 613
diff changeset
   591
		d = opendir((char *) __stringVal(path));
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   592
	    } while ((d == NULL) && (errno == EINTR));
362
claus
parents: 360
diff changeset
   593
	    __END_INTERRUPTABLE__
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   594
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   595
	    if (d == NULL) {
1133
961f2b095c22 underline cleanup
Claus Gittinger <cg@exept.de>
parents: 613
diff changeset
   596
		__INST(lastErrorNumber) = __MKSMALLINT(errno);
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   597
	    } else {
2999
b0e55440cf12 eliminate MKOBJ & MKCP (use MKEXTERNALADDRESS & externalAddressVal)
Claus Gittinger <cg@exept.de>
parents: 2982
diff changeset
   598
		__INST(dirPointer) = dp = __MKEXTERNALADDRESS(d); __STORE(self, dp);
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   599
		ok = true;
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   600
	    }
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   601
	}
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   602
    }
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   603
#else
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   604
# ifdef WIN32
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   605
    HANDLE d;
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   606
    OBJ path, dp;
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   607
    char pattern[512];
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   608
    WIN32_FIND_DATA data;
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   609
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   610
    ok = false;
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   611
    if (__INST(dirPointer) == nil) {
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   612
	path = __INST(pathName);
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   613
	if (__isString(path)) {
3164
4f37ae9c8961 use strncpy to avoid buffer-overruns
Claus Gittinger <cg@exept.de>
parents: 2999
diff changeset
   614
	    int l = __stringSize(path);
4f37ae9c8961 use strncpy to avoid buffer-overruns
Claus Gittinger <cg@exept.de>
parents: 2999
diff changeset
   615
4f37ae9c8961 use strncpy to avoid buffer-overruns
Claus Gittinger <cg@exept.de>
parents: 2999
diff changeset
   616
	    if (l < (sizeof(pattern)-4)) {
3816
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   617
		strncpy(pattern, __stringVal(path), l);
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   618
		strcpy(pattern+l, "\\*");
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   619
#  ifdef DO_WRAP_CALLS
3825
262f33c41418 new wrap-call macros
Claus Gittinger <cg@exept.de>
parents: 3816
diff changeset
   620
		d = __STX_API_CALL2( (void*)FindFirstFile, (void *)pattern, (void *)&data );
3816
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   621
#  else
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   622
		d = FindFirstFile(pattern, &data);
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   623
#  endif
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   624
		if (d == INVALID_HANDLE_VALUE) {
3164
4f37ae9c8961 use strncpy to avoid buffer-overruns
Claus Gittinger <cg@exept.de>
parents: 2999
diff changeset
   625
		    __INST(lastErrorNumber) = __MKSMALLINT(GetLastError());
3816
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   626
		} else {
3164
4f37ae9c8961 use strncpy to avoid buffer-overruns
Claus Gittinger <cg@exept.de>
parents: 2999
diff changeset
   627
		    __INST(dirPointer) = dp = __MKEXTERNALADDRESS(d); __STORE(self, dp);
4f37ae9c8961 use strncpy to avoid buffer-overruns
Claus Gittinger <cg@exept.de>
parents: 2999
diff changeset
   628
		    entry = __MKSTRING( data.cFileName );
4f37ae9c8961 use strncpy to avoid buffer-overruns
Claus Gittinger <cg@exept.de>
parents: 2999
diff changeset
   629
		    ok = true;
4f37ae9c8961 use strncpy to avoid buffer-overruns
Claus Gittinger <cg@exept.de>
parents: 2999
diff changeset
   630
		}
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   631
	    }
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   632
	}
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   633
    }
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   634
# endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   635
#endif
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   636
%}.
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   637
    ok isNil ifTrue:[
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   638
	"
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   639
	 opendir not avalable - use slower pipe
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   640
	"
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   641
	^ PipeStream readingFrom:('cd ' , pathName , '; ls -a')
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   642
    ].
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   643
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   644
    (ok == true) ifTrue:[
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   645
	Lobby register:self.
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   646
	entry isNil ifTrue:[
1664
82793bcf229c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1631
diff changeset
   647
	    self nextLine. "read 1st entry into readAheadEntry buffer"
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   648
	] ifFalse:[
1664
82793bcf229c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1631
diff changeset
   649
	    readAheadEntry := entry.
1631
0d50b800b011 directory readOps for NT
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
   650
	].
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   651
	^ self
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   652
    ].
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   653
    dirPointer notNil ifTrue:[^ self errorOpen].
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   654
    lastErrorNumber notNil ifTrue:[^ self openError].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   655
    ^ nil
a27a279701f8 Initial revision
claus
parents:
diff changeset
   656
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   657
a27a279701f8 Initial revision
claus
parents:
diff changeset
   658
reOpen
38
454b1b94a48e *** empty log message ***
claus
parents: 31
diff changeset
   659
    "reOpen the stream after image restart"
454b1b94a48e *** empty log message ***
claus
parents: 31
diff changeset
   660
2
claus
parents: 1
diff changeset
   661
    dirPointer := nil.
claus
parents: 1
diff changeset
   662
    super reOpen
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   663
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   664
a27a279701f8 Initial revision
claus
parents:
diff changeset
   665
!DirectoryStream methodsFor:'testing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   666
a27a279701f8 Initial revision
claus
parents:
diff changeset
   667
atEnd
a27a279701f8 Initial revision
claus
parents:
diff changeset
   668
    "return true, if position is at end"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   669
1664
82793bcf229c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1631
diff changeset
   670
    ^ readAheadEntry == nil
2945
1a4f2e0d9f1b Add #isEmpty, to check for an empty directory.
Stefan Vogel <sv@exept.de>
parents: 2896
diff changeset
   671
!
1a4f2e0d9f1b Add #isEmpty, to check for an empty directory.
Stefan Vogel <sv@exept.de>
parents: 2896
diff changeset
   672
1a4f2e0d9f1b Add #isEmpty, to check for an empty directory.
Stefan Vogel <sv@exept.de>
parents: 2896
diff changeset
   673
isEmpty
1a4f2e0d9f1b Add #isEmpty, to check for an empty directory.
Stefan Vogel <sv@exept.de>
parents: 2896
diff changeset
   674
    "test for if the unread portion of the directory stream is empty.
1a4f2e0d9f1b Add #isEmpty, to check for an empty directory.
Stefan Vogel <sv@exept.de>
parents: 2896
diff changeset
   675
     This query changes the readPointer of the DirectoryStream"
1a4f2e0d9f1b Add #isEmpty, to check for an empty directory.
Stefan Vogel <sv@exept.de>
parents: 2896
diff changeset
   676
2957
46015145c398 comments
Claus Gittinger <cg@exept.de>
parents: 2945
diff changeset
   677
    |entry|
2945
1a4f2e0d9f1b Add #isEmpty, to check for an empty directory.
Stefan Vogel <sv@exept.de>
parents: 2896
diff changeset
   678
1a4f2e0d9f1b Add #isEmpty, to check for an empty directory.
Stefan Vogel <sv@exept.de>
parents: 2896
diff changeset
   679
    [self atEnd] whileFalse:[
3816
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   680
	entry := self nextLine.
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   681
	entry asFilename isImplicit ifFalse:[
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   682
	    ^ false.
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   683
	]
2945
1a4f2e0d9f1b Add #isEmpty, to check for an empty directory.
Stefan Vogel <sv@exept.de>
parents: 2896
diff changeset
   684
    ].
1a4f2e0d9f1b Add #isEmpty, to check for an empty directory.
Stefan Vogel <sv@exept.de>
parents: 2896
diff changeset
   685
    ^ true
1a4f2e0d9f1b Add #isEmpty, to check for an empty directory.
Stefan Vogel <sv@exept.de>
parents: 2896
diff changeset
   686
1a4f2e0d9f1b Add #isEmpty, to check for an empty directory.
Stefan Vogel <sv@exept.de>
parents: 2896
diff changeset
   687
1a4f2e0d9f1b Add #isEmpty, to check for an empty directory.
Stefan Vogel <sv@exept.de>
parents: 2896
diff changeset
   688
    "
3816
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   689
	(DirectoryStream directoryNamed:'/') isEmpty
af3f917c7759 use wrapCalls for FindFirstFile & FindNextFile (win32 - dir-reading)
Claus Gittinger <cg@exept.de>
parents: 3164
diff changeset
   690
	(DirectoryStream directoryNamed:'/var/tmp') isEmpty
2945
1a4f2e0d9f1b Add #isEmpty, to check for an empty directory.
Stefan Vogel <sv@exept.de>
parents: 2896
diff changeset
   691
    "
1a4f2e0d9f1b Add #isEmpty, to check for an empty directory.
Stefan Vogel <sv@exept.de>
parents: 2896
diff changeset
   692
1a4f2e0d9f1b Add #isEmpty, to check for an empty directory.
Stefan Vogel <sv@exept.de>
parents: 2896
diff changeset
   693
    "Modified: 18.9.1997 / 18:05:31 / stefan"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   694
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   695
1281
b4b3abffdf32 Support optional signal generation on end of stream.
Stefan Vogel <sv@exept.de>
parents: 1133
diff changeset
   696
!DirectoryStream class methodsFor:'documentation'!
b4b3abffdf32 Support optional signal generation on end of stream.
Stefan Vogel <sv@exept.de>
parents: 1133
diff changeset
   697
b4b3abffdf32 Support optional signal generation on end of stream.
Stefan Vogel <sv@exept.de>
parents: 1133
diff changeset
   698
version
3956
51f1a9a4d63f changes for egcs (stdio uses __new / utsname)
Claus Gittinger <cg@exept.de>
parents: 3825
diff changeset
   699
    ^ '$Header: /cvs/stx/stx/libbasic/DirectoryStream.st,v 1.45 1999-01-15 20:52:59 cg Exp $'
1281
b4b3abffdf32 Support optional signal generation on end of stream.
Stefan Vogel <sv@exept.de>
parents: 1133
diff changeset
   700
! !