commit 03e1241b8828ff9e106d46862ca36fcd75cdc3c4 (tree)
parent 6fb636050fd0fac9615e6014316b8d42d8370f42
Author: daurnimator <quae@daurnimator.com>
Date: Fri, 10 Jan 2020 15:03:51 +1100
std: avoid an allocation in inner loop
Diffstat:
1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/lib/std/child_process.zig b/lib/std/child_process.zig
@@ -634,12 +634,12 @@ pub const ChildProcess = struct {
var it = mem.tokenize(PATH, ";");
retry: while (it.next()) |search_path| {
+ const path_no_ext = try fs.path.join(self.allocator, &[_][]const u8{ search_path, app_name });
+ defer self.allocator.free(path_no_ext);
+
var ext_it = mem.tokenize(PATHEXT, ";");
while (ext_it.next()) |app_ext| {
- const app_basename = try mem.concat(self.allocator, u8, &[_][]const u8{ app_name, app_ext });
- defer self.allocator.free(app_basename);
-
- const joined_path = try fs.path.join(self.allocator, &[_][]const u8{ search_path, app_basename });
+ const joined_path = try mem.concat(self.allocator, u8, &[_][]const u8{ path_no_ext, app_ext });
defer self.allocator.free(joined_path);
const joined_path_w = try unicode.utf8ToUtf16LeWithNull(self.allocator, joined_path);