From 34a252ef8432b6abb69f126ce645c4a31ab403c9 Mon Sep 17 00:00:00 2001 From: Larpon Date: Wed, 11 May 2022 15:56:03 +0200 Subject: [PATCH] os: add `raw_execute` on Windows (#14363) --- vlib/os/os_nix.c.v | 9 +++++++++ vlib/os/os_windows.c.v | 10 ++++++++++ 2 files changed, 19 insertions(+) diff --git a/vlib/os/os_nix.c.v b/vlib/os/os_nix.c.v index 68872cf201..2db368baec 100644 --- a/vlib/os/os_nix.c.v +++ b/vlib/os/os_nix.c.v @@ -367,6 +367,15 @@ pub fn execute(cmd string) Result { } } +// raw_execute does the same as `execute` on Unix platforms. +// On Windows raw_execute starts the specified command, waits for it to complete, and returns its output. +// It's marked as `unsafe` to help emphasize the problems that may arise by allowing, for example, +// user provided escape sequences. +[unsafe] +pub fn raw_execute(cmd string) Result { + return execute(cmd) +} + [manualfree] pub fn (mut c Command) start() ? { pcmd := c.path + ' 2>&1' diff --git a/vlib/os/os_windows.c.v b/vlib/os/os_windows.c.v index 5f3df7220a..fa13ad2b6c 100644 --- a/vlib/os/os_windows.c.v +++ b/vlib/os/os_windows.c.v @@ -293,6 +293,8 @@ pub fn get_error_msg(code int) string { } // execute starts the specified command, waits for it to complete, and returns its output. +// In opposition to `raw_execute` this function will safeguard against content that is known to cause +// a lot of problems when executing shell commands on Windows. pub fn execute(cmd string) Result { if cmd.contains(';') || cmd.contains('&&') || cmd.contains('||') || cmd.contains('\n') { return Result{ @@ -300,6 +302,14 @@ pub fn execute(cmd string) Result { output: ';, &&, || and \\n are not allowed in shell commands' } } + return unsafe { raw_execute(cmd) } +} + +// raw_execute starts the specified command, waits for it to complete, and returns its output. +// It's marked as `unsafe` to help emphasize the problems that may arise by allowing, for example, +// user provided escape sequences. +[unsafe] +pub fn raw_execute(cmd string) Result { mut child_stdin := &u32(0) mut child_stdout_read := &u32(0) mut child_stdout_write := &u32(0)