fix random lint issues

This only eliminates errors reported by `make lint`. It shouldn't cause any
functional changes.

This change does remove several functions that are unused. It also removes the
`desc_arr` variable which is both unused and out of date with reality.
This commit is contained in:
Kurtis Rader 2016-05-28 22:28:26 -07:00
parent 3d19b549c8
commit 5bf1b0e5f5
28 changed files with 102 additions and 288 deletions

View File

@ -13,7 +13,16 @@
{ symbol: ["size_t", "private", "<unistd.h>", "public"] }, { symbol: ["size_t", "private", "<unistd.h>", "public"] },
{ symbol: ["size_t", "private", "<stddef.h>", "public"] }, { symbol: ["size_t", "private", "<stddef.h>", "public"] },
{ symbol: ["size_t", "private", "<stdlib.h>", "public"] }, { symbol: ["size_t", "private", "<stdlib.h>", "public"] },
{ symbol: ["intmax_t", "private", "<sys/stdint.h>", "public"] },
{ symbol: ["intmax_t", "private", "<sys/types.h>", "public"] },
{ symbol: ["uint32_t", "private", "<sys/stdint.h>", "public"] },
{ symbol: ["uint32_t", "private", "<sys/types.h>", "public"] },
{ symbol: ["uint64_t", "private", "<sys/stdint.h>", "public"] },
{ symbol: ["uint64_t", "private", "<sys/types.h>", "public"] }, { symbol: ["uint64_t", "private", "<sys/types.h>", "public"] },
{ symbol: ["uintmax_t", "private", "<sys/stdint.h>", "public"] },
{ symbol: ["uintmax_t", "private", "<sys/types.h>", "public"] },
{ symbol: ["clock_gettime", "private", "<sys/time.h>", "public"] },
{ symbol: ["timespec", "private", "<sys/time.h>", "public"] },
{ symbol: ["memset", "private", "<string.h>", "public"] }, { symbol: ["memset", "private", "<string.h>", "public"] },
{ symbol: ["strerror", "private", "<string.h>", "public"] }, { symbol: ["strerror", "private", "<string.h>", "public"] },
] ]

View File

@ -310,7 +310,7 @@ AC_STRUCT_DIRENT_D_TYPE
AC_CHECK_FUNCS( wcsndup ) AC_CHECK_FUNCS( wcsndup )
AC_CHECK_FUNCS( futimes ) AC_CHECK_FUNCS( futimes )
AC_CHECK_FUNCS( wcslcat wcslcpy lrand48_r killpg ) AC_CHECK_FUNCS( wcslcpy lrand48_r killpg )
AC_CHECK_FUNCS( backtrace_symbols getifaddrs ) AC_CHECK_FUNCS( backtrace_symbols getifaddrs )
AC_CHECK_FUNCS( futimens clock_gettime ) AC_CHECK_FUNCS( futimens clock_gettime )

View File

@ -86,7 +86,7 @@ int autoload_t::load(const wcstring &cmd, bool reload) {
this->last_path_tokenized.clear(); this->last_path_tokenized.clear();
tokenize_variable_array(this->last_path, this->last_path_tokenized); tokenize_variable_array(this->last_path, this->last_path_tokenized);
scoped_lock locker(lock); scoped_lock locker(lock); //!OCLINT(side-effect)
this->evict_all_nodes(); this->evict_all_nodes();
} }

View File

@ -81,7 +81,7 @@
// The send stuff to foreground message. // The send stuff to foreground message.
#define FG_MSG _(L"Send job %d, '%ls' to foreground\n") #define FG_MSG _(L"Send job %d, '%ls' to foreground\n")
/// Datastructure to describe a builtin. /// Data structure to describe a builtin.
struct builtin_data_t { struct builtin_data_t {
// Name of the builtin. // Name of the builtin.
const wchar_t *name; const wchar_t *name;
@ -1807,9 +1807,7 @@ static int builtin_random(parser_t &parser, io_streams_t &streams, wchar_t **arg
srand48_r(time(0), &seed_buffer); srand48_r(time(0), &seed_buffer);
} }
lrand48_r(&seed_buffer, &res); lrand48_r(&seed_buffer, &res);
// The labs() shouldn't be necessary since lrand48 is supposed to streams.out.append_format(L"%ld\n", res % 32768);
// return only positive integers but we're going to play it safe.
streams.out.append_format(L"%ld\n", labs(res % 32768));
break; break;
} }
case 1: { case 1: {

View File

@ -67,7 +67,7 @@ static wcstring_list_t *get_transient_stack() {
static bool get_top_transient(wcstring *out_result) { static bool get_top_transient(wcstring *out_result) {
ASSERT_IS_MAIN_THREAD(); ASSERT_IS_MAIN_THREAD();
bool result = false; bool result = false;
scoped_lock locker(transient_commandline_lock); scoped_lock locker(transient_commandline_lock); //!OCLINT(side-effect)
const wcstring_list_t *stack = get_transient_stack(); const wcstring_list_t *stack = get_transient_stack();
if (!stack->empty()) { if (!stack->empty()) {
out_result->assign(stack->back()); out_result->assign(stack->back());
@ -79,7 +79,7 @@ static bool get_top_transient(wcstring *out_result) {
builtin_commandline_scoped_transient_t::builtin_commandline_scoped_transient_t( builtin_commandline_scoped_transient_t::builtin_commandline_scoped_transient_t(
const wcstring &cmd) { const wcstring &cmd) {
ASSERT_IS_MAIN_THREAD(); ASSERT_IS_MAIN_THREAD();
scoped_lock locker(transient_commandline_lock); scoped_lock locker(transient_commandline_lock); //!OCLINT(side-effect)
wcstring_list_t *stack = get_transient_stack(); wcstring_list_t *stack = get_transient_stack();
stack->push_back(cmd); stack->push_back(cmd);
this->token = stack->size(); this->token = stack->size();
@ -87,7 +87,7 @@ builtin_commandline_scoped_transient_t::builtin_commandline_scoped_transient_t(
builtin_commandline_scoped_transient_t::~builtin_commandline_scoped_transient_t() { builtin_commandline_scoped_transient_t::~builtin_commandline_scoped_transient_t() {
ASSERT_IS_MAIN_THREAD(); ASSERT_IS_MAIN_THREAD();
scoped_lock locker(transient_commandline_lock); scoped_lock locker(transient_commandline_lock); //!OCLINT(side-effect)
wcstring_list_t *stack = get_transient_stack(); wcstring_list_t *stack = get_transient_stack();
assert(this->token == stack->size()); assert(this->token == stack->size());
stack->pop_back(); stack->pop_back();

View File

@ -425,7 +425,7 @@ static completion_entry_t &complete_get_exact_entry(const wcstring &cmd, bool cm
void complete_set_authoritative(const wchar_t *cmd, bool cmd_is_path, bool authoritative) { void complete_set_authoritative(const wchar_t *cmd, bool cmd_is_path, bool authoritative) {
CHECK(cmd, ); CHECK(cmd, );
scoped_lock lock(completion_lock); scoped_lock lock(completion_lock); //!OCLINT(has side effects)
completion_entry_t &c = complete_get_exact_entry(cmd, cmd_is_path); completion_entry_t &c = complete_get_exact_entry(cmd, cmd_is_path);
c.authoritative = authoritative; c.authoritative = authoritative;
@ -439,7 +439,7 @@ void complete_add(const wchar_t *cmd, bool cmd_is_path, const wcstring &option,
assert(option.empty() == (option_type == option_type_args_only)); assert(option.empty() == (option_type == option_type_args_only));
// Lock the lock that allows us to edit the completion entry list. // Lock the lock that allows us to edit the completion entry list.
scoped_lock lock(completion_lock); scoped_lock lock(completion_lock); //!OCLINT(has side effects)
completion_entry_t &c = complete_get_exact_entry(cmd, cmd_is_path); completion_entry_t &c = complete_get_exact_entry(cmd, cmd_is_path);
@ -476,7 +476,7 @@ bool completion_entry_t::remove_option(const wcstring &option, complete_option_t
void complete_remove(const wcstring &cmd, bool cmd_is_path, const wcstring &option, void complete_remove(const wcstring &cmd, bool cmd_is_path, const wcstring &option,
complete_option_type_t type) { complete_option_type_t type) {
scoped_lock lock(completion_lock); scoped_lock lock(completion_lock); //!OCLINT(has side effects)
completion_entry_t tmp_entry(cmd, cmd_is_path, false); completion_entry_t tmp_entry(cmd, cmd_is_path, false);
completion_entry_set_t::iterator iter = completion_set.find(tmp_entry); completion_entry_set_t::iterator iter = completion_set.find(tmp_entry);
@ -493,7 +493,7 @@ void complete_remove(const wcstring &cmd, bool cmd_is_path, const wcstring &opti
} }
void complete_remove_all(const wcstring &cmd, bool cmd_is_path) { void complete_remove_all(const wcstring &cmd, bool cmd_is_path) {
scoped_lock lock(completion_lock); scoped_lock lock(completion_lock); //!OCLINT(has side effects)
completion_entry_t tmp_entry(cmd, cmd_is_path, false); completion_entry_t tmp_entry(cmd, cmd_is_path, false);
completion_set.erase(tmp_entry); completion_set.erase(tmp_entry);
@ -1340,6 +1340,7 @@ void complete(const wcstring &cmd_with_subcmds, std::vector<completion_t> *out_c
} }
} }
// cppcheck-suppress nullPointerRedundantCheck
if (cmd_node && cmd_node->location_in_or_at_end_of_source_range(pos)) { if (cmd_node && cmd_node->location_in_or_at_end_of_source_range(pos)) {
// Complete command filename. // Complete command filename.
completer.complete_cmd(current_token, use_function, use_builtin, use_command, completer.complete_cmd(current_token, use_function, use_builtin, use_command,
@ -1478,7 +1479,7 @@ static void append_switch(wcstring &out, const wcstring &opt, const wcstring &ar
wcstring complete_print() { wcstring complete_print() {
wcstring out; wcstring out;
scoped_lock locker(completion_lock); scoped_lock locker(completion_lock); //!OCLINT(side-effect)
// Get a list of all completions in a vector, then sort it by order. // Get a list of all completions in a vector, then sort it by order.
std::vector<const completion_entry_t *> all_completions; std::vector<const completion_entry_t *> all_completions;
@ -1595,7 +1596,7 @@ wcstring_list_t complete_get_wrap_chain(const wcstring &command) {
if (command.empty()) { if (command.empty()) {
return wcstring_list_t(); return wcstring_list_t();
} }
scoped_lock locker(wrapper_lock); scoped_lock locker(wrapper_lock); //!OCLINT(side-effect)
const wrapper_map_t &wraps = wrap_map(); const wrapper_map_t &wraps = wrap_map();
wcstring_list_t result; wcstring_list_t result;
@ -1631,7 +1632,7 @@ wcstring_list_t complete_get_wrap_chain(const wcstring &command) {
wcstring_list_t complete_get_wrap_pairs() { wcstring_list_t complete_get_wrap_pairs() {
wcstring_list_t result; wcstring_list_t result;
scoped_lock locker(wrapper_lock); scoped_lock locker(wrapper_lock); //!OCLINT(side-effect)
const wrapper_map_t &wraps = wrap_map(); const wrapper_map_t &wraps = wrap_map();
for (wrapper_map_t::const_iterator outer = wraps.begin(); outer != wraps.end(); ++outer) { for (wrapper_map_t::const_iterator outer = wraps.begin(); outer != wraps.end(); ++outer) {
const wcstring &cmd = outer->first; const wcstring &cmd = outer->first;

View File

@ -699,7 +699,7 @@ env_var_t env_get_string(const wcstring &key, env_mode_flags_t mode) {
if (search_local || search_global) { if (search_local || search_global) {
/* Lock around a local region */ /* Lock around a local region */
scoped_lock lock(env_lock); scoped_lock lock(env_lock); //!OCLINT(has side effects)
env_node_t *env = search_local ? top : global_env; env_node_t *env = search_local ? top : global_env;
@ -869,7 +869,7 @@ static void add_key_to_string_set(const var_table_t &envs, std::set<wcstring> *s
} }
wcstring_list_t env_get_names(int flags) { wcstring_list_t env_get_names(int flags) {
scoped_lock lock(env_lock); scoped_lock lock(env_lock); //!OCLINT(has side effects)
wcstring_list_t result; wcstring_list_t result;
std::set<wcstring> names; std::set<wcstring> names;

View File

@ -14,6 +14,7 @@
#include <sys/mman.h> #include <sys/mman.h>
#include <sys/socket.h> #include <sys/socket.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <sys/time.h>
#include <sys/types.h> #include <sys/types.h>
#include <unistd.h> #include <unistd.h>
#include <wchar.h> #include <wchar.h>
@ -311,7 +312,7 @@ void env_universal_t::set_internal(const wcstring &key, const wcstring &val, boo
} }
void env_universal_t::set(const wcstring &key, const wcstring &val, bool exportv) { void env_universal_t::set(const wcstring &key, const wcstring &val, bool exportv) {
scoped_lock locker(lock); scoped_lock locker(lock); //!OCLINT(side-effect)
this->set_internal(key, val, exportv, true /* overwrite */); this->set_internal(key, val, exportv, true /* overwrite */);
} }
@ -331,7 +332,7 @@ bool env_universal_t::remove(const wcstring &key) {
wcstring_list_t env_universal_t::get_names(bool show_exported, bool show_unexported) const { wcstring_list_t env_universal_t::get_names(bool show_exported, bool show_unexported) const {
wcstring_list_t result; wcstring_list_t result;
scoped_lock locker(lock); scoped_lock locker(lock); //!OCLINT(side-effect)
var_table_t::const_iterator iter; var_table_t::const_iterator iter;
for (iter = vars.begin(); iter != vars.end(); ++iter) { for (iter = vars.begin(); iter != vars.end(); ++iter) {
const wcstring &key = iter->first; const wcstring &key = iter->first;

View File

@ -433,17 +433,6 @@ bool process_iterator_t::next_process(wcstring *out_str, pid_t *out_pid) {
#endif #endif
std::vector<wcstring> expand_get_all_process_names(void) {
wcstring name;
pid_t pid;
process_iterator_t iterator;
std::vector<wcstring> result;
while (iterator.next_process(&name, &pid)) {
result.push_back(name);
}
return result;
}
// Helper function to do a job search. // Helper function to do a job search.
struct find_job_data_t { struct find_job_data_t {
const wchar_t *proc; // the process to search for - possibly numeric, possibly a name const wchar_t *proc; // the process to search for - possibly numeric, possibly a name

View File

@ -144,9 +144,6 @@ void expand_tilde(wcstring &input);
/// Perform the opposite of tilde expansion on the string, which is modified in place. /// Perform the opposite of tilde expansion on the string, which is modified in place.
wcstring replace_home_directory_with_tilde(const wcstring &str); wcstring replace_home_directory_with_tilde(const wcstring &str);
/// Testing function for getting all process names.
std::vector<wcstring> expand_get_all_process_names(void);
/// Abbreviation support. Expand src as an abbreviation, returning true if one was found, false if /// Abbreviation support. Expand src as an abbreviation, returning true if one was found, false if
/// not. If result is not-null, returns the abbreviation by reference. /// not. If result is not-null, returns the abbreviation by reference.
#define USER_ABBREVIATIONS_VARIABLE_NAME L"fish_user_abbreviations" #define USER_ABBREVIATIONS_VARIABLE_NAME L"fish_user_abbreviations"

View File

@ -90,6 +90,7 @@ char *tparm_solaris_kludge(char *str, ...) {
#endif #endif
#if __APPLE__
/// Fallback implementations of wcsdup and wcscasecmp. On systems where these are not needed (e.g. /// Fallback implementations of wcsdup and wcscasecmp. On systems where these are not needed (e.g.
/// building on Linux) these should end up just being stripped, as they are static functions that /// building on Linux) these should end up just being stripped, as they are static functions that
/// are not referenced in this file. /// are not referenced in this file.
@ -103,6 +104,7 @@ __attribute__((unused)) static wchar_t *wcsdup_fallback(const wchar_t *in) {
memcpy(out, in, sizeof(wchar_t) * (len + 1)); memcpy(out, in, sizeof(wchar_t) * (len + 1));
return out; return out;
} }
#endif
__attribute__((unused)) static int wcscasecmp_fallback(const wchar_t *a, const wchar_t *b) { __attribute__((unused)) static int wcscasecmp_fallback(const wchar_t *a, const wchar_t *b) {
if (*a == 0) { if (*a == 0) {
@ -168,54 +170,6 @@ wchar_t *wcsndup(const wchar_t *in, size_t c) {
} }
#endif #endif
#ifndef HAVE_WCSLCAT
/*$OpenBSD: strlcat.c,v 1.11 2003/06/17 21:56:24 millert Exp $*/
/*
* Copyright (c) 1998 Todd C. Miller <Todd.Miller@courtesan.com>
*
* Permission to use, copy, modify, and distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
size_t wcslcat(wchar_t *dst, const wchar_t *src, size_t siz) {
register wchar_t *d = dst;
register const wchar_t *s = src;
register size_t n = siz;
size_t dlen;
// Find the end of dst and adjust bytes left but don't go past end.
while (n-- != 0 && *d != '\0') d++;
dlen = d - dst;
n = siz - dlen;
if (n == 0) return dlen + wcslen(s);
while (*s != '\0') {
if (n != 1) {
*d++ = *s;
n--;
}
s++;
}
*d = '\0';
return dlen + (s - src);
/* count does not include NUL */
}
#endif
#ifndef HAVE_WCSLCPY #ifndef HAVE_WCSLCPY
/*$OpenBSD: strlcpy.c,v 1.8 2003/06/17 21:56:24 millert Exp $*/ /*$OpenBSD: strlcpy.c,v 1.8 2003/06/17 21:56:24 millert Exp $*/

View File

@ -7,7 +7,6 @@
// compiling several modules that include this header because they use symbols which are defined as // compiling several modules that include this header because they use symbols which are defined as
// macros in <term.h>. // macros in <term.h>.
// IWYU pragma: no_include <term.h> // IWYU pragma: no_include <term.h>
#include <signal.h>
#include <stdint.h> #include <stdint.h>
#include <unistd.h> #include <unistd.h>
// The following include must be kept despite what IWYU says. That's because of the interaction // The following include must be kept despite what IWYU says. That's because of the interaction
@ -83,16 +82,6 @@ wchar_t *wcsndup(const wchar_t *in, size_t c);
wchar_t *wcsndup(const wchar_t *in, size_t c); wchar_t *wcsndup(const wchar_t *in, size_t c);
#endif #endif
#ifndef HAVE_WCSLCAT
/// Appends src to string dst of size siz (unlike wcsncat, siz is the full size of dst, not space
/// left). At most siz-1 characters will be copied. Always NUL terminates (unless siz <=
/// wcslen(dst)). Returns wcslen(src) + MIN(siz, wcslen(initial dst)). If retval >= siz,
/// truncation occurred.
///
/// This is the OpenBSD strlcat function, modified for wide characters, and renamed to reflect this
/// change.
size_t wcslcat(wchar_t *dst, const wchar_t *src, size_t siz);
#endif
#ifndef HAVE_WCSLCPY #ifndef HAVE_WCSLCPY
/// Copy src to string dst of size siz. At most siz-1 characters will be copied. Always NUL /// Copy src to string dst of size siz. At most siz-1 characters will be copied. Always NUL
/// terminates (unless siz == 0). Returns wcslen(src); if retval >= siz, truncation occurred. /// terminates (unless siz == 0). Returns wcslen(src); if retval >= siz, truncation occurred.
@ -103,7 +92,7 @@ size_t wcslcpy(wchar_t *dst, const wchar_t *src, size_t siz);
#endif #endif
#ifndef HAVE_LRAND48_R #ifndef HAVE_LRAND48_R
/// Datastructure for the lrand48_r fallback implementation. /// Data structure for the lrand48_r fallback implementation.
struct drand48_data { struct drand48_data {
unsigned int seed; unsigned int seed;
}; };

View File

@ -15,6 +15,7 @@
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include <sys/select.h> #include <sys/select.h>
#include <sys/time.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/utsname.h> #include <sys/utsname.h>
#include <sys/wait.h> #include <sys/wait.h>
@ -60,7 +61,6 @@
#include "signal.h" #include "signal.h"
#include "tokenizer.h" #include "tokenizer.h"
#include "utf8.h" #include "utf8.h"
#include "util.h"
#include "wcstringutil.h" #include "wcstringutil.h"
#include "wildcard.h" #include "wildcard.h"
#include "wutil.h" // IWYU pragma: keep #include "wutil.h" // IWYU pragma: keep
@ -2194,62 +2194,6 @@ static void test_autosuggestion_combining() {
do_test(combine_command_and_autosuggestion(L"alpha", L"ALPHA") == L"alpha"); do_test(combine_command_and_autosuggestion(L"alpha", L"ALPHA") == L"alpha");
} }
/// Test speed of completion calculations.
void perf_complete() {
wchar_t c;
std::vector<completion_t> out;
long long t1, t2;
int matches = 0;
double t;
wchar_t str[3] = {0, 0, 0};
int i;
say(L"Testing completion performance");
reader_push(L"");
say(L"Here we go");
t1 = get_time();
for (c = L'a'; c <= L'z'; c++) {
str[0] = c;
reader_set_buffer(str, 0);
complete(str, &out, COMPLETION_REQUEST_DEFAULT, env_vars_snapshot_t::current());
matches += out.size();
out.clear();
}
t2 = get_time();
t = (double)(t2 - t1) / (1000000 * 26);
say(L"One letter command completion took %f seconds per completion, %f microseconds/match", t,
(double)(t2 - t1) / matches);
matches = 0;
t1 = get_time();
for (i = 0; i < LAPS; i++) {
str[0] = 'a' + (rand() % 26);
str[1] = 'a' + (rand() % 26);
reader_set_buffer(str, 0);
complete(str, &out, COMPLETION_REQUEST_DEFAULT, env_vars_snapshot_t::current());
matches += out.size();
out.clear();
}
t2 = get_time();
t = (double)(t2 - t1) / (1000000 * LAPS);
say(L"Two letter command completion took %f seconds per completion, %f microseconds/match", t,
(double)(t2 - t1) / matches);
reader_pop();
}
static void test_history_matches(history_search_t &search, size_t matches) { static void test_history_matches(history_search_t &search, size_t matches) {
size_t i; size_t i;
for (i = 0; i < matches; i++) { for (i = 0; i < matches; i++) {
@ -3937,11 +3881,6 @@ int main(int argc, char **argv) {
say(L"Encountered %d errors in low-level tests", err_count); say(L"Encountered %d errors in low-level tests", err_count);
if (s_test_run_count == 0) say(L"*** No Tests Were Actually Run! ***"); if (s_test_run_count == 0) say(L"*** No Tests Were Actually Run! ***");
// Skip performance tests for now, since they seem to hang when running from inside make.
// say( L"Testing performance" );
// perf_complete();
reader_destroy(); reader_destroy();
builtin_destroy(); builtin_destroy();
event_destroy(); event_destroy();

View File

@ -63,7 +63,7 @@ static bool is_autoload = false;
/// loaded. /// loaded.
static int load(const wcstring &name) { static int load(const wcstring &name) {
ASSERT_IS_MAIN_THREAD(); ASSERT_IS_MAIN_THREAD();
scoped_lock lock(functions_lock); scoped_lock lock(functions_lock); //!OCLINT(has side effects)
bool was_autoload = is_autoload; bool was_autoload = is_autoload;
int res; int res;
@ -163,7 +163,7 @@ void function_add(const function_data_t &data, const parser_t &parser, int defin
CHECK(!data.name.empty(), ); CHECK(!data.name.empty(), );
CHECK(data.definition, ); CHECK(data.definition, );
scoped_lock lock(functions_lock); scoped_lock lock(functions_lock); //!OCLINT(has side effects)
// Remove the old function. // Remove the old function.
function_remove(data.name); function_remove(data.name);
@ -184,21 +184,21 @@ void function_add(const function_data_t &data, const parser_t &parser, int defin
int function_exists(const wcstring &cmd) { int function_exists(const wcstring &cmd) {
if (parser_keywords_is_reserved(cmd)) return 0; if (parser_keywords_is_reserved(cmd)) return 0;
scoped_lock lock(functions_lock); scoped_lock lock(functions_lock); //!OCLINT(has side effects)
load(cmd); load(cmd);
return loaded_functions.find(cmd) != loaded_functions.end(); return loaded_functions.find(cmd) != loaded_functions.end();
} }
void function_load(const wcstring &cmd) { void function_load(const wcstring &cmd) {
if (!parser_keywords_is_reserved(cmd)) { if (!parser_keywords_is_reserved(cmd)) {
scoped_lock lock(functions_lock); scoped_lock lock(functions_lock); //!OCLINT(has side effects)
load(cmd); load(cmd);
} }
} }
int function_exists_no_autoload(const wcstring &cmd, const env_vars_snapshot_t &vars) { int function_exists_no_autoload(const wcstring &cmd, const env_vars_snapshot_t &vars) {
if (parser_keywords_is_reserved(cmd)) return 0; if (parser_keywords_is_reserved(cmd)) return 0;
scoped_lock lock(functions_lock); scoped_lock lock(functions_lock); //!OCLINT(has side effects)
return loaded_functions.find(cmd) != loaded_functions.end() || return loaded_functions.find(cmd) != loaded_functions.end() ||
function_autoloader.can_load(cmd, vars); function_autoloader.can_load(cmd, vars);
} }
@ -248,25 +248,25 @@ bool function_get_definition(const wcstring &name, wcstring *out_definition) {
} }
wcstring_list_t function_get_named_arguments(const wcstring &name) { wcstring_list_t function_get_named_arguments(const wcstring &name) {
scoped_lock lock(functions_lock); scoped_lock lock(functions_lock); //!OCLINT(has side effects)
const function_info_t *func = function_get(name); const function_info_t *func = function_get(name);
return func ? func->named_arguments : wcstring_list_t(); return func ? func->named_arguments : wcstring_list_t();
} }
std::map<wcstring, env_var_t> function_get_inherit_vars(const wcstring &name) { std::map<wcstring, env_var_t> function_get_inherit_vars(const wcstring &name) {
scoped_lock lock(functions_lock); scoped_lock lock(functions_lock); //!OCLINT(has side effects)
const function_info_t *func = function_get(name); const function_info_t *func = function_get(name);
return func ? func->inherit_vars : std::map<wcstring, env_var_t>(); return func ? func->inherit_vars : std::map<wcstring, env_var_t>();
} }
int function_get_shadow_builtin(const wcstring &name) { int function_get_shadow_builtin(const wcstring &name) {
scoped_lock lock(functions_lock); scoped_lock lock(functions_lock); //!OCLINT(has side effects)
const function_info_t *func = function_get(name); const function_info_t *func = function_get(name);
return func ? func->shadow_builtin : false; return func ? func->shadow_builtin : false;
} }
int function_get_shadow_scope(const wcstring &name) { int function_get_shadow_scope(const wcstring &name) {
scoped_lock lock(functions_lock); scoped_lock lock(functions_lock); //!OCLINT(has side effects)
const function_info_t *func = function_get(name); const function_info_t *func = function_get(name);
return func ? func->shadow_scope : false; return func ? func->shadow_scope : false;
} }
@ -285,7 +285,7 @@ bool function_get_desc(const wcstring &name, wcstring *out_desc) {
void function_set_desc(const wcstring &name, const wcstring &desc) { void function_set_desc(const wcstring &name, const wcstring &desc) {
load(name); load(name);
scoped_lock lock(functions_lock); scoped_lock lock(functions_lock); //!OCLINT(has side effects)
function_map_t::iterator iter = loaded_functions.find(name); function_map_t::iterator iter = loaded_functions.find(name);
if (iter != loaded_functions.end()) { if (iter != loaded_functions.end()) {
iter->second.description = desc; iter->second.description = desc;
@ -309,7 +309,7 @@ bool function_copy(const wcstring &name, const wcstring &new_name) {
wcstring_list_t function_get_names(int get_hidden) { wcstring_list_t function_get_names(int get_hidden) {
std::set<wcstring> names; std::set<wcstring> names;
scoped_lock lock(functions_lock); scoped_lock lock(functions_lock); //!OCLINT(has side effects)
autoload_names(names, get_hidden); autoload_names(names, get_hidden);
function_map_t::const_iterator iter; function_map_t::const_iterator iter;
@ -326,13 +326,13 @@ wcstring_list_t function_get_names(int get_hidden) {
} }
const wchar_t *function_get_definition_file(const wcstring &name) { const wchar_t *function_get_definition_file(const wcstring &name) {
scoped_lock lock(functions_lock); scoped_lock lock(functions_lock); //!OCLINT(has side effects)
const function_info_t *func = function_get(name); const function_info_t *func = function_get(name);
return func ? func->definition_file : NULL; return func ? func->definition_file : NULL;
} }
int function_get_definition_offset(const wcstring &name) { int function_get_definition_offset(const wcstring &name) {
scoped_lock lock(functions_lock); scoped_lock lock(functions_lock); //!OCLINT(has side effects)
const function_info_t *func = function_get(name); const function_info_t *func = function_get(name);
return func ? func->definition_offset : -1; return func ? func->definition_offset : -1;
} }

View File

@ -1039,6 +1039,7 @@ const highlighter_t::color_array_t &highlighter_t::highlight() {
std::fill(this->color_array.begin(), this->color_array.end(), 0); std::fill(this->color_array.begin(), this->color_array.end(), 0);
#if 0 #if 0
// Disabled for the 2.2.0 release: https://github.com/fish-shell/fish-shell/issues/1809.
const wcstring dump = parse_dump_tree(parse_tree, buff); const wcstring dump = parse_dump_tree(parse_tree, buff);
fprintf(stderr, "%ls\n", dump.c_str()); fprintf(stderr, "%ls\n", dump.c_str());
#endif #endif

View File

@ -661,22 +661,11 @@ static size_t offset_of_next_item_fish_1_x(const char *begin, size_t mmap_length
static size_t offset_of_next_item(const char *begin, size_t mmap_length, static size_t offset_of_next_item(const char *begin, size_t mmap_length,
history_file_type_t mmap_type, size_t *inout_cursor, history_file_type_t mmap_type, size_t *inout_cursor,
time_t cutoff_timestamp) { time_t cutoff_timestamp) {
size_t result; size_t result = (size_t)-1;
switch (mmap_type) { if (mmap_type == history_type_fish_2_0) {
case history_type_fish_2_0: { result = offset_of_next_item_fish_2_0(begin, mmap_length, inout_cursor, cutoff_timestamp);
result = } else if (mmap_type == history_type_fish_1_x) {
offset_of_next_item_fish_2_0(begin, mmap_length, inout_cursor, cutoff_timestamp); result = offset_of_next_item_fish_1_x(begin, mmap_length, inout_cursor);
break;
}
case history_type_fish_1_x: {
result = offset_of_next_item_fish_1_x(begin, mmap_length, inout_cursor);
break;
}
case history_type_unknown: {
// Oh well.
result = (size_t)-1;
break;
}
} }
return result; return result;
} }

View File

@ -131,39 +131,6 @@ wcstring describe_char(wint_t c) {
return format_string(L"%02x", c); return format_string(L"%02x", c);
} }
/// Description of each supported input function.
static const wchar_t *desc_arr[] = {
L"Move to beginning of line",
L"Move to end of line",
L"Move forward one character",
L"Move backward one character",
L"Move forward one word",
L"Move backward one word",
L"Search backward through list of previous commands",
L"Search forward through list of previous commands",
L"Delete one character forward",
L"Delete one character backward",
L"Move contents from cursor to end of line to killring",
L"Paste contents of killring",
L"Rotate to previous killring entry",
L"Guess the rest of the next input token",
L"Move to first item of history",
L"Move to last item of history",
L"Clear current line",
L"Move contents from beginning of line to cursor to killring",
L"Move entire line to killring",
L"Move next word to killring",
L"Move previous word to killring",
L"Write out key bindings",
L"Clear entire screen",
L"Quit the running program",
L"Search backward through list of previous commands for matching token",
L"Search forward through list of previous commands for matching token",
L"Insert the pressed key",
L"Do nothing",
L"End of file",
L"Repeat command"};
/// Internal code for each supported input function. /// Internal code for each supported input function.
static const wchar_t code_arr[] = {R_BEGINNING_OF_LINE, static const wchar_t code_arr[] = {R_BEGINNING_OF_LINE,
R_END_OF_LINE, R_END_OF_LINE,

View File

@ -38,8 +38,8 @@ static pthread_mutex_t intern_lock = PTHREAD_MUTEX_INITIALIZER;
static const wchar_t *intern_with_dup(const wchar_t *in, bool dup) { static const wchar_t *intern_with_dup(const wchar_t *in, bool dup) {
if (!in) return NULL; if (!in) return NULL;
// debug( 0, L"intern %ls", in ); debug(5, L"intern %ls", in);
scoped_lock lock(intern_lock); scoped_lock lock(intern_lock); //!OCLINT(has side effects)
const wchar_t *result; const wchar_t *result;
#if USE_SET #if USE_SET

View File

@ -8,6 +8,7 @@
#include <stdbool.h> #include <stdbool.h>
#include <stdio.h> #include <stdio.h>
#include <sys/select.h> #include <sys/select.h>
#include <sys/time.h>
#include <sys/types.h> #include <sys/types.h>
#include <unistd.h> #include <unistd.h>
#include <queue> #include <queue>
@ -107,7 +108,7 @@ static SpawnRequest_t *dequeue_spawn_request(void) {
} }
static void enqueue_thread_result(SpawnRequest_t *req) { static void enqueue_thread_result(SpawnRequest_t *req) {
scoped_lock lock(s_result_queue_lock); scoped_lock lock(s_result_queue_lock); //!OCLINT(has side effects)
s_result_queue.push(req); s_result_queue.push(req);
} }
@ -195,7 +196,7 @@ int iothread_perform_base(int (*handler)(void *), void (*completionCallback)(voi
{ {
// Lock around a local region. Note that we can only access s_active_thread_count under the // Lock around a local region. Note that we can only access s_active_thread_count under the
// lock. // lock.
scoped_lock lock(s_spawn_queue_lock); scoped_lock lock(s_spawn_queue_lock); //!OCLINT(has side effects)
add_to_queue(req); add_to_queue(req);
if (s_active_thread_count < IO_MAX_THREADS) { if (s_active_thread_count < IO_MAX_THREADS) {
s_active_thread_count++; s_active_thread_count++;
@ -293,7 +294,7 @@ static void iothread_service_main_thread_requests(void) {
// Move the queue to a local variable. // Move the queue to a local variable.
std::queue<MainThreadRequest_t *> request_queue; std::queue<MainThreadRequest_t *> request_queue;
{ {
scoped_lock queue_lock(s_main_thread_request_queue_lock); scoped_lock queue_lock(s_main_thread_request_queue_lock); //!OCLINT(has side effects)
std::swap(request_queue, s_main_thread_request_queue); std::swap(request_queue, s_main_thread_request_queue);
} }
@ -316,7 +317,7 @@ static void iothread_service_main_thread_requests(void) {
// //
// Because the waiting thread performs step 1 under the lock, if we take the lock, we avoid // Because the waiting thread performs step 1 under the lock, if we take the lock, we avoid
// posting before the waiting thread is waiting. // posting before the waiting thread is waiting.
scoped_lock broadcast_lock(s_main_thread_performer_lock); scoped_lock broadcast_lock(s_main_thread_performer_lock); //!OCLINT(has side effects)
VOMIT_ON_FAILURE(pthread_cond_broadcast(&s_main_thread_performer_condition)); VOMIT_ON_FAILURE(pthread_cond_broadcast(&s_main_thread_performer_condition));
} }
} }
@ -326,7 +327,7 @@ static void iothread_service_result_queue() {
// Move the queue to a local variable. // Move the queue to a local variable.
std::queue<SpawnRequest_t *> result_queue; std::queue<SpawnRequest_t *> result_queue;
{ {
scoped_lock queue_lock(s_result_queue_lock); scoped_lock queue_lock(s_result_queue_lock); //!OCLINT(has side effects)
std::swap(result_queue, s_result_queue); std::swap(result_queue, s_result_queue);
} }
@ -357,7 +358,7 @@ int iothread_perform_on_main_base(int (*handler)(void *), void *context) {
// Append it. Do not delete the nested scope as it is crucial to the proper functioning of this // Append it. Do not delete the nested scope as it is crucial to the proper functioning of this
// code by virtue of the lock management. // code by virtue of the lock management.
{ {
scoped_lock queue_lock(s_main_thread_request_queue_lock); scoped_lock queue_lock(s_main_thread_request_queue_lock); //!OCLINT(has side effects)
s_main_thread_request_queue.push(&req); s_main_thread_request_queue.push(&req);
} }
@ -366,7 +367,7 @@ int iothread_perform_on_main_base(int (*handler)(void *), void *context) {
VOMIT_ON_FAILURE(!write_loop(s_write_pipe, &wakeup_byte, sizeof wakeup_byte)); VOMIT_ON_FAILURE(!write_loop(s_write_pipe, &wakeup_byte, sizeof wakeup_byte));
// Wait on the condition, until we're done. // Wait on the condition, until we're done.
scoped_lock perform_lock(s_main_thread_performer_lock); scoped_lock perform_lock(s_main_thread_performer_lock); //!OCLINT(has side effects)
while (!req.done) { while (!req.done) {
// It would be nice to support checking for cancellation here, but the clients need a // It would be nice to support checking for cancellation here, but the clients need a
// deterministic way to clean up to avoid leaks // deterministic way to clean up to avoid leaks

View File

@ -4,7 +4,6 @@
// previous cuts. // previous cuts.
#include "config.h" // IWYU pragma: keep #include "config.h" // IWYU pragma: keep
#include <stdbool.h>
#include <stddef.h> #include <stddef.h>
#include <algorithm> #include <algorithm>
#include <list> #include <list>
@ -13,8 +12,6 @@
#include "common.h" #include "common.h"
#include "fallback.h" // IWYU pragma: keep #include "fallback.h" // IWYU pragma: keep
#include "kill.h"
#include "path.h"
/** Kill ring */ /** Kill ring */
typedef std::list<wcstring> kill_list_t; typedef std::list<wcstring> kill_list_t;

View File

@ -31,7 +31,7 @@
static int writeb_internal(char c); static int writeb_internal(char c);
/// The function used for output. /// The function used for output.
static int (*out)(char c) = &writeb_internal; static int (*out)(char c) = writeb_internal;
/// Name of terminal. /// Name of terminal.
static wcstring current_term; static wcstring current_term;
@ -119,7 +119,7 @@ void write_color(rgb_color_t color, bool is_fg) {
// Background: ^[48;2;<r>;<g>;<b>m // Background: ^[48;2;<r>;<g>;<b>m
color24_t rgb = color.to_color24(); color24_t rgb = color.to_color24();
char buff[128]; char buff[128];
snprintf(buff, sizeof buff, "\x1b[%u;2;%u;%u;%um", is_fg ? 38 : 48, rgb.rgb[0], rgb.rgb[1], snprintf(buff, sizeof buff, "\x1b[%d;2;%u;%u;%um", is_fg ? 38 : 48, rgb.rgb[0], rgb.rgb[1],
rgb.rgb[2]); rgb.rgb[2]);
int (*writer)(char) = output_get_writer(); int (*writer)(char) = output_get_writer();
if (writer) { if (writer) {
@ -263,7 +263,7 @@ void set_color(rgb_color_t c, rgb_color_t c2) {
} }
/// Default output method, simply calls write() on stdout. /// Default output method, simply calls write() on stdout.
static int writeb_internal(char c) { static int writeb_internal(char c) { // cppcheck
write_loop(1, &c, 1); write_loop(1, &c, 1);
return 0; return 0;
} }

View File

@ -335,7 +335,10 @@ static inline parse_token_type_t parse_token_type_from_tokenizer_token(
return result; return result;
} }
/// Helper function for dump_tree. #if 0
// Disabled for the 2.2.0 release: https://github.com/fish-shell/fish-shell/issues/1809.
/// Helper function for parse_dump_tree().
static void dump_tree_recursive(const parse_node_tree_t &nodes, const wcstring &src, static void dump_tree_recursive(const parse_node_tree_t &nodes, const wcstring &src,
node_offset_t node_idx, size_t indent, wcstring *result, node_offset_t node_idx, size_t indent, wcstring *result,
size_t *line, node_offset_t *inout_first_node_not_dumped) { size_t *line, node_offset_t *inout_first_node_not_dumped) {
@ -411,6 +414,7 @@ wcstring parse_dump_tree(const parse_node_tree_t &nodes, const wcstring &src) {
} }
return result; return result;
} }
#endif
/// Struct representing elements of the symbol stack, used in the internal state of the LL parser. /// Struct representing elements of the symbol stack, used in the internal state of the LL parser.
struct parse_stack_element_t { struct parse_stack_element_t {
@ -467,7 +471,7 @@ class parse_ll_t {
// failure (e.g. it is not an unclosed block). // failure (e.g. it is not an unclosed block).
bool report_error_for_unclosed_block(); bool report_error_for_unclosed_block();
void dump_stack(void) const; // void dump_stack(void) const;
/// Get the node corresponding to the top element of the stack. /// Get the node corresponding to the top element of the stack.
parse_node_t &node_for_top_symbol() { parse_node_t &node_for_top_symbol() {
@ -586,6 +590,7 @@ class parse_ll_t {
void acquire_output(parse_node_tree_t *output, parse_error_list_t *errors); void acquire_output(parse_node_tree_t *output, parse_error_list_t *errors);
}; };
#if 0
void parse_ll_t::dump_stack(void) const { void parse_ll_t::dump_stack(void) const {
// Walk backwards from the top, looking for parents. // Walk backwards from the top, looking for parents.
wcstring_list_t lines; wcstring_list_t lines;
@ -609,6 +614,7 @@ void parse_ll_t::dump_stack(void) const {
fprintf(stderr, " %ls\n", lines.at(idx).c_str()); fprintf(stderr, " %ls\n", lines.at(idx).c_str());
} }
} }
#endif
// Give each node a source range equal to the union of the ranges of its children. Terminal nodes // Give each node a source range equal to the union of the ranges of its children. Terminal nodes
// already have source ranges (and no children). Since children always appear after their parents, // already have source ranges (and no children). Since children always appear after their parents,

View File

@ -75,7 +75,7 @@ class io_chain_t;
/// Unknown block description. /// Unknown block description.
#define UNKNOWN_BLOCK N_(L"unknown/invalid block") #define UNKNOWN_BLOCK N_(L"unknown/invalid block")
/// Datastructure to describe a block type, like while blocks, command substitution blocks, etc. /// Data structure to describe a block type, like while blocks, command substitution blocks, etc.
struct block_lookup_entry { struct block_lookup_entry {
// The block type id. The legal values are defined in parser.h. // The block type id. The legal values are defined in parser.h.
block_type_t type; block_type_t type;
@ -225,6 +225,8 @@ const wchar_t *parser_t::get_block_desc(int block) const {
return _(UNKNOWN_BLOCK); return _(UNKNOWN_BLOCK);
} }
#if 0
// TODO: Lint says this isn't used (which is true). Should this be removed?
wcstring parser_t::block_stack_description() const { wcstring parser_t::block_stack_description() const {
wcstring result; wcstring result;
size_t idx = this->block_count(); size_t idx = this->block_count();
@ -241,6 +243,7 @@ wcstring parser_t::block_stack_description() const {
} }
return result; return result;
} }
#endif
const block_t *parser_t::block_at_index(size_t idx) const { const block_t *parser_t::block_at_index(size_t idx) const {
// Zero corresponds to the last element in our vector. // Zero corresponds to the last element in our vector.
@ -253,11 +256,7 @@ block_t *parser_t::block_at_index(size_t idx) {
return idx < count ? block_stack.at(count - idx - 1) : NULL; return idx < count ? block_stack.at(count - idx - 1) : NULL;
} }
const block_t *parser_t::current_block() const { block_t *const parser_t::current_block() { return block_stack.empty() ? NULL : block_stack.back(); }
return block_stack.empty() ? NULL : block_stack.back();
}
block_t *parser_t::current_block() { return block_stack.empty() ? NULL : block_stack.back(); }
void parser_t::forbid_function(const wcstring &function) { forbidden_function.push_back(function); } void parser_t::forbid_function(const wcstring &function) { forbidden_function.push_back(function); }

View File

@ -193,8 +193,11 @@ class parser_t {
/// The list of blocks, allocated with new. It's our responsibility to delete these. /// The list of blocks, allocated with new. It's our responsibility to delete these.
std::vector<block_t *> block_stack; std::vector<block_t *> block_stack;
#if 0
// TODO: Lint says this isn't used (which is true). Should this be removed?
/// Gets a description of the block stack, for debugging. /// Gets a description of the block stack, for debugging.
wcstring block_stack_description() const; wcstring block_stack_description() const;
#endif
/// List of profile items, allocated with new. /// List of profile items, allocated with new.
std::vector<profile_item_t *> profile_items; std::vector<profile_item_t *> profile_items;
@ -269,8 +272,7 @@ class parser_t {
block_t *block_at_index(size_t idx); block_t *block_at_index(size_t idx);
/// Returns the current (innermost) block. /// Returns the current (innermost) block.
const block_t *current_block() const; block_t *const current_block();
block_t *current_block();
/// Count of blocks. /// Count of blocks.
size_t block_count() const { return block_stack.size(); } size_t block_count() const { return block_stack.size(); }

View File

@ -167,7 +167,7 @@ static pthread_mutex_t job_id_lock = PTHREAD_MUTEX_INITIALIZER;
static std::vector<bool> consumed_job_ids; static std::vector<bool> consumed_job_ids;
job_id_t acquire_job_id(void) { job_id_t acquire_job_id(void) {
scoped_lock lock(job_id_lock); scoped_lock lock(job_id_lock); //!OCLINT(has side effects)
// Find the index of the first 0 slot. // Find the index of the first 0 slot.
std::vector<bool>::iterator slot = std::vector<bool>::iterator slot =
@ -186,7 +186,7 @@ job_id_t acquire_job_id(void) {
void release_job_id(job_id_t jid) { void release_job_id(job_id_t jid) {
assert(jid > 0); assert(jid > 0);
scoped_lock lock(job_id_lock); scoped_lock lock(job_id_lock); //!OCLINT(has side effects)
size_t slot = (size_t)(jid - 1), count = consumed_job_ids.size(); size_t slot = (size_t)(jid - 1), count = consumed_job_ids.size();
// Make sure this slot is within our vector and is currently set to consumed. // Make sure this slot is within our vector and is currently set to consumed.
@ -649,61 +649,35 @@ int job_reap(bool interactive) {
/// Get the CPU time for the specified process. /// Get the CPU time for the specified process.
unsigned long proc_get_jiffies(process_t *p) { unsigned long proc_get_jiffies(process_t *p) {
wchar_t fn[FN_SIZE]; if (p->pid <= 0) return 0;
wchar_t fn[FN_SIZE];
char state; char state;
int pid, ppid, pgrp, session, tty_nr, tpgid, exit_signal, processor; int pid, ppid, pgrp, session, tty_nr, tpgid, exit_signal, processor;
long int cutime, cstime, priority, nice, placeholder, itrealvalue, rss; long int cutime, cstime, priority, nice, placeholder, itrealvalue, rss;
unsigned long int flags, minflt, cminflt, majflt, cmajflt, utime, stime, starttime, vsize, rlim, unsigned long int flags, minflt, cminflt, majflt, cmajflt, utime, stime, starttime, vsize, rlim,
startcode, endcode, startstack, kstkesp, kstkeip, signal, blocked, sigignore, sigcatch, startcode, endcode, startstack, kstkesp, kstkeip, signal, blocked, sigignore, sigcatch,
wchan, nswap, cnswap; wchan, nswap, cnswap;
char comm[1024]; char comm[1024];
if (p->pid <= 0) return 0;
swprintf(fn, FN_SIZE, L"/proc/%d/stat", p->pid); swprintf(fn, FN_SIZE, L"/proc/%d/stat", p->pid);
FILE *f = wfopen(fn, "r"); FILE *f = wfopen(fn, "r");
if (!f) return 0; if (!f) return 0;
int count = fscanf( // TODO: replace the use of fscanf() as it is brittle and should never be used.
f, int count = fscanf(f,
"%d %s %c " "%9d %1023s %c %9d %9d %9d %9d %9d %9lu "
"%d %d %d " "%9lu %9lu %9lu %9lu %9lu %9lu %9ld %9ld %9ld "
"%d %d %lu " "%9ld %9ld %9ld %9lu %9lu %9ld %9lu %9lu %9lu "
"%9lu %9lu %9lu %9lu %9lu %9lu %9lu %9lu %9lu "
"%lu %lu %lu " "%9lu %9d %9d ",
"%lu %lu %lu " &pid, comm, &state, &ppid, &pgrp, &session, &tty_nr, &tpgid, &flags, &minflt,
"%ld %ld %ld " &cminflt, &majflt, &cmajflt, &utime, &stime, &cutime, &cstime, &priority,
&nice, &placeholder, &itrealvalue, &starttime, &vsize, &rss, &rlim,
"%ld %ld %ld " &startcode, &endcode, &startstack, &kstkesp, &kstkeip, &signal, &blocked,
"%lu %lu %ld " &sigignore, &sigcatch, &wchan, &nswap, &cnswap, &exit_signal, &processor);
"%lu %lu %lu "
"%lu %lu %lu "
"%lu %lu %lu "
"%lu %lu %lu "
"%lu %d %d ",
&pid, comm, &state, &ppid, &pgrp, &session, &tty_nr, &tpgid, &flags,
&minflt, &cminflt, &majflt, &cmajflt, &utime, &stime, &cutime, &cstime, &priority,
&nice, &placeholder, &itrealvalue, &starttime, &vsize, &rss, &rlim, &startcode, &endcode,
&startstack, &kstkesp, &kstkeip, &signal, &blocked, &sigignore, &sigcatch, &wchan, &nswap,
&cnswap, &exit_signal, &processor);
// Don't need to check exit status of fclose on read-only streams.
fclose(f); fclose(f);
if (count < 17) return 0;
if (count < 17) {
return 0;
}
return utime + stime + cutime + cstime; return utime + stime + cutime + cstime;
} }

View File

@ -198,11 +198,13 @@ static void default_handler(int signal, siginfo_t *info, void *context) {
} }
} }
#ifdef SIGWINCH
/// Respond to a winch signal by checking the terminal size. /// Respond to a winch signal by checking the terminal size.
static void handle_winch(int sig, siginfo_t *info, void *context) { static void handle_winch(int sig, siginfo_t *info, void *context) {
common_handle_winch(sig); common_handle_winch(sig);
default_handler(sig, 0, 0); default_handler(sig, 0, 0);
} }
#endif
/// Respond to a hup signal by exiting, unless it is caught by a shellscript function, in which case /// Respond to a hup signal by exiting, unless it is caught by a shellscript function, in which case
/// we do nothing. /// we do nothing.

View File

@ -6,7 +6,6 @@
#include <errno.h> #include <errno.h>
#include <stdlib.h> #include <stdlib.h>
#include <sys/time.h> #include <sys/time.h>
#include <sys/types.h>
#include <wchar.h> #include <wchar.h>
#include <wctype.h> #include <wctype.h>

View File

@ -415,7 +415,7 @@ const wchar_t *wgettext(const wchar_t *in) {
wgettext_init_if_necessary(); wgettext_init_if_necessary();
wcstring key = in; wcstring key = in;
scoped_lock lock(wgettext_lock); scoped_lock lock(wgettext_lock); //!OCLINT(has side effects)
wcstring &val = wgettext_map[key]; wcstring &val = wgettext_map[key];
if (val.empty()) { if (val.empty()) {