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.26 by root, Tue Apr 18 00:14:16 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
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
19
8*** HINT: BerkeleyDB must be linked against version 4.4 or above 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
9 26
10EOF 27EOF
11 28
12if ($^O =~ /win32/i or $^O =~ /mswin/) { 29if ($^O =~ /win32/i or $^O =~ /mswin/) {
13 warn "do manual configuration, please\n"; 30 print <<EOF;
31*** microsoft compatibility forced us to only support manual configuration
32*** by editing Makefile.PL. complain to microsoft.
33
34EOF
14 $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";
15 $LIBS = "-L/gtk/lib -lSDL -lSDL_image -lSDL_mixer -lpangoft2-1.0 -lpango-1.0 -lgobject-2.0 -lgmodule-2.0 -ldl -lglib-2.0 -lfreetype -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",
16} else { 37} else {
17 $INC = join " ", qx<sdl-config --cflags>, qx<pkg-config pangoft2 --cflags>; 38 $INC = join " ", qx<sdl-config --cflags>, qx<pkg-config pangoft2 --cflags>;
18 $LIBS = join " ", qx<sdl-config --libs>, "-lSDL_image -lSDL_mixer", qx<pkg-config pangoft2 --libs>; 39 $LIBS = join " ", qx<sdl-config --libs>, "-lSDL_image -lSDL_mixer", qx<pkg-config pangoft2 --libs>, "-lGL";
19 40
20 $INC =~ s/\n/ /g for $INC, $LIBS; 41 $INC =~ s/\n/ /g for $INC, $LIBS;
21} 42}
22 43
23WriteMakefile( 44WriteMakefile(
24 dist => { 45 dist => {
25 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 . ;',
26 COMPRESS => 'gzip -9v', 47 COMPRESS => 'gzip -9v',
27 SUFFIX => '.gz', 48 SUFFIX => '.gz',
28 }, 49 },
29 NAME => "CFClient", 50 NAME => "CFPlus",
30 INC => $INC, 51 INC => $INC,
31 LIBS => [$LIBS], 52 LIBS => [$LIBS],
32 EXE_FILES => [qw(bin/pclient)], 53 EXE_FILES => [qw(bin/cfplus)],
33 VERSION_FROM => "CFClient.pm", 54 VERSION_FROM => "CFPlus.pm",
34 PREREQ_PM => { 55 PREREQ_PM => {
35 BerkeleyDB => 0.27, 56 BerkeleyDB => 0.27,
36 SDL => 2.1,
37 Crossfire => 0.1, 57 Crossfire => 0.96,
38 Time::HiRes => 0, 58 Time::HiRes => 0,
39 Event => 1.01, 59 Event => 1.07,
40 AnyEvent => 0, 60 AnyEvent => 0,
41 Compress::LZF => 1.6, 61 Compress::LZF => 1.6,
62 Pod::POM => 0.15,
42 }, 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' },
43 PM => { 68 PM => {
44 'CFClient.pm' => '$(INST_LIBDIR)/CFClient.pm', 69 'CFPlus.pm' => '$(INST_LIBDIR)/CFPlus.pm',
70 'CFPlus/Protocol.pm' => '$(INST_LIBDIR)/CFPlus/Protocol.pm',
71 'CFPlus/OpenGL.pm' => '$(INST_LIBDIR)/CFPlus/OpenGL.pm',
72 'CFPlus/Texture.pm' => '$(INST_LIBDIR)/CFPlus/Texture.pm',
45 'CFClient/UI.pm' => '$(INST_LIBDIR)/CFClient/UI.pm', 73 'CFPlus/UI.pm' => '$(INST_LIBDIR)/CFPlus/UI.pm',
46 (map +($_ => "\$(INST_LIBDIR)/CFClient/$_"), <resources/*.ttf>, <resources/*.png>, <resources/sounds/*.wav>), 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',
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',
81 (map +($_ => "\$(INST_LIBDIR)/CFPlus/$_"), manifest_resources),
47 } 82 }
48); 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