6 my($grid_Y_size)=225; # xfig
7 my($grid_X_size)=225; # xfig
14 open INPUT, $filename;
16 while (defined($line=<INPUT>)) {
19 my($event,$date,$id,$type,$father,@name) = split(/\s+/,$line);
21 $Cat{$id}{name}="@name ";
22 $Cat{$id}{name}=~s/\"//g;
23 $Cat{$id}{father}=$father;
24 $Cat{$id}{type}=$type;
25 $Cat{$id}{date}=$date;
34 my($filename,$Cat)=@_;
37 open INPUT, $filename;
39 while (defined($line=<INPUT>)) {
41 if($line =~ /^11\s/) {
42 my($event,$date,$type,$id,$state) = split(/\s+/,$line);
43 push @{$$Cat{$id}{state}}, [$date,$state];
45 if($line =~ /^12\s/) {
46 my($event,$date,$type,$id) = split(/\s+/,$line);
47 push @{$$Cat{$id}{state}}, [$date];
58 open INPUT, $filename;
60 while (defined($line=<INPUT>)) {
62 if($line =~ /^16\s/) {
63 my($event,$date,$type,$father,$channel,$src,$key) = split(/\s+/,$line);
64 $link{$key}{src}=$src;
65 $link{$key}{src_date}=$date;
67 if($line =~ /^17\s/) {
68 my($event,$date,$type,$father,$channel,$dst,$key) = split(/\s+/,$line);
69 $link{$key}{dst}=$dst;
70 $link{$key}{dst_date}=$date;
83 foreach $cat (keys %$Cat) {
84 if($$Cat{$cat}{father} eq $root) {
85 push @childs, build_cat_tree($cat,$Cat);
87 # print "$$Cat{$cat}{name}\t\t $Cat{$cat}{father}\n";
90 return [$root,@childs];
94 my($tree,$cat_list)=@_;
95 my($root) = shift @$tree;
98 push @$cat_list,$root;
100 foreach $u (@$tree) {
101 build_cat_list($u,$cat_list);
103 unshift @$tree, $root;
107 sub set_cat_position {
108 my($Cat,$cat_list)=@_;
111 foreach $cat (@$cat_list) {
112 $$Cat{$cat}{Y_min} = $i;
113 $$Cat{$cat}{Y_max} = $i+1;
121 $fig->{object} = 'compound'; # Compound
122 $fig->{elements} = [];
123 $fig->{version} = 3.2;
124 $fig->{orientation} = 'Landscape';
125 $fig->{justification} = 'Center';
126 $fig->{units} = 'Metric';
127 $fig->{papersize} = 'A4';
128 $fig->{magnification} = '100.00';
129 $fig->{multiplepage} = 'Single';
130 $fig->{transparent} = '-2';
131 $fig->{resolution} = '1200';
132 $fig->{coordsystem} = '2';
133 $fig->{filename} = $filename;
138 my($fig,$Cat,$Link)=@_;
140 foreach $cat (keys %$Cat) {
141 next unless (defined($$Cat{$cat}{Y_min}) &&
142 defined($$Cat{$cat}{Y_max}));
143 my($text) = new XFig ('text');
144 $text->{'text'} = $$Cat{$cat}{name};
145 $text->{'y'} = ($$Cat{$cat}{Y_min}+$$Cat{$cat}{Y_max})/2*$grid_Y_size+68;
148 foreach $cat (keys %$Cat) {
149 next unless (defined($$Cat{$cat}{Y_min}) &&
150 defined($$Cat{$cat}{Y_max}));
153 foreach $e (@{$$Cat{$cat}{state}}) {
154 my($new_date,$state) = ($$e[0],$$e[1]);
155 if(defined($state)) {
158 my($old_event) = pop @states;
159 my($old_date) = $$old_event[0];
160 $state = $$old_event[1];
162 my($line) = new XFig ('polyline');
164 $line->{'subtype'} = 1; # line
165 $line->{'points'} = [ [$old_date*$grid_X_size, $$Cat{$cat}{Y_min}*$grid_Y_size],
166 [$new_date*$grid_X_size, $$Cat{$cat}{Y_min}*$grid_Y_size],
167 [$new_date*$grid_X_size, $$Cat{$cat}{Y_max}*$grid_Y_size],
168 [$old_date*$grid_X_size, $$Cat{$cat}{Y_max}*$grid_Y_size] ];
169 $line->{'areafill'} = 20;
171 $line->{'fillcolor'} = 1;
172 } elsif ($state eq "E") {
173 $line->{'fillcolor'} = 2;
174 } elsif ($state eq "B") {
175 $line->{'fillcolor'} = 3;
176 } elsif ($state eq "C") {
177 $line->{'fillcolor'} = 4;
184 foreach $link (keys %$Link) {
185 my($line) = new XFig ('polyline');
186 my($src_date)=$$Link{$link}{src_date};
187 my($src)=$$Link{$link}{src};
188 my($dst_date)=$$Link{$link}{dst_date};
189 my($dst)=$$Link{$link}{dst};
190 $line->{'subtype'} = 1; # line
192 $line->{'points'} = [ [$src_date*$grid_X_size,
193 ($$Cat{$src}{Y_min}+$$Cat{$src}{Y_max})/2*$grid_Y_size],
194 [$dst_date*$grid_X_size,
195 ($$Cat{$dst}{Y_min}+$$Cat{$dst}{Y_max})/2*$grid_Y_size] ];
196 $line->{'forwardarrow'} = ['1', '1', '1.00', '60.00', '120.00'];
202 my($Cat) = read_cat($ARGV[0]);
203 my($cat_tree)=build_cat_tree("0",$Cat);
204 read_event($ARGV[0],$Cat);
205 my($Link)=read_link($ARGV[0]);
206 # print Dumper($cat_tree);
207 # print Dumper($Cat);
209 build_cat_list($cat_tree,$cat_list);
212 print "@$cat_list \n";
214 set_cat_position($Cat,$cat_list);
216 my($fig)=create_fig("toto.fig");
217 draw_cat($fig,$Cat,$Link);
219 system "fig2dev -L pdf toto.fig toto.pdf";