--- deliantra/Deliantra-Client/Makefile.PL 2006/04/16 07:45:25 1.23 +++ deliantra/Deliantra-Client/Makefile.PL 2006/08/15 05:58:13 1.61 @@ -1,64 +1,93 @@ use ExtUtils::MakeMaker; +sub manifest_resources { + open my $manifest, "MANIFEST" or die "Couldn't open MANIFEST: $!"; + map { chomp; $_ } grep /^resources\//, <$manifest> +} + print <, qx; + $LIBS = join " ", qx, "-lSDL_image -lSDL_mixer", qx, "-lGL"; -# sdl-config -# -lSDL_image -# pkg-config pangoft2 -# freetype-config + $INC =~ s/\n/ /g for $INC, $LIBS; +} WriteMakefile( dist => { - PREOP => 'pod2text CFClient.pm | tee README >$(DISTVNAME)/README; chmod -R u=rwX,go=rX . ;', + PREOP => 'pod2text bin/cfplus | tee README >$(DISTVNAME)/README; chmod -R u=rwX,go=rX . ;', COMPRESS => 'gzip -9v', SUFFIX => '.gz', }, - NAME => "CFClient", - INC => '-I/usr/include/SDL -I/usr/include/pango-1.0 -I/usr/include/glib-2.0 -I/usr/lib/glib-2.0/include -I/usr/include/freetype2', - LIBS => ["-lSDL -lSDL_image -lpangoft2-1.0 -lpango-1.0 -lgobject-2.0 -lgmodule-2.0 -ldl -lglib-2.0 -lfreetype -lz"], - EXE_FILES => [qw(bin/pclient)], - VERSION_FROM => "CFClient.pm", + NAME => "CFPlus", + INC => $INC, + LIBS => [$LIBS], + EXE_FILES => [qw(bin/cfplus)], + VERSION_FROM => "CFPlus.pm", PREREQ_PM => { BerkeleyDB => 0.27, - SDL => 2.1, - Crossfire => 0.1, + Crossfire => 0.8, Time::HiRes => 0, Event => 1.01, AnyEvent => 0, Compress::LZF => 1.6, + Pod::POM => 0.15, }, + depend => { + "CFPlus.o" => 'glfunc.h pangoopengl.h pango-font.c pango-fontmap.c pango-render.c texcache.c', + }, + clean => { FILES => 'docwiki.pst' }, PM => { - 'CFClient.pm' => '$(INST_LIBDIR)/CFClient.pm', - 'CFClient/UI.pm' => '$(INST_LIBDIR)/CFClient/UI.pm', - 'resources/uifont.ttf' => '$(INST_LIBDIR)/CFClient/resources/uifont.ttf', - 'resources/uifontb.ttf' => '$(INST_LIBDIR)/CFClient/resources/uifontb.ttf', - 'resources/uifonti.ttf' => '$(INST_LIBDIR)/CFClient/resources/uifonti.ttf', - 'resources/uifontbi.ttf' => '$(INST_LIBDIR)/CFClient/resources/uifontbi.ttf', - 'resources/d1_bg.png' => '$(INST_LIBDIR)/CFClient/resources/d1_bg.png', - 'resources/d1_border_top.png' => '$(INST_LIBDIR)/CFClient/resources/d1_border_top.png', - 'resources/d1_border_bottom.png' => '$(INST_LIBDIR)/CFClient/resources/d1_border_bottom.png', - 'resources/d1_border_left.png' => '$(INST_LIBDIR)/CFClient/resources/d1_border_left.png', - 'resources/d1_border_right.png' => '$(INST_LIBDIR)/CFClient/resources/d1_border_right.png', - 'resources/b1_button_active.png' => '$(INST_LIBDIR)/CFClient/resources/b1_button_active.png', - 'resources/s1_slider.png' => '$(INST_LIBDIR)/CFClient/resources/s1_slider.png', - 'resources/s1_slider_bg.png' => '$(INST_LIBDIR)/CFClient/resources/s1_slider_bg.png', - 'resources/c1_checkbox_bg.png' => '$(INST_LIBDIR)/CFClient/resources/c1_checkbox_bg.png', - 'resources/c1_checkbox_active.png' => '$(INST_LIBDIR)/CFClient/resources/c1_checkbox_active.png', - 'resources/g1_food_gauge_empty.png' => '$(INST_LIBDIR)/CFClient/resources/g1_food_gauge_empty.png', - 'resources/g1_food_gauge_full.png' => '$(INST_LIBDIR)/CFClient/resources/g1_food_gauge_full.png', - 'resources/g1_grace_gauge_empty.png' => '$(INST_LIBDIR)/CFClient/resources/g1_grace_gauge_empty.png', - 'resources/g1_grace_gauge_full.png' => '$(INST_LIBDIR)/CFClient/resources/g1_grace_gauge_full.png', - 'resources/g1_hp_gauge_empty.png' => '$(INST_LIBDIR)/CFClient/resources/g1_hp_gauge_empty.png', - 'resources/g1_hp_gauge_full.png' => '$(INST_LIBDIR)/CFClient/resources/g1_hp_gauge_full.png', - 'resources/g1_mana_gauge_empty.png' => '$(INST_LIBDIR)/CFClient/resources/g1_mana_gauge_empty.png', - 'resources/g1_mana_gauge_full.png' => '$(INST_LIBDIR)/CFClient/resources/g1_mana_gauge_full.png', - + 'CFPlus.pm' => '$(INST_LIBDIR)/CFPlus.pm', + 'CFPlus/Protocol.pm' => '$(INST_LIBDIR)/CFPlus/Protocol.pm', + 'CFPlus/OpenGL.pm' => '$(INST_LIBDIR)/CFPlus/OpenGL.pm', + 'CFPlus/Texture.pm' => '$(INST_LIBDIR)/CFPlus/Texture.pm', + 'CFPlus/UI.pm' => '$(INST_LIBDIR)/CFPlus/UI.pm', + 'CFPlus/Pod.pm' => '$(INST_LIBDIR)/CFPlus/Pod.pm', + 'CFPlus/MapWidget.pm' => '$(INST_LIBDIR)/CFPlus/MapWidget.pm', + 'CFPlus/BindingEditor.pm' => '$(INST_LIBDIR)/CFPlus/BindingEditor.pm', + 'docwiki.pst' => '$(INST_LIBDIR)/CFPlus/resources/docwiki.pst', + (map +($_ => "\$(INST_LIBDIR)/CFPlus/$_"), manifest_resources), } ); + +sub MY::postamble { + my $self=shift; + + my $pods = join " ", ; + + <