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
33250206
Commit
33250206
authored
Jun 13, 2007
by
Dan Hipschman
Committed by
Alexandre Julliard
Jun 14, 2007
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
widl: Handle wire_marshal pointer attributes.
parent
2bc8808b
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
67 additions
and
2 deletions
+67
-2
server.c
dlls/rpcrt4/tests/server.c
+40
-0
server.idl
dlls/rpcrt4/tests/server.idl
+17
-0
typegen.c
tools/widl/typegen.c
+10
-2
No files found.
dlls/rpcrt4/tests/server.c
View file @
33250206
...
@@ -238,6 +238,13 @@ s_dot_copy_vectors(vector_t u, vector_t v)
...
@@ -238,6 +238,13 @@ s_dot_copy_vectors(vector_t u, vector_t v)
return
u
.
x
*
v
.
x
+
u
.
y
*
v
.
y
+
u
.
z
*
v
.
z
;
return
u
.
x
*
v
.
x
+
u
.
y
*
v
.
y
+
u
.
z
*
v
.
z
;
}
}
int
s_square_test_us
(
test_us_t
*
tus
)
{
int
n
=
atoi
(
tus
->
us
.
x
);
return
n
*
n
;
}
void
void
s_stop
(
void
)
s_stop
(
void
)
{
{
...
@@ -432,14 +439,47 @@ puint_t_UserFree(ULONG *flags, puint_t *p)
...
@@ -432,14 +439,47 @@ puint_t_UserFree(ULONG *flags, puint_t *p)
HeapFree
(
GetProcessHeap
(),
0
,
*
p
);
HeapFree
(
GetProcessHeap
(),
0
,
*
p
);
}
}
ULONG
__RPC_USER
us_t_UserSize
(
ULONG
*
flags
,
ULONG
start
,
us_t
*
pus
)
{
return
start
+
sizeof
(
struct
wire_us
);
}
unsigned
char
*
__RPC_USER
us_t_UserMarshal
(
ULONG
*
flags
,
unsigned
char
*
buffer
,
us_t
*
pus
)
{
struct
wire_us
wus
;
wus
.
x
=
atoi
(
pus
->
x
);
memcpy
(
buffer
,
&
wus
,
sizeof
wus
);
return
buffer
+
sizeof
wus
;
}
unsigned
char
*
__RPC_USER
us_t_UserUnmarshal
(
ULONG
*
flags
,
unsigned
char
*
buffer
,
us_t
*
pus
)
{
struct
wire_us
wus
;
memcpy
(
&
wus
,
buffer
,
sizeof
wus
);
pus
->
x
=
HeapAlloc
(
GetProcessHeap
(),
0
,
10
);
sprintf
(
pus
->
x
,
"%d"
,
wus
.
x
);
return
buffer
+
sizeof
wus
;
}
void
__RPC_USER
us_t_UserFree
(
ULONG
*
flags
,
us_t
*
pus
)
{
HeapFree
(
GetProcessHeap
(),
0
,
pus
->
x
);
}
static
void
static
void
pointer_tests
(
void
)
pointer_tests
(
void
)
{
{
static
char
p1
[]
=
"11"
;
static
char
p1
[]
=
"11"
;
test_list_t
*
list
=
make_list
(
make_list
(
make_list
(
null_list
())));
test_list_t
*
list
=
make_list
(
make_list
(
make_list
(
null_list
())));
static
test_us_t
tus
=
{{
p1
}};
ok
(
test_list_length
(
list
)
==
3
,
"RPC test_list_length
\n
"
);
ok
(
test_list_length
(
list
)
==
3
,
"RPC test_list_length
\n
"
);
ok
(
square_puint
(
p1
)
==
121
,
"RPC square_puint
\n
"
);
ok
(
square_puint
(
p1
)
==
121
,
"RPC square_puint
\n
"
);
ok
(
square_test_us
(
&
tus
)
==
121
,
"RPC square_test_us
\n
"
);
free_list
(
list
);
free_list
(
list
);
}
}
...
...
dlls/rpcrt4/tests/server.idl
View file @
33250206
...
@@ -133,5 +133,22 @@ interface IServer
...
@@ -133,5 +133,22 @@ interface IServer
typedef [wire_marshal(int)] void *puint_t;
typedef [wire_marshal(int)] void *puint_t;
int square_puint(puint_t p);
int square_puint(puint_t p);
int dot_copy_vectors(vector_t u, vector_t v);
int dot_copy_vectors(vector_t u, vector_t v);
typedef struct wire_us *wire_us_t;
typedef [wire_marshal(wire_us_t)] struct us us_t;
struct us
{
void *x;
};
struct wire_us
{
int x;
};
typedef struct
{
us_t us;
} test_us_t;
int square_test_us(test_us_t *tus);
void stop(void);
void stop(void);
}
}
tools/widl/typegen.c
View file @
33250206
...
@@ -828,7 +828,7 @@ static int processed(const type_t *type)
...
@@ -828,7 +828,7 @@ static int processed(const type_t *type)
static
void
write_user_tfs
(
FILE
*
file
,
type_t
*
type
,
unsigned
int
*
tfsoff
)
static
void
write_user_tfs
(
FILE
*
file
,
type_t
*
type
,
unsigned
int
*
tfsoff
)
{
{
unsigned
int
start
,
absoff
;
unsigned
int
start
,
absoff
,
flags
;
unsigned
int
align
=
0
,
ualign
=
0
;
unsigned
int
align
=
0
,
ualign
=
0
;
const
char
*
name
;
const
char
*
name
;
type_t
*
utype
=
get_user_type
(
type
,
&
name
);
type_t
*
utype
=
get_user_type
(
type
,
&
name
);
...
@@ -854,11 +854,19 @@ static void write_user_tfs(FILE *file, type_t *type, unsigned int *tfsoff)
...
@@ -854,11 +854,19 @@ static void write_user_tfs(FILE *file, type_t *type, unsigned int *tfsoff)
absoff
=
utype
->
typestring_offset
;
absoff
=
utype
->
typestring_offset
;
}
}
if
(
utype
->
type
==
RPC_FC_RP
)
flags
=
0x40
;
else
if
(
utype
->
type
==
RPC_FC_UP
)
flags
=
0x80
;
else
flags
=
0
;
start
=
*
tfsoff
;
start
=
*
tfsoff
;
update_tfsoff
(
type
,
start
,
file
);
update_tfsoff
(
type
,
start
,
file
);
print_file
(
file
,
0
,
"/* %d */
\n
"
,
start
);
print_file
(
file
,
0
,
"/* %d */
\n
"
,
start
);
print_file
(
file
,
2
,
"0x%x,
\t
/* FC_USER_MARSHAL */
\n
"
,
RPC_FC_USER_MARSHAL
);
print_file
(
file
,
2
,
"0x%x,
\t
/* FC_USER_MARSHAL */
\n
"
,
RPC_FC_USER_MARSHAL
);
print_file
(
file
,
2
,
"0x%x,
\t
/* %d */
\n
"
,
align
-
1
,
align
-
1
);
print_file
(
file
,
2
,
"0x%x,
\t
/* Alignment= %d, Flags= %02x */
\n
"
,
flags
|
(
align
-
1
),
align
-
1
,
flags
);
print_file
(
file
,
2
,
"NdrFcShort(0x%hx),
\t
/* Function offset= %hu */
\n
"
,
funoff
,
funoff
);
print_file
(
file
,
2
,
"NdrFcShort(0x%hx),
\t
/* Function offset= %hu */
\n
"
,
funoff
,
funoff
);
print_file
(
file
,
2
,
"NdrFcShort(0x%lx),
\t
/* %lu */
\n
"
,
usize
,
usize
);
print_file
(
file
,
2
,
"NdrFcShort(0x%lx),
\t
/* %lu */
\n
"
,
usize
,
usize
);
print_file
(
file
,
2
,
"NdrFcShort(0x%lx),
\t
/* %lu */
\n
"
,
size
,
size
);
print_file
(
file
,
2
,
"NdrFcShort(0x%lx),
\t
/* %lu */
\n
"
,
size
,
size
);
...
...
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