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.34 by elmex, Fri Apr 21 12:27:19 2006 UTC vs.
Revision 1.64 by root, Wed Sep 20 16:01:07 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*** 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
11 21
12EOF 22EOF
13 23
14if ($^O =~ /win32/i or $^O =~ /mswin/) { 24if ($^O =~ /win32/i or $^O =~ /mswin/) {
15 warn "do manual configuration, please\n"; 25 print <<EOF;
26*** microsoft compatibility forced us to only support manual configuration
27*** by editing Makefile.PL. complain to microsoft.
28
29EOF
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"; 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";
17 $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", 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",
18} else { 32} else {
19 $INC = join " ", qx<sdl-config --cflags>, qx<pkg-config pangoft2 --cflags>; 33 $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>; 34 $LIBS = join " ", qx<sdl-config --libs>, "-lSDL_image -lSDL_mixer", qx<pkg-config pangoft2 --libs>, "-lGL";
21 35
22 $INC =~ s/\n/ /g for $INC, $LIBS; 36 $INC =~ s/\n/ /g for $INC, $LIBS;
23} 37}
24 38
25WriteMakefile( 39WriteMakefile(
26 dist => { 40 dist => {
27 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 . ;',
28 COMPRESS => 'gzip -9v', 42 COMPRESS => 'gzip -9v',
29 SUFFIX => '.gz', 43 SUFFIX => '.gz',
30 }, 44 },
31 NAME => "CFClient", 45 NAME => "CFPlus",
32 INC => $INC, 46 INC => $INC,
33 LIBS => [$LIBS], 47 LIBS => [$LIBS],
34 EXE_FILES => [qw(bin/pclient)], 48 EXE_FILES => [qw(bin/cfplus)],
35 VERSION_FROM => "CFClient.pm", 49 VERSION_FROM => "CFPlus.pm",
36 PREREQ_PM => { 50 PREREQ_PM => {
37 BerkeleyDB => 0.27, 51 BerkeleyDB => 0.27,
38 Crossfire => 0.1, 52 Crossfire => 0.91,
39 Time::HiRes => 0, 53 Time::HiRes => 0,
40 Event => 1.01, 54 Event => 1.01,
41 AnyEvent => 0, 55 AnyEvent => 0,
42 Compress::LZF => 1.6, 56 Compress::LZF => 1.6,
57 Pod::POM => 0.15,
43 }, 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' },
44 PM => { 63 PM => {
45 'CFClient.pm' => '$(INST_LIBDIR)/CFClient.pm', 64 'CFPlus.pm' => '$(INST_LIBDIR)/CFPlus.pm',
65 'CFPlus/Protocol.pm' => '$(INST_LIBDIR)/CFPlus/Protocol.pm',
46 'CFClient/OpenGL.pm' => '$(INST_LIBDIR)/CFClient/OpenGL.pm', 66 'CFPlus/OpenGL.pm' => '$(INST_LIBDIR)/CFPlus/OpenGL.pm',
67 'CFPlus/Texture.pm' => '$(INST_LIBDIR)/CFPlus/Texture.pm',
47 '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',
48 'CFClient/MapWidget.pm' => '$(INST_LIBDIR)/CFClient/MapWidget.pm', 70 'CFPlus/MapWidget.pm' => '$(INST_LIBDIR)/CFPlus/MapWidget.pm',
71 'CFPlus/BindingEditor.pm' => '$(INST_LIBDIR)/CFPlus/BindingEditor.pm',
72 'docwiki.pst' => '$(INST_LIBDIR)/CFPlus/resources/docwiki.pst',
49 (map +($_ => "\$(INST_LIBDIR)/CFClient/$_"), 73 (map +($_ => "\$(INST_LIBDIR)/CFPlus/$_"), manifest_resources),
50 <resources/*.ttf>,
51 <resources/*.png>,
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 } 74 }
60); 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