… | |
… | |
17 | |
17 | |
18 | *** Pod::POM, Compress::LZF, BerkeleyDB, Crossfire, Event, AnyEvent perl modules |
18 | *** Pod::POM, Compress::LZF, BerkeleyDB, Crossfire, Event, AnyEvent perl modules |
19 | |
19 | |
20 | *** 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 | |
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 |
|
|
26 | |
22 | EOF |
27 | EOF |
23 | |
28 | |
24 | if ($^O =~ /win32/i or $^O =~ /mswin/) { |
29 | if ($^O =~ /win32/i or $^O =~ /mswin/) { |
25 | print <<EOF; |
30 | print <<EOF; |
26 | *** microsoft compatibility forced us to only support manual configuration |
31 | *** microsoft compatibility forced us to only support manual configuration |
27 | *** by editing Makefile.PL. complain to microsoft. |
32 | *** by editing Makefile.PL. complain to microsoft. |
28 | |
33 | |
29 | EOF |
34 | EOF |
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"; |
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"; |
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", |
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", |
32 | } else { |
37 | } else { |
33 | $INC = join " ", qx<sdl-config --cflags>, qx<pkg-config pangoft2 --cflags>; |
38 | $INC = join " ", qx<sdl-config --cflags>, qx<pkg-config pangoft2 --cflags>; |
34 | $LIBS = join " ", qx<sdl-config --libs>, "-lSDL_image -lSDL_mixer", qx<pkg-config pangoft2 --libs>, "-lGL"; |
39 | $LIBS = join " ", qx<sdl-config --libs>, "-lSDL_image -lSDL_mixer", qx<pkg-config pangoft2 --libs>, "-lGL"; |
35 | |
40 | |
36 | $INC =~ s/\n/ /g for $INC, $LIBS; |
41 | $INC =~ s/\n/ /g for $INC, $LIBS; |
37 | } |
42 | } |
38 | |
43 | |
39 | WriteMakefile( |
44 | WriteMakefile( |
40 | dist => { |
45 | dist => { |
41 | PREOP => 'pod2text CFPlus.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 . ;', |
42 | COMPRESS => 'gzip -9v', |
47 | COMPRESS => 'gzip -9v', |
43 | SUFFIX => '.gz', |
48 | SUFFIX => '.gz', |
44 | }, |
49 | }, |
45 | NAME => "CFPlus", |
50 | NAME => "CFPlus", |
46 | INC => $INC, |
51 | INC => $INC, |
47 | LIBS => [$LIBS], |
52 | LIBS => [$LIBS], |
48 | EXE_FILES => [qw(bin/cfplus)], |
53 | EXE_FILES => [qw(bin/cfplus)], |
49 | VERSION_FROM => "CFPlus.pm", |
54 | VERSION_FROM => "CFPlus.pm", |
50 | PREREQ_PM => { |
55 | PREREQ_PM => { |
51 | BerkeleyDB => 0.27, |
56 | BerkeleyDB => 0.27, |
52 | Crossfire => 0.1, |
57 | Crossfire => 0.95, |
53 | Time::HiRes => 0, |
58 | Time::HiRes => 0, |
54 | Event => 1.01, |
59 | Event => 1.07, |
55 | AnyEvent => 0, |
60 | AnyEvent => 0, |
56 | Compress::LZF => 1.6, |
61 | Compress::LZF => 1.6, |
57 | Pod::POM => 0.15, |
62 | Pod::POM => 0.15, |
58 | JSON::PC => 0.01, |
|
|
59 | }, |
63 | }, |
60 | depend => { |
64 | depend => { |
61 | "CFPlus.o" => 'glfunc.h pangoopengl.h pango-font.c pango-fontmap.c pango-render.c texcache.c', |
65 | "CFPlus.o" => 'glfunc.h pangoopengl.h pango-font.c pango-fontmap.c pango-render.c texcache.c', |
62 | }, |
66 | }, |
|
|
67 | clean => { FILES => 'docwiki.pst' }, |
63 | PM => { |
68 | PM => { |
64 | 'CFPlus.pm' => '$(INST_LIBDIR)/CFPlus.pm', |
69 | 'CFPlus.pm' => '$(INST_LIBDIR)/CFPlus.pm', |
65 | 'CFPlus/Protocol.pm' => '$(INST_LIBDIR)/CFPlus/Protocol.pm', |
70 | 'CFPlus/Protocol.pm' => '$(INST_LIBDIR)/CFPlus/Protocol.pm', |
66 | 'CFPlus/OpenGL.pm' => '$(INST_LIBDIR)/CFPlus/OpenGL.pm', |
71 | 'CFPlus/OpenGL.pm' => '$(INST_LIBDIR)/CFPlus/OpenGL.pm', |
67 | 'CFPlus/Texture.pm' => '$(INST_LIBDIR)/CFPlus/Texture.pm', |
72 | 'CFPlus/Texture.pm' => '$(INST_LIBDIR)/CFPlus/Texture.pm', |
68 | 'CFPlus/UI.pm' => '$(INST_LIBDIR)/CFPlus/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', |
69 | 'CFPlus/Pod.pm' => '$(INST_LIBDIR)/CFPlus/Pod.pm', |
77 | 'CFPlus/Pod.pm' => '$(INST_LIBDIR)/CFPlus/Pod.pm', |
70 | 'CFPlus/MapWidget.pm' => '$(INST_LIBDIR)/CFPlus/MapWidget.pm', |
78 | 'CFPlus/MapWidget.pm' => '$(INST_LIBDIR)/CFPlus/MapWidget.pm', |
71 | 'CFPlus/BindingEditor.pm' => '$(INST_LIBDIR)/CFPlus/BindingEditor.pm', |
79 | 'CFPlus/Macro.pm' => '$(INST_LIBDIR)/CFPlus/Macro.pm', |
|
|
80 | 'docwiki.pst' => '$(INST_LIBDIR)/CFPlus/resources/docwiki.pst', |
72 | (map +($_ => "\$(INST_LIBDIR)/CFPlus/$_"), manifest_resources), |
81 | (map +($_ => "\$(INST_LIBDIR)/CFPlus/$_"), manifest_resources), |
73 | } |
82 | } |
74 | ); |
83 | ); |
|
|
84 | |
|
|
85 | sub 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 | |
|
|
96 | all :: docwiki.pst |
|
|
97 | |
|
|
98 | docwiki.pst: bin/pod2wiki $pods |
|
|
99 | \$(PERL) -Mlib=. bin/pod2wiki $pods |
|
|
100 | |
|
|
101 | EOF |
|
|
102 | } |
|
|
103 | |