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.50 by elmex, Wed Jun 28 09:42:39 2006 UTC vs.
Revision 1.64 by root, Wed Sep 20 16:01:07 2006 UTC

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

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines