Add support for UNC style paths (David Bolen)

git-svn-id: https://svn.code.sf.net/p/freedos/svn/kernel/trunk@604 6ac86273-5f31-0410-b378-82cca8765d1b
This commit is contained in:
Bart Oldeman 2003-06-15 22:06:03 +00:00
parent d56013c885
commit 4c88863f24
5 changed files with 49 additions and 30 deletions

View File

@ -16,6 +16,9 @@
* distinguish between the builtin DOS version and the settable * distinguish between the builtin DOS version and the settable
DOS version. DOS version.
* console.asm now accepts extended scancodes (modified by Bart) * console.asm now accepts extended scancodes (modified by Bart)
* added BOOTONLY option to SYS (modified by Bart)
+ Changes David Bolen
* add support for UNC-style paths (that start with "\\")
+ Changes Bart + Changes Bart
* flip some slashes in drivers/*.asm * flip some slashes in drivers/*.asm
(enables cross-assembly on Linux) (enables cross-assembly on Linux)

View File

@ -92,7 +92,7 @@ STATIC int remote_lock_unlock(sft FAR *sftp, /* SFT for file */
/* get current directory structure for drive /* get current directory structure for drive
return NULL if the CDS is not valid or the return NULL if the CDS is not valid or the
drive is not within range */ drive is not within range */
struct cds FAR *get_cds(int drive) struct cds FAR *get_cds(unsigned drive)
{ {
struct cds FAR *cdsp; struct cds FAR *cdsp;
unsigned flags; unsigned flags;
@ -966,7 +966,8 @@ COUNT DosChangeDir(BYTE FAR * s)
return result; return result;
} }
if (strlen(PriPathName) > sizeof(current_ldt->cdsCurrentPath) - 1) if ((FP_OFF(current_ldt) != 0xFFFF) &&
(strlen(PriPathName) > sizeof(current_ldt->cdsCurrentPath) - 1))
return DE_PATHNOTFND; return DE_PATHNOTFND;
#if defined(CHDIR_DEBUG) #if defined(CHDIR_DEBUG)
@ -987,9 +988,13 @@ COUNT DosChangeDir(BYTE FAR * s)
Some redirectors do not write back to the CDS. Some redirectors do not write back to the CDS.
SHSUCdX needs this. jt SHSUCdX needs this. jt
*/ */
fstrcpy(current_ldt->cdsCurrentPath, PriPathName);
if (FP_OFF(current_ldt) != 0xFFFF)
{
fstrcpy(current_ldt->cdsCurrentPath, PriPathName); fstrcpy(current_ldt->cdsCurrentPath, PriPathName);
if (PriPathName[7] == 0) if (PriPathName[7] == 0)
current_ldt->cdsCurrentPath[8] = 0; /* Need two Zeros at the end */ current_ldt->cdsCurrentPath[8] = 0; /* Need two Zeros at the end */
}
return SUCCESS; return SUCCESS;
} }
@ -1271,7 +1276,7 @@ COUNT DosRenameTrue(BYTE * path1, BYTE * path2, int attrib)
{ {
return DE_DEVICE; /* not same device */ return DE_DEVICE; /* not same device */
} }
if (current_ldt->cdsFlags & CDSNETWDRV) if (FP_OFF(current_ldt) == 0xFFFF || (current_ldt->cdsFlags & CDSNETWDRV))
return remote_rename(); return remote_rename();
return dos_rename(path1, path2, attrib); return dos_rename(path1, path2, attrib);

View File

@ -108,7 +108,7 @@ int DosMkTmp(BYTE FAR * pathname, UWORD attr)
#define DEBUG_TRUENAME #define DEBUG_TRUENAME
#endif #endif
#define drLetterToNr(dr) ((dr) - 'A') #define drLetterToNr(dr) ((unsigned char)((dr) - 'A'))
/* Convert an uppercased drive letter into the drive index */ /* Convert an uppercased drive letter into the drive index */
#define drNrToLetter(dr) ((dr) + 'A') #define drNrToLetter(dr) ((dr) + 'A')
/* the other direction */ /* the other direction */
@ -117,22 +117,6 @@ int DosMkTmp(BYTE FAR * pathname, UWORD attr)
is always a logical drive letter associated with a path is always a logical drive letter associated with a path
spec. This letter is also the index into the CDS */ spec. This letter is also the index into the CDS */
COUNT get_verify_drive(const char FAR * src)
{
int drive;
/* Do we have a drive? */
if (src[1] == ':')
drive = drLetterToNr(DosUpFChar(src[0]));
else
drive = default_drive;
if (get_cds(drive) == NULL)
return DE_PATHNOTFND;
return drive;
}
/* /*
Definition of functions for the handling of the Current Definition of functions for the handling of the Current
Directory Structure. Directory Structure.
@ -260,7 +244,7 @@ COUNT get_verify_drive(const char FAR * src)
#define addChar(c) \ #define addChar(c) \
{ \ { \
if (p - dest >= SFTMAX) PATH_ERROR; /* path too long */ \ if (p >= dest + SFTMAX) PATH_ERROR; /* path too long */ \
*p++ = c; \ *p++ = c; \
} }
@ -321,6 +305,7 @@ COUNT truename(const char FAR * src, char * dest, COUNT mode)
struct cds FAR *cdsEntry; struct cds FAR *cdsEntry;
char *p = dest; /* dynamic pointer into dest */ char *p = dest; /* dynamic pointer into dest */
char *rootPos; char *rootPos;
char src0;
enum { DONT_ADD, ADD, ADD_UNLESS_LAST } addSep; enum { DONT_ADD, ADD, ADD_UNLESS_LAST } addSep;
tn_printf(("truename(%S)\n", src)); tn_printf(("truename(%S)\n", src));
@ -330,14 +315,37 @@ COUNT truename(const char FAR * src, char * dest, COUNT mode)
/* In opposite of the TRUENAME shell command, an empty string is /* In opposite of the TRUENAME shell command, an empty string is
rejected by MS DOS 6 */ rejected by MS DOS 6 */
if (src[0] == '\0') src0 = src[0];
if (src0 == '\0')
return DE_FILENOTFND; return DE_FILENOTFND;
result = get_verify_drive(src); if (src0 == '\\' && src[1] == '\\') {
if (result < SUCCESS) const char FAR *unc_src = src;
return result; /* Flag UNC paths and short circuit processing. Set current LDT */
/* to sentinel (offset 0xFFFF) for redirector processing. */
tn_printf(("Truename: UNC detected\n"));
do {
src0 = unc_src[0];
addChar(src0);
unc_src++;
} while (src0);
current_ldt = (struct cds FAR *)MK_FP(0xFFFF,0xFFFF);
tn_printf(("Returning path: \"%s\"\n", dest));
/* Flag as network - drive bits are empty but shouldn't get */
/* referenced for network with empty current_ldt. */
return IS_NETWORK;
}
/* Do we have a drive? */
if (src[1] == ':')
result = drLetterToNr(DosUpFChar(src0));
else
result = default_drive;
cdsEntry = get_cds(result);
if (cdsEntry == NULL)
return DE_PATHNOTFND;
cdsEntry = &CDSp[result];
tn_printf(("CDS entry: #%u @%p (%u) '%S'\n", result, cdsEntry, tn_printf(("CDS entry: #%u @%p (%u) '%S'\n", result, cdsEntry,
cdsEntry->cdsBackslashOffset, cdsEntry->cdsCurrentPath)); cdsEntry->cdsBackslashOffset, cdsEntry->cdsCurrentPath));
/* is the current_ldt thing necessary for compatibly?? /* is the current_ldt thing necessary for compatibly??

View File

@ -111,7 +111,7 @@ BOOL IsShareInstalled(void);
COUNT DosLockUnlock(COUNT hndl, LONG pos, LONG len, COUNT unlock); COUNT DosLockUnlock(COUNT hndl, LONG pos, LONG len, COUNT unlock);
sft FAR *idx_to_sft(int SftIndex); sft FAR *idx_to_sft(int SftIndex);
int get_sft_idx(UCOUNT hndl); int get_sft_idx(UCOUNT hndl);
struct cds FAR *get_cds(int dsk); struct cds FAR *get_cds(unsigned dsk);
COUNT DosTruename(const char FAR * src, char FAR * dest); COUNT DosTruename(const char FAR * src, char FAR * dest);
/*dosidle.asm */ /*dosidle.asm */
@ -340,7 +340,6 @@ VOID InitPSP(VOID);
/* newstuff.c */ /* newstuff.c */
int SetJFTSize(UWORD nHandles); int SetJFTSize(UWORD nHandles);
int DosMkTmp(BYTE FAR * pathname, UWORD attr); int DosMkTmp(BYTE FAR * pathname, UWORD attr);
COUNT get_verify_drive(const char FAR * src);
COUNT truename(const char FAR * src, char * dest, COUNT t); COUNT truename(const char FAR * src, char * dest, COUNT t);
/* network.c */ /* network.c */

View File

@ -92,6 +92,10 @@ void DosGetTime(struct dostime *dt)
int DosSetTime(const struct dostime *dt) int DosSetTime(const struct dostime *dt)
{ {
if (dt->hour > 23 || dt->minute > 59 ||
dt->second > 59 || dt->hundredth > 99)
return DE_INVLDDATA;
/* for ClkRecord.clkDays */ /* for ClkRecord.clkDays */
ExecuteClockDriverRequest(C_INPUT); ExecuteClockDriverRequest(C_INPUT);