Move update_rects out of Surface.xs and make SDL::UpdateRects work
[sdlgit/SDL_perl.git] / Build.PL
old mode 100755 (executable)
new mode 100644 (file)
index ca0cbec..142b973
--- a/Build.PL
+++ b/Build.PL
@@ -41,6 +41,34 @@ my %subsystems =
                libraries => [qw( SDL SDL_image SDL_mixer SDL_net SDL_ttf SDL_gfx
                                  png jpeg smpeg )],
        },
+       Rect => {
+               file      => {
+                       from  => 'src/Core/objects/Rect.xs',
+                       to    => 'lib/SDL/Rect.xs',
+               },
+               libraries => [qw( SDL  )],
+       },
+       Color => {
+               file      => {
+                       from  => 'src/Core/objects/Color.xs',
+                       to    => 'lib/SDL/Color.xs',
+               },
+               libraries => [qw( SDL )],
+       },
+       Surface => {
+               file      => {
+                       from  => 'src/Core/objects/Surface.xs',
+                       to    => 'lib/SDL/Surface.xs',
+               },
+               libraries => [qw( SDL SDL_image )],
+       },
+       PixelFormat => {
+               file      => {
+                       from  => 'src/Core/objects/PixelFormat.xs',
+                       to    => 'lib/SDL/PixelFormat.xs',
+               },
+               libraries => [qw( SDL SDL_image )],
+       },
        OpenGL => {
                file      => {
                        from => 'src/OpenGL.xs',
@@ -127,13 +155,16 @@ my $build   = SDL::Build->new(
        dist_name            => 'SDL_Perl', 
        license              => 'lgpl',
        dist_version_from    => 'lib/SDL.pm',
-       build_requires       =>
+       configure_requires            =>
        {
-               'Test::Simple' => '0.47',
-               'Module::Build' => '0.22',
                'YAML'  => '0.68',
-               'Alien::SDL'    => '0.02',
-               'ExtUtils::CBuilder' => '0.260301'
+               'ExtUtils::CBuilder' => '0.260301',
+               'Alien::SDL' => '0.7.1',
+       },
+       build_requires =>
+       {
+               'Test::Simple' => '0.47',
+
        },
        build_recommends     =>
        {
@@ -143,11 +174,18 @@ my $build   = SDL::Build->new(
        xs_files             => \%xs,
        meta_add             =>      
        {
-               no_index =>  { file => [ <make/lib/SDL/*.pm>, <make/lib/SDL/Build/*.pm> ] },
+               no_index =>  { file => [ <make/lib/SDL/*.pm>, <make/lib/SDL/Build/*.pm>, <make/lib/ExtUtils/CBuilder/*>, <make/lib/ExtUtils/*>, <make/lib/ExtUtils/CBuilder/Platform/Windows.pm> ] },
        },
-       dist_author          => 'David J. Goehrig <DGOEHRIG@cpan.org>',
+       dist_author          => 'David J. Goehrig <DGOEHRIG@cpan.org>, Kartik Thakore <KTHAKORE@cpan.org>',
 );
 
+if($arch eq 'Darwin')
+{
+       $build->{c_source} = $arch->build_c_source( \%libraries, $build_systems );
+       $build->{c_sources} = $arch->build_c_sources( \%libraries, $build_systems );
+       $build->{install_base} = $arch->build_install_base( \%libraries, $build_systems );
+
+}
 
 # and here's where the real (and ugly) magic works... see SDL::Build
 $build->set_flags(