4621: implement lean_uri_escape
authorTim Pierce <twp@curoverse.com>
Tue, 25 Nov 2014 22:52:05 +0000 (17:52 -0500)
committerTim Pierce <twp@curoverse.com>
Tue, 25 Nov 2014 22:54:20 +0000 (17:54 -0500)
lean_uri_escape implements URI escaping as in URI::Escape, but with
substantially less RAM (at the cost of less error checking).

Also fixes a bug in crunch-job's strftime call.

sdk/cli/bin/crunch-job
sdk/perl/lib/Arvados/Request.pm

index 0d35d53f9d2b924ea8b583fda5b5a3a682be09fb..0265a4862f1bd6cf09f62498ea2d30100ee57a9f 100755 (executable)
@@ -1702,7 +1702,7 @@ sub api_call {
     if ($next_try_at < time) {
       $retry_msg = "Retrying.";
     } else {
-      my $next_try_fmt = strftime("%Y-%m-%d %H:%M:%S", $next_try_at);
+      my $next_try_fmt = strftime("%Y-%m-%d %H:%M:%S", localtime($next_try_at));
       $retry_msg = "Retrying at $next_try_fmt.";
     }
     Log(undef, "API method $method_name failed: $errmsg. $retry_msg");
index 07ca763d2b3efd6a3182c072ab92a023307c65a5..f2a9b63631502ce9ed8f1053c9bd60b436d4bf15 100644 (file)
@@ -49,9 +49,9 @@ sub process_request
     my $content;
     while (($p, $v) = each %content) {
         $content .= '&' unless $content eq '';
-        $content .= uri_escape($p);
+        $content .= lean_uri_escape($p);
         $content .= '=';
-        $content .= uri_escape($v);
+        $content .= lean_uri_escape($v);
     }
     $self->{'req'}->content_type("application/x-www-form-urlencoded; charset='utf8'");
     $self->{'req'}->content(Encode::encode('utf8', $content));
@@ -94,4 +94,12 @@ sub get_headers
     ""
 }
 
+# lean_uri_escape consumes about half as much memory
+# as URI::Escape::uri_escape.
+sub lean_uri_escape {
+    my ($text) = @_;
+    $text =~ s/([^A-Za-z0-9\-\._~])/$URI::Escape::escapes{$&}/ge;
+    return $text;
+}
+
 1;