diff options
Diffstat (limited to 'vms/vms.c')
-rw-r--r-- | vms/vms.c | 122 |
1 files changed, 61 insertions, 61 deletions
@@ -13243,66 +13243,66 @@ mp_do_vms_realpath(pTHX_ const char *filespec, char *outbuf, if (haslower) __mystrtolower(rslt); } } -+ } else { -+ -+ /* Now for some hacks to deal with backwards and forward */ -+ /* compatibilty */ -+ if (!decc_efs_charset) { -+ -+ /* 1. ODS-2 mode wants to do a syntax only translation */ -+ rslt = do_rmsexpand(filespec, outbuf, -+ 0, NULL, 0, NULL, utf8_fl); -+ -+ } else { -+ if (decc_filename_unix_report) { -+ char * dir_name; -+ char * vms_dir_name; -+ char * file_name; -+ -+ /* 2. ODS-5 / UNIX report mode should return a failure */ -+ /* if the parent directory also does not exist */ -+ /* Otherwise, get the real path for the parent */ -+ /* and add the child to it. -+ -+ /* basename / dirname only available for VMS 7.0+ */ -+ /* So we may need to implement them as common routines */ -+ -+ Newx(dir_name, VMS_MAXRSS + 1, char); -+ Newx(vms_dir_name, VMS_MAXRSS + 1, char); -+ dir_name[0] = '\0'; -+ file_name = NULL; -+ -+ /* First try a VMS parse */ -+ sts = vms_split_path -+ (filespec, -+ &v_spec, -+ &v_len, -+ &r_spec, -+ &r_len, -+ &d_spec, -+ &d_len, -+ &n_spec, -+ &n_len, -+ &e_spec, -+ &e_len, -+ &vs_spec, -+ &vs_len); -+ -+ if (sts == 0) { -+ /* This is VMS */ -+ -+ int dir_len = v_len + r_len + d_len + n_len; -+ if (dir_len > 0) { -+ strncpy(dir_name, filespec, dir_len); -+ dir_name[dir_len] = '\0'; -+ file_name = (char *)&filespec[dir_len + 1]; -+ } -+ } else { -+ /* This must be UNIX */ -+ char * tchar; -+ -+ tchar = strrchr(filespec, '/'); -+ + } else { + + /* Now for some hacks to deal with backwards and forward */ + /* compatibilty */ + if (!decc_efs_charset) { + + /* 1. ODS-2 mode wants to do a syntax only translation */ + rslt = do_rmsexpand(filespec, outbuf, + 0, NULL, 0, NULL, utf8_fl); + + } else { + if (decc_filename_unix_report) { + char * dir_name; + char * vms_dir_name; + char * file_name; + + /* 2. ODS-5 / UNIX report mode should return a failure */ + /* if the parent directory also does not exist */ + /* Otherwise, get the real path for the parent */ + /* and add the child to it. + + /* basename / dirname only available for VMS 7.0+ */ + /* So we may need to implement them as common routines */ + + Newx(dir_name, VMS_MAXRSS + 1, char); + Newx(vms_dir_name, VMS_MAXRSS + 1, char); + dir_name[0] = '\0'; + file_name = NULL; + + /* First try a VMS parse */ + sts = vms_split_path + (filespec, + &v_spec, + &v_len, + &r_spec, + &r_len, + &d_spec, + &d_len, + &n_spec, + &n_len, + &e_spec, + &e_len, + &vs_spec, + &vs_len); + + if (sts == 0) { + /* This is VMS */ + + int dir_len = v_len + r_len + d_len + n_len; + if (dir_len > 0) { + strncpy(dir_name, filespec, dir_len); + dir_name[dir_len] = '\0'; + file_name = (char *)&filespec[dir_len + 1]; + } + } else { + /* This must be UNIX */ + char * tchar; + + tchar = strrchr(filespec, '/'); + if (tchar != NULL) { int dir_len = tchar - filespec; strncpy(dir_name, filespec, dir_len); @@ -13337,7 +13337,7 @@ mp_do_vms_realpath(pTHX_ const char *filespec, char *outbuf, Safefree(dir_name); } } - + } Safefree(vms_spec); } return rslt; |