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.38 by root, Sun May 14 22:24:14 2006 UTC vs.
Revision 1.70 by root, Fri Jan 26 13:09:05 2007 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*** microsoft compatibility forced us to only support manual configuration 10*** opengl 1.1 is required to run this client
6*** by editing Makefile.PL. complain to microsoft. 11*** opengl 1.2 is recommended to run this client
12*** opengl 2.0 helps some more....
7 13
8*** opengl 1.2 is required to run this client 14*** other dependencies:
15*** pango-1.12.3, glib-2.10
16*** libsdl, libSDL_mixer, libSDL_image
17
18*** Pod::POM, Compress::LZF, BerkeleyDB, Crossfire, Event, AnyEvent perl modules
9 19
10*** 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
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
11 26
12EOF 27EOF
13 28
14if ($^O =~ /win32/i or $^O =~ /mswin/) { 29if ($^O =~ /win32/i or $^O =~ /mswin/) {
15 warn "\ndo manual configuration by editing Makefile.PL, please\n\n"; 30 print <<EOF;
31*** microsoft compatibility forced us to only support manual configuration
32*** by editing Makefile.PL. complain to microsoft.
33
34EOF
16 $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 -I/gtk/include/cairo"; 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";
17 $LIBS = "-L/gtk/lib -lSDL -lSDL_image -lSDL_mixer -lpangoft2-1.0 -lpangocairo-1.0 -lpango-1.0 -lgobject-2.0 -lgmodule-2.0 -ldl -lglib-2.0 -lfreetype -lcairo -lfontconfig -lz -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",
18} else { 37} else {
19 $INC = join " ", qx<sdl-config --cflags>, qx<pkg-config pangoft2 --cflags>, qx<pkg-config pangocairo --cflags>; 38 $INC = join " ", qx<sdl-config --cflags>, qx<pkg-config pangoft2 --cflags>;
20 $LIBS = join " ", qx<sdl-config --libs>, "-lSDL_image -lSDL_mixer", qx<pkg-config pangoft2 --libs>, qx<pkg-config pangocairo --libs>; 39 $LIBS = join " ", qx<sdl-config --libs>, "-lSDL_image -lSDL_mixer", qx<pkg-config pangoft2 --libs>, "-lGL";
21 40
22 $INC =~ s/\n/ /g for $INC, $LIBS; 41 $INC =~ s/\n/ /g for $INC, $LIBS;
23} 42}
24 43
25WriteMakefile( 44WriteMakefile(
26 dist => { 45 dist => {
27 PREOP => 'pod2text CFClient.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 . ;',
28 COMPRESS => 'gzip -9v', 47 COMPRESS => 'gzip -9v',
29 SUFFIX => '.gz', 48 SUFFIX => '.gz',
30 }, 49 },
31 NAME => "CFClient", 50 NAME => "CFPlus",
32 INC => $INC, 51 INC => $INC,
33 LIBS => [$LIBS], 52 LIBS => [$LIBS],
34 EXE_FILES => [qw(bin/pclient)], 53 EXE_FILES => [qw(bin/cfplus)],
35 VERSION_FROM => "CFClient.pm", 54 VERSION_FROM => "CFPlus.pm",
36 PREREQ_PM => { 55 PREREQ_PM => {
37 BerkeleyDB => 0.27, 56 BerkeleyDB => 0.27,
38 Crossfire => 0.1, 57 Crossfire => 0.96,
39 Time::HiRes => 0, 58 Time::HiRes => 0,
40 Event => 1.01, 59 Event => 1.07,
41 AnyEvent => 0, 60 AnyEvent => 0,
42 Compress::LZF => 1.6, 61 Compress::LZF => 1.6,
62 Pod::POM => 0.15,
43 }, 63 },
64 depend => {
65 "CFPlus.o" => 'glfunc.h pangoopengl.h pango-font.c pango-fontmap.c pango-render.c texcache.c',
66 },
67 clean => { FILES => 'docwiki.pst' },
44 PM => { 68 PM => {
45 'CFClient.pm' => '$(INST_LIBDIR)/CFClient.pm', 69 'CFPlus.pm' => '$(INST_LIBDIR)/CFPlus.pm',
70 'CFPlus/Protocol.pm' => '$(INST_LIBDIR)/CFPlus/Protocol.pm',
46 'CFClient/OpenGL.pm' => '$(INST_LIBDIR)/CFClient/OpenGL.pm', 71 'CFPlus/OpenGL.pm' => '$(INST_LIBDIR)/CFPlus/OpenGL.pm',
72 'CFPlus/Texture.pm' => '$(INST_LIBDIR)/CFPlus/Texture.pm',
47 'CFClient/UI.pm' => '$(INST_LIBDIR)/CFClient/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',
77 'CFPlus/Pod.pm' => '$(INST_LIBDIR)/CFPlus/Pod.pm',
48 'CFClient/MapWidget.pm' => '$(INST_LIBDIR)/CFClient/MapWidget.pm', 78 'CFPlus/MapWidget.pm' => '$(INST_LIBDIR)/CFPlus/MapWidget.pm',
79 'CFPlus/Macro.pm' => '$(INST_LIBDIR)/CFPlus/Macro.pm',
80 'docwiki.pst' => '$(INST_LIBDIR)/CFPlus/resources/docwiki.pst',
49 (map +($_ => "\$(INST_LIBDIR)/CFClient/$_"), 81 (map +($_ => "\$(INST_LIBDIR)/CFPlus/$_"), manifest_resources),
50 <resources/*.png>,
51 <resources/fonts/*.ttf>,
52 <resources/sounds/*.wav>,
53 <resources/sounds/*.ogg>,
54 <resources/sounds/config>,
55 <resources/music/*.ogg>,
56 <resources/ui/*.png>,
57 <resources/ui/resist/*.png>,
58 ),
59 } 82 }
60); 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