Find SDL libraries in Perl's include/lib path.
[sdlgit/SDL_perl.git] / make / lib / SDL / Build / Darwin.pm
index 18d5b1e..76f1252 100644 (file)
@@ -34,28 +34,62 @@ use base 'SDL::Build';
 
 sub fetch_includes
 {
+       use Config;
+
+       my (@include_path, @lib_path);
+
+       {
+               my %seen;
+               foreach (
+                       ($Config{ccflags} =~ /-I(\S+)/g),
+                       ($Config{cppflags} =~ /-I(\S+)/g),
+               ) {
+                       foreach my $sdl_lib_dir ($_, "$_/SDL") {
+                               next unless -f "$sdl_lib_dir/SDL.h";
+                               push @include_path, $sdl_lib_dir unless $seen{$sdl_lib_dir}++;
+                       }
+               }
+       }
+
+       {
+               my %seen;
+               foreach (
+                       ($Config{libpth} =~ /(\S+)/g),
+                       ($Config{libsdirs} =~ /(\S+)/g),
+                       ($Config{libspath} =~ /(\S+)/g),
+                       ($Config{lddlflags} =~ /-I(\S+)/g),
+                       ($Config{ldflags} =~ /-I(\S+)/g),
+               ) {
+                       next unless -f "$_/libSDL.a";
+                       push @lib_path, $_ unless $seen{$_}++;
+               }
+       }
+
+       die "Can't find an SDL library" unless @include_path and @lib_path;
+       warn "Found SDL headers in $include_path[0] and library in $lib_path[0]";
+
        return (
-       '/usr/local/include/SDL'   => '/usr/local/lib',
-       '/usr/local/include'       => '/usr/local/lib',
-       '/usr/local/include/smpeg' => '/usr/local/lib',
-       '/usr/include/SDL'         => '/usr/lib',
-       '/usr/include'             => '/usr/lib',
-       '/usr/include/smpeg'       => '/usr/lib',
-       '/usr/local/include/GL'    => '/usr/local/lib',
-       '/usr/local/include/gl'    => '/usr/local/lib',
-       '/usr/include/GL'          => '/usr/lib', 
-       '/usr/include/gl'          => '/usr/lib', 
-
-       '/System/Library/Frameworks/SDL_mixer.framework/Headers'     => '../../lib',
-       '/System/Library/Frameworks/SDL_image.framework/Headers'     => '../../lib',
-       '/System/Library/Frameworks/SDL_ttf.framework/Headers'       => '../../lib',
-       '/System/Library/Frameworks/libogg.framework/Headers'        => '../../lib',
-       '/System/Library/Frameworks/libvorbis.framework/Headers'     => '../../lib',
-       '/System/Library/Frameworks/libvorbisfile.framework/Headers' => '../../lib',
-       '/System/Library/Frameworks/libvorbisenc.framework/Headers'  => '../../lib',
-       '../../include'                                              => '../../lib',
-       '/System/Library/Frameworks/OpenGL.framework/Headers'        =>
-               '/System/Library/Frameworks/OpenGL.framework/Libraries',
+               $include_path[0] => $lib_path[0],
+
+               # Local libraries.
+               '/usr/local/include/smpeg' => '/usr/local/lib',
+               '/usr/local/include/GL'    => '/usr/local/lib',
+               '/usr/local/include/gl'    => '/usr/local/lib',
+
+               # System libraries.
+               '/usr/include/smpeg'       => '/usr/lib',
+               '/usr/include/GL'          => '/usr/lib', 
+               '/usr/include/gl'          => '/usr/lib', 
+
+               # System-wide frameworks.
+               '/System/Library/Frameworks/libogg.framework/Headers'        => '../../lib',
+               '/System/Library/Frameworks/libvorbis.framework/Headers'     => '../../lib',
+               '/System/Library/Frameworks/libvorbisfile.framework/Headers' => '../../lib',
+               '/System/Library/Frameworks/libvorbisenc.framework/Headers'  => '../../lib',
+               '/System/Library/Frameworks/OpenGL.framework/Headers'        => '/System/Library/Frameworks/OpenGL.framework/Libraries',
+
+               # System libraries.
+               '/System/Library/Frameworks/OpenGL.framework/Headers'        => '/System/Library/Frameworks/OpenGL.framework/Libraries',
        );
 }
 
@@ -73,23 +107,29 @@ sub build_c_source
 
 sub build_install_base
 {
-       return "SDL Perl.app/Contents/Resources";       
+       return "SDLPerl.app/Contents/Resources";        
 }
 
 sub build_bundle
 {
-       $bundle_contents="SDL Perl.app/Contents";
+       $bundle_contents="SDLPerl.app/Contents";
        system "mkdir -p \"$bundle_contents\"";
        mkdir "$bundle_contents/MacOS",0755;
-       $libs = `sdl-config --libs`;
+       $cflags = `sdl-config --cflags`;
+       chomp($cflags);
+       $cflags .= ' ' . `perl -MExtUtils::Embed -e ccopts`;
+       chomp($cflags);
+       $libs = `sdl-config  --libs`;
+       chomp($libs);
+       $libs .= ' ' . `perl -MExtUtils::Embed -e ldopts`;
        chomp($libs);
        $libs =~ s/-lSDLmain//g;
-       system "gcc $libs -framework Cocoa `perl -MExtUtils::Embed -e ldopts` MacOSX/launcher.o -o \"$bundle_contents/MacOS/SDL Perl\"";
-
+       print STDERR "gcc $cflags MacOSX/launcher.m $libs -framework Cocoa -o \"$bundle_contents/MacOS/SDLPerl\"";
+       print STDERR `gcc $cflags MacOSX/launcher.m $libs -framework Cocoa -o \"$bundle_contents/MacOS/SDLPerl\"`;
        mkdir "$bundle_contents/Resources",0755;
        system "echo \"APPL????\" > \"$bundle_contents/PkgInfo\"";
        system "cp MacOSX/Info.plist \"$bundle_contents/\"";
-       system "cp \"MacOSX/SDL Perl.icns\" \"$bundle_contents/Resources\"";
+       system "cp \"MacOSX/SDLPerl.icns\" \"$bundle_contents/Resources\"";
 }
 
 1;