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
73e7346d
Commit
73e7346d
authored
Apr 05, 2012
by
Vincent Povirk
Committed by
Alexandre Julliard
Apr 06, 2012
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
winedump: Add basic support for dumping the property store in lnk files.
parent
018161e7
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
108 additions
and
0 deletions
+108
-0
lnk.c
tools/winedump/lnk.c
+108
-0
No files found.
tools/winedump/lnk.c
View file @
73e7346d
...
@@ -67,6 +67,7 @@ typedef enum {
...
@@ -67,6 +67,7 @@ typedef enum {
#define EXP_SPECIAL_FOLDER_SIG 0xa0000005
#define EXP_SPECIAL_FOLDER_SIG 0xa0000005
#define EXP_DARWIN_ID_SIG 0xa0000006
#define EXP_DARWIN_ID_SIG 0xa0000006
#define EXP_SZ_ICON_SIG 0xa0000007
#define EXP_SZ_ICON_SIG 0xa0000007
#define EXP_PROPERTYSTORAGE_SIG 0xa0000009
typedef
struct
tagDATABLOCKHEADER
typedef
struct
tagDATABLOCKHEADER
{
{
...
@@ -99,6 +100,22 @@ typedef struct tagLINK_SZ_BLOCK
...
@@ -99,6 +100,22 @@ typedef struct tagLINK_SZ_BLOCK
WCHAR
bufW
[
MAX_PATH
];
WCHAR
bufW
[
MAX_PATH
];
}
LINK_SZ_BLOCK
;
}
LINK_SZ_BLOCK
;
typedef
struct
tagLINK_PROPERTYSTORAGE_GUID
{
DWORD
size
;
DWORD
magic
;
GUID
fmtid
;
}
LINK_PROPERTYSTORAGE_GUID
;
typedef
struct
tagLINK_PROPERTYSTORAGE_VALUE
{
DWORD
size
;
DWORD
pid
;
BYTE
unknown8
;
DWORD
vt
;
DWORD
unknown25
;
}
LINK_PROPERTYSTORAGE_VALUE
;
typedef
struct
_LOCATION_INFO
typedef
struct
_LOCATION_INFO
{
{
DWORD
dwTotalSize
;
DWORD
dwTotalSize
;
...
@@ -386,6 +403,94 @@ static int dump_darwin_id(const DATABLOCK_HEADER* bhdr)
...
@@ -386,6 +403,94 @@ static int dump_darwin_id(const DATABLOCK_HEADER* bhdr)
return
0
;
return
0
;
}
}
static
void
dump_property_storage_value
(
const
LINK_PROPERTYSTORAGE_VALUE
*
lnk_value_hdr
,
DWORD
data_size
)
{
int
got_terminator
=
0
,
i
,
value_size
;
const
unsigned
char
*
value
;
while
(
data_size
>=
sizeof
(
DWORD
))
{
if
(
!
lnk_value_hdr
->
size
)
{
got_terminator
=
1
;
break
;
}
if
(
lnk_value_hdr
->
size
>
data_size
||
lnk_value_hdr
->
size
<
sizeof
(
*
lnk_value_hdr
))
{
printf
(
" size: %d (invald)
\n
"
,
lnk_value_hdr
->
size
);
return
;
}
printf
(
" pid: %d
\n
"
,
lnk_value_hdr
->
pid
);
printf
(
" unknown8: %d
\n
"
,
lnk_value_hdr
->
unknown8
);
printf
(
" vartype: %d
\n
"
,
lnk_value_hdr
->
vt
);
printf
(
" unknown25: %d
\n
"
,
lnk_value_hdr
->
unknown25
);
value_size
=
lnk_value_hdr
->
size
-
sizeof
(
*
lnk_value_hdr
);
value
=
(
const
unsigned
char
*
)(
lnk_value_hdr
+
1
);
printf
(
" value (%2d bytes) : "
,
value_size
);
for
(
i
=
0
;
i
<
value_size
;
i
++
)
printf
(
"%02x "
,
value
[
i
]);
printf
(
"
\n\n
"
);
data_size
-=
lnk_value_hdr
->
size
;
lnk_value_hdr
=
(
void
*
)((
char
*
)
lnk_value_hdr
+
lnk_value_hdr
->
size
);
}
if
(
!
got_terminator
)
printf
(
" missing terminator!
\n
"
);
}
static
int
dump_property_storage
(
const
DATABLOCK_HEADER
*
bhdr
)
{
int
data_size
;
const
LINK_PROPERTYSTORAGE_GUID
*
lnk_guid_hdr
;
int
got_terminator
=
0
;
printf
(
"Property Storage
\n
"
);
printf
(
"--------------
\n\n
"
);
data_size
=
bhdr
->
cbSize
-
sizeof
(
*
bhdr
);
lnk_guid_hdr
=
(
void
*
)((
const
char
*
)
bhdr
+
sizeof
(
*
bhdr
));
while
(
data_size
>=
sizeof
(
DWORD
))
{
if
(
!
lnk_guid_hdr
->
size
)
{
got_terminator
=
1
;
break
;
}
if
(
lnk_guid_hdr
->
size
>
data_size
||
lnk_guid_hdr
->
size
<
sizeof
(
*
lnk_guid_hdr
))
{
printf
(
"size: %d (invald)
\n
"
,
lnk_guid_hdr
->
size
);
return
1
;
}
if
(
lnk_guid_hdr
->
magic
!=
0x53505331
)
printf
(
"magic: %x
\n
"
,
lnk_guid_hdr
->
magic
);
printf
(
"fmtid: %s
\n
"
,
get_guid_str
(
&
lnk_guid_hdr
->
fmtid
));
dump_property_storage_value
((
void
*
)(
lnk_guid_hdr
+
1
),
lnk_guid_hdr
->
size
-
sizeof
(
*
lnk_guid_hdr
));
data_size
-=
lnk_guid_hdr
->
size
;
lnk_guid_hdr
=
(
void
*
)((
char
*
)
lnk_guid_hdr
+
lnk_guid_hdr
->
size
);
}
if
(
!
got_terminator
)
printf
(
"missing terminator!
\n
"
);
printf
(
"
\n
"
);
return
0
;
}
static
int
dump_raw_block
(
const
DATABLOCK_HEADER
*
bhdr
)
static
int
dump_raw_block
(
const
DATABLOCK_HEADER
*
bhdr
)
{
{
int
data_size
;
int
data_size
;
...
@@ -539,6 +644,9 @@ void lnk_dump(void)
...
@@ -539,6 +644,9 @@ void lnk_dump(void)
case
EXP_DARWIN_ID_SIG
:
case
EXP_DARWIN_ID_SIG
:
dump_darwin_id
(
bhdr
);
dump_darwin_id
(
bhdr
);
break
;
break
;
case
EXP_PROPERTYSTORAGE_SIG
:
dump_property_storage
(
bhdr
);
break
;
default:
default:
dump_raw_block
(
bhdr
);
dump_raw_block
(
bhdr
);
}
}
...
...
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