summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCraig A. Berry <craigberry@mac.com>2006-01-14 05:02:38 +0000
committerCraig A. Berry <craigberry@mac.com>2006-01-14 05:02:38 +0000
commitddcbaa1cece03b86d18feae2329582fa255e94be (patch)
tree32d5a62b3aa6f6de068f99acab9ad0817b6dd907
parent949c04aee626cdc911dc3af16ce8746375a07533 (diff)
downloadperl-ddcbaa1cece03b86d18feae2329582fa255e94be.tar.gz
Eek. #25783 broke all pre-v8.2 VMS builds. Undo all the bits
having to do with dirent, opendir, etc. Must be Friday the 13th. p4raw-id: //depot/perl@26844
-rw-r--r--configure.com11
-rw-r--r--vms/vms.c24
-rw-r--r--vms/vmsish.h59
3 files changed, 25 insertions, 69 deletions
diff --git a/configure.com b/configure.com
index 11c085384d..5dd96aeae3 100644
--- a/configure.com
+++ b/configure.com
@@ -5670,16 +5670,7 @@ $ WC "d_dbl_dig='define'"
$ WC "d_dbminitproto='undef'"
$ WC "d_difftime='define'"
$ WC "d_dirfd='undef'"
-$ if (vms_ver .GES. "8.2") .AND. (archname .NES. "VMS_VAX")
-$ then
-$! Sorry, CRTL does not have this, and in order to support
-$! POSIX filespecifications, the CRTL readdir() structures
-$! need to be used globally for now.
-$ echo "Building for OpenVMS 8.2 uses CRTL dirent.h, so no dirnamlen member"
-$ WC "d_dirnamlen='undef'"
-$ else
-$ WC "d_dirnamlen='define'"
-$ endif
+$ WC "d_dirnamlen='define'"
$ WC "d_dlerror='undef'"
$ WC "d_dlsymun='undef'"
$ WC "d_dosuid='undef'"
diff --git a/vms/vms.c b/vms/vms.c
index ac47224250..916a463498 100644
--- a/vms/vms.c
+++ b/vms/vms.c
@@ -7491,10 +7491,10 @@ Perl_trim_unixpath(pTHX_ char *fspec, const char *wildspec, int opts)
* Open a directory, return a handle for later use.
*/
/*{{{ DIR *opendir(char*name) */
-MY_DIR *
+DIR *
Perl_opendir(pTHX_ const char *name)
{
- MY_DIR *dd;
+ DIR *dd;
char dir[NAM$C_MAXRSS+1];
Stat_t sb;
@@ -7514,7 +7514,7 @@ Perl_opendir(pTHX_ const char *name)
return NULL;
}
/* Get memory for the handle, and the pattern. */
- Newx(dd,1,MY_DIR);
+ Newx(dd,1,DIR);
Newx(dd->pattern,strlen(dir)+sizeof "*.*" + 1,char);
/* Fill in the fields; mainly playing with the descriptor. */
@@ -7542,7 +7542,7 @@ Perl_opendir(pTHX_ const char *name)
*/
/*{{{ void vmsreaddirversions(DIR *dd, int flag)*/
void
-vmsreaddirversions(MY_DIR *dd, int flag)
+vmsreaddirversions(DIR *dd, int flag)
{
dd->vms_wantversions = flag;
}
@@ -7553,7 +7553,7 @@ vmsreaddirversions(MY_DIR *dd, int flag)
*/
/*{{{ void closedir(DIR *dd)*/
void
-Perl_closedir(MY_DIR *dd)
+Perl_closedir(DIR *dd)
{
int sts;
@@ -7571,11 +7571,11 @@ Perl_closedir(MY_DIR *dd)
* Collect all the version numbers for the current file.
*/
static void
-collectversions(pTHX_ MY_DIR *dd)
+collectversions(pTHX_ DIR *dd)
{
struct dsc$descriptor_s pat;
struct dsc$descriptor_s res;
- struct my_dirent *e;
+ struct dirent *e;
char *p, *text, buff[sizeof dd->entry.d_name];
int i;
unsigned long context, tmpsts;
@@ -7624,8 +7624,8 @@ collectversions(pTHX_ MY_DIR *dd)
* Read the next entry from the directory.
*/
/*{{{ struct dirent *readdir(DIR *dd)*/
-struct my_dirent *
-Perl_readdir(pTHX_ MY_DIR *dd)
+struct dirent *
+Perl_readdir(pTHX_ DIR *dd)
{
struct dsc$descriptor_s res;
char *p, buff[sizeof dd->entry.d_name];
@@ -7690,7 +7690,7 @@ Perl_readdir(pTHX_ MY_DIR *dd)
*/
/*{{{ int readdir_r(DIR *dd, struct dirent *entry, struct dirent **result)*/
int
-Perl_readdir_r(pTHX_ MY_DIR *dd, struct my_dirent *entry, struct my_dirent **result)
+Perl_readdir_r(pTHX_ DIR *dd, struct dirent *entry, struct dirent **result)
{
int retval;
@@ -7712,7 +7712,7 @@ Perl_readdir_r(pTHX_ MY_DIR *dd, struct my_dirent *entry, struct my_dirent **res
*/
/*{{{ long telldir(DIR *dd)*/
long
-Perl_telldir(MY_DIR *dd)
+Perl_telldir(DIR *dd)
{
return dd->count;
}
@@ -7723,7 +7723,7 @@ Perl_telldir(MY_DIR *dd)
*/
/*{{{ void seekdir(DIR *dd,long count)*/
void
-Perl_seekdir(pTHX_ MY_DIR *dd, long count)
+Perl_seekdir(pTHX_ DIR *dd, long count)
{
int vms_wantversions;
diff --git a/vms/vmsish.h b/vms/vmsish.h
index 0953700dcf..69b4bf16e8 100644
--- a/vms/vmsish.h
+++ b/vms/vmsish.h
@@ -54,9 +54,6 @@
#include <processes.h> /* for vfork() */
#include <unixio.h>
#include <unixlib.h>
-#if __CRTL_VER >= 80200000 && !defined(__VAX)
-#include <dirent.h>
-#endif
#include <file.h> /* it's not <sys/file.h>, so don't use I_SYS_FILE */
#if (defined(__DECC) && defined(__DECC_VER) && __DECC_VER > 20000000) || defined(__DECCXX)
# include <unistd.h> /* DECC has this; gcc doesn't */
@@ -130,9 +127,7 @@
#define pathify_dirspec Perl_pathify_dirspec
#define pathify_dirspec_ts Perl_pathify_dirspec_ts
#define trim_unixpath Perl_trim_unixpath
-#ifndef DONT_MASK_RTL_CALLS
#define opendir Perl_opendir
-#endif
#define rmscopy Perl_rmscopy
#define my_mkdir Perl_my_mkdir
#define vms_do_aexec Perl_vms_do_aexec
@@ -143,9 +138,7 @@
#define my_utime Perl_my_utime
#define my_chdir Perl_my_chdir
#define do_aspawn Perl_do_aspawn
-#ifndef DONT_MASK_RTL_CALLS
#define seekdir Perl_seekdir
-#endif
#define my_gmtime Perl_my_gmtime
#define my_localtime Perl_my_localtime
#define my_time Perl_my_time
@@ -181,9 +174,7 @@
#define rmsexpand(a,b,c,d) Perl_rmsexpand(aTHX_ a,b,c,d)
#define rmsexpand_ts(a,b,c,d) Perl_rmsexpand_ts(aTHX_ a,b,c,d)
#define trim_unixpath(a,b,c) Perl_trim_unixpath(aTHX_ a,b,c)
-#ifndef DONT_MASK_RTL_CALLS
#define opendir(a) Perl_opendir(aTHX_ a)
-#endif
#define rmscopy(a,b,c) Perl_rmscopy(aTHX_ a,b,c)
#define my_mkdir(a,b) Perl_my_mkdir(aTHX_ a,b)
#define vms_do_aexec(a,b,c) Perl_vms_do_aexec(aTHX_ a,b,c)
@@ -194,9 +185,7 @@
#define my_utime(a,b) Perl_my_utime(aTHX_ a,b)
#define my_chdir(a) Perl_my_chdir(aTHX_ a)
#define do_aspawn(a,b,c) Perl_do_aspawn(aTHX_ a,b,c)
-#ifndef DONT_MASK_RTL_CALLS
#define seekdir(a,b) Perl_seekdir(aTHX_ a,b)
-#endif
#define my_gmtime(a) Perl_my_gmtime(aTHX_ a)
#define my_localtime(a) Perl_my_localtime(aTHX_ a)
#define my_time(a) Perl_my_time(aTHX_ a)
@@ -207,16 +196,12 @@
#define my_getpwnam(a) Perl_my_getpwnam(aTHX_ a)
#define my_getpwuid(a) Perl_my_getpwuid(aTHX_ a)
#define my_flush(a) Perl_my_flush(aTHX_ a)
-#ifndef DONT_MASK_RTL_CALLS
#define readdir(a) Perl_readdir(aTHX_ a)
#define readdir_r(a,b,c) Perl_readdir_r(aTHX_ a,b,c)
#endif
-#endif
#define my_gconvert Perl_my_gconvert
-#ifndef DONT_MASK_RTL_CALLS
#define telldir Perl_telldir
#define closedir Perl_closedir
-#endif
#define vmsreaddirversions Perl_vmsreaddirversions
#define my_sigemptyset Perl_my_sigemptyset
#define my_sigfillset Perl_my_sigfillset
@@ -593,21 +578,11 @@ struct utimbuf {
* vmsreaddirversions(), and preprocessor stuff on which these depend:
* Written by Rich $alz, <rsalz@bbn.com> in August, 1990.
*
- * Feb 2005 - POSIX filespecs need real opendir() structures.
- * rename to remove conflicts. J. Malmberg (HP OpenVMS)
*/
/* Data structure returned by READDIR(). */
-struct my_dirent {
+struct dirent {
char d_name[256]; /* File name */
-# if defined _XOPEN_SOURCE || !defined _POSIX_C_SOURCE
-#if !_USE_STD_STAT
- /* 3 word array */
- __ino_t d_ino[3]; /* file serial number (vms-style inode) */
- unsigned short fill;
-#else /* quadword */
- __ino_t d_ino;
-#endif
int d_namlen; /* Length of d_name */
int vms_verscount; /* Number of versions */
int vms_versions[20]; /* Version numbers */
@@ -615,26 +590,18 @@ struct my_dirent {
/* Handle returned by opendir(), used by the other routines. You
* are not supposed to care what's inside this structure. */
-typedef struct my_dirdesc {
-#if __CRTL_VER >= 80200000 && !defined(__VAX)
- int flags;
- DIR *vms_dirdesc;
-#endif
+typedef struct _dirdesc {
long context;
int vms_wantversions;
unsigned long int count;
char *pattern;
- struct my_dirent entry;
+ struct dirent entry;
struct dsc$descriptor_s pat;
void *mutex;
-} MY_DIR;
+} DIR;
-#ifndef DONT_MASK_RTL_CALLS
-#define DIR MY_DIR
-#define dirent my_dirent
#define rewinddir(dirp) seekdir((dirp), 0)
-#endif
/* used for our emulation of getpw* */
struct passwd {
@@ -712,8 +679,6 @@ struct mystat
#define st_fab_fsz crtl_stat.st_fab_fsz
#define st_fab_mrs crtl_stat_st_fab_mrs
-#endif /* defined(USE_LARGE_FILES) */
-
#if defined(__DECC) || defined(__DECCXX)
# pragma __member_alignment __restore
#endif
@@ -807,7 +772,7 @@ char * Perl_pathify_dirspec_ts (const char *, char *);
char * Perl_rmsexpand (const char *, char *, const char *, unsigned);
char * Perl_rmsexpand_ts (const char *, char *, const char *, unsigned);
int Perl_trim_unixpath (char *, const char*, int);
-MY_DIR * Perl_opendir (const char *);
+DIR * Perl_opendir (const char *);
int Perl_rmscopy (const char *, const char *, int);
int Perl_my_mkdir (const char *, Mode_t);
bool Perl_vms_do_aexec (SV *, SV **, SV **);
@@ -830,7 +795,7 @@ char * Perl_pathify_dirspec_ts (pTHX_ const char *, char *);
char * Perl_rmsexpand (pTHX_ const char *, char *, const char *, unsigned);
char * Perl_rmsexpand_ts (pTHX_ const char *, char *, const char *, unsigned);
int Perl_trim_unixpath (pTHX_ char *, const char*, int);
-MY_DIR * Perl_opendir (pTHX_ const char *);
+DIR * Perl_opendir (pTHX_ const char *);
int Perl_rmscopy (pTHX_ const char *, const char *, int);
int Perl_my_mkdir (pTHX_ const char *, Mode_t);
bool Perl_vms_do_aexec (pTHX_ SV *, SV **, SV **);
@@ -855,12 +820,12 @@ void Perl_csighandler_init (void);
#endif
int Perl_my_utime (pTHX_ const char *, const struct utimbuf *);
void Perl_vms_image_init (int *, char ***);
-struct my_dirent * Perl_readdir (pTHX_ MY_DIR *);
-int Perl_readdir_r(pTHX_ MY_DIR *, struct my_dirent *, struct my_dirent **);
-long Perl_telldir (MY_DIR *);
-void Perl_seekdir (pTHX_ MY_DIR *, long);
-void Perl_closedir (MY_DIR *);
-void vmsreaddirversions (MY_DIR *, int);
+struct dirent * Perl_readdir (pTHX_ DIR *);
+int Perl_readdir_r(pTHX_ DIR *, struct dirent *, struct dirent **);
+long Perl_telldir (DIR *);
+void Perl_seekdir (pTHX_ DIR *, long);
+void Perl_closedir (DIR *);
+void vmsreaddirversions (DIR *, int);
struct tm * Perl_my_gmtime (pTHX_ const time_t *);
struct tm * Perl_my_localtime (pTHX_ const time_t *);
time_t Perl_my_time (pTHX_ time_t *);