diff options
author | Leo Tenenbaum <pommicket@gmail.com> | 2021-03-04 10:40:32 -0500 |
---|---|---|
committer | Leo Tenenbaum <pommicket@gmail.com> | 2021-03-04 10:40:32 -0500 |
commit | 1cbaa8c30f63b854696b9a0761376eda5ea87ecd (patch) | |
tree | c249b7ff2b5311f4d4d6b84ff403687df36cb63d | |
parent | c8fe98bf37f5364543b365d6d423a785c3c66452 (diff) |
string arguments
-rw-r--r-- | build.c | 2 | ||||
-rw-r--r-- | command.c | 23 | ||||
-rw-r--r-- | command.h | 3 | ||||
-rw-r--r-- | config.c | 35 | ||||
-rw-r--r-- | main.c | 2 | ||||
-rw-r--r-- | ted.cfg | 2 | ||||
-rw-r--r-- | ted.h | 5 |
7 files changed, 65 insertions, 7 deletions
@@ -137,7 +137,7 @@ static int parse_nonnegative_integer(char32_t **str, char32_t *end) { // could this character (reasonably) appear in a source file path? static bool is_source_path(char32_t c) { - char const *allowed_ascii_symbols_in_path = "./\\-_"; + char const *allowed_ascii_symbols_in_path = "./\\-_:"; return c > CHAR_MAX || isalnum((char)c) || strchr(allowed_ascii_symbols_in_path, (char)c); } @@ -17,6 +17,17 @@ char const *command_to_str(Command c) { return "???"; } +// get the string corresponding to this argument; returns NULL if it's not a string argument +char const *arg_get_string(Ted *ted, i64 argument) { + if (argument < 0) return NULL; + if (argument & ARG_STRING) { + argument -= ARG_STRING; + if (argument < ted->nstrings) + return ted->strings[argument]; + } + return NULL; +} + void command_execute(Ted *ted, Command c, i64 argument) { TextBuffer *buffer = ted->active_buffer; Node *node = ted->active_node; @@ -336,9 +347,15 @@ void command_execute(Ted *ted, Command c, i64 argument) { case CMD_BUILD_PREV_ERROR: build_prev_error(ted); break; - case CMD_SHELL: - menu_open(ted, MENU_SHELL); - break; + case CMD_SHELL: { + char const *str = arg_get_string(ted, argument); + if (str) { + strbuf_cpy(ted->build_dir, ted->cwd); + build_start_with_command(ted, str); + } else { + menu_open(ted, MENU_SHELL); + } + } break; case CMD_GOTO_DEFINITION: menu_open(ted, MENU_GOTO_DEFINITION); @@ -1,3 +1,6 @@ +// i | ARG_STRING = ted->strings[i] +#define ARG_STRING 0x4000000000000000 + ENUM_U16 { CMD_UNKNOWN, CMD_NOOP, // do nothing @@ -293,8 +293,35 @@ void config_read(Ted *ted, char const *filename) { char *endp; argument = strtoll(value, &endp, 10); value = endp; - while (isspace(*value)) ++value; // skip past space following number + } else if (*value == '"') { + // string argument + int backslashes = 0; + char const *p; + for (p = value + 1; *p; ++p) { + bool done = false; + switch (*p) { + case '\\': + ++backslashes; + break; + case '"': + if (backslashes % 2 == 0) + done = true; + break; + } + if (done) break; + } + if (!*p) { + config_err(cfg, "String doesn't end."); + break; + } + if (ted->nstrings < TED_MAX_STRINGS) { + char *str = strn_dup(value + 1, (size_t)(p - (value + 1))); + argument = ted->nstrings | ARG_STRING; + ted->strings[ted->nstrings++] = str; + } + value = p + 1; } + while (isspace(*value)) ++value; // skip past space following argument if (*value == ':') { // read the command Command command = command_from_str(value + 1); @@ -428,9 +455,13 @@ void config_read(Ted *ted, char const *filename) { } } -static void settings_free(Settings *settings) { +static void config_free(Ted *ted) { + Settings *settings = &ted->settings; for (u16 i = 0; i < LANG_COUNT; ++i) { free(settings->language_extensions[i]); settings->language_extensions[i] = NULL; } + for (u32 i = 0; i < ted->nstrings; ++i) { + free(ted->strings[i]); + } } @@ -956,7 +956,7 @@ int main(int argc, char **argv) { buffer_free(&ted->argument_buffer); text_font_free(ted->font); text_font_free(ted->font_bold); - settings_free(&ted->settings); + config_free(ted); free(ted); #if _WIN32 for (int i = 0; i < argc; ++i) @@ -127,6 +127,8 @@ Ctrl+[ = :build-prev-error Ctrl+] = :build-next-error Ctrl+! = :shell +Ctrl+t = "ctags *.c *.h" :shell + Ctrl+d = :goto-definition Ctrl+g = :goto-line @@ -218,6 +218,8 @@ typedef struct Node { #define TED_MAX_NODES 256 // max tabs per node #define TED_MAX_TABS 100 +// max strings in config file +#define TED_MAX_STRINGS 1000 typedef struct { BufferPos start; @@ -327,6 +329,9 @@ typedef struct Ted { // NOTE: the buffer at index 0 is reserved as a "null buffer" and should not be used. bool buffers_used[TED_MAX_BUFFERS]; TextBuffer buffers[TED_MAX_BUFFERS]; + // config file strings + u32 nstrings; + char *strings[TED_MAX_STRINGS]; char window_title[256]; char error[512]; char error_shown[512]; // error display in box on screen |