--- deliantra/Deliantra-Client/Makefile.PL 2006/07/24 08:23:27 1.55 +++ deliantra/Deliantra-Client/Makefile.PL 2007/12/26 18:09:30 1.95 @@ -1,5 +1,10 @@ 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"; @@ -33,48 +42,69 @@ WriteMakefile( dist => { - PREOP => 'pod2text CFClient.pm | tee README >$(DISTVNAME)/README; chmod -R u=rwX,go=rX . ;', + PREOP => 'pod2text bin/deliantra | tee README >$(DISTVNAME)/README; chmod -R u=rwX,go=rX . ;', COMPRESS => 'gzip -9v', SUFFIX => '.gz', }, - NAME => "CFClient", + NAME => "CFPlus", INC => $INC, LIBS => [$LIBS], - EXE_FILES => [qw(bin/cfplus)], - VERSION_FROM => "CFClient.pm", + EXE_FILES => [qw(bin/deliantra)], + VERSION_FROM => "CFPlus.pm", PREREQ_PM => { - BerkeleyDB => 0.27, - Crossfire => 0.1, + BDB => 1.4, + Deliantra => 1.13, Time::HiRes => 0, - Event => 1.01, - AnyEvent => 0, + EV => 1.72, + AnyEvent => 2.6, Compress::LZF => 1.6, Pod::POM => 0.15, - YAML => 0.58, + LWP => 0, + JSON::XS => 2.01, }, depend => { - "CFClient.o" => 'glfunc.h pangoopengl.h pango-font.c pango-fontmap.c pango-render.c texcache.c', + "CFPlus.o" => 'glfunc.h pangoopengl.h pango-font.c pango-fontmap.c pango-render.c texcache.c rendercache.c', }, + clean => { FILES => 'docwiki.pst' }, PM => { - 'CFClient.pm' => '$(INST_LIBDIR)/CFClient.pm', - 'CFClient/Protocol.pm' => '$(INST_LIBDIR)/CFClient/Protocol.pm', - 'CFClient/OpenGL.pm' => '$(INST_LIBDIR)/CFClient/OpenGL.pm', - 'CFClient/Texture.pm' => '$(INST_LIBDIR)/CFClient/Texture.pm', - 'CFClient/UI.pm' => '$(INST_LIBDIR)/CFClient/UI.pm', - 'CFClient/Pod.pm' => '$(INST_LIBDIR)/CFClient/Pod.pm', - 'CFClient/MapWidget.pm' => '$(INST_LIBDIR)/CFClient/MapWidget.pm', - 'CFClient/BindingEditor.pm' => '$(INST_LIBDIR)/CFClient/BindingEditor.pm', - (map +($_ => "\$(INST_LIBDIR)/CFClient/$_"), - , - , - , - , - , - , - , - , - , - , - ), + '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/DB.pm' => '$(INST_LIBDIR)/CFPlus/DB.pm', + 'CFPlus/UI.pm' => '$(INST_LIBDIR)/CFPlus/UI.pm', + 'CFPlus/UI/Canvas.pm' => '$(INST_LIBDIR)/CFPlus/UI/Canvas.pm', + 'CFPlus/UI/Dockable.pm' => '$(INST_LIBDIR)/CFPlus/UI/Dockable.pm', + 'CFPlus/UI/Inventory.pm' => '$(INST_LIBDIR)/CFPlus/UI/Inventory.pm', + 'CFPlus/UI/SpellList.pm' => '$(INST_LIBDIR)/CFPlus/UI/SpellList.pm', + 'CFPlus/UI/Canvas.pm' => '$(INST_LIBDIR)/CFPlus/UI/Canvas.pm', + 'CFPlus/UI/ChatView.pm' => '$(INST_LIBDIR)/CFPlus/UI/ChatView.pm', + 'CFPlus/UI/MessageWindow.pm' => '$(INST_LIBDIR)/CFPlus/UI/MessageWindow.pm', + 'CFPlus/Item.pm' => '$(INST_LIBDIR)/CFPlus/Item.pm', + 'CFPlus/Pod.pm' => '$(INST_LIBDIR)/CFPlus/Pod.pm', + 'CFPlus/MapWidget.pm' => '$(INST_LIBDIR)/CFPlus/MapWidget.pm', + 'CFPlus/Macro.pm' => '$(INST_LIBDIR)/CFPlus/Macro.pm', + 'docwiki.pst' => '$(INST_LIBDIR)/CFPlus/resources/docwiki.pst', + (map +($_ => "\$(INST_LIBDIR)/CFPlus/$_"), manifest_resources), } ); + +sub MY::postamble { + my $self = shift; + + # try to add MANIFEST to CONFIGDEP + s/^CONFIGDEP = /CONFIGDEP = MANIFEST /m + for @{ $self->{RESULT} }; + + my $pods = join " ", ; + + <