aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPedro Alves <palves@redhat.com>2017-04-13 11:46:07 +0100
committerPedro Alves <palves@redhat.com>2017-04-13 11:46:07 +0100
commit808480f667e41e2fdb66bfdc9d5e047f1aa34a68 (patch)
tree6af17a76cdbe8aa21e47ea3e68c173f553c5dec4 /opcodes/m32r-desc.c
parent * config.sub: Sync with master version in config project. (diff)
downloadbinutils-gdb-808480f667e41e2fdb66bfdc9d5e047f1aa34a68.tar.gz
binutils-gdb-808480f667e41e2fdb66bfdc9d5e047f1aa34a68.tar.bz2
binutils-gdb-808480f667e41e2fdb66bfdc9d5e047f1aa34a68.zip
fork-child.c: Avoid unnecessary heap-allocation / string copying
The previous change to fork-child.c converted the argv building from an alloca-allocated array of non-owning arg pointers, to a std::vector of owning pointers, which results in N string dups, with N being the number of arguments in the vector, and then requires manually releasing the pointers owned by the vector. This patch makes the vector hold non-owning pointers, and avoids the string dups, by doing one single string copy of the arguments upfront, and replacing separators with NULL terminators in place, like we used to. All the logic to do that is encapsulated in a new class. With this, there's no need to remember to manually release the argv elements with free_vector_argv either. gdb/ChangeLog: 2017-04-13 Pedro Alves <palves@redhat.com> * fork-child.c (execv_argv): New class. (breakup_args): Refactored as ... (execv_argv::init_for_no_shell): .. this method of execv_argv. Copy arguments to storage and replace separators with NULL terminators in place. (escape_bang_in_quoted_argument): Adjust to return bool. (execv_argv::execv_argv): New ctor. (execv_argv::init_for_shell): New method, factored out from fork_inferior. Don't strdup strings into the vector. (fork_inferior): Eliminate "shell" local and use execv_argv. Use Remove free_vector_argv call.
Diffstat (limited to 'opcodes/m32r-desc.c')
0 files changed, 0 insertions, 0 deletions