Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
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-cw
Commits
44941a55
Commit
44941a55
authored
Aug 21, 2008
by
Roy Shea
Committed by
Alexandre Julliard
Aug 21, 2008
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
expand: Extended expand program to accept /r argument.
parent
ca736551
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
75 additions
and
6 deletions
+75
-6
expand.c
programs/expand/expand.c
+75
-6
No files found.
programs/expand/expand.c
View file @
44941a55
...
...
@@ -26,6 +26,30 @@
#include <lzexpand.h>
#include <setupapi.h>
static
UINT
CALLBACK
set_outfile
(
PVOID
context
,
UINT
notification
,
UINT_PTR
param1
,
UINT_PTR
param2
)
{
FILE_IN_CABINET_INFO_A
*
info
=
(
FILE_IN_CABINET_INFO_A
*
)
param1
;
char
buffer
[
MAX_PATH
];
char
*
basename
;
switch
(
notification
)
{
case
SPFILENOTIFY_FILEINCABINET
:
{
LPSTR
outfile
=
context
;
if
(
outfile
[
0
]
!=
0
)
{
SetLastError
(
ERROR_NOT_SUPPORTED
);
return
FILEOP_ABORT
;
}
GetFullPathNameA
(
info
->
NameInCabinet
,
sizeof
(
buffer
),
buffer
,
&
basename
);
strcpy
(
outfile
,
basename
);
return
FILEOP_SKIP
;
}
default:
return
NO_ERROR
;
}
}
static
UINT
CALLBACK
extract_callback
(
PVOID
context
,
UINT
notification
,
UINT_PTR
param1
,
UINT_PTR
param2
)
{
FILE_IN_CABINET_INFO_A
*
info
=
(
FILE_IN_CABINET_INFO_A
*
)
param1
;
...
...
@@ -43,29 +67,74 @@ static UINT CALLBACK extract_callback( PVOID context, UINT notification, UINT_PT
}
}
static
BOOL
option_equal
(
LPCSTR
str1
,
LPCSTR
str2
)
{
if
(
str1
[
0
]
!=
'/'
&&
str1
[
0
]
!=
'-'
)
return
FALSE
;
return
!
lstrcmpA
(
str1
+
1
,
str2
);
}
int
main
(
int
argc
,
char
*
argv
[])
{
int
ret
=
0
;
char
infile
[
MAX_PATH
],
outfile
[
MAX_PATH
],
actual_name
[
MAX_PATH
];
char
outfile_basename
[
MAX_PATH
],
*
basename_index
;
UINT
comp
;
if
(
argc
<
3
)
{
fprintf
(
stderr
,
"Usage: %s infile outfile
\n
"
,
argv
[
0
]
);
fprintf
(
stderr
,
"Usage:
\n
"
);
fprintf
(
stderr
,
"
\t
%s infile outfile
\n
"
,
argv
[
0
]
);
fprintf
(
stderr
,
"
\t
%s /r infile
\n
"
,
argv
[
0
]
);
return
1
;
}
if
(
argc
==
3
&&
(
option_equal
(
argv
[
1
],
"R"
)
||
option_equal
(
argv
[
1
],
"r"
)))
GetFullPathNameA
(
argv
[
2
],
sizeof
(
infile
),
infile
,
NULL
);
else
GetFullPathNameA
(
argv
[
1
],
sizeof
(
infile
),
infile
,
NULL
);
GetFullPathNameA
(
argv
[
2
],
sizeof
(
outfile
),
outfile
,
NULL
);
if
(
!
lstrcmpiA
(
infile
,
outfile
))
if
(
!
SetupGetFileCompressionInfoExA
(
infile
,
actual_name
,
sizeof
(
actual_name
),
NULL
,
NULL
,
NULL
,
&
comp
))
{
fprintf
(
stderr
,
"%s: can't
expand file to itself
\n
"
,
argv
[
0
]
);
fprintf
(
stderr
,
"%s: can't
open input file %s
\n
"
,
argv
[
0
],
infile
);
return
1
;
}
if
(
!
SetupGetFileCompressionInfoExA
(
infile
,
actual_name
,
sizeof
(
actual_name
),
NULL
,
NULL
,
NULL
,
&
comp
))
if
(
argc
==
3
&&
(
option_equal
(
argv
[
1
],
"R"
)
||
option_equal
(
argv
[
1
],
"r"
)))
{
fprintf
(
stderr
,
"%s: can't open input file %s
\n
"
,
argv
[
0
],
infile
);
switch
(
comp
)
{
case
FILE_COMPRESSION_MSZIP
:
{
outfile_basename
[
0
]
=
0
;
if
(
!
SetupIterateCabinetA
(
infile
,
0
,
set_outfile
,
(
PVOID
)
outfile_basename
))
{
fprintf
(
stderr
,
"%s: can't determine original name
\n
"
,
argv
[
0
]
);
return
1
;
}
GetFullPathNameA
(
infile
,
sizeof
(
outfile
),
outfile
,
&
basename_index
);
*
basename_index
=
0
;
strcat
(
outfile
,
outfile_basename
);
break
;
}
case
FILE_COMPRESSION_WINLZA
:
{
GetExpandedNameA
(
infile
,
outfile_basename
);
break
;
}
default:
{
fprintf
(
stderr
,
"%s: can't determine original
\n
"
,
argv
[
0
]
);
return
1
;
}
}
}
else
GetFullPathNameA
(
argv
[
2
],
sizeof
(
outfile
),
outfile
,
NULL
);
if
(
!
lstrcmpiA
(
infile
,
outfile
))
{
fprintf
(
stderr
,
"%s: can't expand file to itself
\n
"
,
argv
[
0
]
);
return
1
;
}
...
...
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