Use std::move instead of swap in a few places where it improves clarity

This commit is contained in:
ridiculousfish 2017-01-26 16:14:50 -08:00
parent fec83fa975
commit 1efb81456b
13 changed files with 26 additions and 28 deletions

View file

@ -1330,7 +1330,7 @@ static bool unescape_string_internal(const wchar_t *const input, const size_t in
// Return the string by reference, and then success. // Return the string by reference, and then success.
if (!errored) { if (!errored) {
output_str->swap(result); *output_str = std::move(result);
} }
return !errored; return !errored;
} }
@ -1340,7 +1340,7 @@ bool unescape_string_in_place(wcstring *str, unescape_flags_t escape_special) {
wcstring output; wcstring output;
bool success = unescape_string_internal(str->c_str(), str->size(), &output, escape_special); bool success = unescape_string_internal(str->c_str(), str->size(), &output, escape_special);
if (success) { if (success) {
str->swap(output); *str = std::move(output);
} }
return success; return success;
} }

View file

@ -598,15 +598,16 @@ class scoped_push {
public: public:
explicit scoped_push(T *r) : ref(r), saved_value(*r), restored(false) {} explicit scoped_push(T *r) : ref(r), saved_value(*r), restored(false) {}
scoped_push(T *r, const T &new_value) : ref(r), saved_value(*r), restored(false) { scoped_push(T *r, T new_value) : ref(r), restored(false) {
*r = new_value; saved_value = std::move(*ref);
*ref = std::move(new_value);
} }
~scoped_push() { restore(); } ~scoped_push() { restore(); }
void restore() { void restore() {
if (!restored) { if (!restored) {
std::swap(*ref, saved_value); *ref = std::move(saved_value);
restored = true; restored = true;
} }
} }

View file

@ -1624,7 +1624,7 @@ wcstring_list_t complete_get_wrap_chain(const wcstring &command) {
wcstring target; wcstring target;
while (!to_visit.empty()) { while (!to_visit.empty()) {
// Grab the next command to visit, put it in target. // Grab the next command to visit, put it in target.
target.swap(to_visit.back()); target = std::move(to_visit.back());
to_visit.pop_back(); to_visit.pop_back();
// Try inserting into visited. If it was already present, we skip it; this is how we avoid // Try inserting into visited. If it was already present, we skip it; this is how we avoid

View file

@ -389,13 +389,13 @@ void env_universal_t::acquire_variables(var_table_t *vars_to_acquire) {
// source entry in vars since we are about to get rid of this->vars entirely. // source entry in vars since we are about to get rid of this->vars entirely.
var_entry_t &src = src_iter->second; var_entry_t &src = src_iter->second;
var_entry_t &dst = (*vars_to_acquire)[key]; var_entry_t &dst = (*vars_to_acquire)[key];
dst.val.swap(src.val); dst.val = std::move(src.val);
dst.exportv = src.exportv; dst.exportv = src.exportv;
} }
} }
// We have constructed all the callbacks and updated vars_to_acquire. Acquire it! // We have constructed all the callbacks and updated vars_to_acquire. Acquire it!
this->vars.swap(*vars_to_acquire); this->vars = std::move(*vars_to_acquire);
} }
void env_universal_t::load_from_fd(int fd, callback_data_list_t *callbacks) { void env_universal_t::load_from_fd(int fd, callback_data_list_t *callbacks) {
@ -844,7 +844,7 @@ void env_universal_t::parse_message_internal(const wcstring &msgstr, var_table_t
if (unescape_string(tmp + 1, &val, 0)) { if (unescape_string(tmp + 1, &val, 0)) {
var_entry_t &entry = (*vars)[key]; var_entry_t &entry = (*vars)[key];
entry.exportv = exportv; entry.exportv = exportv;
entry.val.swap(val); // acquire the value entry.val = std::move(val); // acquire the value
} }
} else { } else {
debug(1, PARSE_ERR, msg); debug(1, PARSE_ERR, msg);

View file

@ -291,8 +291,8 @@ static bool io_transmogrify(const io_chain_t &in_chain, io_chain_t *out_chain,
// Now either return success, or clean up. // Now either return success, or clean up.
if (success) { if (success) {
out_chain->swap(result_chain); *out_chain = std::move(result_chain);
out_opened_fds->swap(opened_fds); *out_opened_fds = std::move(opened_fds);
} else { } else {
result_chain.clear(); result_chain.clear();
io_cleanup_fds(opened_fds); io_cleanup_fds(opened_fds);

View file

@ -820,7 +820,7 @@ static int expand_variables(const wcstring &instr, std::vector<completion_t> *ou
} }
// string_values is the new var_item_list. // string_values is the new var_item_list.
var_item_list.swap(string_values); var_item_list = std::move(string_values);
} }
} }

View file

@ -237,7 +237,7 @@ bool plain_statement_get_expanded_command(const wcstring &src, const parse_node_
if (tree.command_for_plain_statement(plain_statement, src, &cmd) && if (tree.command_for_plain_statement(plain_statement, src, &cmd) &&
expand_one(cmd, EXPAND_SKIP_CMDSUBST | EXPAND_SKIP_VARIABLES | EXPAND_SKIP_JOBS)) { expand_one(cmd, EXPAND_SKIP_CMDSUBST | EXPAND_SKIP_VARIABLES | EXPAND_SKIP_JOBS)) {
// Success, return the expanded string by reference. // Success, return the expanded string by reference.
out_cmd->swap(cmd); *out_cmd = std::move(cmd);
return true; return true;
} }
return false; return false;

View file

@ -293,7 +293,7 @@ static void iothread_service_main_thread_requests(void) {
std::queue<main_thread_request_t *> request_queue; std::queue<main_thread_request_t *> request_queue;
{ {
scoped_lock queue_lock(s_main_thread_request_q_lock); scoped_lock queue_lock(s_main_thread_request_q_lock);
std::swap(request_queue, s_main_thread_request_queue); request_queue.swap(s_main_thread_request_queue);
} }
if (!request_queue.empty()) { if (!request_queue.empty()) {
@ -326,7 +326,7 @@ static void iothread_service_result_queue() {
std::queue<spawn_request_t> result_queue; std::queue<spawn_request_t> result_queue;
{ {
scoped_lock queue_lock(s_result_queue_lock); scoped_lock queue_lock(s_result_queue_lock);
std::swap(result_queue, s_result_queue); result_queue.swap(s_result_queue);
} }
// Perform each completion in order. We are responsibile for cleaning them up. // Perform each completion in order. We are responsibile for cleaning them up.

View file

@ -948,14 +948,11 @@ parse_execution_result_t parse_execution_context_t::determine_arguments(
} }
} }
// Now copy over any expanded arguments. Do it using swap() to avoid extra allocations; this // Now copy over any expanded arguments. Use std::move() to avoid extra allocations; this
// is called very frequently. // is called very frequently.
size_t old_arg_count = out_arguments->size(); out_arguments->reserve(out_arguments->size() + arg_expanded.size());
size_t new_arg_count = arg_expanded.size(); for (completion_t &new_arg : arg_expanded) {
out_arguments->resize(old_arg_count + new_arg_count); out_arguments->push_back(std::move(new_arg.completion));
for (size_t i = 0; i < new_arg_count; i++) {
wcstring &new_arg = arg_expanded.at(i).completion;
out_arguments->at(old_arg_count + i).swap(new_arg);
} }
} }
@ -1035,7 +1032,7 @@ bool parse_execution_context_t::determine_io_chain(const parse_node_t &statement
} }
if (out_chain && !errored) { if (out_chain && !errored) {
out_chain->swap(result); *out_chain = std::move(result);
} }
return !errored; return !errored;
} }

View file

@ -1293,11 +1293,11 @@ parser_test_error_bits_t parse_util_detect_errors(const wcstring &buff_src,
if (has_unclosed_block || has_unclosed_quote) res |= PARSER_TEST_INCOMPLETE; if (has_unclosed_block || has_unclosed_quote) res |= PARSER_TEST_INCOMPLETE;
if (out_errors != NULL) { if (out_errors != NULL) {
out_errors->swap(parse_errors); *out_errors = std::move(parse_errors);
} }
if (out_tree != NULL) { if (out_tree != NULL) {
out_tree->swap(node_tree); *out_tree = std::move(node_tree);
} }
return res; return res;

View file

@ -72,7 +72,7 @@ static bool path_get_path_core(const wcstring &cmd, wcstring *out_path,
continue; continue;
} }
if (S_ISREG(buff.st_mode)) { if (S_ISREG(buff.st_mode)) {
if (out_path) out_path->swap(nxt_path); if (out_path) *out_path = std::move(nxt_path);
return true; return true;
} }
err = EACCES; err = EACCES;

View file

@ -625,7 +625,7 @@ bool reader_data_t::expand_abbreviation_as_necessary(size_t cursor_backtrack) {
// lengths. // lengths.
size_t new_buff_pos = el->position + new_cmdline.size() - el->text.size(); size_t new_buff_pos = el->position + new_cmdline.size() - el->text.size();
el->text.swap(new_cmdline); el->text = std::move(new_cmdline);
update_buff_pos(el, new_buff_pos); update_buff_pos(el, new_buff_pos);
data->command_line_changed(el); data->command_line_changed(el);
result = true; result = true;

View file

@ -609,7 +609,7 @@ wcstring tok_first(const wcstring &str) {
tokenizer_t t(str.c_str(), TOK_SQUASH_ERRORS); tokenizer_t t(str.c_str(), TOK_SQUASH_ERRORS);
tok_t token; tok_t token;
if (t.next(&token) && token.type == TOK_STRING) { if (t.next(&token) && token.type == TOK_STRING) {
result.swap(token.text); result = std::move(token.text);
} }
return result; return result;
} }