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

Comparing deliantra/Deliantra/Deliantra.pm (file contents):
Revision 1.110 by root, Mon May 28 21:33:28 2007 UTC vs.
Revision 1.116 by root, Thu Nov 8 01:21:54 2007 UTC

4 4
5=cut 5=cut
6 6
7package Crossfire; 7package Crossfire;
8 8
9our $VERSION = '0.99'; 9our $VERSION = '1.11';
10 10
11use strict; 11use strict;
12 12
13use base 'Exporter'; 13use base 'Exporter';
14 14
16use File::Spec; 16use File::Spec;
17use List::Util qw(min max); 17use List::Util qw(min max);
18use Storable qw(freeze thaw); 18use Storable qw(freeze thaw);
19 19
20our @EXPORT = qw( 20our @EXPORT = qw(
21 read_pak read_arch *ARCH TILESIZE $TILE *FACE editor_archs arch_extents 21 read_pak read_arch
22 *ARCH $TILE *FACE *FACEDATA
23 TILESIZE CACHESTRIDE
24 editor_archs arch_extents
22); 25);
23 26
24use JSON::XS qw(from_json to_json); 27use JSON::XS qw(from_json to_json);
25 28
26our $LIB = $ENV{CROSSFIRE_LIBDIR}; 29our $LIB = $ENV{CROSSFIRE_LIBDIR};
29 : $ENV{AppData} ? "$ENV{APPDATA}/crossfire" 32 : $ENV{AppData} ? "$ENV{APPDATA}/crossfire"
30 : File::Spec->tmpdir . "/crossfire"; 33 : File::Spec->tmpdir . "/crossfire";
31 34
32mkdir $VARDIR, 0777; 35mkdir $VARDIR, 0777;
33 36
34sub TILESIZE (){ 32 } 37sub TILESIZE (){ 32 }
38sub CACHESTRIDE (){ 64 }
35 39
36our %ARCH; 40our %ARCH;
41our %FACE; # face32
37our %FACE; 42our %FACEDATA;
38our $TILE; 43our $TILE;
39 44
40our %FIELD_MULTILINE = ( 45our %FIELD_MULTILINE = (
41 msg => "endmsg", 46 msg => "endmsg",
42 lore => "endlore", 47 lore => "endlore",
803 808
804 my (%ignore); 809 my (%ignore);
805 my (@section_order, %section, @attr_order); 810 my (@section_order, %section, @attr_order);
806 811
807 while (my $type = shift @import) { 812 while (my $type = shift @import) {
813 push @import,
814 grep $_,
815 map $Crossfire::Data::TYPE{$_},
808 push @import, @{$type->{import} || []}; 816 @{$type->{import} || []};
809 817
810 $attr->{$_} ||= $type->{$_} 818 $attr->{$_} ||= $type->{$_}
811 for qw(name desc use); 819 for qw(name desc use);
812 820
813 for (@{$type->{ignore} || []}) { 821 for (@{$type->{ignore} || []}) {
902} 910}
903 911
904sub construct_tilecache_pb { 912sub construct_tilecache_pb {
905 my ($idx, $cache) = @_; 913 my ($idx, $cache) = @_;
906 914
907 my $pb = new Gtk2::Gdk::Pixbuf "rgb", 1, 8, 64 * TILESIZE, TILESIZE * int +($idx + 63) / 64; 915 my $pb = new Gtk2::Gdk::Pixbuf "rgb", 1, 8, CACHESTRIDE * TILESIZE, TILESIZE * int +($idx + CACHESTRIDE - 1) / CACHESTRIDE;
908 916
909 while (my ($name, $tile) = each %$cache) { 917 while (my ($name, $tile) = each %$cache) {
910 my $tpb = delete $tile->{pb}; 918 my $tpb = delete $tile->{pb};
911 my $ofs = $tile->{idx}; 919 my $ofs = $tile->{idx};
912 920
913 for my $x (0 .. $tile->{w} - 1) { 921 for my $x (0 .. $tile->{w} - 1) {
914 for my $y (0 .. $tile->{h} - 1) { 922 for my $y (0 .. $tile->{h} - 1) {
915 my $idx = $ofs + $x + $y * $tile->{w}; 923 my $idx = $ofs + $x + $y * $tile->{w};
916 $tpb->copy_area ($x * TILESIZE, $y * TILESIZE, TILESIZE, TILESIZE, 924 $tpb->copy_area ($x * TILESIZE, $y * TILESIZE, TILESIZE, TILESIZE,
917 $pb, ($idx % 64) * TILESIZE, TILESIZE * int $idx / 64); 925 $pb, ($idx % CACHESTRIDE) * TILESIZE, TILESIZE * int $idx / CACHESTRIDE);
918 } 926 }
919 } 927 }
920 } 928 }
921 929
922 $pb->save ("$VARDIR/tilecache.png", "png", compression => 1); 930 $pb->save ("$VARDIR/tilecache.png", "png", compression => 1);
938=cut 946=cut
939 947
940sub load_tilecache() { 948sub load_tilecache() {
941 require Gtk2; 949 require Gtk2;
942 950
943 if (-e "$LIB/crossfire.0") { # Crossfire1 version
944 cache_file "$LIB/crossfire.0", "$VARDIR/tilecache.pst", \&use_tilecache,
945 sub {
946 my $tile = read_pak "$LIB/crossfire.0";
947
948 my %cache;
949
950 my $idx = 0;
951
952 for my $name (sort keys %$tile) {
953 my $pb = new Gtk2::Gdk::PixbufLoader;
954 $pb->write ($tile->{$name});
955 $pb->close;
956 my $pb = $pb->get_pixbuf;
957
958 my $tile = $cache{$name} = {
959 pb => $pb,
960 idx => $idx,
961 w => int $pb->get_width / TILESIZE,
962 h => int $pb->get_height / TILESIZE,
963 };
964
965 $idx += $tile->{w} * $tile->{h};
966 }
967
968 construct_tilecache_pb $idx, \%cache;
969
970 \%cache
971 };
972
973 } else { # Crossfire+ version
974 cache_file "$LIB/facedata", "$VARDIR/tilecache.pst", \&use_tilecache, 951 cache_file "$LIB/facedata", "$VARDIR/tilecache.pst", \&use_tilecache,
975 sub { 952 sub {
976 my %cache; 953 my %cache;
977 my $facedata = Storable::retrieve "$LIB/facedata"; 954 my $facedata = Storable::retrieve "$LIB/facedata";
978 955
979 $facedata->{version} == 2 956 $facedata->{version} == 2
980 or die "$LIB/facedata: version mismatch, cannot proceed."; 957 or die "$LIB/facedata: version mismatch, cannot proceed.";
981 958
982 my $faces = $facedata->{faceinfo}; 959 my $faces = $facedata->{faceinfo};
983 my $idx = 0; 960 my $idx = 0;
984 961
985 for (sort keys %$faces) { 962 for (sort keys %$faces) {
986 my ($face, $info) = ($_, $faces->{$_}); 963 my ($face, $info) = ($_, $faces->{$_});
987 964
988 my $pb = new Gtk2::Gdk::PixbufLoader; 965 my $pb = new Gtk2::Gdk::PixbufLoader;
989 $pb->write ($info->{data32}); 966 $pb->write ($info->{data32});
990 $pb->close; 967 $pb->close;
991 my $pb = $pb->get_pixbuf; 968 my $pb = $pb->get_pixbuf;
992 969
993 my $tile = $cache{$face} = { 970 my $tile = $cache{$face} = {
994 pb => $pb, 971 pb => $pb,
995 idx => $idx, 972 idx => $idx,
996 w => int $pb->get_width / TILESIZE, 973 w => int $pb->get_width / TILESIZE,
997 h => int $pb->get_height / TILESIZE, 974 h => int $pb->get_height / TILESIZE,
998 }; 975 };
999 976
1000 $idx += $tile->{w} * $tile->{h}; 977 $idx += $tile->{w} * $tile->{h};
1001 } 978 }
1002 979
1003 construct_tilecache_pb $idx, \%cache; 980 construct_tilecache_pb $idx, \%cache;
1004 981
1005 \%cache 982 \%cache
1006 }; 983 };
1007 }
1008} 984}
1009 985
1010=head1 AUTHOR 986=head1 AUTHOR
1011 987
1012 Marc Lehmann <schmorp@schmorp.de> 988 Marc Lehmann <schmorp@schmorp.de>
1016 http://www.ta-sa.org/ 992 http://www.ta-sa.org/
1017 993
1018=cut 994=cut
1019 995
10201 9961
997

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines