mirror of
https://github.com/gwenhael-le-moine/sway-patched-tray-menu.git
synced 2024-12-26 21:58:08 +01:00
stringop.c: remove unused functions
The only use of `join_list` in swaybar/tray/icon.c has been rewritten.
This commit is contained in:
parent
017a7c4da1
commit
5c8424c074
3 changed files with 38 additions and 137 deletions
|
@ -150,29 +150,6 @@ void free_argv(int argc, char **argv) {
|
||||||
free(argv);
|
free(argv);
|
||||||
}
|
}
|
||||||
|
|
||||||
char *code_strstr(const char *haystack, const char *needle) {
|
|
||||||
/* TODO */
|
|
||||||
return strstr(haystack, needle);
|
|
||||||
}
|
|
||||||
|
|
||||||
char *code_strchr(const char *str, char delimiter) {
|
|
||||||
int in_string = 0, in_character = 0;
|
|
||||||
int i = 0;
|
|
||||||
while (str[i] != '\0') {
|
|
||||||
if (str[i] == '"' && !in_character) {
|
|
||||||
in_string = !in_string;
|
|
||||||
} else if (str[i] == '\'' && !in_string) {
|
|
||||||
in_character = !in_character;
|
|
||||||
} else if (!in_character && !in_string) {
|
|
||||||
if (str[i] == delimiter) {
|
|
||||||
return (char *)str + i;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
++i;
|
|
||||||
}
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
int unescape_string(char *string) {
|
int unescape_string(char *string) {
|
||||||
/* TODO: More C string escapes */
|
/* TODO: More C string escapes */
|
||||||
int len = strlen(string);
|
int len = strlen(string);
|
||||||
|
@ -276,84 +253,6 @@ char *join_args(char **argv, int argc) {
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool has_whitespace(const char *str) {
|
|
||||||
while (*str) {
|
|
||||||
if (isspace(*str)) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
++str;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Add quotes around any argv with whitespaces.
|
|
||||||
*/
|
|
||||||
void add_quotes(char **argv, int argc) {
|
|
||||||
int i;
|
|
||||||
for (i = 0; i < argc; ++i) {
|
|
||||||
if (has_whitespace(argv[i])) {
|
|
||||||
int len = strlen(argv[i]) + 3;
|
|
||||||
char *tmp = argv[i];
|
|
||||||
argv[i] = malloc(len * sizeof(char));
|
|
||||||
snprintf(argv[i], len, "\"%s\"", tmp);
|
|
||||||
free(tmp);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Join a list of strings, adding separator in between. Separator can be NULL.
|
|
||||||
*/
|
|
||||||
char *join_list(list_t *list, char *separator) {
|
|
||||||
if (!sway_assert(list != NULL, "list != NULL") || list->length == 0) {
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t len = 1; // NULL terminator
|
|
||||||
size_t sep_len = 0;
|
|
||||||
if (separator != NULL) {
|
|
||||||
sep_len = strlen(separator);
|
|
||||||
len += (list->length - 1) * sep_len;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (int i = 0; i < list->length; i++) {
|
|
||||||
len += strlen(list->items[i]);
|
|
||||||
}
|
|
||||||
|
|
||||||
char *res = malloc(len);
|
|
||||||
|
|
||||||
char *p = res + strlen(list->items[0]);
|
|
||||||
strcpy(res, list->items[0]);
|
|
||||||
|
|
||||||
for (int i = 1; i < list->length; i++) {
|
|
||||||
if (sep_len) {
|
|
||||||
memcpy(p, separator, sep_len);
|
|
||||||
p += sep_len;
|
|
||||||
}
|
|
||||||
strcpy(p, list->items[i]);
|
|
||||||
p += strlen(list->items[i]);
|
|
||||||
}
|
|
||||||
|
|
||||||
*p = '\0';
|
|
||||||
|
|
||||||
return res;
|
|
||||||
}
|
|
||||||
|
|
||||||
char *cmdsep(char **stringp, const char *delim) {
|
|
||||||
// skip over leading delims
|
|
||||||
char *head = *stringp + strspn(*stringp, delim);
|
|
||||||
// Find end token
|
|
||||||
char *tail = *stringp += strcspn(*stringp, delim);
|
|
||||||
// Set stringp to beginning of next token
|
|
||||||
*stringp += strspn(*stringp, delim);
|
|
||||||
// Set stringp to null if last token
|
|
||||||
if (!**stringp) *stringp = NULL;
|
|
||||||
// Nullify end of first token
|
|
||||||
*tail = 0;
|
|
||||||
return head;
|
|
||||||
}
|
|
||||||
|
|
||||||
char *argsep(char **stringp, const char *delim) {
|
char *argsep(char **stringp, const char *delim) {
|
||||||
char *start = *stringp;
|
char *start = *stringp;
|
||||||
char *end = start;
|
char *end = start;
|
||||||
|
@ -389,17 +288,3 @@ char *argsep(char **stringp, const char *delim) {
|
||||||
found:
|
found:
|
||||||
return start;
|
return start;
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *strcasestr(const char *haystack, const char *needle) {
|
|
||||||
size_t needle_len = strlen(needle);
|
|
||||||
const char *pos = haystack;
|
|
||||||
const char *end = pos + strlen(haystack) - needle_len;
|
|
||||||
|
|
||||||
while (pos <= end) {
|
|
||||||
if (strncasecmp(pos, needle, needle_len) == 0) {
|
|
||||||
return pos;
|
|
||||||
}
|
|
||||||
++pos;
|
|
||||||
}
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
|
@ -4,7 +4,6 @@
|
||||||
#include "list.h"
|
#include "list.h"
|
||||||
|
|
||||||
void strip_whitespace(char *str);
|
void strip_whitespace(char *str);
|
||||||
char *strip_comments(char *str);
|
|
||||||
void strip_quotes(char *str);
|
void strip_quotes(char *str);
|
||||||
|
|
||||||
// strcat that does nothing if dest or src is NULL
|
// strcat that does nothing if dest or src is NULL
|
||||||
|
@ -21,22 +20,10 @@ list_t *split_string(const char *str, const char *delims);
|
||||||
char **split_args(const char *str, int *argc);
|
char **split_args(const char *str, int *argc);
|
||||||
void free_argv(int argc, char **argv);
|
void free_argv(int argc, char **argv);
|
||||||
|
|
||||||
char *code_strchr(const char *string, char delimiter);
|
|
||||||
char *code_strstr(const char *haystack, const char *needle);
|
|
||||||
int unescape_string(char *string);
|
int unescape_string(char *string);
|
||||||
char *join_args(char **argv, int argc);
|
char *join_args(char **argv, int argc);
|
||||||
char *join_list(list_t *list, char *separator);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Add quotes around any argv with whitespaces.
|
|
||||||
*/
|
|
||||||
void add_quotes(char **argv, int argc);
|
|
||||||
|
|
||||||
// split string into 2 by delim.
|
|
||||||
char *cmdsep(char **stringp, const char *delim);
|
|
||||||
// Split string into 2 by delim, handle quotes
|
// Split string into 2 by delim, handle quotes
|
||||||
char *argsep(char **stringp, const char *delim);
|
char *argsep(char **stringp, const char *delim);
|
||||||
|
|
||||||
const char *strcasestr(const char *haystack, const char *needle);
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -301,6 +301,43 @@ static list_t *load_themes_in_dir(char *basedir) {
|
||||||
return themes;
|
return themes;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void log_loaded_themes(list_t *themes) {
|
||||||
|
if (themes->length == 0) {
|
||||||
|
sway_log(SWAY_INFO, "Warning: no icon themes loaded");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *sep = ", ";
|
||||||
|
size_t sep_len = strlen(sep);
|
||||||
|
|
||||||
|
size_t len = 1 - sep_len;
|
||||||
|
for (int i = 0; i < themes->length; ++i) {
|
||||||
|
struct icon_theme *theme = themes->items[i];
|
||||||
|
len += strlen(theme->name) + sep_len;
|
||||||
|
}
|
||||||
|
|
||||||
|
char *str = malloc(len);
|
||||||
|
if (!str) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
char *p = str;
|
||||||
|
for (int i = 0; i < themes->length; ++i) {
|
||||||
|
if (i > 0) {
|
||||||
|
memcpy(p, sep, sep_len);
|
||||||
|
p += sep_len;
|
||||||
|
}
|
||||||
|
|
||||||
|
struct icon_theme *theme = themes->items[i];
|
||||||
|
size_t name_len = strlen(theme->name);
|
||||||
|
memcpy(p, theme->name, name_len);
|
||||||
|
p += name_len;
|
||||||
|
}
|
||||||
|
*p = '\0';
|
||||||
|
|
||||||
|
sway_log(SWAY_DEBUG, "Loaded icon themes: %s", str);
|
||||||
|
free(str);
|
||||||
|
}
|
||||||
|
|
||||||
void init_themes(list_t **themes, list_t **basedirs) {
|
void init_themes(list_t **themes, list_t **basedirs) {
|
||||||
*basedirs = get_basedirs();
|
*basedirs = get_basedirs();
|
||||||
|
|
||||||
|
@ -311,15 +348,7 @@ void init_themes(list_t **themes, list_t **basedirs) {
|
||||||
list_free(dir_themes);
|
list_free(dir_themes);
|
||||||
}
|
}
|
||||||
|
|
||||||
list_t *theme_names = create_list();
|
log_loaded_themes(*themes);
|
||||||
for (int i = 0; i < (*themes)->length; ++i) {
|
|
||||||
struct icon_theme *theme = (*themes)->items[i];
|
|
||||||
list_add(theme_names, theme->name);
|
|
||||||
}
|
|
||||||
char *theme_list = join_list(theme_names, ", ");
|
|
||||||
sway_log(SWAY_DEBUG, "Loaded themes: %s", theme_list);
|
|
||||||
free(theme_list);
|
|
||||||
list_free(theme_names);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void finish_themes(list_t *themes, list_t *basedirs) {
|
void finish_themes(list_t *themes, list_t *basedirs) {
|
||||||
|
|
Loading…
Reference in a new issue