ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/gde/GCE/Util.pm
(Generate patch)

Comparing deliantra/gde/GCE/Util.pm (file contents):
Revision 1.4 by elmex, Sun Mar 12 23:32:58 2006 UTC vs.
Revision 1.15 by elmex, Sun Apr 2 17:57:37 2006 UTC

15use Storable; 15use Storable;
16use List::Util qw(min max); 16use List::Util qw(min max);
17 17
18use Crossfire; 18use Crossfire;
19use Crossfire::MapWidget; 19use Crossfire::MapWidget;
20use File::Spec::Functions;
21use Cwd 'abs_path';
20 22
21our @EXPORT = qw(insert_arch_stack_layer replace_arch_stack_layer new_arch_pb fill_pb_from_arch arch_is_floor stack_find_floor stack_find_wall stack_find arch_is_wall arch_is_monster add_table_widget); 23our @EXPORT = qw(insert_arch_stack_layer replace_arch_stack_layer new_arch_pb fill_pb_from_arch arch_is_floor stack_find_floor stack_find_wall stack_find arch_is_wall arch_is_monster add_table_widget quick_msg def arch_is_exit map2abs exit_paths pseudohtml2txt);
24
25sub pseudohtml2txt {
26 my ($html) = @_;
27
28 $html =~ s/<br\s*?\/?>/\n/gsi;
29 $html =~ s/<b>(.*?)<\/b>/_\1_/gsi;
30 $html =~ s/<\/?\s*li>//gi;
31 $html =~ s/<\/?\s*ul>//gi;
32 $html =~ s/&gt;/>/g;
33 $html =~ s/&lt;/</g;
34 $html
35}
36
37sub exit_paths {
38 my ($mappath, $map1path, $map2path) = @_;
39 $mappath = abs_path $mappath;
40 $map1path = abs_path $map1path;
41 $map2path = abs_path $map2path;
42
43 if ( (substr $map1path, 0, length $mappath) eq $mappath
44 and (substr $map2path, 0, length $mappath) eq $mappath) {
45 substr $map1path, 0, length $mappath, '';
46 substr $map2path, 0, length $mappath, '';
47
48 my ($v1, $d1, $f1) = File::Spec->splitpath ($map1path);
49 my ($v2, $d2, $f2) = File::Spec->splitpath ($map2path);
50
51 my @di1 = File::Spec->splitdir ($d1);
52 my @di2 = File::Spec->splitdir ($d2);
53
54 if ((defined $di1[1]) and (defined $di2[1]) and $di1[1] eq $di2[1]) {
55 my $m1 = File::Spec->abs2rel ($map1path, File::Spec->catdir (@di2));
56 my $m2 = File::Spec->abs2rel ($map2path, File::Spec->catdir (@di1));
57 return ($m1, $m2);
58 } else {
59 return ($map1path, $map2path);
60 }
61 } else {
62 return ('', '');
63 }
64}
65
66sub map2abs {
67 my ($dest, $mape) = @_;
68
69 my $dir;
70 if (File::Spec->file_name_is_absolute($dest)) {
71 $dir = catdir ($::CFG->{MAPDIR}, $dest);
72 } else {
73 my ($v, $p, $f) = File::Spec->splitpath ($mape->{path});
74 $dir = File::Spec->rel2abs ($dest, File::Spec->catpath ($v, $p));
75 }
76 return $dir;
77}
78
79sub def($$) {
80 return defined ($_[0]) ? $_[0] : $_[1];
81}
82
83sub quick_msg {
84 my $wid = shift;
85 my $msg;
86 my $win = $::MAINWIN;
87 if (ref $wid) {
88 $win = $wid;
89 $msg = shift;
90 } else {
91 $msg = $wid;
92 }
93 my $dia = Gtk2::Dialog->new ('Message', $win, 'destroy-with-parent', 'gtk-ok' => 'none');
94
95 my $lbl = Gtk2::Label->new ($msg);
96 $dia->vbox->add ($lbl);
97 $dia->signal_connect (response => sub { $_[0]->destroy });
98
99 unless (defined $_[0]) {
100 Glib::Timeout->add (1000, sub { $dia->destroy; 0 });
101 }
102
103 $dia->show_all;
104}
22 105
23sub new_arch_pb { 106sub new_arch_pb {
24 # this is awful, is this really the best way? 107 # this is awful, is this really the best way?
25 my $pb = new Gtk2::Gdk::Pixbuf 'rgb', 1, 8, TILESIZE, TILESIZE; 108 my $pb = new Gtk2::Gdk::Pixbuf 'rgb', 1, 8, TILESIZE, TILESIZE;
26 return $pb; 109 return $pb;
27} 110}
28 111
29sub fill_pb_from_arch { 112sub fill_pb_from_arch {
30 my ($pb, $arch) = @_; 113 my ($pb, $a) = @_;
114
115 my $o = $Crossfire::ARCH{$a->{_name}};
116 my $face = $Crossfire::FACE{$a->{face} || $o->{face} || "blank.111"}
117 or warn "no gfx found for arch '$a->{_name}' at ($x|$y)\n";
118
119 $face or return;
31 120
32 $pb->fill (0x00000000); 121 $pb->fill (0x00000000);
33 $TILE->composite ($pb, 122 $TILE->composite ($pb,
34 0, 0, 123 0, 0,
35 TILESIZE, TILESIZE, 124 TILESIZE, TILESIZE,
36 - ($arch->{_face} % 64) * TILESIZE, - TILESIZE * int $arch->{_face} / 64, 125 - ($face->{idx} % 64) * TILESIZE, - TILESIZE * int $face->{idx} / 64,
37 1, 1, 'nearest', 255 126 1, 1, 'nearest', 255
38 ); 127 );
39} 128}
40 129
41sub classify_arch_layer { 130sub classify_arch_layer {
53 142
54 return 'between'; 143 return 'between';
55 } 144 }
56} 145}
57 146
147sub arch_is_exit {
148 my ($a) = @_;
149 my $type = $Crossfire::ARCH{$a->{_name}}->{type};
150 return $type eq '66' || $type eq '41';
151}
152
58sub arch_is_floor { 153sub arch_is_floor {
59 my ($a) = @_; 154 my ($a) = @_;
155 my $ar = Crossfire::arch_attr $a;
156 return (substr $ar->{name}, 0, 5) eq 'Floor';
60 return $Crossfire::ARCH{$a->{_name}}->{is_floor}; 157#return $Crossfire::ARCH{$a->{_name}}->{is_floor};
61} 158}
62 159
63sub arch_is_wall { 160sub arch_is_wall {
64 my ($a) = @_; 161 my ($a) = @_;
162 my $ar = Crossfire::arch_attr $a;
163 return $ar->{name} eq 'Wall';
65 return $Crossfire::ARCH{$a->{_name}}->{no_pass}; 164#return $Crossfire::ARCH{$a->{_name}}->{no_pass};
66} 165}
67 166
68sub arch_is_monster { 167sub arch_is_monster {
69 my ($a) = @_; 168 my ($a) = @_;
70 my $arch = $Crossfire::ARCH{$a->{_name}}; 169 my $arch = $Crossfire::ARCH{$a->{_name}};

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines