ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/Deliantra/res2pm
(Generate patch)

Comparing deliantra/Deliantra/res2pm (file contents):
Revision 1.5 by root, Wed Feb 22 22:36:45 2006 UTC vs.
Revision 1.14 by elmex, Fri Mar 19 23:11:43 2010 UTC

1#!/opt/bin/perl 1#!/opt/bin/perl
2 2
3# usage: res2pm 3# usage: res2pm
4 4
5open STDOUT, ">:utf8", "Crossfire/Data.pm" 5open STDOUT, ">:utf8", "Deliantra/Data.pm"
6 or die "Crossfire/Data.pm: $!"; 6 or die "Deliantra/Data.pm: $!";
7 7
8print <<EOF; 8print <<EOF;
9=head1 NAME 9=head1 NAME
10 10
11Crossfire::Data - various data structures useful for understanding archs and objects 11Deliantra::Data - various data structures useful for understanding archs and objects
12 12
13=head1 13=head1
14 14
15THIS FILE IS AUTOGENERATED, DO NOT EDIT! 15THIS FILE IS AUTOGENERATED, DO NOT EDIT!
16 16
22 22
23See F<res/README> for more info. 23See F<res/README> for more info.
24 24
25=cut 25=cut
26 26
27package Crossfire::Data; 27package Deliantra::Data;
28 28
29EOF 29EOF
30 30
31use Data::Dumper; 31use Data::Dumper;
32use XML::Grove::Builder;
32use XML::Parser::Grove; 33use XML::Parser::PerlSAX;
34
33 35
34sub dump_hash { 36sub dump_hash {
35 my ($names, $refs) = @_; 37 my ($names, $refs) = @_;
36 38
37 $d = new Data::Dumper ($refs, [map "*$_", @$names]); 39 $d = new Data::Dumper ($refs, [map "*$_", @$names]);
62 64
63 print "our $sigil$name = $v;\n\n"; 65 print "our $sigil$name = $v;\n\n";
64 } 66 }
65} 67}
66 68
67my $type = XML::Parser->new (Style => 'grove')->parsefile ("res/types.xml"); 69my $grove_builder = XML::Grove::Builder->new;
70my $parser = XML::Parser::PerlSAX->new ( Handler => $grove_builder );
71my $type = $parser->parse ( Source => { SystemId => "res/types.xml" } );
68 72
69my %bitmask; 73my %bitmask;
70my %list; 74my %list;
71my %type; 75my %type;
72my %typename; 76my %typename;
75my %ignore_list; 79my %ignore_list;
76my %default_attr; 80my %default_attr;
77my %spell; 81my %spell;
78 82
79sub string($) { 83sub string($) {
80 local $_ = join "", @{shift->contents}; 84 local $_ = join "", map $_->{Data}, @{shift->{Contents}};
81 $_ =~ s/^\s+//; 85 $_ =~ s/^\s+//;
82 $_ =~ s/\s+$//; 86 $_ =~ s/\s+$//;
83 $_ =~ s/\s+/ /g; 87 $_ =~ s/\s+/ /g;
84 $_ 88 $_
85} 89}
86 90
87sub parse_attr { 91sub parse_attr {
88 my ($e, $sect) = @_; 92 my ($e, $sect) = @_;
89 93
90 my $arch = { 94 my $arch = {
91 type => $e->attr ("type"), 95 type => $e->{Attributes}->{type},
92 name => $e->attr ("editor"), 96 name => $e->{Attributes}->{editor},
93 desc => string $e, 97 desc => string $e,
94 $e->attr("arch_begin") ? (end => $e->attr("arch_end")) : (), 98 $e->{Attributes}->{arch_begin} ? (end => $e->{Attributes}->{arch_end}) : (),
95 }; 99 };
96 100
97 delete $arch->{name} unless defined $arch->{name}; 101 delete $arch->{name} unless defined $arch->{name};
98 delete $arch->{desc} unless length $arch->{desc}; 102 delete $arch->{desc} unless length $arch->{desc};
99 103
100 if ($arch->{type} =~ s/^(bitmask)_(.*)/$1/) { 104 if ($arch->{type} =~ s/^(bitmask)_(.*)/$1/) {
101 $arch->{value} = $bitmask{$2} ||= {}; 105 $arch->{value} = $bitmask{$2} ||= {};
102 } elsif ($arch->{type} =~ s/^(list)_(.*)/$1/) { 106 } elsif ($arch->{type} =~ s/^(list)_(.*)/$1/) {
103 $arch->{value} = $list{$2} ||= {}; 107 $arch->{value} = $list{$2} ||= {};
108 } elsif ($arch->{type} eq "fixed") {
109 $arch->{value} = $e->{Attributes}->{value};
104 } elsif ($arch->{type} =~ s/^bool_special$/bool/) { 110 } elsif ($arch->{type} =~ s/^bool_special$/bool/) {
105 $arch->{value} = [$e->attr ("false"), $e->attr ("true")]; 111 $arch->{value} = [$e->{Attributes}->{false}, $e->{Attributes}->{true}];
106 } 112 }
107 113
108 $sect->{$e->attr ("arch") || $e->attr("arch_begin")} = $arch; 114 push @$sect, [$e->{Attributes}->{arch} || $e->{Attributes}->{arch_begin}, $arch];
109} 115}
110 116
111sub parse_type { 117sub parse_type {
112 my ($e, $type) = @_; 118 my ($e, $type) = @_;
113 119
114 my %main; 120 my %main;
115 121
116 for my $e (grep ref, @{$e->contents}) { 122 for my $e (grep { $_->isa ('XML::Grove::Element') } @{$e->{Contents}}) {
117 if ($e->name eq "required") { 123 if ($e->{Name} eq "required") {
118 for my $i (grep ref, @{$e->contents}) { 124 # not used
119 $type->{required}{$i->attr ("arch")} = $i->attr ("value"); 125 #for my $i (grep $_->isa ('XML::Grove::Element'), @{$e->{Contents}}) {
126 # $type->{required}{$i->{Attributes}->{arch}} = $i->{Attributes}->{value};
120 } 127 #}
121 } elsif ($e->name eq "attribute") { 128 } elsif ($e->{Name} eq "attribute") {
122 parse_attr $e, $type->{attr} ||= {}; 129 parse_attr $e, $type->{attr} ||= [];
123 } elsif ($e->name eq "ignore") { 130 } elsif ($e->{Name} eq "ignore") {
124 for my $i (grep ref, @{$e->contents}) { 131 for my $i (grep $_->isa ('XML::Grove::Element'), @{$e->{Contents}}) {
125 if ($i->name eq "ignore_list") { 132 if ($i->{Name} eq "ignore_list") {
126 push @{$type->{ignore}}, $ignore_list{$i->attr ("name")} ||= []; 133 push @{$type->{ignore}}, $ignore_list{$i->{Attributes}->{name}} ||= [];
127 } elsif ($i->name eq "attribute") { 134 } elsif ($i->{Name} eq "attribute") {
128 push @{$type->{ignore}}, $i->attr ("arch"); 135 push @{$type->{ignore}}, $i->{Attributes}->{arch};
129 } 136 }
130 } 137 }
131 } elsif ($e->name eq "import_type") { 138 } elsif ($e->{Name} eq "import_type") {
132 push @{$type->{import}}, $type{$e->attr ("name")} ||= {}; 139 #push @{$type->{import}}, $type{$e->{Attributes}->{name}} ||= {};
140 push @{$type->{import}}, $e->{Attributes}->{name};
133 } elsif ($e->name eq "use") { 141 } elsif ($e->{Name} eq "use") {
134 $type->{use} = string $e; 142 $type->{use} = string $e;
135 } elsif ($e->name eq "description") { 143 } elsif ($e->{Name} eq "description") {
136 $type->{desc} = string $e; 144 $type->{desc} = string $e;
137 } elsif ($e->name eq "section") { 145 } elsif ($e->{Name} eq "section") {
138 my %attr; 146 my @attr;
139 for my $i (grep ref, @{$e->contents}) { 147 for my $i (grep $_->isa ('XML::Grove::Element'), @{$e->{Contents}}) {
140 parse_attr $i, \%attr; 148 parse_attr $i, \@attr;
141 } 149 }
142 push @{ $type->{section} }, [$e->attr ("name") => \%attr]; 150 push @{ $type->{section} }, [$e->{Attributes}->{name} => \@attr];
143 } else { 151 } else {
144 warn "unknown types subelement ", $e->name; 152 warn "unknown types subelement ", $e->{Name};
145 } 153 }
146 } 154 }
147 155
148 $type 156 $type
149} 157}
150 158
151for my $e (grep ref, @{$type->root->contents}) { 159for my $e (grep $_->isa ('XML::Grove::Element'), @{$type->root->{Contents}}) {
152 if ($e->name eq "bitmask") { 160 if ($e->{Name} eq "bitmask") {
153 my $bm = $bitmask{$e->attr ("name")} ||= {}; 161 my $bm = $bitmask{$e->{Attributes}->{name}} ||= {};
154 for my $b (grep ref, @{$e->contents}) { 162 for my $b (grep $_->isa ('XML::Grove::Element'), @{$e->{Contents}}) {
155 $bm->{$b->attr ("bit")} = $b->attr ("name"); 163 $bm->{$b->{Attributes}->{bit}} = $b->{Attributes}->{name};
156 } 164 }
157 } elsif ($e->name eq "list") { 165 } elsif ($e->{Name} eq "list") {
158 my $list = $list{$e->attr ("name")} ||= {}; 166 my $list = $list{$e->{Attributes}->{name}} ||= {};
159 for my $b (grep ref, @{$e->contents}) { 167 for my $b (grep $_->isa ('XML::Grove::Element'), @{$e->{Contents}}) {
160 $list->{$b->attr ("value")} = $b->attr ("name"); 168 $list->{$b->{Attributes}->{value}} = $b->{Attributes}->{name};
161 } 169 }
162 } elsif ($e->name eq "ignore_list") { 170 } elsif ($e->{Name} eq "ignore_list") {
163 my $list = $ignore_list{$e->attr ("name")} ||= []; 171 my $list = $ignore_list{$e->{Attributes}->{name}} ||= [];
164 for my $b (grep ref, @{$e->contents}) { 172 for my $b (grep $_->isa ('XML::Grove::Element'), @{$e->{Contents}}) {
165 push @$list, $b->attr ("arch"); 173 push @$list, $b->{Attributes}->{arch};
166 } 174 }
167 } elsif ($e->name eq "default_type") { 175 } elsif ($e->{Name} eq "default_type") {
168 parse_type $e, \%default_attr; 176 parse_type $e, \%default_attr;
169 } elsif ($e->name eq "type") { 177 } elsif ($e->{Name} eq "type") {
170 my $type = $type{$e->attr ("name")} ||= {}; 178 my $type = $type{$e->{Attributes}->{name}} ||= {};
179
180 $type->{name} = $e->{Attributes}->{name};
181
171 parse_type $e, $type; 182 parse_type $e, $type;
172 #unshift @{$type->{import}}, \%default_attr;
173 183
174 if ($e->attr ("number") > 0) { 184 if ($e->{Attributes}->{number} > 0) {
175 $attr{$e->attr ("number")} = $type; 185 $attr{$e->{Attributes}->{number}} = $type;
176 } elsif ($e->attr ("name") eq "Misc") { 186 } elsif ($e->{Attributes}->{name} eq "Misc") {
177 delete $type->{required}; 187 delete $type->{required};
178 } else { 188 } else {
179 push @attr0, $type; 189 push @attr0, $type;
180 } 190 }
181 191
182 } else { 192 } else {
183 warn "unknown types element ", $e->name; 193 warn "unknown types element ", $e->{Name};
184 } 194 }
185} 195}
186 196
187my $type = XML::Parser->new (Style => 'grove')->parsefile ("res/typenumbers.xml"); 197my $type = $parser->parse ( Source => { SystemId => "res/typenumbers.xml" } );
188 198
189for (grep ref, @{$type->root->contents}) { 199for (grep $_->isa ('XML::Grove::Element'), @{$type->root->{Contents}}) {
190 $typename{$_->attr ("number")} = $_->attr ("name"); 200 $typename{$_->{Attributes}->{number}} = $_->{Attributes}->{name};
191} 201}
192 202
193my $spell = XML::Parser->new (Style => 'grove')->parsefile ("res/spells.xml") 203my $spell = $parser->parse ( Source => { SystemId => "res/spells.xml" } )
194 or die; 204 or die;
195 205
196for (grep ref, @{$spell->root->contents}) { 206for (grep $_->isa ('XML::Grove::Element'), @{$spell->root->{Contents}}) {
197 $spell{$_->attr ("id")} = $_->attr ("name"); 207 $spell{$_->{Attributes}->{id}} = $_->{Attributes}->{name};
198} 208}
199 209
200dump_hash ["BITMASK", "LIST", "IGNORE_LIST", "DEFAULT_ATTR", "TYPE", "ATTR0", "ATTR", "TYPENAME", "SPELL"], 210dump_hash ["BITMASK", "LIST", "IGNORE_LIST", "DEFAULT_ATTR", "TYPE", "ATTR", "TYPENAME", "SPELL"],
201 [\%bitmask, \%list, \%ignore_list, \%default_attr, \%type, \@attr0, \%attr, \%typename, \%spell]; 211 [\%bitmask, \%list, \%ignore_list, \%default_attr, \%type, \%attr, \%typename, \%spell];
202 212
203print <<EOF; 213print <<EOF;
204 214
205=head1 AUTHOR 215=head1 AUTHOR
206 216

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines