Jelajahi Sumber

Merge pull request #49 from infosiftr/script-bugs

Fix a few minor issues with the push script (especially UTF-8 compatibility)
yosifkit 11 tahun lalu
induk
melakukan
c8f5fc09ea
1 mengubah file dengan 9 tambahan dan 8 penghapusan
  1. 9 8
      push.pl

+ 9 - 8
push.pl

@@ -1,11 +1,12 @@
 #!/usr/bin/perl -w
 use strict;
 use warnings;
+use open ':encoding(utf8)';
 
 use File::Temp;
 use Getopt::Long;
 use Mojo::UserAgent;
-use Mojo::Util qw(slurp spurt trim);
+use Mojo::Util qw(decode encode slurp spurt trim);
 use Term::ReadKey;
 
 my $username;
@@ -112,19 +113,19 @@ if ($error->size) {
 }
 
 while (my $repo = shift) { # '/_/hylang', '/u/tianon/perl', etc
+	$repo =~ s!/+$!!;
 	$repo = '/_/' . $repo unless $repo =~ m!/!;
 	$repo = '/' . $repo unless $repo =~ m!^/!;
-	$repo =~ s!/+$!!;
 	
 	my $repoName = $repo;
 	$repoName =~ s!^.*/!!; # 'hylang', 'perl', etc
 	
 	my $shortFile = $repoName . '/README-short.txt';
-	my $short = slurp $shortFile or die 'missing ' . $shortFile;
+	my $short = slurp $shortFile or warn 'missing ' . $shortFile;
 	$short = trim $short;
 	
 	my $longFile = $repoName . '/README.md';
-	my $long = slurp $longFile or die 'missing ' . $longFile;
+	my $long = slurp $longFile or warn 'missing ' . $longFile;
 	$long = trim $long;
 	
 	my $repoUrl = 'https://registry.hub.docker.com' . $repo . '/settings/';
@@ -141,17 +142,17 @@ while (my $repo = shift) { # '/_/hylang', '/u/tianon/perl', etc
 	if ($hubShort ne $short) {
 		my $file = File::Temp->new(SUFFIX => '.txt');
 		my $filename = $file->filename;
-		spurt $hubShort . "\n", $filename;
+		spurt encode('UTF-8', $hubShort . "\n"), $filename;
 		system('vimdiff', $filename, $shortFile) == 0 or die "vimdiff on $filename and $shortFile failed";
-		$hubShort = trim(slurp($filename));
+		$hubShort = trim(decode('UTF-8', slurp($filename)));
 	}
 	
 	if ($hubLong ne $long) {
 		my $file = File::Temp->new(SUFFIX => '.md');
 		my $filename = $file->filename;
-		spurt $hubLong . "\n", $filename;
+		spurt encode('UTF-8', $hubLong . "\n"), $filename;
 		system('vimdiff', $filename, $longFile) == 0 or die "vimdiff on $filename and $longFile failed";
-		$hubLong = trim(slurp($filename));
+		$hubLong = trim(decode('UTF-8', slurp($filename)));
 	}
 	
 	say 'no change to ' . $repoName . '; skipping' and next if $settingsBits->{description} eq $hubShort and $settingsBits->{full_description} eq $hubLong;