Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
6f6eb82d
Commit
6f6eb82d
authored
Mar 30, 2003
by
Jukka Heinonen
Committed by
Alexandre Julliard
Mar 30, 2003
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add prototype for GetCompressedFileSize. Move some int21 functions to
winedos. Improve file attribute functions.
parent
ac89a159
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
3 additions
and
134 deletions
+3
-134
int21.c
dlls/winedos/int21.c
+0
-0
winbase.h
include/winbase.h
+3
-0
int21.c
msdos/int21.c
+0
-134
No files found.
dlls/winedos/int21.c
View file @
6f6eb82d
This diff is collapsed.
Click to expand it.
include/winbase.h
View file @
6f6eb82d
...
@@ -1300,6 +1300,9 @@ BOOL WINAPI GetCommTimeouts(HANDLE,LPCOMMTIMEOUTS);
...
@@ -1300,6 +1300,9 @@ BOOL WINAPI GetCommTimeouts(HANDLE,LPCOMMTIMEOUTS);
LPSTR
WINAPI
GetCommandLineA
(
void
);
LPSTR
WINAPI
GetCommandLineA
(
void
);
LPWSTR
WINAPI
GetCommandLineW
(
void
);
LPWSTR
WINAPI
GetCommandLineW
(
void
);
#define GetCommandLine WINELIB_NAME_AW(GetCommandLine)
#define GetCommandLine WINELIB_NAME_AW(GetCommandLine)
DWORD
WINAPI
GetCompressedFileSizeA
(
LPCSTR
,
LPDWORD
);
DWORD
WINAPI
GetCompressedFileSizeW
(
LPCWSTR
,
LPDWORD
);
#define GetCompressedFileSize WINELIB_NAME_AW(GetCompressedFileSize)
BOOL
WINAPI
GetComputerNameA
(
LPSTR
,
LPDWORD
);
BOOL
WINAPI
GetComputerNameA
(
LPSTR
,
LPDWORD
);
BOOL
WINAPI
GetComputerNameW
(
LPWSTR
,
LPDWORD
);
BOOL
WINAPI
GetComputerNameW
(
LPWSTR
,
LPDWORD
);
#define GetComputerName WINELIB_NAME_AW(GetComputerName)
#define GetComputerName WINELIB_NAME_AW(GetComputerName)
...
...
msdos/int21.c
View file @
6f6eb82d
...
@@ -1020,28 +1020,6 @@ void WINAPI INT_Int21Handler( CONTEXT86 *context )
...
@@ -1020,28 +1020,6 @@ void WINAPI INT_Int21Handler( CONTEXT86 *context )
if
(
!
INT21_GetFreeDiskSpace
(
context
))
SET_AX
(
context
,
0xffff
);
if
(
!
INT21_GetFreeDiskSpace
(
context
))
SET_AX
(
context
,
0xffff
);
break
;
break
;
case
0x39
:
/* "MKDIR" - CREATE SUBDIRECTORY */
TRACE
(
"MKDIR %s
\n
"
,
(
LPCSTR
)
CTX_SEG_OFF_TO_LIN
(
context
,
context
->
SegDs
,
context
->
Edx
));
bSetDOSExtendedError
=
(
!
CreateDirectory16
(
CTX_SEG_OFF_TO_LIN
(
context
,
context
->
SegDs
,
context
->
Edx
),
NULL
));
/* FIXME: CreateDirectory's LastErrors will clash with the ones
* used by dos. AH=39 only returns 3 (path not found) and 5 (access
* denied), while CreateDirectory return several ones. remap some of
* them. -Marcus
*/
if
(
bSetDOSExtendedError
)
{
switch
(
GetLastError
())
{
case
ERROR_ALREADY_EXISTS
:
case
ERROR_FILENAME_EXCED_RANGE
:
case
ERROR_DISK_FULL
:
SetLastError
(
ERROR_ACCESS_DENIED
);
break
;
default:
break
;
}
}
break
;
case
0x3b
:
/* "CHDIR" - SET CURRENT DIRECTORY */
case
0x3b
:
/* "CHDIR" - SET CURRENT DIRECTORY */
TRACE
(
"CHDIR %s
\n
"
,
TRACE
(
"CHDIR %s
\n
"
,
(
LPCSTR
)
CTX_SEG_OFF_TO_LIN
(
context
,
context
->
SegDs
,
context
->
Edx
));
(
LPCSTR
)
CTX_SEG_OFF_TO_LIN
(
context
,
context
->
SegDs
,
context
->
Edx
));
...
@@ -1060,69 +1038,6 @@ void WINAPI INT_Int21Handler( CONTEXT86 *context )
...
@@ -1060,69 +1038,6 @@ void WINAPI INT_Int21Handler( CONTEXT86 *context )
OpenExistingFile
(
context
);
OpenExistingFile
(
context
);
break
;
break
;
case
0x3f
:
/* "READ" - READ FROM FILE OR DEVICE */
TRACE
(
"READ from %d to %04lX:%04X for %d byte
\n
"
,
BX_reg
(
context
),
context
->
SegDs
,
DX_reg
(
context
),
CX_reg
(
context
)
);
{
LONG
result
;
if
(
ISV86
(
context
))
result
=
_hread16
(
BX_reg
(
context
),
CTX_SEG_OFF_TO_LIN
(
context
,
context
->
SegDs
,
context
->
Edx
),
CX_reg
(
context
)
);
else
result
=
WIN16_hread
(
BX_reg
(
context
),
MAKESEGPTR
(
context
->
SegDs
,
context
->
Edx
),
CX_reg
(
context
)
);
if
(
result
==
-
1
)
bSetDOSExtendedError
=
TRUE
;
else
SET_AX
(
context
,
(
WORD
)
result
);
}
break
;
case
0x42
:
/* "LSEEK" - SET CURRENT FILE POSITION */
TRACE
(
"LSEEK handle %d offset %ld from %s
\n
"
,
BX_reg
(
context
),
MAKELONG
(
DX_reg
(
context
),
CX_reg
(
context
)),
(
AL_reg
(
context
)
==
0
)
?
"start of file"
:
(
AL_reg
(
context
)
==
1
)
?
"current file position"
:
"end of file"
);
{
LONG
status
=
_llseek16
(
BX_reg
(
context
),
MAKELONG
(
DX_reg
(
context
),
CX_reg
(
context
)),
AL_reg
(
context
)
);
if
(
status
==
-
1
)
bSetDOSExtendedError
=
TRUE
;
else
{
SET_AX
(
context
,
LOWORD
(
status
)
);
SET_DX
(
context
,
HIWORD
(
status
)
);
}
}
break
;
case
0x43
:
/* FILE ATTRIBUTES */
switch
(
AL_reg
(
context
))
{
case
0x00
:
TRACE
(
"GET FILE ATTRIBUTES for %s
\n
"
,
(
LPCSTR
)
CTX_SEG_OFF_TO_LIN
(
context
,
context
->
SegDs
,
context
->
Edx
));
SET_AX
(
context
,
GetFileAttributesA
(
CTX_SEG_OFF_TO_LIN
(
context
,
context
->
SegDs
,
context
->
Edx
)));
if
(
AX_reg
(
context
)
==
0xffff
)
bSetDOSExtendedError
=
TRUE
;
else
SET_CX
(
context
,
AX_reg
(
context
)
);
break
;
case
0x01
:
TRACE
(
"SET FILE ATTRIBUTES 0x%02x for %s
\n
"
,
CX_reg
(
context
),
(
LPCSTR
)
CTX_SEG_OFF_TO_LIN
(
context
,
context
->
SegDs
,
context
->
Edx
));
bSetDOSExtendedError
=
(
!
SetFileAttributesA
(
CTX_SEG_OFF_TO_LIN
(
context
,
context
->
SegDs
,
context
->
Edx
),
CX_reg
(
context
)
));
break
;
case
0x02
:
FIXME
(
"GET COMPRESSED FILE SIZE for %s stub
\n
"
,
(
LPCSTR
)
CTX_SEG_OFF_TO_LIN
(
context
,
context
->
SegDs
,
context
->
Edx
));
}
break
;
case
0x44
:
/* IOCTL */
case
0x44
:
/* IOCTL */
switch
(
AL_reg
(
context
))
switch
(
AL_reg
(
context
))
{
{
...
@@ -1334,55 +1249,6 @@ void WINAPI INT_Int21Handler( CONTEXT86 *context )
...
@@ -1334,55 +1249,6 @@ void WINAPI INT_Int21Handler( CONTEXT86 *context )
case
0x71
:
/* MS-DOS 7 (Windows95) - LONG FILENAME FUNCTIONS */
case
0x71
:
/* MS-DOS 7 (Windows95) - LONG FILENAME FUNCTIONS */
switch
(
AL_reg
(
context
))
switch
(
AL_reg
(
context
))
{
{
case
0x39
:
/* Create directory */
TRACE
(
"LONG FILENAME - MAKE DIRECTORY %s
\n
"
,
(
LPCSTR
)
CTX_SEG_OFF_TO_LIN
(
context
,
context
->
SegDs
,
context
->
Edx
));
bSetDOSExtendedError
=
(
!
CreateDirectoryA
(
CTX_SEG_OFF_TO_LIN
(
context
,
context
->
SegDs
,
context
->
Edx
),
NULL
));
/* FIXME: CreateDirectory's LastErrors will clash with the ones
* used by dos. AH=39 only returns 3 (path not found) and 5 (access
* denied), while CreateDirectory return several ones. remap some of
* them. -Marcus
*/
if
(
bSetDOSExtendedError
)
{
switch
(
GetLastError
())
{
case
ERROR_ALREADY_EXISTS
:
case
ERROR_FILENAME_EXCED_RANGE
:
case
ERROR_DISK_FULL
:
SetLastError
(
ERROR_ACCESS_DENIED
);
break
;
default:
break
;
}
}
break
;
case
0x43
:
/* Get/Set file attributes */
TRACE
(
"LONG FILENAME -EXTENDED GET/SET FILE ATTRIBUTES %s
\n
"
,
(
LPCSTR
)
CTX_SEG_OFF_TO_LIN
(
context
,
context
->
SegDs
,
context
->
Edx
));
switch
(
BL_reg
(
context
))
{
case
0x00
:
/* Get file attributes */
TRACE
(
"
\t
retrieve attributes
\n
"
);
SET_CX
(
context
,
GetFileAttributesA
(
CTX_SEG_OFF_TO_LIN
(
context
,
context
->
SegDs
,
context
->
Edx
)));
if
(
CX_reg
(
context
)
==
0xffff
)
bSetDOSExtendedError
=
TRUE
;
break
;
case
0x01
:
TRACE
(
"
\t
set attributes 0x%04x
\n
"
,
CX_reg
(
context
));
bSetDOSExtendedError
=
(
!
SetFileAttributesA
(
CTX_SEG_OFF_TO_LIN
(
context
,
context
->
SegDs
,
context
->
Edx
),
CX_reg
(
context
)
)
);
break
;
default:
FIXME
(
"Unimplemented long file name function:
\n
"
);
INT_BARF
(
context
,
0x21
);
SET_CFLAG
(
context
);
SET_AL
(
context
,
0
);
break
;
}
break
;
case
0x47
:
/* Get current directory */
case
0x47
:
/* Get current directory */
TRACE
(
" LONG FILENAME - GET CURRENT DIRECTORY for drive %s
\n
"
,
TRACE
(
" LONG FILENAME - GET CURRENT DIRECTORY for drive %s
\n
"
,
INT21_DriveName
(
DL_reg
(
context
)));
INT21_DriveName
(
DL_reg
(
context
)));
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment