mirror of
https://github.com/RGBCube/serenity
synced 2025-05-31 10:28:10 +00:00
env: Use Core::System::exec()
This commit is contained in:
parent
f0aba519c3
commit
f64ff945b2
1 changed files with 6 additions and 17 deletions
|
@ -8,7 +8,6 @@
|
||||||
#include <LibCore/DirIterator.h>
|
#include <LibCore/DirIterator.h>
|
||||||
#include <LibCore/System.h>
|
#include <LibCore/System.h>
|
||||||
#include <LibMain/Main.h>
|
#include <LibMain/Main.h>
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
|
@ -18,7 +17,7 @@ ErrorOr<int> serenity_main(Main::Arguments arguments)
|
||||||
|
|
||||||
bool ignore_env = false;
|
bool ignore_env = false;
|
||||||
char const* split_string = nullptr;
|
char const* split_string = nullptr;
|
||||||
Vector<char const*> values;
|
Vector<String> values;
|
||||||
|
|
||||||
Core::ArgsParser args_parser;
|
Core::ArgsParser args_parser;
|
||||||
args_parser.set_stop_on_first_non_option(true);
|
args_parser.set_stop_on_first_non_option(true);
|
||||||
|
@ -34,21 +33,17 @@ ErrorOr<int> serenity_main(Main::Arguments arguments)
|
||||||
|
|
||||||
size_t argv_start;
|
size_t argv_start;
|
||||||
for (argv_start = 0; argv_start < values.size(); ++argv_start) {
|
for (argv_start = 0; argv_start < values.size(); ++argv_start) {
|
||||||
if (StringView { values[argv_start] }.contains('=')) {
|
if (values[argv_start].contains('=')) {
|
||||||
putenv(const_cast<char*>(values[argv_start]));
|
putenv(const_cast<char*>(values[argv_start].characters()));
|
||||||
} else {
|
} else {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Vector<String> split_string_storage;
|
Vector<StringView> new_argv;
|
||||||
Vector<char const*> new_argv;
|
|
||||||
if (split_string) {
|
if (split_string) {
|
||||||
for (auto view : StringView(split_string).split_view(' ')) {
|
for (auto view : StringView(split_string).split_view(' ')) {
|
||||||
split_string_storage.append(view);
|
new_argv.append(view);
|
||||||
}
|
|
||||||
for (auto& str : split_string_storage) {
|
|
||||||
new_argv.append(str.characters());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -63,12 +58,6 @@ ErrorOr<int> serenity_main(Main::Arguments arguments)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
new_argv.append(nullptr);
|
TRY(Core::System::exec(new_argv[0], new_argv, Core::System::SearchInPath::Yes));
|
||||||
|
|
||||||
char const* executable = new_argv[0];
|
|
||||||
char* const* new_argv_ptr = const_cast<char* const*>(&new_argv[0]);
|
|
||||||
|
|
||||||
execvp(executable, new_argv_ptr);
|
|
||||||
perror("execvp");
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue