ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/Deliantra-Client/Makefile.PL
(Generate patch)

Comparing deliantra/Deliantra-Client/Makefile.PL (file contents):
Revision 1.56 by root, Sun Jul 30 13:14:15 2006 UTC vs.
Revision 1.69 by root, Tue Dec 12 14:46:21 2006 UTC

1use ExtUtils::MakeMaker; 1use ExtUtils::MakeMaker;
2
3sub manifest_resources {
4 open my $manifest, "MANIFEST" or die "Couldn't open MANIFEST: $!";
5 map { chomp; $_ } grep /^resources\//, <$manifest>
6}
2 7
3print <<EOF; 8print <<EOF;
4 9
5*** opengl 1.1 is required to run this client 10*** opengl 1.1 is required to run this client
6*** opengl 1.2 is recommended to run this client 11*** opengl 1.2 is recommended to run this client
12 17
13*** Pod::POM, Compress::LZF, BerkeleyDB, Crossfire, Event, AnyEvent perl modules 18*** Pod::POM, Compress::LZF, BerkeleyDB, Crossfire, Event, AnyEvent perl modules
14 19
15*** HINT: BerkeleyDB must be linked against version 4.3 or higher of libdb 20*** HINT: BerkeleyDB must be linked against version 4.3 or higher of libdb
16 21
22*** HINT: Debian/Ubuntu users might have luck with:
23*** apt-get install perl libpango1.0-dev libglib2.0-dev libsdl1.2-dev
24*** apt-get install libevent-perl libsdl-mixer1.2-dev libsdl-image1.2-dev
25*** apt-get install libberkeleydb-perl anyevent-perl
26
17EOF 27EOF
18 28
19if ($^O =~ /win32/i or $^O =~ /mswin/) { 29if ($^O =~ /win32/i or $^O =~ /mswin/) {
20 print <<EOF; 30 print <<EOF;
21*** microsoft compatibility forced us to only support manual configuration 31*** microsoft compatibility forced us to only support manual configuration
22*** by editing Makefile.PL. complain to microsoft. 32*** by editing Makefile.PL. complain to microsoft.
23 33
24EOF 34EOF
25 $INC = "-I/gtk/include -I/gtk/include/pango-1.0 -I/gtk/include/glib-2.0 -I/gtk/lib/glib-2.0/include/ -I/gtk/include/freetype2"; 35 $INC = "-I/gtk/include -I/gtk/include/pango-1.0 -I/gtk/include/glib-2.0 -I/gtk/lib/glib-2.0/include/ -I/gtk/include/freetype2";
26 $LIBS = "-L/gtk/lib -lSDL -lSDL_image -lSDL_mixer -lpango-1.0 -lpangoft2-1.0 -lgobject-2.0 -lgmodule-2.0 -lglib-2.0 -lfreetype -lfontconfig -lopengl32", 36 $LIBS = "-L/gtk/lib -lSDL -lSDL_image -lSDL_mixer -lpango-1.0 -lpangoft2-1.0 -lgobject-2.0 -lgmodule-2.0 -lglib-2.0 -lfreetype -lfontconfig -lopengl32 -lwininet",
27} else { 37} else {
28 $INC = join " ", qx<sdl-config --cflags>, qx<pkg-config pangoft2 --cflags>; 38 $INC = join " ", qx<sdl-config --cflags>, qx<pkg-config pangoft2 --cflags>;
29 $LIBS = join " ", qx<sdl-config --libs>, "-lSDL_image -lSDL_mixer", qx<pkg-config pangoft2 --libs>, "-lGL"; 39 $LIBS = join " ", qx<sdl-config --libs>, "-lSDL_image -lSDL_mixer", qx<pkg-config pangoft2 --libs>, "-lGL";
30 40
31 $INC =~ s/\n/ /g for $INC, $LIBS; 41 $INC =~ s/\n/ /g for $INC, $LIBS;
32} 42}
33 43
34WriteMakefile( 44WriteMakefile(
35 dist => { 45 dist => {
36 PREOP => 'pod2text CFPlus.pm | tee README >$(DISTVNAME)/README; chmod -R u=rwX,go=rX . ;', 46 PREOP => 'pod2text bin/cfplus | tee README >$(DISTVNAME)/README; chmod -R u=rwX,go=rX . ;',
37 COMPRESS => 'gzip -9v', 47 COMPRESS => 'gzip -9v',
38 SUFFIX => '.gz', 48 SUFFIX => '.gz',
39 }, 49 },
40 NAME => "CFPlus", 50 NAME => "CFPlus",
41 INC => $INC, 51 INC => $INC,
42 LIBS => [$LIBS], 52 LIBS => [$LIBS],
43 EXE_FILES => [qw(bin/cfplus)], 53 EXE_FILES => [qw(bin/cfplus)],
44 VERSION_FROM => "CFPlus.pm", 54 VERSION_FROM => "CFPlus.pm",
45 PREREQ_PM => { 55 PREREQ_PM => {
46 BerkeleyDB => 0.27, 56 BerkeleyDB => 0.27,
47 Crossfire => 0.1, 57 Crossfire => 0.95,
48 Time::HiRes => 0, 58 Time::HiRes => 0,
49 Event => 1.01, 59 Event => 1.07,
50 AnyEvent => 0, 60 AnyEvent => 0,
51 Compress::LZF => 1.6, 61 Compress::LZF => 1.6,
52 Pod::POM => 0.15, 62 Pod::POM => 0.15,
53 JSON::PC => 0.01,
54 }, 63 },
55 depend => { 64 depend => {
56 "CFPlus.o" => 'glfunc.h pangoopengl.h pango-font.c pango-fontmap.c pango-render.c texcache.c', 65 "CFPlus.o" => 'glfunc.h pangoopengl.h pango-font.c pango-fontmap.c pango-render.c texcache.c',
57 }, 66 },
67 clean => { FILES => 'docwiki.pst' },
58 PM => { 68 PM => {
59 'CFPlus.pm' => '$(INST_LIBDIR)/CFPlus.pm', 69 'CFPlus.pm' => '$(INST_LIBDIR)/CFPlus.pm',
60 'CFPlus/Protocol.pm' => '$(INST_LIBDIR)/CFPlus/Protocol.pm', 70 'CFPlus/Protocol.pm' => '$(INST_LIBDIR)/CFPlus/Protocol.pm',
61 'CFPlus/OpenGL.pm' => '$(INST_LIBDIR)/CFPlus/OpenGL.pm', 71 'CFPlus/OpenGL.pm' => '$(INST_LIBDIR)/CFPlus/OpenGL.pm',
62 'CFPlus/Texture.pm' => '$(INST_LIBDIR)/CFPlus/Texture.pm', 72 'CFPlus/Texture.pm' => '$(INST_LIBDIR)/CFPlus/Texture.pm',
63 'CFPlus/UI.pm' => '$(INST_LIBDIR)/CFPlus/UI.pm', 73 'CFPlus/UI.pm' => '$(INST_LIBDIR)/CFPlus/UI.pm',
74 'CFPlus/UI/Inventory.pm' => '$(INST_LIBDIR)/CFPlus/UI/Inventory.pm',
75 'CFPlus/UI/SpellList.pm' => '$(INST_LIBDIR)/CFPlus/UI/SpellList.pm',
76 'CFPlus/Item.pm' => '$(INST_LIBDIR)/CFPlus/Item.pm',
64 'CFPlus/Pod.pm' => '$(INST_LIBDIR)/CFPlus/Pod.pm', 77 'CFPlus/Pod.pm' => '$(INST_LIBDIR)/CFPlus/Pod.pm',
65 'CFPlus/MapWidget.pm' => '$(INST_LIBDIR)/CFPlus/MapWidget.pm', 78 'CFPlus/MapWidget.pm' => '$(INST_LIBDIR)/CFPlus/MapWidget.pm',
66 'CFPlus/BindingEditor.pm' => '$(INST_LIBDIR)/CFPlus/BindingEditor.pm', 79 'CFPlus/Macro.pm' => '$(INST_LIBDIR)/CFPlus/Macro.pm',
80 'docwiki.pst' => '$(INST_LIBDIR)/CFPlus/resources/docwiki.pst',
67 (map +($_ => "\$(INST_LIBDIR)/CFPlus/$_"), 81 (map +($_ => "\$(INST_LIBDIR)/CFPlus/$_"), manifest_resources),
68 <resources/*.png>,
69 <resources/fonts/*.ttf>,
70 <resources/sounds/*.wav>,
71 <resources/sounds/*.ogg>,
72 <resources/sounds/config>,
73 <resources/music/*.ogg>,
74 <resources/ui/*.png>,
75 <resources/ui/resist/*.png>,
76 <resources/pod/*.pod>,
77 <resources/pod/*.png>,
78 ),
79 } 82 }
80); 83);
84
85sub MY::postamble {
86 my $self = shift;
87
88 # try to add MANIFEST to CONFIGDEP
89 s/^CONFIGDEP = /CONFIGDEP = MANIFEST /m
90 for @{ $self->{RESULT} };
91
92 my $pods = join " ", <pod/*.pod>;
93
94 <<EOF
95
96all :: docwiki.pst
97
98docwiki.pst: bin/pod2wiki $pods
99 \$(PERL) -Mlib=. bin/pod2wiki $pods
100
101EOF
102}
103

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines