[Bps-public-commit] r12247 -
    sunnavy at bestpractical.com 
    sunnavy at bestpractical.com
       
    Mon May 12 06:45:47 EDT 2008
    
    
  
Author: sunnavy
Date: Mon May 12 06:45:44 2008
New Revision: 12247
Modified:
   /   (props changed)
   Shipwright/trunk/lib/Shipwright/Source.pm
Log:
 r12252 at sunnavys-mb:  sunnavy | 2008-05-12 17:49:15 +0800
 refactor source type inference: only svn,svn,http and ftp types can be omitted sometimes
Modified: Shipwright/trunk/lib/Shipwright/Source.pm
==============================================================================
--- Shipwright/trunk/lib/Shipwright/Source.pm	(original)
+++ Shipwright/trunk/lib/Shipwright/Source.pm	Mon May 12 06:45:44 2008
@@ -9,18 +9,17 @@
 
 Hash::Merge::set_behavior('RIGHT_PRECEDENT');
 
-our %DEFAULT = (
-    follow            => 1,
-);
+our %DEFAULT = ( follow => 1, );
 
 $DEFAULT{directory} = tempdir( CLEANUP => 0 );
 $DEFAULT{download_directory} =
   File::Spec->catfile( $DEFAULT{directory}, 'download' );
 $DEFAULT{map_path} = File::Spec->catfile( $DEFAULT{directory}, 'map.yml' );
 $DEFAULT{url_path} = File::Spec->catfile( $DEFAULT{directory}, 'url.yml' );
-$DEFAULT{version_path} = File::Spec->catfile( $DEFAULT{directory}, 'version.yml' );
+$DEFAULT{version_path} =
+  File::Spec->catfile( $DEFAULT{directory}, 'version.yml' );
 
-for ( qw/map_path url_path version_path/ ) {
+for (qw/map_path url_path version_path/) {
     open my $fh, '>', $DEFAULT{$_} or die "can't write to $DEFAULT{$_}: $!";
     close $fh;
 }
@@ -33,10 +32,12 @@
     my $class = shift;
     my %args = %{ merge( \%DEFAULT, {@_} ) };
 
-    my $type = delete $args{type} || type( $args{source} );
-
     croak "need source option" unless $args{source};
 
+    my $type = type( \$args{source} );
+
+    croak "invalid source $args{source}" unless $type;
+
     my $module = 'Shipwright::Source::' . $type;
     $module->require or die $@;
     return $module->new(%args);
@@ -49,33 +50,19 @@
 sub type {
     my $source = shift;
 
-    if ( -e $source ) {
-        if ( -d $source ) {
-            return 'Directory';
+    # prefix that can't be omitted
+    return 'Compressed' if $$source =~ s/^file://i;
+    return 'Directory'  if $$source =~ s/^dir(ectory)?://i;
+    return 'CPAN'       if $$source =~ s/^cpan://i;
+
+    # prefix that can be omitted
+    for my $type (qw/svk svn http ftp/) {
+        if ( $$source =~ /^$type:/i ) {
+            $$source =~ s{^$type:(?!//)}{}i;
+            return uc $type;
         }
-        elsif ( -f $source && $source =~ /\.(tgz|tar\.(gz|bz2))$/ ) {
-            return 'Compressed';
-        }
-        else {
-            croak
-"only support directory and compressed file which contains only one directory";
-        }
-    }
-    elsif ( $source =~ m{^\s*http://} ) {
-        return 'HTTP';
-    }
-    elsif ( $source =~ m{^\s*ftp://} ) {
-        return 'FTP';
-    }
-    elsif ( $source =~ m{^\s*svn[:+]} ) {
-        return 'SVN';
-    }
-    elsif ( $source =~ m{^\s*(svk:|//)} ) {
-        return 'SVK';
-    }
-    else {
-        return 'CPAN';
     }
+
 }
 
 1;
    
    
More information about the Bps-public-commit
mailing list