mirror of
https://github.com/samba-team/samba.git
synced 2025-01-11 05:18:09 +03:00
r4551: add support for a pidl extensions
'declare bitmap foo1;'
'declare enum foo2;'
and also allow
typedef [public] bitmap ...
typedef [public] enum ...
you need to a forward declaration of bitmaps and enums
when you want to use them in another idl file,
and you need to make the real declaration to be public
see the next commit to samr.idl and netlogon.idl
metze
(This used to be commit a8d61aa473
)
This commit is contained in:
parent
e159e42d84
commit
e3fd874341
@ -199,6 +199,19 @@ sub HeaderType($$$)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#####################################################################
|
||||||
|
# parse a declare
|
||||||
|
sub HeaderDeclare($)
|
||||||
|
{
|
||||||
|
my($declare) = shift;
|
||||||
|
|
||||||
|
if ($declare->{DATA}->{TYPE} eq "ENUM") {
|
||||||
|
util::enum_bitmap($declare, $declare->{NAME});
|
||||||
|
} elsif ($declare->{DATA}->{TYPE} eq "BITMAP") {
|
||||||
|
util::register_bitmap($declare, $declare->{NAME});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#####################################################################
|
#####################################################################
|
||||||
# parse a typedef
|
# parse a typedef
|
||||||
sub HeaderTypedef($)
|
sub HeaderTypedef($)
|
||||||
@ -237,6 +250,23 @@ sub HeaderTypedefProto($)
|
|||||||
$res .= "void ndr_print_$d->{NAME}(struct ndr_print *ndr, const char *name, int level, union $d->{NAME} *r);\n";
|
$res .= "void ndr_print_$d->{NAME}(struct ndr_print *ndr, const char *name, int level, union $d->{NAME} *r);\n";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($d->{DATA}{TYPE} eq "ENUM") {
|
||||||
|
$res .= "NTSTATUS ndr_push_$d->{NAME}(struct ndr_push *ndr, enum $d->{NAME} r);\n";
|
||||||
|
$res .= "NTSTATUS ndr_pull_$d->{NAME}(struct ndr_pull *ndr, enum $d->{NAME} *r);\n";
|
||||||
|
if (!util::has_property($d, "noprint")) {
|
||||||
|
$res .= "void ndr_print_$d->{NAME}(struct ndr_print *ndr, const char *name, enum $d->{NAME} r);\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($d->{DATA}{TYPE} eq "BITMAP") {
|
||||||
|
my $type_decl = util::bitmap_type_decl($d->{DATA});
|
||||||
|
$res .= "NTSTATUS ndr_push_$d->{NAME}(struct ndr_push *ndr, $type_decl r);\n";
|
||||||
|
$res .= "NTSTATUS ndr_pull_$d->{NAME}(struct ndr_pull *ndr, $type_decl *r);\n";
|
||||||
|
if (!util::has_property($d, "noprint")) {
|
||||||
|
$res .= "void ndr_print_$d->{NAME}(struct ndr_print *ndr, const char *name, $type_decl r);\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#####################################################################
|
#####################################################################
|
||||||
@ -431,6 +461,8 @@ sub HeaderInterface($)
|
|||||||
foreach my $d (@{$data}) {
|
foreach my $d (@{$data}) {
|
||||||
($d->{TYPE} eq "CONST") &&
|
($d->{TYPE} eq "CONST") &&
|
||||||
HeaderConst($d);
|
HeaderConst($d);
|
||||||
|
($d->{TYPE} eq "DECLARE") &&
|
||||||
|
HeaderDeclare($d);
|
||||||
($d->{TYPE} eq "TYPEDEF") &&
|
($d->{TYPE} eq "TYPEDEF") &&
|
||||||
HeaderTypedef($d);
|
HeaderTypedef($d);
|
||||||
($d->{TYPE} eq "TYPEDEF") &&
|
($d->{TYPE} eq "TYPEDEF") &&
|
||||||
@ -438,7 +470,7 @@ sub HeaderInterface($)
|
|||||||
($d->{TYPE} eq "FUNCTION") &&
|
($d->{TYPE} eq "FUNCTION") &&
|
||||||
HeaderFunction($d);
|
HeaderFunction($d);
|
||||||
($d->{TYPE} eq "FUNCTION") &&
|
($d->{TYPE} eq "FUNCTION") &&
|
||||||
HeaderFnProto($interface, $d);
|
HeaderFnProto($interface, $d);
|
||||||
}
|
}
|
||||||
|
|
||||||
(util::has_property($interface, "object")) &&
|
(util::has_property($interface, "object")) &&
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -55,7 +55,7 @@ definitions:
|
|||||||
;
|
;
|
||||||
|
|
||||||
|
|
||||||
definition: function | const | typedef
|
definition: function | const | typedef | declare
|
||||||
;
|
;
|
||||||
|
|
||||||
const: 'const' identifier identifier '=' anytext ';'
|
const: 'const' identifier identifier '=' anytext ';'
|
||||||
@ -86,6 +86,30 @@ function: property_list type identifier '(' element_list2 ')' ';'
|
|||||||
}}
|
}}
|
||||||
;
|
;
|
||||||
|
|
||||||
|
declare: 'declare' property_list decl_type identifier';'
|
||||||
|
{{
|
||||||
|
"TYPE" => "DECLARE",
|
||||||
|
"PROPERTIES" => $_[2],
|
||||||
|
"NAME" => $_[4],
|
||||||
|
"DATA" => $_[3],
|
||||||
|
}}
|
||||||
|
;
|
||||||
|
|
||||||
|
decl_type: decl_enum | decl_bitmap
|
||||||
|
;
|
||||||
|
|
||||||
|
decl_enum: 'enum'
|
||||||
|
{{
|
||||||
|
"TYPE" => "ENUM"
|
||||||
|
}}
|
||||||
|
;
|
||||||
|
|
||||||
|
decl_bitmap: 'bitmap'
|
||||||
|
{{
|
||||||
|
"TYPE" => "BITMAP"
|
||||||
|
}}
|
||||||
|
;
|
||||||
|
|
||||||
typedef: 'typedef' property_list type identifier array_len ';'
|
typedef: 'typedef' property_list type identifier array_len ';'
|
||||||
{{
|
{{
|
||||||
"TYPE" => "TYPEDEF",
|
"TYPE" => "TYPEDEF",
|
||||||
@ -327,7 +351,7 @@ again:
|
|||||||
if (s/^([\w_]+)//) {
|
if (s/^([\w_]+)//) {
|
||||||
$parser->YYData->{LAST_TOKEN} = $1;
|
$parser->YYData->{LAST_TOKEN} = $1;
|
||||||
if ($1 =~
|
if ($1 =~
|
||||||
/^(coclass|interface|const|typedef|union
|
/^(coclass|interface|const|typedef|declare|union
|
||||||
|struct|enum|bitmap|void|case|default)$/x) {
|
|struct|enum|bitmap|void|case|default)$/x) {
|
||||||
return $1;
|
return $1;
|
||||||
}
|
}
|
||||||
|
@ -1716,9 +1716,12 @@ sub ParseInterface($)
|
|||||||
my($data) = $interface->{DATA};
|
my($data) = $interface->{DATA};
|
||||||
|
|
||||||
foreach my $d (@{$data}) {
|
foreach my $d (@{$data}) {
|
||||||
|
if ($d->{TYPE} eq "DECLARE") {
|
||||||
|
$structs{$d->{NAME}} = $d;
|
||||||
|
}
|
||||||
if ($d->{TYPE} eq "TYPEDEF") {
|
if ($d->{TYPE} eq "TYPEDEF") {
|
||||||
$structs{$d->{NAME}} = $d;
|
$structs{$d->{NAME}} = $d;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach my $d (@{$data}) {
|
foreach my $d (@{$data}) {
|
||||||
|
Loading…
Reference in New Issue
Block a user