mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-04 00:58:46 +00:00
Convert constant macros to constexpr expressions
Also convert some `const[expr] static xxx` to `const[expr] xxx` where it makes sense to let the compiler deduce on its own whether or not to allocate storage for a constant variable rather than imposing our view that it should have STATIC storage set aside for it. A few call sites were not making use of the `XXX_LEN` definitions and were calling `strlen(XXX)` - these have been updated to use `const_strlen(XXX)` instead. I'm not sure if any toolchains will have raise any issues with these changes... CI will tell!
This commit is contained in:
parent
549958a7ea
commit
e1626818f7
37 changed files with 115 additions and 116 deletions
|
@ -17,7 +17,7 @@
|
||||||
#include "wutil.h" // IWYU pragma: keep
|
#include "wutil.h" // IWYU pragma: keep
|
||||||
|
|
||||||
/// The time before we'll recheck an autoloaded file.
|
/// The time before we'll recheck an autoloaded file.
|
||||||
static const int kAutoloadStalenessInterval = 15;
|
const int kAutoloadStalenessInterval = 15;
|
||||||
|
|
||||||
/// Represents a file that we might want to autoload.
|
/// Represents a file that we might want to autoload.
|
||||||
namespace {
|
namespace {
|
||||||
|
|
|
@ -224,7 +224,8 @@ static maybe_t<int> builtin_generic(parser_t &parser, io_streams_t &streams, con
|
||||||
|
|
||||||
// How many bytes we read() at once.
|
// How many bytes we read() at once.
|
||||||
// Since this is just for counting, it can be massive.
|
// Since this is just for counting, it can be massive.
|
||||||
#define COUNT_CHUNK_SIZE (512 * 256)
|
constexpr int COUNT_CHUNK_SIZE = 512 * 256;
|
||||||
|
|
||||||
/// Implementation of the builtin count command, used to count the number of arguments sent to it.
|
/// Implementation of the builtin count command, used to count the number of arguments sent to it.
|
||||||
static maybe_t<int> builtin_count(parser_t &parser, io_streams_t &streams, const wchar_t **argv) {
|
static maybe_t<int> builtin_count(parser_t &parser, io_streams_t &streams, const wchar_t **argv) {
|
||||||
UNUSED(parser);
|
UNUSED(parser);
|
||||||
|
@ -413,7 +414,7 @@ static constexpr builtin_data_t builtin_datas[] = {
|
||||||
};
|
};
|
||||||
ASSERT_SORTED_BY_NAME(builtin_datas);
|
ASSERT_SORTED_BY_NAME(builtin_datas);
|
||||||
|
|
||||||
#define BUILTIN_COUNT (sizeof builtin_datas / sizeof *builtin_datas)
|
constexpr int BUILTIN_COUNT = sizeof builtin_datas / sizeof *builtin_datas;
|
||||||
|
|
||||||
/// Look up a builtin_data_t for a specified builtin
|
/// Look up a builtin_data_t for a specified builtin
|
||||||
///
|
///
|
||||||
|
|
|
@ -19,7 +19,7 @@
|
||||||
#include "../wutil.h" // IWYU pragma: keep
|
#include "../wutil.h" // IWYU pragma: keep
|
||||||
|
|
||||||
// The maximum number of points after the decimal that we'll print.
|
// The maximum number of points after the decimal that we'll print.
|
||||||
static constexpr int kDefaultScale = 6;
|
constexpr int kDefaultScale = 6;
|
||||||
|
|
||||||
// The end of the range such that every integer is representable as a double.
|
// The end of the range such that every integer is representable as a double.
|
||||||
// i.e. this is the first value such that x + 1 == x (or == x + 2, depending on rounding mode).
|
// i.e. this is the first value such that x + 1 == x (or == x + 2, depending on rounding mode).
|
||||||
|
|
|
@ -34,7 +34,7 @@
|
||||||
// How many bytes we read() at once.
|
// How many bytes we read() at once.
|
||||||
// We use PATH_MAX here so we always get at least one path,
|
// We use PATH_MAX here so we always get at least one path,
|
||||||
// and so we can automatically detect NULL-separated input.
|
// and so we can automatically detect NULL-separated input.
|
||||||
#define PATH_CHUNK_SIZE PATH_MAX
|
constexpr int PATH_CHUNK_SIZE = PATH_MAX;
|
||||||
|
|
||||||
static void path_error(io_streams_t &streams, const wchar_t *fmt, ...) {
|
static void path_error(io_streams_t &streams, const wchar_t *fmt, ...) {
|
||||||
streams.err.append(L"path ");
|
streams.err.append(L"path ");
|
||||||
|
|
|
@ -247,7 +247,7 @@ static int read_interactive(parser_t &parser, wcstring &buff, int nchars, bool s
|
||||||
/// Bash uses 128 bytes for its chunk size. Very informal testing I did suggested that a smaller
|
/// Bash uses 128 bytes for its chunk size. Very informal testing I did suggested that a smaller
|
||||||
/// chunk size performed better. However, we're going to use the bash value under the assumption
|
/// chunk size performed better. However, we're going to use the bash value under the assumption
|
||||||
/// they've done more extensive testing.
|
/// they've done more extensive testing.
|
||||||
#define READ_CHUNK_SIZE 128
|
constexpr int READ_CHUNK_SIZE = 128;
|
||||||
|
|
||||||
/// Read from the fd in chunks until we see newline or null, as requested, is seen. This is only
|
/// Read from the fd in chunks until we see newline or null, as requested, is seen. This is only
|
||||||
/// used when the fd is seekable (so not from a tty or pipe) and we're not reading a specific number
|
/// used when the fd is seekable (so not from a tty or pipe) and we're not reading a specific number
|
||||||
|
|
|
@ -34,7 +34,7 @@
|
||||||
// Empirically determined.
|
// Empirically determined.
|
||||||
// This is probably down to some pipe buffer or some such,
|
// This is probably down to some pipe buffer or some such,
|
||||||
// but too small means we need to call `read(2)` and str2wcstring a lot.
|
// but too small means we need to call `read(2)` and str2wcstring a lot.
|
||||||
#define STRING_CHUNK_SIZE 1024
|
constexpr int STRING_CHUNK_SIZE = 1024;
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
|
|
|
@ -81,7 +81,7 @@ static const struct resource_t resource_arr[] = {
|
||||||
|
|
||||||
/// This is likely to be the same as RLIMIT_INFINITY, but it shouldn't get used
|
/// This is likely to be the same as RLIMIT_INFINITY, but it shouldn't get used
|
||||||
/// in the same context (that is, compared to the result of a getrlimit call).
|
/// in the same context (that is, compared to the result of a getrlimit call).
|
||||||
#define RLIMIT_UNKNOWN -1
|
constexpr int RLIMIT_UNKNOWN = -1;
|
||||||
|
|
||||||
/// Get the implicit multiplication factor for the specified resource limit.
|
/// Get the implicit multiplication factor for the specified resource limit.
|
||||||
static int get_multiplier(int what) {
|
static int get_multiplier(int what) {
|
||||||
|
|
|
@ -1372,7 +1372,7 @@ static bool unescape_string_internal(const wchar_t *const input, const size_t in
|
||||||
if (unescape_special && input_position == 0 &&
|
if (unescape_special && input_position == 0 &&
|
||||||
!std::wcscmp(input, PROCESS_EXPAND_SELF_STR)) {
|
!std::wcscmp(input, PROCESS_EXPAND_SELF_STR)) {
|
||||||
to_append_or_none = PROCESS_EXPAND_SELF;
|
to_append_or_none = PROCESS_EXPAND_SELF;
|
||||||
input_position += PROCESS_EXPAND_SELF_STR_LEN - 1; // skip over 'self's
|
input_position += const_strlen(PROCESS_EXPAND_SELF_STR) - 1; // skip over 'self's
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
36
src/common.h
36
src/common.h
|
@ -55,34 +55,34 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Common string type.
|
// Common string type.
|
||||||
typedef std::wstring wcstring;
|
using wcstring = std::wstring;
|
||||||
typedef std::vector<wcstring> wcstring_list_t;
|
using wcstring_list_t = std::vector<wcstring>;
|
||||||
|
|
||||||
struct termsize_t;
|
struct termsize_t;
|
||||||
|
|
||||||
// Highest legal ASCII value.
|
// Highest legal ASCII value.
|
||||||
#define ASCII_MAX 127u
|
constexpr char ASCII_MAX = 127U;
|
||||||
|
|
||||||
// Highest legal 16-bit Unicode value.
|
// Highest legal 16-bit Unicode value.
|
||||||
#define UCS2_MAX 0xFFFFu
|
constexpr uint16_t UCS2_MAX = 0xFFFF;
|
||||||
|
|
||||||
// Highest legal byte value.
|
// Highest legal byte value.
|
||||||
#define BYTE_MAX 0xFFu
|
constexpr uint8_t BYTE_MAX = 0xFF;
|
||||||
|
|
||||||
// Unicode BOM value.
|
// Unicode BOM value.
|
||||||
#define UTF8_BOM_WCHAR 0xFEFFu
|
constexpr uint16_t UTF8_BOM_WCHAR = 0xFEFF;
|
||||||
|
|
||||||
// Use Unicode "noncharacters" for internal characters as much as we can. This
|
// Use Unicode "noncharacters" for internal characters as much as we can. This
|
||||||
// gives us 32 "characters" for internal use that we can guarantee should not
|
// gives us 32 "characters" for internal use that we can guarantee should not
|
||||||
// appear in our input stream. See http://www.unicode.org/faq/private_use.html.
|
// appear in our input stream. See http://www.unicode.org/faq/private_use.html.
|
||||||
#define RESERVED_CHAR_BASE static_cast<wchar_t>(0xFDD0)
|
constexpr wchar_t RESERVED_CHAR_BASE = static_cast<wchar_t>(0xFDD0);
|
||||||
#define RESERVED_CHAR_END static_cast<wchar_t>(0xFDF0)
|
constexpr wchar_t RESERVED_CHAR_END = static_cast<wchar_t>(0xFDF0);
|
||||||
// Split the available noncharacter values into two ranges to ensure there are
|
// Split the available noncharacter values into two ranges to ensure there are
|
||||||
// no conflicts among the places we use these special characters.
|
// no conflicts among the places we use these special characters.
|
||||||
#define EXPAND_RESERVED_BASE RESERVED_CHAR_BASE
|
constexpr wchar_t EXPAND_RESERVED_BASE = RESERVED_CHAR_BASE;
|
||||||
#define EXPAND_RESERVED_END (EXPAND_RESERVED_BASE + 16)
|
constexpr wchar_t EXPAND_RESERVED_END = (EXPAND_RESERVED_BASE + 16);
|
||||||
#define WILDCARD_RESERVED_BASE EXPAND_RESERVED_END
|
constexpr wchar_t WILDCARD_RESERVED_BASE = EXPAND_RESERVED_END;
|
||||||
#define WILDCARD_RESERVED_END (WILDCARD_RESERVED_BASE + 16)
|
constexpr wchar_t WILDCARD_RESERVED_END = (WILDCARD_RESERVED_BASE + 16);
|
||||||
// Make sure the ranges defined above don't exceed the range for noncharacters.
|
// Make sure the ranges defined above don't exceed the range for noncharacters.
|
||||||
// This is to make sure we didn't do something stupid in subdividing the
|
// This is to make sure we didn't do something stupid in subdividing the
|
||||||
// Unicode range for our needs.
|
// Unicode range for our needs.
|
||||||
|
@ -102,8 +102,8 @@ struct termsize_t;
|
||||||
// Note: We don't use the highest 8 bit range (0xF800 - 0xF8FF) because we know
|
// Note: We don't use the highest 8 bit range (0xF800 - 0xF8FF) because we know
|
||||||
// of at least one use of a codepoint in that range: the Apple symbol (0xF8FF)
|
// of at least one use of a codepoint in that range: the Apple symbol (0xF8FF)
|
||||||
// on Mac OS X. See http://www.unicode.org/faq/private_use.html.
|
// on Mac OS X. See http://www.unicode.org/faq/private_use.html.
|
||||||
#define ENCODE_DIRECT_BASE static_cast<wchar_t>(0xF600)
|
constexpr wchar_t ENCODE_DIRECT_BASE = static_cast<wchar_t>(0xF600);
|
||||||
#define ENCODE_DIRECT_END (ENCODE_DIRECT_BASE + 256)
|
constexpr wchar_t ENCODE_DIRECT_END = (ENCODE_DIRECT_BASE + 256);
|
||||||
|
|
||||||
// NAME_MAX is not defined on Solaris
|
// NAME_MAX is not defined on Solaris
|
||||||
#if !defined(NAME_MAX)
|
#if !defined(NAME_MAX)
|
||||||
|
@ -140,7 +140,7 @@ enum {
|
||||||
UNESCAPE_INCOMPLETE = 1 << 1, // allow incomplete escape sequences
|
UNESCAPE_INCOMPLETE = 1 << 1, // allow incomplete escape sequences
|
||||||
UNESCAPE_NO_BACKSLASHES = 1 << 2, // don't handle backslash escapes
|
UNESCAPE_NO_BACKSLASHES = 1 << 2, // don't handle backslash escapes
|
||||||
};
|
};
|
||||||
typedef unsigned int unescape_flags_t;
|
using unescape_flags_t = unsigned int;
|
||||||
|
|
||||||
// Flags for the escape_string() function. These are only applicable when the escape style is
|
// Flags for the escape_string() function. These are only applicable when the escape style is
|
||||||
// "script" (i.e., STRING_STYLE_SCRIPT).
|
// "script" (i.e., STRING_STYLE_SCRIPT).
|
||||||
|
@ -156,7 +156,7 @@ enum {
|
||||||
/// Replace nonprintable control characters with Unicode symbols.
|
/// Replace nonprintable control characters with Unicode symbols.
|
||||||
ESCAPE_SYMBOLIC = 1 << 3
|
ESCAPE_SYMBOLIC = 1 << 3
|
||||||
};
|
};
|
||||||
typedef unsigned int escape_flags_t;
|
using escape_flags_t = unsigned int;
|
||||||
|
|
||||||
/// A user-visible job ID.
|
/// A user-visible job ID.
|
||||||
using job_id_t = int;
|
using job_id_t = int;
|
||||||
|
@ -300,7 +300,7 @@ std::string wcs2string(const wchar_t *in, size_t len);
|
||||||
void wcs2string_appending(const wchar_t *in, size_t len, std::string *receiver);
|
void wcs2string_appending(const wchar_t *in, size_t len, std::string *receiver);
|
||||||
|
|
||||||
// Check if we are running in the test mode, where we should suppress error output
|
// Check if we are running in the test mode, where we should suppress error output
|
||||||
#define TESTS_PROGRAM_NAME L"(ignore)"
|
constexpr const wchar_t TESTS_PROGRAM_NAME[] = L"(ignore)";
|
||||||
bool should_suppress_stderr_for_tests();
|
bool should_suppress_stderr_for_tests();
|
||||||
|
|
||||||
/// Branch prediction hints. Idea borrowed from Linux kernel. Just used for asserts.
|
/// Branch prediction hints. Idea borrowed from Linux kernel. Just used for asserts.
|
||||||
|
@ -637,7 +637,7 @@ enum {
|
||||||
|
|
||||||
// Custom hash function used by unordered_map/unordered_set when key is const
|
// Custom hash function used by unordered_map/unordered_set when key is const
|
||||||
#ifndef CONST_WCSTRING_HASH
|
#ifndef CONST_WCSTRING_HASH
|
||||||
#define CONST_WCSTRING_HASH 1
|
#define CONST_WCSTRING_HASH
|
||||||
namespace std {
|
namespace std {
|
||||||
template <>
|
template <>
|
||||||
struct hash<const wcstring> {
|
struct hash<const wcstring> {
|
||||||
|
|
|
@ -27,7 +27,7 @@ struct completion_mode_t {
|
||||||
};
|
};
|
||||||
|
|
||||||
/// Character that separates the completion and description on programmable completions.
|
/// Character that separates the completion and description on programmable completions.
|
||||||
#define PROG_COMPLETE_SEP L'\t'
|
constexpr char PROG_COMPLETE_SEP = L'\t';
|
||||||
|
|
||||||
class parser_t;
|
class parser_t;
|
||||||
|
|
||||||
|
|
16
src/env.cpp
16
src/env.cpp
|
@ -38,19 +38,19 @@
|
||||||
#include "wutil.h" // IWYU pragma: keep
|
#include "wutil.h" // IWYU pragma: keep
|
||||||
|
|
||||||
/// Some configuration path environment variables.
|
/// Some configuration path environment variables.
|
||||||
#define FISH_DATADIR_VAR L"__fish_data_dir"
|
constexpr const wchar_t FISH_DATADIR_VAR[] = L"__fish_data_dir";
|
||||||
#define FISH_SYSCONFDIR_VAR L"__fish_sysconf_dir"
|
constexpr const wchar_t FISH_SYSCONFDIR_VAR[] = L"__fish_sysconf_dir";
|
||||||
#define FISH_HELPDIR_VAR L"__fish_help_dir"
|
constexpr const wchar_t FISH_HELPDIR_VAR[] = L"__fish_help_dir";
|
||||||
#define FISH_BIN_DIR L"__fish_bin_dir"
|
constexpr const wchar_t FISH_BIN_DIR[] = L"__fish_bin_dir";
|
||||||
#define FISH_CONFIG_DIR L"__fish_config_dir"
|
constexpr const wchar_t FISH_CONFIG_DIR[] = L"__fish_config_dir";
|
||||||
#define FISH_USER_DATA_DIR L"__fish_user_data_dir"
|
constexpr const wchar_t FISH_USER_DATA_DIR[] = L"__fish_user_data_dir";
|
||||||
|
|
||||||
/// At init, we read all the environment variables from this array.
|
/// At init, we read all the environment variables from this array.
|
||||||
extern char **environ;
|
extern char **environ;
|
||||||
|
|
||||||
/// The character used to delimit path and non-path variables in exporting and in string expansion.
|
/// The character used to delimit path and non-path variables in exporting and in string expansion.
|
||||||
static constexpr wchar_t PATH_ARRAY_SEP = L':';
|
constexpr wchar_t PATH_ARRAY_SEP = L':';
|
||||||
static constexpr wchar_t NONPATH_ARRAY_SEP = L' ';
|
constexpr wchar_t NONPATH_ARRAY_SEP = L' ';
|
||||||
|
|
||||||
bool curses_initialized = false;
|
bool curses_initialized = false;
|
||||||
|
|
||||||
|
|
|
@ -55,16 +55,16 @@
|
||||||
#endif // Haiku
|
#endif // Haiku
|
||||||
|
|
||||||
/// Error message.
|
/// Error message.
|
||||||
#define PARSE_ERR L"Unable to parse universal variable message: '%ls'"
|
constexpr const wchar_t PARSE_ERR[] = L"Unable to parse universal variable message: '%ls'";
|
||||||
|
|
||||||
/// Small note about not editing ~/.fishd manually. Inserted at the top of all .fishd files.
|
/// Small note about not editing ~/.fishd manually. Inserted at the top of all .fishd files.
|
||||||
#define SAVE_MSG "# This file contains fish universal variable definitions.\n"
|
constexpr const char SAVE_MSG[] = "# This file contains fish universal variable definitions.\n";
|
||||||
|
|
||||||
/// Version for fish 3.0
|
/// Version for fish 3.0
|
||||||
#define UVARS_VERSION_3_0 "3.0"
|
#define UVARS_VERSION_3_0 "3.0"
|
||||||
|
|
||||||
// Maximum file size we'll read.
|
// Maximum file size we'll read.
|
||||||
static constexpr size_t k_max_read_size = 16 * 1024 * 1024;
|
constexpr size_t k_max_read_size = 16 * 1024 * 1024;
|
||||||
|
|
||||||
// Fields used in fish 2.x uvars.
|
// Fields used in fish 2.x uvars.
|
||||||
namespace fish2x_uvars {
|
namespace fish2x_uvars {
|
||||||
|
@ -211,11 +211,11 @@ static bool append_file_entry(env_var_t::env_var_flags_t flags, const wcstring &
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Encoding of a null string.
|
/// Encoding of a null string.
|
||||||
static const wchar_t *const ENV_NULL = L"\x1d";
|
constexpr const wchar_t ENV_NULL[] = L"\x1d";
|
||||||
|
|
||||||
/// Character used to separate arrays in universal variables file.
|
/// Character used to separate arrays in universal variables file.
|
||||||
/// This is 30, the ASCII record separator.
|
/// This is 30, the ASCII record separator.
|
||||||
static const wchar_t UVAR_ARRAY_SEP = 0x1e;
|
constexpr const wchar_t UVAR_ARRAY_SEP = 0x1e;
|
||||||
|
|
||||||
/// Decode a serialized universal variable value into a list.
|
/// Decode a serialized universal variable value into a list.
|
||||||
static wcstring_list_t decode_serialized(const wcstring &val) {
|
static wcstring_list_t decode_serialized(const wcstring &val) {
|
||||||
|
@ -869,7 +869,7 @@ void env_universal_t::parse_message_2x_internal(const wcstring &msgstr, var_tabl
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Maximum length of hostname. Longer hostnames are truncated.
|
/// Maximum length of hostname. Longer hostnames are truncated.
|
||||||
#define HOSTNAME_LEN 255
|
constexpr int HOSTNAME_LEN = 255;
|
||||||
|
|
||||||
/// Function to get an identifier based on the hostname.
|
/// Function to get an identifier based on the hostname.
|
||||||
bool get_hostname_identifier(wcstring &result) {
|
bool get_hostname_identifier(wcstring &result) {
|
||||||
|
@ -898,8 +898,8 @@ class universal_notifier_shmem_poller_t final : public universal_notifier_t {
|
||||||
uint32_t universal_variable_seed;
|
uint32_t universal_variable_seed;
|
||||||
};
|
};
|
||||||
|
|
||||||
#define SHMEM_MAGIC_NUMBER 0xF154
|
constexpr int SHMEM_MAGIC_NUMBER = 0xF154;
|
||||||
#define SHMEM_VERSION_CURRENT 1000
|
constexpr int SHMEM_VERSION_CURRENT = 1000;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
long long last_change_time{0};
|
long long last_change_time{0};
|
||||||
|
|
|
@ -19,7 +19,7 @@
|
||||||
struct io_streams_t;
|
struct io_streams_t;
|
||||||
|
|
||||||
/// The process id that is used to match any process id.
|
/// The process id that is used to match any process id.
|
||||||
#define EVENT_ANY_PID 0
|
constexpr int EVENT_ANY_PID = 0;
|
||||||
|
|
||||||
/// Enumeration of event types.
|
/// Enumeration of event types.
|
||||||
enum class event_type_t {
|
enum class event_type_t {
|
||||||
|
|
|
@ -39,9 +39,9 @@
|
||||||
|
|
||||||
/// Characters which make a string unclean if they are the first character of the string. See \c
|
/// Characters which make a string unclean if they are the first character of the string. See \c
|
||||||
/// expand_is_clean().
|
/// expand_is_clean().
|
||||||
#define UNCLEAN_FIRST L"~%"
|
constexpr const wchar_t UNCLEAN_FIRST[] = L"~%";
|
||||||
/// Unclean characters. See \c expand_is_clean().
|
/// Unclean characters. See \c expand_is_clean().
|
||||||
#define UNCLEAN L"$*?\\\"'({})"
|
constexpr const wchar_t UNCLEAN[] = L"$*?\\\"'({})";
|
||||||
|
|
||||||
static void remove_internal_separator(wcstring *s, bool conv);
|
static void remove_internal_separator(wcstring *s, bool conv);
|
||||||
|
|
||||||
|
|
|
@ -133,8 +133,7 @@ struct expand_result_t {
|
||||||
};
|
};
|
||||||
|
|
||||||
/// The string represented by PROCESS_EXPAND_SELF
|
/// The string represented by PROCESS_EXPAND_SELF
|
||||||
#define PROCESS_EXPAND_SELF_STR L"%self"
|
constexpr const wchar_t PROCESS_EXPAND_SELF_STR[] = L"%self";
|
||||||
#define PROCESS_EXPAND_SELF_STR_LEN 5
|
|
||||||
|
|
||||||
/// Perform various forms of expansion on in, such as tilde expansion (\~USER becomes the users home
|
/// Perform various forms of expansion on in, such as tilde expansion (\~USER becomes the users home
|
||||||
/// directory), variable expansion (\$VAR_NAME becomes the value of the environment variable
|
/// directory), variable expansion (\$VAR_NAME becomes the value of the environment variable
|
||||||
|
|
|
@ -14,7 +14,7 @@
|
||||||
#include "iothread.h"
|
#include "iothread.h"
|
||||||
#include "wutil.h"
|
#include "wutil.h"
|
||||||
|
|
||||||
static constexpr uint64_t kUsecPerMsec = 1000;
|
constexpr uint64_t kUsecPerMsec = 1000;
|
||||||
|
|
||||||
fd_monitor_t::fd_monitor_t() = default;
|
fd_monitor_t::fd_monitor_t() = default;
|
||||||
|
|
||||||
|
|
|
@ -19,9 +19,9 @@
|
||||||
|
|
||||||
// The first fd in the "high range." fds below this are allowed to be used directly by users in
|
// The first fd in the "high range." fds below this are allowed to be used directly by users in
|
||||||
// redirections, e.g. >&3
|
// redirections, e.g. >&3
|
||||||
const int k_first_high_fd = 10;
|
constexpr int k_first_high_fd = 10;
|
||||||
static constexpr uint64_t kUsecPerMsec = 1000;
|
constexpr uint64_t kUsecPerMsec = 1000;
|
||||||
static constexpr uint64_t kUsecPerSec [[gnu::unused]] = 1000 * kUsecPerMsec;
|
constexpr uint64_t kUsecPerSec [[gnu::unused]] = 1000 * kUsecPerMsec;
|
||||||
|
|
||||||
void autoclose_fd_t::close() {
|
void autoclose_fd_t::close() {
|
||||||
if (fd_ < 0) return;
|
if (fd_ < 0) return;
|
||||||
|
|
|
@ -56,7 +56,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
|
||||||
|
|
||||||
// The number of spaces per indent isn't supposed to be configurable.
|
// The number of spaces per indent isn't supposed to be configurable.
|
||||||
// See discussion at https://github.com/fish-shell/fish-shell/pull/6790
|
// See discussion at https://github.com/fish-shell/fish-shell/pull/6790
|
||||||
#define SPACES_PER_INDENT 4
|
constexpr int SPACES_PER_INDENT = 4;
|
||||||
|
|
||||||
static bool dump_parse_tree = false;
|
static bool dump_parse_tree = false;
|
||||||
static int ret = 0;
|
static int ret = 0;
|
||||||
|
|
|
@ -121,11 +121,11 @@ static bool should_test_function(const char *func_name, bool default_on = true)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// The number of tests to run.
|
/// The number of tests to run.
|
||||||
#define ESCAPE_TEST_COUNT 100000
|
constexpr int ESCAPE_TEST_COUNT = 100000;
|
||||||
/// The average length of strings to unescape.
|
/// The average length of strings to unescape.
|
||||||
#define ESCAPE_TEST_LENGTH 100
|
constexpr int ESCAPE_TEST_LENGTH = 100;
|
||||||
/// The highest character number of character to try and escape.
|
/// The highest character number of character to try and escape.
|
||||||
#define ESCAPE_TEST_CHAR 4000
|
constexpr int ESCAPE_TEST_CHAR = 4000;
|
||||||
|
|
||||||
/// Number of encountered errors.
|
/// Number of encountered errors.
|
||||||
static int err_count = 0;
|
static int err_count = 0;
|
||||||
|
@ -3928,8 +3928,8 @@ static void test_undo() {
|
||||||
do_test(line.text() == L"abc");
|
do_test(line.text() == L"abc");
|
||||||
}
|
}
|
||||||
|
|
||||||
#define UVARS_PER_THREAD 8
|
constexpr int UVARS_PER_THREAD = 8;
|
||||||
#define UVARS_TEST_PATH L"test/fish_uvars_test/varsfile.txt"
|
constexpr const wchar_t UVARS_TEST_PATH[] = L"test/fish_uvars_test/varsfile.txt";
|
||||||
|
|
||||||
static int test_universal_helper(int x) {
|
static int test_universal_helper(int x) {
|
||||||
callback_data_list_t callbacks;
|
callback_data_list_t callbacks;
|
||||||
|
|
|
@ -550,7 +550,7 @@ static void color_string_internal(const wcstring &buffstr, highlight_spec_t base
|
||||||
|
|
||||||
// Hacky support for %self which must be an unquoted literal argument.
|
// Hacky support for %self which must be an unquoted literal argument.
|
||||||
if (buffstr == PROCESS_EXPAND_SELF_STR) {
|
if (buffstr == PROCESS_EXPAND_SELF_STR) {
|
||||||
std::fill_n(colors, std::wcslen(PROCESS_EXPAND_SELF_STR), highlight_role_t::operat);
|
std::fill_n(colors, const_strlen(PROCESS_EXPAND_SELF_STR), highlight_role_t::operat);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -52,21 +52,21 @@
|
||||||
// Newlines are replaced by \n. Backslashes are replaced by \\.
|
// Newlines are replaced by \n. Backslashes are replaced by \\.
|
||||||
|
|
||||||
// This is the history session ID we use by default if the user has not set env var fish_history.
|
// This is the history session ID we use by default if the user has not set env var fish_history.
|
||||||
#define DFLT_FISH_HISTORY_SESSION_ID L"fish"
|
constexpr const wchar_t DFLT_FISH_HISTORY_SESSION_ID[] = L"fish";
|
||||||
|
|
||||||
// When we rewrite the history, the number of items we keep.
|
// When we rewrite the history, the number of items we keep.
|
||||||
#define HISTORY_SAVE_MAX (1024 * 256)
|
constexpr int HISTORY_SAVE_MAX = 1024 * 256;
|
||||||
|
|
||||||
// Default buffer size for flushing to the history file.
|
// Default buffer size for flushing to the history file.
|
||||||
#define HISTORY_OUTPUT_BUFFER_SIZE (64 * 1024)
|
constexpr int HISTORY_OUTPUT_BUFFER_SIZE = 64 * 1024;
|
||||||
|
|
||||||
// The file access mode we use for creating history files
|
// The file access mode we use for creating history files
|
||||||
static constexpr int history_file_mode = 0600;
|
constexpr int history_file_mode = 0600;
|
||||||
|
|
||||||
// How many times we retry to save
|
// How many times we retry to save
|
||||||
// Saving may fail if the file is modified in between our opening
|
// Saving may fail if the file is modified in between our opening
|
||||||
// the file and taking the lock
|
// the file and taking the lock
|
||||||
static constexpr int max_save_tries = 1024;
|
constexpr int max_save_tries = 1024;
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
|
|
|
@ -32,7 +32,7 @@
|
||||||
#include "wutil.h" // IWYU pragma: keep
|
#include "wutil.h" // IWYU pragma: keep
|
||||||
|
|
||||||
/// A name for our own key mapping for nul.
|
/// A name for our own key mapping for nul.
|
||||||
static const wchar_t *k_nul_mapping_name = L"nul";
|
constexpr const wchar_t k_nul_mapping_name[] = L"nul";
|
||||||
|
|
||||||
/// Struct representing a keybinding. Returned by input_get_mappings.
|
/// Struct representing a keybinding. Returned by input_get_mappings.
|
||||||
struct input_mapping_t {
|
struct input_mapping_t {
|
||||||
|
@ -72,7 +72,7 @@ struct terminfo_mapping_t {
|
||||||
terminfo_mapping_t(const wchar_t *name, std::string s) : name(name), seq(std::move(s)) {}
|
terminfo_mapping_t(const wchar_t *name, std::string s) : name(name), seq(std::move(s)) {}
|
||||||
};
|
};
|
||||||
|
|
||||||
static constexpr size_t input_function_count = R_END_INPUT_FUNCTIONS;
|
constexpr size_t input_function_count = R_END_INPUT_FUNCTIONS;
|
||||||
|
|
||||||
/// Input function metadata. This list should be kept in sync with the key code list in
|
/// Input function metadata. This list should be kept in sync with the key code list in
|
||||||
/// input_common.h.
|
/// input_common.h.
|
||||||
|
|
|
@ -14,8 +14,8 @@
|
||||||
#include "input_common.h"
|
#include "input_common.h"
|
||||||
#include "maybe.h"
|
#include "maybe.h"
|
||||||
|
|
||||||
#define FISH_BIND_MODE_VAR L"fish_bind_mode"
|
constexpr wchar_t FISH_BIND_MODE_VAR[] = L"fish_bind_mode";
|
||||||
#define DEFAULT_BIND_MODE L"default"
|
constexpr wchar_t DEFAULT_BIND_MODE[]= L"default";
|
||||||
|
|
||||||
class event_queue_peeker_t;
|
class event_queue_peeker_t;
|
||||||
class parser_t;
|
class parser_t;
|
||||||
|
|
|
@ -30,7 +30,7 @@
|
||||||
/// Time in milliseconds to wait for another byte to be available for reading
|
/// Time in milliseconds to wait for another byte to be available for reading
|
||||||
/// after \x1B is read before assuming that escape key was pressed, and not an
|
/// after \x1B is read before assuming that escape key was pressed, and not an
|
||||||
/// escape sequence.
|
/// escape sequence.
|
||||||
#define WAIT_ON_ESCAPE_DEFAULT 30
|
constexpr int WAIT_ON_ESCAPE_DEFAULT = 30;
|
||||||
static int wait_on_escape_ms = WAIT_ON_ESCAPE_DEFAULT;
|
static int wait_on_escape_ms = WAIT_ON_ESCAPE_DEFAULT;
|
||||||
|
|
||||||
input_event_queue_t::input_event_queue_t(int in) : in_(in) {}
|
input_event_queue_t::input_event_queue_t(int in) : in_(in) {}
|
||||||
|
|
|
@ -26,7 +26,7 @@
|
||||||
#define NOCLOB_ERROR _(L"The file '%ls' already exists")
|
#define NOCLOB_ERROR _(L"The file '%ls' already exists")
|
||||||
|
|
||||||
/// Base open mode to pass to calls to open.
|
/// Base open mode to pass to calls to open.
|
||||||
#define OPEN_MASK 0666
|
constexpr int OPEN_MASK = 0666;
|
||||||
|
|
||||||
/// Provide the fd monitor used for background fillthread operations.
|
/// Provide the fd monitor used for background fillthread operations.
|
||||||
static fd_monitor_t &fd_monitor() {
|
static fd_monitor_t &fd_monitor() {
|
||||||
|
|
|
@ -21,7 +21,7 @@
|
||||||
#include "maybe.h"
|
#include "maybe.h"
|
||||||
|
|
||||||
/// We just define a thread limit of 1024.
|
/// We just define a thread limit of 1024.
|
||||||
#define IO_MAX_THREADS 1024
|
constexpr int IO_MAX_THREADS = 1024;
|
||||||
|
|
||||||
// iothread has a thread pool. Sometimes there's no work to do, but extant threads wait around for a
|
// iothread has a thread pool. Sometimes there's no work to do, but extant threads wait around for a
|
||||||
// while (on a condition variable) in case new work comes soon. However condition variables are not
|
// while (on a condition variable) in case new work comes soon. However condition variables are not
|
||||||
|
@ -29,9 +29,9 @@
|
||||||
// See https://github.com/google/sanitizers/issues/1259
|
// See https://github.com/google/sanitizers/issues/1259
|
||||||
// When using TSan, disable the wait-around feature.
|
// When using TSan, disable the wait-around feature.
|
||||||
#ifdef FISH_TSAN_WORKAROUNDS
|
#ifdef FISH_TSAN_WORKAROUNDS
|
||||||
#define IO_WAIT_FOR_WORK_DURATION_MS 0
|
constexpr int IO_WAIT_FOR_WORK_DURATION_MS = 0;
|
||||||
#else
|
#else
|
||||||
#define IO_WAIT_FOR_WORK_DURATION_MS 500
|
constexpr int IO_WAIT_FOR_WORK_DURATION_MS = 500;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
using void_function_t = std::function<void()>;
|
using void_function_t = std::function<void()>;
|
||||||
|
|
|
@ -30,16 +30,16 @@ using comp_t = pager_t::comp_t;
|
||||||
using comp_info_list_t = std::vector<comp_t>;
|
using comp_info_list_t = std::vector<comp_t>;
|
||||||
|
|
||||||
/// The minimum width (in characters) the terminal must to show completions at all.
|
/// The minimum width (in characters) the terminal must to show completions at all.
|
||||||
#define PAGER_MIN_WIDTH 16
|
constexpr int PAGER_MIN_WIDTH = 16;
|
||||||
|
|
||||||
/// Minimum height to show completions
|
/// Minimum height to show completions
|
||||||
#define PAGER_MIN_HEIGHT 4
|
constexpr int PAGER_MIN_HEIGHT = 4;
|
||||||
|
|
||||||
/// The maximum number of columns of completion to attempt to fit onto the screen.
|
/// The maximum number of columns of completion to attempt to fit onto the screen.
|
||||||
#define PAGER_MAX_COLS 6
|
constexpr int PAGER_MAX_COLS = 6;
|
||||||
|
|
||||||
/// Width of the search field.
|
/// Width of the search field.
|
||||||
#define PAGER_SEARCH_FIELD_WIDTH 12
|
constexpr int PAGER_SEARCH_FIELD_WIDTH = 12;
|
||||||
|
|
||||||
/// Text we use for the search field.
|
/// Text we use for the search field.
|
||||||
#define SEARCH_FIELD_PROMPT _(L"search: ")
|
#define SEARCH_FIELD_PROMPT _(L"search: ")
|
||||||
|
|
|
@ -15,7 +15,7 @@
|
||||||
|
|
||||||
struct termsize_t;
|
struct termsize_t;
|
||||||
|
|
||||||
#define PAGER_SELECTION_NONE static_cast<size_t>(-1)
|
constexpr size_t PAGER_SELECTION_NONE = static_cast<size_t>(-1);
|
||||||
|
|
||||||
/// Represents rendering from the pager.
|
/// Represents rendering from the pager.
|
||||||
class page_rendering_t {
|
class page_rendering_t {
|
||||||
|
@ -56,11 +56,11 @@ enum class selection_motion_t {
|
||||||
};
|
};
|
||||||
|
|
||||||
// The space between adjacent completions.
|
// The space between adjacent completions.
|
||||||
#define PAGER_SPACER_STRING L" "
|
constexpr const wchar_t PAGER_SPACER_STRING[] = L" ";
|
||||||
#define PAGER_SPACER_STRING_WIDTH 2
|
constexpr int PAGER_SPACER_STRING_WIDTH = const_strlen(PAGER_SPACER_STRING);
|
||||||
|
|
||||||
// How many rows we will show in the "initial" pager.
|
// How many rows we will show in the "initial" pager.
|
||||||
#define PAGER_UNDISCLOSED_MAX_ROWS 4
|
constexpr int PAGER_UNDISCLOSED_MAX_ROWS = 4;
|
||||||
|
|
||||||
class pager_t {
|
class pager_t {
|
||||||
size_t available_term_width{0};
|
size_t available_term_width{0};
|
||||||
|
|
|
@ -189,13 +189,13 @@ struct parse_error_t {
|
||||||
wcstring describe_with_prefix(const wcstring &src, const wcstring &prefix, bool is_interactive,
|
wcstring describe_with_prefix(const wcstring &src, const wcstring &prefix, bool is_interactive,
|
||||||
bool skip_caret) const;
|
bool skip_caret) const;
|
||||||
};
|
};
|
||||||
typedef std::vector<parse_error_t> parse_error_list_t;
|
using parse_error_list_t = std::vector<parse_error_t>;
|
||||||
|
|
||||||
wcstring token_type_user_presentable_description(parse_token_type_t type,
|
wcstring token_type_user_presentable_description(parse_token_type_t type,
|
||||||
parse_keyword_t keyword = parse_keyword_t::none);
|
parse_keyword_t keyword = parse_keyword_t::none);
|
||||||
|
|
||||||
// Special source_start value that means unknown.
|
// Special source_start value that means unknown.
|
||||||
#define SOURCE_LOCATION_UNKNOWN (static_cast<size_t>(-1))
|
constexpr size_t SOURCE_LOCATION_UNKNOWN = static_cast<size_t>(-1);
|
||||||
|
|
||||||
/// Helper function to offset error positions by the given amount. This is used when determining
|
/// Helper function to offset error positions by the given amount. This is used when determining
|
||||||
/// errors in a substring of a larger source buffer.
|
/// errors in a substring of a larger source buffer.
|
||||||
|
@ -209,7 +209,7 @@ enum class pipeline_position_t : uint8_t {
|
||||||
};
|
};
|
||||||
|
|
||||||
/// Maximum number of function calls.
|
/// Maximum number of function calls.
|
||||||
#define FISH_MAX_STACK_DEPTH 128
|
constexpr int FISH_MAX_STACK_DEPTH = 128;
|
||||||
|
|
||||||
/// Error message on a function that calls itself immediately.
|
/// Error message on a function that calls itself immediately.
|
||||||
#define INFINITE_FUNC_RECURSION_ERR_MSG \
|
#define INFINITE_FUNC_RECURSION_ERR_MSG \
|
||||||
|
|
|
@ -43,7 +43,7 @@
|
||||||
#define TIME_IN_PIPELINE_ERR_MSG _(L"The 'time' command may only be at the beginning of a pipeline")
|
#define TIME_IN_PIPELINE_ERR_MSG _(L"The 'time' command may only be at the beginning of a pipeline")
|
||||||
|
|
||||||
/// Maximum length of a variable name to show in error reports before truncation
|
/// Maximum length of a variable name to show in error reports before truncation
|
||||||
static constexpr int var_err_len = 16;
|
constexpr int var_err_len = 16;
|
||||||
|
|
||||||
int parse_util_lineno(const wcstring &str, size_t offset) {
|
int parse_util_lineno(const wcstring &str, size_t offset) {
|
||||||
// Return the line number of position offset, starting with 1.
|
// Return the line number of position offset, starting with 1.
|
||||||
|
|
|
@ -10,15 +10,14 @@
|
||||||
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
|
|
||||||
#define CMD_LEN 1024
|
constexpr int CMD_LEN = 1024;
|
||||||
|
constexpr char HELP_ERR[] = "Could not show help message\n";
|
||||||
#define HELP_ERR "Could not show help message\n"
|
|
||||||
|
|
||||||
void print_help(const char *c, int fd) {
|
void print_help(const char *c, int fd) {
|
||||||
char cmd[CMD_LEN];
|
char cmd[CMD_LEN];
|
||||||
int printed = snprintf(cmd, CMD_LEN, "fish -c '__fish_print_help %s >&%d'", c, fd);
|
int printed = snprintf(cmd, CMD_LEN, "fish -c '__fish_print_help %s >&%d'", c, fd);
|
||||||
|
|
||||||
if (printed < CMD_LEN && system(cmd) == -1) {
|
if (printed < CMD_LEN && system(cmd) == -1) {
|
||||||
write_loop(2, HELP_ERR, std::strlen(HELP_ERR));
|
write_loop(2, HELP_ERR, const_strlen(HELP_ERR));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -83,47 +83,47 @@
|
||||||
|
|
||||||
// Name of the variable that tells how long it took, in milliseconds, for the previous
|
// Name of the variable that tells how long it took, in milliseconds, for the previous
|
||||||
// interactive command to complete.
|
// interactive command to complete.
|
||||||
#define ENV_CMD_DURATION L"CMD_DURATION"
|
constexpr const wchar_t ENV_CMD_DURATION[] = L"CMD_DURATION";
|
||||||
|
|
||||||
/// Maximum length of prefix string when printing completion list. Longer prefixes will be
|
/// Maximum length of prefix string when printing completion list. Longer prefixes will be
|
||||||
/// ellipsized.
|
/// ellipsized.
|
||||||
#define PREFIX_MAX_LEN 9
|
constexpr int PREFIX_MAX_LEN = 9;
|
||||||
|
|
||||||
/// A simple prompt for reading shell commands that does not rely on fish specific commands, meaning
|
/// A simple prompt for reading shell commands that does not rely on fish specific commands, meaning
|
||||||
/// it will work even if fish is not installed. This is used by read_i.
|
/// it will work even if fish is not installed. This is used by read_i.
|
||||||
#define DEFAULT_PROMPT L"echo -n \"$USER@$hostname $PWD \"'> '"
|
constexpr const wchar_t DEFAULT_PROMPT[] = L"echo -n \"$USER@$hostname $PWD \"'> '";
|
||||||
|
|
||||||
/// The name of the function that prints the fish prompt.
|
/// The name of the function that prints the fish prompt.
|
||||||
#define LEFT_PROMPT_FUNCTION_NAME L"fish_prompt"
|
constexpr const wchar_t LEFT_PROMPT_FUNCTION_NAME[] = L"fish_prompt";
|
||||||
|
|
||||||
/// The name of the function that prints the fish right prompt (RPROMPT).
|
/// The name of the function that prints the fish right prompt (RPROMPT).
|
||||||
#define RIGHT_PROMPT_FUNCTION_NAME L"fish_right_prompt"
|
constexpr const wchar_t RIGHT_PROMPT_FUNCTION_NAME[] = L"fish_right_prompt";
|
||||||
|
|
||||||
/// The name of the function to use in place of the left prompt if we're in the debugger context.
|
/// The name of the function to use in place of the left prompt if we're in the debugger context.
|
||||||
#define DEBUG_PROMPT_FUNCTION_NAME L"fish_breakpoint_prompt"
|
constexpr const wchar_t DEBUG_PROMPT_FUNCTION_NAME[] = L"fish_breakpoint_prompt";
|
||||||
|
|
||||||
/// The name of the function for getting the input mode indicator.
|
/// The name of the function for getting the input mode indicator.
|
||||||
#define MODE_PROMPT_FUNCTION_NAME L"fish_mode_prompt"
|
constexpr const wchar_t MODE_PROMPT_FUNCTION_NAME[] = L"fish_mode_prompt";
|
||||||
|
|
||||||
/// The default title for the reader. This is used by reader_readline.
|
/// The default title for the reader. This is used by reader_readline.
|
||||||
#define DEFAULT_TITLE L"echo (status current-command) \" \" $PWD"
|
constexpr const wchar_t DEFAULT_TITLE[] = L"echo (status current-command) \" \" $PWD";
|
||||||
|
|
||||||
/// The maximum number of characters to read from the keyboard without repainting. Note that this
|
/// The maximum number of characters to read from the keyboard without repainting. Note that this
|
||||||
/// readahead will only occur if new characters are available for reading, fish will never block for
|
/// readahead will only occur if new characters are available for reading, fish will never block for
|
||||||
/// more input without repainting.
|
/// more input without repainting.
|
||||||
static constexpr size_t READAHEAD_MAX = 256;
|
constexpr size_t READAHEAD_MAX = 256;
|
||||||
|
|
||||||
/// When tab-completing with a wildcard, we expand the wildcard up to this many results.
|
/// When tab-completing with a wildcard, we expand the wildcard up to this many results.
|
||||||
/// If expansion would exceed this many results, beep and do nothing.
|
/// If expansion would exceed this many results, beep and do nothing.
|
||||||
static const size_t TAB_COMPLETE_WILDCARD_MAX_EXPANSION = 256;
|
constexpr size_t TAB_COMPLETE_WILDCARD_MAX_EXPANSION = 256;
|
||||||
|
|
||||||
/// A mode for calling the reader_kill function. In this mode, the new string is appended to the
|
/// A mode for calling the reader_kill function. In this mode, the new string is appended to the
|
||||||
/// current contents of the kill buffer.
|
/// current contents of the kill buffer.
|
||||||
#define KILL_APPEND 0
|
constexpr int KILL_APPEND = 0;
|
||||||
|
|
||||||
/// A mode for calling the reader_kill function. In this mode, the new string is prepended to the
|
/// A mode for calling the reader_kill function. In this mode, the new string is prepended to the
|
||||||
/// current contents of the kill buffer.
|
/// current contents of the kill buffer.
|
||||||
#define KILL_PREPEND 1
|
constexpr int KILL_PREPEND = 1;
|
||||||
|
|
||||||
enum class jump_direction_t { forward, backward };
|
enum class jump_direction_t { forward, backward };
|
||||||
enum class jump_precision_t { till, to };
|
enum class jump_precision_t { till, to };
|
||||||
|
@ -169,7 +169,7 @@ static operation_context_t get_bg_context(const std::shared_ptr<environment_t> &
|
||||||
/// typed. But we do not want it to block forever - e.g. it may hang on determining if an arbitrary
|
/// typed. But we do not want it to block forever - e.g. it may hang on determining if an arbitrary
|
||||||
/// argument is a path. This is how long we'll wait (in milliseconds) before giving up and
|
/// argument is a path. This is how long we'll wait (in milliseconds) before giving up and
|
||||||
/// performing a no-io syntax highlighting. See #7418, #5912.
|
/// performing a no-io syntax highlighting. See #7418, #5912.
|
||||||
static constexpr long kHighlightTimeoutForExecutionMs = 250;
|
constexpr long kHighlightTimeoutForExecutionMs = 250;
|
||||||
|
|
||||||
/// Get the debouncer for autosuggestions and background highlighting.
|
/// Get the debouncer for autosuggestions and background highlighting.
|
||||||
/// These are deliberately leaked to avoid shutdown dtor registration.
|
/// These are deliberately leaked to avoid shutdown dtor registration.
|
||||||
|
|
|
@ -45,7 +45,7 @@
|
||||||
#include "termsize.h"
|
#include "termsize.h"
|
||||||
|
|
||||||
/// The number of characters to indent new blocks.
|
/// The number of characters to indent new blocks.
|
||||||
#define INDENT_STEP 4u
|
constexpr uint32_t INDENT_STEP = 4U;
|
||||||
|
|
||||||
/// RAII class to begin and end buffering around an outputter.
|
/// RAII class to begin and end buffering around an outputter.
|
||||||
namespace {
|
namespace {
|
||||||
|
|
|
@ -26,17 +26,17 @@ enum class token_type_t : uint8_t {
|
||||||
|
|
||||||
/// Flag telling the tokenizer to accept incomplete parameters, i.e. parameters with mismatching
|
/// Flag telling the tokenizer to accept incomplete parameters, i.e. parameters with mismatching
|
||||||
/// parenthesis, etc. This is useful for tab-completion.
|
/// parenthesis, etc. This is useful for tab-completion.
|
||||||
#define TOK_ACCEPT_UNFINISHED 1
|
constexpr int TOK_ACCEPT_UNFINISHED = 1;
|
||||||
|
|
||||||
/// Flag telling the tokenizer not to remove comments. Useful for syntax highlighting.
|
/// Flag telling the tokenizer not to remove comments. Useful for syntax highlighting.
|
||||||
#define TOK_SHOW_COMMENTS 2
|
constexpr int TOK_SHOW_COMMENTS = 2;
|
||||||
|
|
||||||
/// Ordinarily, the tokenizer ignores newlines following a newline, or a semicolon. This flag tells
|
/// Ordinarily, the tokenizer ignores newlines following a newline, or a semicolon. This flag tells
|
||||||
/// the tokenizer to return each of them as a separate END.
|
/// the tokenizer to return each of them as a separate END.
|
||||||
#define TOK_SHOW_BLANK_LINES 4
|
constexpr int TOK_SHOW_BLANK_LINES = 4;
|
||||||
|
|
||||||
/// Make an effort to continue after an error.
|
/// Make an effort to continue after an error.
|
||||||
#define TOK_CONTINUE_AFTER_ERROR 8
|
constexpr int TOK_CONTINUE_AFTER_ERROR = 8;
|
||||||
|
|
||||||
using tok_flags_t = unsigned int;
|
using tok_flags_t = unsigned int;
|
||||||
|
|
||||||
|
|
10
src/utf8.cpp
10
src/utf8.cpp
|
@ -24,12 +24,12 @@
|
||||||
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
|
|
||||||
#define _NXT 0x80
|
constexpr char _NXT = 0x80;
|
||||||
#define _SEQ2 0xc0
|
constexpr char _SEQ2 = 0xc0;
|
||||||
#define _SEQ3 0xe0
|
constexpr char _SEQ3 = 0xe0;
|
||||||
#define _SEQ4 0xf0
|
constexpr char _SEQ4 = 0xf0;
|
||||||
|
|
||||||
#define _BOM 0xfeff
|
constexpr uint16_t _BOM = 0xfeff;
|
||||||
|
|
||||||
// We can tweak the following typedef to allow us to simulate Windows-style 16 bit wchar's on Unix.
|
// We can tweak the following typedef to allow us to simulate Windows-style 16 bit wchar's on Unix.
|
||||||
using utf8_wchar_t = wchar_t;
|
using utf8_wchar_t = wchar_t;
|
||||||
|
|
|
@ -22,8 +22,8 @@
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#define UTF8_IGNORE_ERROR 0x01
|
constexpr int UTF8_IGNORE_ERROR = 0x01;
|
||||||
#define UTF8_SKIP_BOM 0x02
|
constexpr int UTF8_SKIP_BOM = 0x02;
|
||||||
|
|
||||||
/// Convert a string between UTF8 and UCS-2/4 (depending on size of wchar_t). Returns true if
|
/// Convert a string between UTF8 and UCS-2/4 (depending on size of wchar_t). Returns true if
|
||||||
/// successful, storing the result of the conversion in *result*.
|
/// successful, storing the result of the conversion in *result*.
|
||||||
|
|
|
@ -176,7 +176,7 @@ struct dir_t {
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifndef HASH_FILE_ID
|
#ifndef HASH_FILE_ID
|
||||||
#define HASH_FILE_ID 1
|
#define HASH_FILE_ID
|
||||||
namespace std {
|
namespace std {
|
||||||
template <>
|
template <>
|
||||||
struct hash<file_id_t> {
|
struct hash<file_id_t> {
|
||||||
|
|
Loading…
Reference in a new issue