zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

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:
Mlib/std/child_process.zig | 8++++----
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);