--- deliantra/Deliantra-Client/Makefile.PL 2007/12/26 18:09:30 1.95 +++ deliantra/Deliantra-Client/Makefile.PL 2018/11/18 01:43:12 1.130 @@ -1,5 +1,9 @@ +use Config; +use ExtUtils::CXX; use ExtUtils::MakeMaker; +my $lddlflags = $Config{lddlflags}; + sub manifest_resources { open my $manifest, "MANIFEST" or die "Couldn't open MANIFEST: $!"; map { chomp; $_ } grep /^resources\//, <$manifest> @@ -13,7 +17,7 @@ *** other dependencies: *** pango-1.12.3, glib-2.10 -*** libsdl, libSDL_mixer, libSDL_image +*** libsdl-1.2.10, libSDL_mixer, libSDL_image *** Pod::POM, Compress::LZF, BDB, Deliantra, EV, AnyEvent perl modules @@ -21,7 +25,7 @@ *** apt-get install perl libpango1.0-dev libglib2.0-dev libsdl1.2-dev *** apt-get install libsdl-mixer1.2-dev libsdl-image1.2-dev *** apt-get install libwww-perl libdb4.4-dev -*** apt-get install anyevent-perl +*** apt-get install libanyevent-perl EOF @@ -34,60 +38,83 @@ $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"; $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", } else { - $INC = join " ", qx, qx; - $LIBS = join " ", qx, "-lSDL_image -lSDL_mixer", qx, "-lGL"; + $INC = join " ", qx, qx; + $LIBS = join "", map " $_ ", + qx, + "-lSDL_image -lSDL_mixer", + qx, + "-L/usr/X11/lib"; + + $LIBS .= " -lGL" unless $^O =~ /darwin/i; # sigh... os x is so borked + + $_ =~ s/\n/ /g for $INC, $LIBS; - $INC =~ s/\n/ /g for $INC, $LIBS; + # for extra horrid macosx joys + $lddlflags .= " $1" while $LIBS =~ s/ (-Wl,\S+) / /; } -WriteMakefile( - dist => { - PREOP => 'pod2text bin/deliantra | tee README >$(DISTVNAME)/README; chmod -R u=rwX,go=rX . ;', - COMPRESS => 'gzip -9v', - SUFFIX => '.gz', - }, - NAME => "CFPlus", - INC => $INC, - LIBS => [$LIBS], - EXE_FILES => [qw(bin/deliantra)], - VERSION_FROM => "CFPlus.pm", - PREREQ_PM => { - BDB => 1.4, - Deliantra => 1.13, - Time::HiRes => 0, - EV => 1.72, - AnyEvent => 2.6, - Compress::LZF => 1.6, - Pod::POM => 0.15, - LWP => 0, - JSON::XS => 2.01, - }, - depend => { - "CFPlus.o" => 'glfunc.h pangoopengl.h pango-font.c pango-fontmap.c pango-render.c texcache.c rendercache.c', - }, - clean => { FILES => 'docwiki.pst' }, - PM => { - '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), - } -); +extutils_cxx { + WriteMakefile( + dist => { + PREOP => 'pod2text bin/deliantra | tee README >$(DISTVNAME)/README; chmod -R u=rwX,go=rX . ;', + COMPRESS => 'gzip -9v', + SUFFIX => '.gz', + }, + NAME => "Deliantra::Client", + INC => $INC, + LIBS => [$LIBS], + LDDLFLAGS => $lddlflags, + EXE_FILES => [qw(bin/deliantra)], + VERSION_FROM => "DC.pm", + PREREQ_PM => { + common::sense => 3.6, + BDB => 1.83, + Deliantra => 1.31, + Time::HiRes => 0, + EV => 3.42, + Guard => 1, + AnyEvent => 4.331, + Compress::LZF => 3.41, + Pod::POM => 0.27, + LWP => 0, + JSON::XS => 2.2222, + IO::AIO => 4, + AnyEvent::AIO => 1, + Coro => 6, + Coro::EV => 0, + Urlader => 1, + }, + depend => { + "Client.o" => 'glfunc.h pangoopengl.h pango-font.c pango-fontmap.c pango-render.c texcache.c rendercache.c', + }, + clean => { FILES => 'docwiki.pst' }, + PM => { + 'Client.pm' => '$(INST_LIBDIR)/Client.pm', + 'DC.pm' => '$(INST_LIBDIR)/Client/private/DC.pm', + 'DC/Main.pm' => '$(INST_LIBDIR)/Client/private/DC/Main.pm', + 'DC/Protocol.pm' => '$(INST_LIBDIR)/Client/private/DC/Protocol.pm', + 'DC/Audio.pm' => '$(INST_LIBDIR)/Client/private/DC/Audio.pm', + 'DC/OpenGL.pm' => '$(INST_LIBDIR)/Client/private/DC/OpenGL.pm', + 'DC/Texture.pm' => '$(INST_LIBDIR)/Client/private/DC/Texture.pm', + 'DC/DB.pm' => '$(INST_LIBDIR)/Client/private/DC/DB.pm', + 'DC/UI.pm' => '$(INST_LIBDIR)/Client/private/DC/UI.pm', + 'DC/MessageDistributor.pm' => '$(INST_LIBDIR)/Client/private/DC/MessageDistributor.pm', + 'DC/UI/Canvas.pm' => '$(INST_LIBDIR)/Client/private/DC/UI/Canvas.pm', + 'DC/UI/Dockable.pm' => '$(INST_LIBDIR)/Client/private/DC/UI/Dockable.pm', + 'DC/UI/Dockbar.pm' => '$(INST_LIBDIR)/Client/private/DC/UI/Dockbar.pm', + 'DC/UI/Inventory.pm' => '$(INST_LIBDIR)/Client/private/DC/UI/Inventory.pm', + 'DC/UI/SpellList.pm' => '$(INST_LIBDIR)/Client/private/DC/UI/SpellList.pm', + 'DC/UI/Canvas.pm' => '$(INST_LIBDIR)/Client/private/DC/UI/Canvas.pm', + 'DC/UI/ChatView.pm' => '$(INST_LIBDIR)/Client/private/DC/UI/ChatView.pm', + 'DC/Item.pm' => '$(INST_LIBDIR)/Client/private/DC/Item.pm', + 'DC/Pod.pm' => '$(INST_LIBDIR)/Client/private/DC/Pod.pm', + 'DC/MapWidget.pm' => '$(INST_LIBDIR)/Client/private/DC/MapWidget.pm', + 'DC/Macro.pm' => '$(INST_LIBDIR)/Client/private/DC/Macro.pm', + 'docwiki.pst' => '$(INST_LIBDIR)/Client/private/resources/docwiki.pst', + (map +($_ => "\$(INST_LIBDIR)/Client/private/$_"), manifest_resources), + } + ); +}; sub MY::postamble { my $self = shift;