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
18b1fe8d
Commit
18b1fe8d
authored
Jan 20, 2005
by
Huw Davies
Committed by
Alexandre Julliard
Jan 20, 2005
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
MIDL adds two sets of custom data to the library: one is a timestamp
and the second is MIDL's version number.
parent
4e59e4b9
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
53 additions
and
13 deletions
+53
-13
write_msft.c
tools/widl/write_msft.c
+53
-13
No files found.
tools/widl/write_msft.c
View file @
18b1fe8d
...
@@ -35,6 +35,7 @@
...
@@ -35,6 +35,7 @@
#include <stdarg.h>
#include <stdarg.h>
#include <stdio.h>
#include <stdio.h>
#include <ctype.h>
#include <ctype.h>
#include <time.h>
#define NONAMELESSUNION
#define NONAMELESSUNION
#define NONAMELESSSTRUCT
#define NONAMELESSSTRUCT
...
@@ -1056,9 +1057,8 @@ static int ctl2_find_nth_reference(
...
@@ -1056,9 +1057,8 @@ static int ctl2_find_nth_reference(
}
}
static
void
write_value
(
msft_type
info_t
*
typeinfo
,
int
*
out
,
var_t
*
arg
,
int
type
,
void
*
value
)
static
void
write_value
(
msft_type
lib_t
*
typelib
,
int
*
out
,
int
vt
,
void
*
value
)
{
{
int
vt
=
(
type
>>
16
)
&
0x1ff
;
switch
(
vt
)
{
switch
(
vt
)
{
case
VT_I2
:
case
VT_I2
:
case
VT_I4
:
case
VT_I4
:
...
@@ -1078,10 +1078,10 @@ static void write_value(msft_typeinfo_t* typeinfo, int *out, var_t *arg, int typ
...
@@ -1078,10 +1078,10 @@ static void write_value(msft_typeinfo_t* typeinfo, int *out, var_t *arg, int typ
*
out
|=
vt
<<
26
;
*
out
|=
vt
<<
26
;
*
out
|=
*
lv
;
*
out
|=
*
lv
;
}
else
{
}
else
{
int
offset
=
ctl2_alloc_segment
(
type
info
->
type
lib
,
MSFT_SEG_CUSTDATA
,
8
,
0
);
int
offset
=
ctl2_alloc_segment
(
typelib
,
MSFT_SEG_CUSTDATA
,
8
,
0
);
*
((
unsigned
short
*
)
&
type
info
->
type
lib
->
typelib_segment_data
[
MSFT_SEG_CUSTDATA
][
offset
])
=
vt
;
*
((
unsigned
short
*
)
&
typelib
->
typelib_segment_data
[
MSFT_SEG_CUSTDATA
][
offset
])
=
vt
;
memcpy
(
&
type
info
->
type
lib
->
typelib_segment_data
[
MSFT_SEG_CUSTDATA
][
offset
+
2
],
value
,
4
);
memcpy
(
&
typelib
->
typelib_segment_data
[
MSFT_SEG_CUSTDATA
][
offset
+
2
],
value
,
4
);
*
((
unsigned
short
*
)
&
type
info
->
type
lib
->
typelib_segment_data
[
MSFT_SEG_CUSTDATA
][
offset
+
6
])
=
0x5757
;
*
((
unsigned
short
*
)
&
typelib
->
typelib_segment_data
[
MSFT_SEG_CUSTDATA
][
offset
+
6
])
=
0x5757
;
*
out
=
offset
;
*
out
=
offset
;
}
}
return
;
return
;
...
@@ -1090,13 +1090,13 @@ static void write_value(msft_typeinfo_t* typeinfo, int *out, var_t *arg, int typ
...
@@ -1090,13 +1090,13 @@ static void write_value(msft_typeinfo_t* typeinfo, int *out, var_t *arg, int typ
{
{
char
*
s
=
(
char
*
)
value
;
char
*
s
=
(
char
*
)
value
;
int
len
=
strlen
(
s
),
seg_len
=
(
len
+
6
+
3
)
&
~
0x3
;
int
len
=
strlen
(
s
),
seg_len
=
(
len
+
6
+
3
)
&
~
0x3
;
int
offset
=
ctl2_alloc_segment
(
type
info
->
type
lib
,
MSFT_SEG_CUSTDATA
,
seg_len
,
0
);
int
offset
=
ctl2_alloc_segment
(
typelib
,
MSFT_SEG_CUSTDATA
,
seg_len
,
0
);
*
((
unsigned
short
*
)
&
type
info
->
type
lib
->
typelib_segment_data
[
MSFT_SEG_CUSTDATA
][
offset
])
=
vt
;
*
((
unsigned
short
*
)
&
typelib
->
typelib_segment_data
[
MSFT_SEG_CUSTDATA
][
offset
])
=
vt
;
*
((
unsigned
int
*
)
&
type
info
->
type
lib
->
typelib_segment_data
[
MSFT_SEG_CUSTDATA
][
offset
+
2
])
=
len
;
*
((
unsigned
int
*
)
&
typelib
->
typelib_segment_data
[
MSFT_SEG_CUSTDATA
][
offset
+
2
])
=
len
;
memcpy
(
&
type
info
->
type
lib
->
typelib_segment_data
[
MSFT_SEG_CUSTDATA
][
offset
+
6
],
value
,
len
);
memcpy
(
&
typelib
->
typelib_segment_data
[
MSFT_SEG_CUSTDATA
][
offset
+
6
],
value
,
len
);
len
+=
6
;
len
+=
6
;
while
(
len
<
seg_len
)
{
while
(
len
<
seg_len
)
{
*
((
char
*
)
&
type
info
->
type
lib
->
typelib_segment_data
[
MSFT_SEG_CUSTDATA
][
offset
+
len
])
=
0x57
;
*
((
char
*
)
&
typelib
->
typelib_segment_data
[
MSFT_SEG_CUSTDATA
][
offset
+
len
])
=
0x57
;
len
++
;
len
++
;
}
}
*
out
=
offset
;
*
out
=
offset
;
...
@@ -1109,6 +1109,36 @@ static void write_value(msft_typeinfo_t* typeinfo, int *out, var_t *arg, int typ
...
@@ -1109,6 +1109,36 @@ static void write_value(msft_typeinfo_t* typeinfo, int *out, var_t *arg, int typ
return
;
return
;
}
}
static
HRESULT
set_custdata
(
msft_typelib_t
*
typelib
,
REFGUID
guid
,
int
vt
,
void
*
value
,
int
*
offset
)
{
MSFT_GuidEntry
guidentry
;
int
guidoffset
;
int
custoffset
;
int
*
custdata
;
int
data_out
;
guidentry
.
guid
=
*
guid
;
guidentry
.
hreftype
=
-
1
;
guidentry
.
next_hash
=
-
1
;
guidoffset
=
ctl2_alloc_guid
(
typelib
,
&
guidentry
);
if
(
guidoffset
==
-
1
)
return
E_OUTOFMEMORY
;
write_value
(
typelib
,
&
data_out
,
vt
,
value
);
custoffset
=
ctl2_alloc_segment
(
typelib
,
MSFT_SEG_CUSTDATAGUID
,
12
,
0
);
if
(
custoffset
==
-
1
)
return
E_OUTOFMEMORY
;
custdata
=
(
int
*
)
&
typelib
->
typelib_segment_data
[
MSFT_SEG_CUSTDATAGUID
][
custoffset
];
custdata
[
0
]
=
guidoffset
;
custdata
[
1
]
=
data_out
;
custdata
[
2
]
=
*
offset
;
*
offset
=
custoffset
;
return
S_OK
;
}
static
HRESULT
add_func_desc
(
msft_typeinfo_t
*
typeinfo
,
func_t
*
func
)
static
HRESULT
add_func_desc
(
msft_typeinfo_t
*
typeinfo
,
func_t
*
func
)
{
{
int
offset
;
int
offset
;
...
@@ -1224,7 +1254,7 @@ static HRESULT add_func_desc(msft_typeinfo_t* typeinfo, func_t *func)
...
@@ -1224,7 +1254,7 @@ static HRESULT add_func_desc(msft_typeinfo_t* typeinfo, func_t *func)
expr_t
*
expr
=
(
expr_t
*
)
attr
->
u
.
pval
;
expr_t
*
expr
=
(
expr_t
*
)
attr
->
u
.
pval
;
paramflags
|=
0x30
;
/* PARAMFLAG_FHASDEFAULT | PARAMFLAG_FOPT */
paramflags
|=
0x30
;
/* PARAMFLAG_FHASDEFAULT | PARAMFLAG_FOPT */
chat
(
"default value %ld
\n
"
,
expr
->
cval
);
chat
(
"default value %ld
\n
"
,
expr
->
cval
);
write_value
(
typeinfo
,
defaultdata
,
arg
,
*
paramdata
,
&
expr
->
cval
);
write_value
(
typeinfo
->
typelib
,
defaultdata
,
(
*
paramdata
>>
16
)
&
0x1ff
,
&
expr
->
cval
);
break
;
break
;
}
}
case
ATTR_DEFAULTVALUE_STRING
:
case
ATTR_DEFAULTVALUE_STRING
:
...
@@ -1232,7 +1262,7 @@ static HRESULT add_func_desc(msft_typeinfo_t* typeinfo, func_t *func)
...
@@ -1232,7 +1262,7 @@ static HRESULT add_func_desc(msft_typeinfo_t* typeinfo, func_t *func)
char
*
s
=
(
char
*
)
attr
->
u
.
pval
;
char
*
s
=
(
char
*
)
attr
->
u
.
pval
;
paramflags
|=
0x30
;
/* PARAMFLAG_FHASDEFAULT | PARAMFLAG_FOPT */
paramflags
|=
0x30
;
/* PARAMFLAG_FHASDEFAULT | PARAMFLAG_FOPT */
chat
(
"default value '%s'
\n
"
,
s
);
chat
(
"default value '%s'
\n
"
,
s
);
write_value
(
typeinfo
,
defaultdata
,
arg
,
*
paramdata
,
s
);
write_value
(
typeinfo
->
typelib
,
defaultdata
,
(
*
paramdata
>>
16
)
&
0x1ff
,
s
);
break
;
break
;
}
}
case
ATTR_IN
:
case
ATTR_IN
:
...
@@ -1861,6 +1891,10 @@ int create_msft_typelib(typelib_t *typelib)
...
@@ -1861,6 +1891,10 @@ int create_msft_typelib(typelib_t *typelib)
msft_typelib_t
*
msft
;
msft_typelib_t
*
msft
;
int
failed
=
0
,
typelib_idx
;
int
failed
=
0
,
typelib_idx
;
typelib_entry_t
*
entry
;
typelib_entry_t
*
entry
;
time_t
cur_time
;
unsigned
int
version
=
5
<<
24
|
1
<<
16
|
164
;
/* 5.01.0164 */
GUID
midl_time_guid
=
{
0xde77ba63
,
0x517c
,
0x11d1
,{
0xa2
,
0xda
,
0x00
,
0x00
,
0xf8
,
0x77
,
0x3c
,
0xe9
}};
GUID
midl_version_guid
=
{
0xde77ba64
,
0x517c
,
0x11d1
,{
0xa2
,
0xda
,
0x00
,
0x00
,
0xf8
,
0x77
,
0x3c
,
0xe9
}};
msft
=
malloc
(
sizeof
(
*
msft
));
msft
=
malloc
(
sizeof
(
*
msft
));
if
(
!
msft
)
return
0
;
if
(
!
msft
)
return
0
;
...
@@ -1898,6 +1932,12 @@ int create_msft_typelib(typelib_t *typelib)
...
@@ -1898,6 +1932,12 @@ int create_msft_typelib(typelib_t *typelib)
set_help_string_dll
(
msft
);
set_help_string_dll
(
msft
);
set_help_string_context
(
msft
);
set_help_string_context
(
msft
);
/* midl adds two sets of custom data to the library: the current unix time
and midl's version number */
cur_time
=
time
(
NULL
);
set_custdata
(
msft
,
&
midl_time_guid
,
VT_UI4
,
&
cur_time
,
&
msft
->
typelib_header
.
CustomDataOffset
);
set_custdata
(
msft
,
&
midl_version_guid
,
VT_UI4
,
&
version
,
&
msft
->
typelib_header
.
CustomDataOffset
);
typelib_idx
=
0
;
typelib_idx
=
0
;
for
(
entry
=
typelib
->
entry
;
NEXT_LINK
(
entry
);
entry
=
NEXT_LINK
(
entry
))
for
(
entry
=
typelib
->
entry
;
NEXT_LINK
(
entry
);
entry
=
NEXT_LINK
(
entry
))
;
;
...
...
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