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.88 by root, Wed Dec 5 10:49:17 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, EV, 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 some luck with:
23*** apt-get install perl libpango1.0-dev libglib2.0-dev libsdl1.2-dev
24*** apt-get install libsdl-mixer1.2-dev libsdl-image1.2-dev
25*** apt-get install libberkeleydb-perl libwww-perl libdb4.4-dev
26*** apt-get install anyevent-perl
11 27
12EOF 28EOF
13 29
14if ($^O =~ /win32/i or $^O =~ /mswin/) { 30if ($^O =~ /win32/i or $^O =~ /mswin/) {
15 warn "\ndo manual configuration by editing Makefile.PL, please\n\n"; 31 print <<EOF;
32*** microsoft compatibility forced us to only support manual configuration
33*** by editing Makefile.PL. complain to microsoft.
34
35EOF
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"; 36 $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", 37 $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 { 38} else {
19 $INC = join " ", qx<sdl-config --cflags>, qx<pkg-config pangoft2 --cflags>, qx<pkg-config pangocairo --cflags>; 39 $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>; 40 $LIBS = join " ", qx<sdl-config --libs>, "-lSDL_image -lSDL_mixer", qx<pkg-config pangoft2 --libs>, "-lGL";
21 41
22 $INC =~ s/\n/ /g for $INC, $LIBS; 42 $INC =~ s/\n/ /g for $INC, $LIBS;
23} 43}
24 44
25WriteMakefile( 45WriteMakefile(
26 dist => { 46 dist => {
27 PREOP => 'pod2text CFClient.pm | tee README >$(DISTVNAME)/README; chmod -R u=rwX,go=rX . ;', 47 PREOP => 'pod2text bin/deliantra | tee README >$(DISTVNAME)/README; chmod -R u=rwX,go=rX . ;',
28 COMPRESS => 'gzip -9v', 48 COMPRESS => 'gzip -9v',
29 SUFFIX => '.gz', 49 SUFFIX => '.gz',
30 }, 50 },
31 NAME => "CFClient", 51 NAME => "CFPlus",
32 INC => $INC, 52 INC => $INC,
33 LIBS => [$LIBS], 53 LIBS => [$LIBS],
34 EXE_FILES => [qw(bin/pclient)], 54 EXE_FILES => [qw(bin/deliantra)],
35 VERSION_FROM => "CFClient.pm", 55 VERSION_FROM => "CFPlus.pm",
36 PREREQ_PM => { 56 PREREQ_PM => {
37 BerkeleyDB => 0.27, 57 BerkeleyDB => 0.27,
38 Crossfire => 0.1, 58 Crossfire => 1.1,
39 Time::HiRes => 0, 59 Time::HiRes => 0,
40 Event => 1.01, 60 EV => 0.9,
41 AnyEvent => 0, 61 AnyEvent => 2.6,
42 Compress::LZF => 1.6, 62 Compress::LZF => 1.6,
63 Pod::POM => 0.15,
64 LWP => 0,
65 JSON::XS => 2.01,
43 }, 66 },
67 depend => {
68 "CFPlus.o" => 'glfunc.h pangoopengl.h pango-font.c pango-fontmap.c pango-render.c texcache.c rendercache.c',
69 },
70 clean => { FILES => 'docwiki.pst' },
44 PM => { 71 PM => {
45 'CFClient.pm' => '$(INST_LIBDIR)/CFClient.pm', 72 'CFPlus.pm' => '$(INST_LIBDIR)/CFPlus.pm',
73 'CFPlus/Protocol.pm' => '$(INST_LIBDIR)/CFPlus/Protocol.pm',
46 'CFClient/OpenGL.pm' => '$(INST_LIBDIR)/CFClient/OpenGL.pm', 74 'CFPlus/OpenGL.pm' => '$(INST_LIBDIR)/CFPlus/OpenGL.pm',
75 'CFPlus/Texture.pm' => '$(INST_LIBDIR)/CFPlus/Texture.pm',
76 'CFPlus/DB.pm' => '$(INST_LIBDIR)/CFPlus/DB.pm',
47 'CFClient/UI.pm' => '$(INST_LIBDIR)/CFClient/UI.pm', 77 'CFPlus/UI.pm' => '$(INST_LIBDIR)/CFPlus/UI.pm',
78 'CFPlus/UI/Canvas.pm' => '$(INST_LIBDIR)/CFPlus/UI/Canvas.pm',
79 'CFPlus/UI/Dockable.pm' => '$(INST_LIBDIR)/CFPlus/UI/Dockable.pm',
80 'CFPlus/UI/Inventory.pm' => '$(INST_LIBDIR)/CFPlus/UI/Inventory.pm',
81 'CFPlus/UI/SpellList.pm' => '$(INST_LIBDIR)/CFPlus/UI/SpellList.pm',
82 'CFPlus/UI/Canvas.pm' => '$(INST_LIBDIR)/CFPlus/UI/Canvas.pm',
83 'CFPlus/UI/ChatView.pm' => '$(INST_LIBDIR)/CFPlus/UI/ChatView.pm',
84 'CFPlus/UI/MessageWindow.pm' => '$(INST_LIBDIR)/CFPlus/UI/MessageWindow.pm',
85 'CFPlus/Item.pm' => '$(INST_LIBDIR)/CFPlus/Item.pm',
86 'CFPlus/Pod.pm' => '$(INST_LIBDIR)/CFPlus/Pod.pm',
48 'CFClient/MapWidget.pm' => '$(INST_LIBDIR)/CFClient/MapWidget.pm', 87 'CFPlus/MapWidget.pm' => '$(INST_LIBDIR)/CFPlus/MapWidget.pm',
88 'CFPlus/Macro.pm' => '$(INST_LIBDIR)/CFPlus/Macro.pm',
89 'docwiki.pst' => '$(INST_LIBDIR)/CFPlus/resources/docwiki.pst',
49 (map +($_ => "\$(INST_LIBDIR)/CFClient/$_"), 90 (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 } 91 }
60); 92);
93
94sub MY::postamble {
95 my $self = shift;
96
97 # try to add MANIFEST to CONFIGDEP
98 s/^CONFIGDEP = /CONFIGDEP = MANIFEST /m
99 for @{ $self->{RESULT} };
100
101 my $pods = join " ", <pod/*.pod>;
102
103 <<EOF
104
105all :: docwiki.pst
106
107docwiki.pst: bin/pod2wiki $pods
108 \$(PERL) -Mlib=. bin/pod2wiki $pods
109
110EOF
111}
112

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines