mirror of
https://github.com/labwc/labwc.git
synced 2025-11-04 13:30:07 -05:00
Simplify and merge {config,theme}-dir.c
This commit is contained in:
parent
fc6fca6945
commit
f003abf608
20 changed files with 181 additions and 163 deletions
|
|
@ -1,5 +1,7 @@
|
||||||
#ifndef __LABWC_THEME_DIR_H
|
#ifndef __LABWC_DIR_H
|
||||||
#define __LABWC_THEME_DIR_H
|
#define __LABWC_DIR_H
|
||||||
|
|
||||||
|
char *config_dir(void);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* theme_dir - find theme directory containing theme @theme_name
|
* theme_dir - find theme directory containing theme @theme_name
|
||||||
|
|
@ -7,4 +9,4 @@
|
||||||
*/
|
*/
|
||||||
char *theme_dir(const char *theme_name);
|
char *theme_dir(const char *theme_name);
|
||||||
|
|
||||||
#endif /* __LABWC_THEME_DIR_H */
|
#endif /* __LABWC_DIR_H */
|
||||||
|
|
@ -1,6 +0,0 @@
|
||||||
#ifndef __LABWC_CONFIG_DIR_H
|
|
||||||
#define __LABWC_CONFIG_DIR_H
|
|
||||||
|
|
||||||
char *config_dir(void);
|
|
||||||
|
|
||||||
#endif /* __LABWC_CONFIG_DIR_H */
|
|
||||||
135
src/common/dir.c
Normal file
135
src/common/dir.c
Normal file
|
|
@ -0,0 +1,135 @@
|
||||||
|
/*
|
||||||
|
* Find the configuration and theme directories
|
||||||
|
*
|
||||||
|
* Copyright Johan Malm 2020
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
#include <stdbool.h>
|
||||||
|
#include <glib.h>
|
||||||
|
|
||||||
|
#include "common/dir.h"
|
||||||
|
|
||||||
|
struct dir {
|
||||||
|
const char *prefix;
|
||||||
|
const char *path;
|
||||||
|
};
|
||||||
|
|
||||||
|
/* clang-format off */
|
||||||
|
static struct dir config_dirs[] = {
|
||||||
|
{ "XDG_CONFIG_HOME", "labwc" },
|
||||||
|
{ "HOME", ".config/labwc" },
|
||||||
|
{ "XDG_CONFIG_DIRS", "labwc" },
|
||||||
|
{ NULL, "/etc/xdg/labwc" },
|
||||||
|
{ "XDG_CONFIG_HOME", "openbox" },
|
||||||
|
{ "HOME", ".config/openbox" },
|
||||||
|
{ "XDG_CONFIG_DIRS", "openbox" },
|
||||||
|
{ NULL, "/etc/xdg/openbox" },
|
||||||
|
{ NULL, NULL }
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct dir theme_dirs[] = {
|
||||||
|
{ "XDG_DATA_HOME", "themes" },
|
||||||
|
{ "HOME", ".local/share/themes" },
|
||||||
|
{ "HOME", ".themes" },
|
||||||
|
{ "XDG_DATA_DIRS", "themes" },
|
||||||
|
{ NULL, "/usr/share/themes" },
|
||||||
|
{ NULL, "/usr/local/share/themes" },
|
||||||
|
{ NULL, "opt/share/themes" },
|
||||||
|
{ NULL, NULL }
|
||||||
|
};
|
||||||
|
/* clang-format on */
|
||||||
|
|
||||||
|
static bool isdir(const char *path)
|
||||||
|
{
|
||||||
|
struct stat st;
|
||||||
|
return (!stat(path, &st) && S_ISDIR(st.st_mode));
|
||||||
|
}
|
||||||
|
|
||||||
|
struct ctx {
|
||||||
|
void (*build_path_fn)(struct ctx *ctx, char *prefix, const char *path);
|
||||||
|
char *buf;
|
||||||
|
size_t len;
|
||||||
|
struct dir *dirs;
|
||||||
|
const char *theme_name;
|
||||||
|
};
|
||||||
|
|
||||||
|
static void build_config_path(struct ctx *ctx, char *prefix, const char *path)
|
||||||
|
{
|
||||||
|
if (!prefix)
|
||||||
|
snprintf(ctx->buf, ctx->len, "%s", path);
|
||||||
|
else
|
||||||
|
snprintf(ctx->buf, ctx->len, "%s/%s", prefix, path);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void build_theme_path(struct ctx *ctx, char *prefix, const char *path)
|
||||||
|
{
|
||||||
|
if (!prefix)
|
||||||
|
snprintf(ctx->buf, ctx->len, "%s/%s/openbox-3", path,
|
||||||
|
ctx->theme_name);
|
||||||
|
else
|
||||||
|
snprintf(ctx->buf, ctx->len, "%s/%s/%s/openbox-3", prefix, path,
|
||||||
|
ctx->theme_name);
|
||||||
|
}
|
||||||
|
|
||||||
|
char *find_dir(struct ctx *ctx)
|
||||||
|
{
|
||||||
|
char *debug = getenv("LABWC_DEBUG_DIR_CONFIG_AND_THEME");
|
||||||
|
|
||||||
|
for (int i = 0; ctx->dirs[i].path; i++) {
|
||||||
|
struct dir d = ctx->dirs[i];
|
||||||
|
if (!d.prefix) {
|
||||||
|
/* handle /etc/xdg... */
|
||||||
|
ctx->build_path_fn(ctx, NULL, d.path);
|
||||||
|
if (debug)
|
||||||
|
fprintf(stderr, "DEBUG: %s\n", ctx->buf);
|
||||||
|
if (isdir(ctx->buf))
|
||||||
|
return ctx->buf;
|
||||||
|
} else {
|
||||||
|
/* handle $HOME/.config/... and $XDG_* */
|
||||||
|
char *prefix = getenv(d.prefix);
|
||||||
|
if (!prefix)
|
||||||
|
continue;
|
||||||
|
gchar **prefixes = g_strsplit(prefix, ":", -1);
|
||||||
|
for (gchar **p = prefixes; *p; p++) {
|
||||||
|
ctx->build_path_fn(ctx, *p, d.path);
|
||||||
|
if (debug)
|
||||||
|
fprintf(stderr, "DEBUG: %s\n",
|
||||||
|
ctx->buf);
|
||||||
|
if (isdir(ctx->buf))
|
||||||
|
return ctx->buf;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* no directory was found */
|
||||||
|
ctx->buf[0] = '.';
|
||||||
|
ctx->buf[1] = '\0';
|
||||||
|
return ctx->buf;
|
||||||
|
}
|
||||||
|
|
||||||
|
char *config_dir(void)
|
||||||
|
{
|
||||||
|
static char buf[4096] = { 0 };
|
||||||
|
if (buf[0] != '\0')
|
||||||
|
return buf;
|
||||||
|
struct ctx ctx = { .build_path_fn = build_config_path,
|
||||||
|
.buf = buf,
|
||||||
|
.len = sizeof(buf),
|
||||||
|
.dirs = config_dirs };
|
||||||
|
return find_dir(&ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
char *theme_dir(const char *theme_name)
|
||||||
|
{
|
||||||
|
static char buf[4096] = { 0 };
|
||||||
|
if (buf[0] != '\0')
|
||||||
|
return buf;
|
||||||
|
struct ctx ctx = { .build_path_fn = build_theme_path,
|
||||||
|
.buf = buf,
|
||||||
|
.len = sizeof(buf),
|
||||||
|
.dirs = theme_dirs,
|
||||||
|
.theme_name = theme_name };
|
||||||
|
return find_dir(&ctx);
|
||||||
|
}
|
||||||
|
|
@ -1,5 +1,6 @@
|
||||||
labwc_sources += files(
|
labwc_sources += files(
|
||||||
'buf.c',
|
'buf.c',
|
||||||
|
'dir.c',
|
||||||
'font.c',
|
'font.c',
|
||||||
'grab-file.c',
|
'grab-file.c',
|
||||||
'spawn.c',
|
'spawn.c',
|
||||||
|
|
|
||||||
|
|
@ -1,70 +0,0 @@
|
||||||
/*
|
|
||||||
* Find the labwc configuration directory
|
|
||||||
*
|
|
||||||
* Copyright Johan Malm 2020
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <sys/stat.h>
|
|
||||||
#include <stdbool.h>
|
|
||||||
#include <glib.h>
|
|
||||||
|
|
||||||
#include "config/config-dir.h"
|
|
||||||
|
|
||||||
struct dir {
|
|
||||||
const char *prefix;
|
|
||||||
const char *path;
|
|
||||||
};
|
|
||||||
|
|
||||||
/* clang-format off */
|
|
||||||
static struct dir config_dirs[] = {
|
|
||||||
{ "XDG_CONFIG_HOME", "labwc" },
|
|
||||||
{ "HOME", ".config/labwc" },
|
|
||||||
{ "XDG_CONFIG_DIRS", "labwc" },
|
|
||||||
{ NULL, "/etc/xdg/labwc" },
|
|
||||||
{ "XDG_CONFIG_HOME", "openbox" },
|
|
||||||
{ "HOME", ".config/openbox" },
|
|
||||||
{ "XDG_CONFIG_DIRS", "openbox" },
|
|
||||||
{ NULL, "/etc/xdg/openbox" },
|
|
||||||
{ NULL, NULL }
|
|
||||||
};
|
|
||||||
/* clang-format on */
|
|
||||||
|
|
||||||
static bool isdir(const char *path)
|
|
||||||
{
|
|
||||||
struct stat st;
|
|
||||||
return (!stat(path, &st) && S_ISDIR(st.st_mode));
|
|
||||||
}
|
|
||||||
|
|
||||||
char *config_dir(void)
|
|
||||||
{
|
|
||||||
static char buf[4096] = { 0 };
|
|
||||||
if (buf[0] != '\0')
|
|
||||||
return buf;
|
|
||||||
|
|
||||||
for (int i = 0; config_dirs[i].path; i++) {
|
|
||||||
struct dir d = config_dirs[i];
|
|
||||||
if (!d.prefix) {
|
|
||||||
/* handle /etc/xdg... */
|
|
||||||
snprintf(buf, sizeof(buf), "%s", d.path);
|
|
||||||
if (isdir(buf))
|
|
||||||
return buf;
|
|
||||||
} else {
|
|
||||||
/* handle $HOME/.config/... and $XDG_* */
|
|
||||||
char *prefix = getenv(d.prefix);
|
|
||||||
if (!prefix)
|
|
||||||
continue;
|
|
||||||
gchar **prefixes = g_strsplit(prefix, ":", -1);
|
|
||||||
for (gchar **p = prefixes; *p; p++) {
|
|
||||||
snprintf(buf, sizeof(buf), "%s/%s", *p, d.path);
|
|
||||||
if (isdir(buf))
|
|
||||||
return buf;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/* no config directory was found */
|
|
||||||
buf[0] = '.';
|
|
||||||
buf[1] = '\0';
|
|
||||||
return buf;
|
|
||||||
}
|
|
||||||
|
|
@ -1,5 +1,4 @@
|
||||||
labwc_sources += files(
|
labwc_sources += files(
|
||||||
'config-dir.c',
|
|
||||||
'rcxml.c',
|
'rcxml.c',
|
||||||
'keybind.c',
|
'keybind.c',
|
||||||
)
|
)
|
||||||
|
|
|
||||||
|
|
@ -12,7 +12,7 @@
|
||||||
|
|
||||||
#include "config/rcxml.h"
|
#include "config/rcxml.h"
|
||||||
#include "config/keybind.h"
|
#include "config/keybind.h"
|
||||||
#include "config/config-dir.h"
|
#include "common/dir.h"
|
||||||
#include "common/bug-on.h"
|
#include "common/bug-on.h"
|
||||||
#include "common/font.h"
|
#include "common/font.h"
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,5 @@
|
||||||
labwc_sources += files(
|
labwc_sources += files(
|
||||||
'theme.c',
|
'theme.c',
|
||||||
'theme-dir.c',
|
|
||||||
)
|
)
|
||||||
|
|
||||||
subdir('xbm')
|
subdir('xbm')
|
||||||
|
|
|
||||||
|
|
@ -1,68 +0,0 @@
|
||||||
/*
|
|
||||||
* Find the openbox theme directory
|
|
||||||
*
|
|
||||||
* Copyright Johan Malm 2020
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <sys/stat.h>
|
|
||||||
#include <stdbool.h>
|
|
||||||
#include <glib.h>
|
|
||||||
|
|
||||||
struct dir {
|
|
||||||
const char *prefix;
|
|
||||||
const char *path;
|
|
||||||
};
|
|
||||||
|
|
||||||
/* clang-format off */
|
|
||||||
static struct dir theme_dirs[] = {
|
|
||||||
{ "XDG_DATA_HOME", "themes" },
|
|
||||||
{ "HOME", ".local/share/themes" },
|
|
||||||
{ "HOME", ".themes" },
|
|
||||||
{ "XDG_DATA_DIRS", "themes" },
|
|
||||||
{ NULL, "/usr/share/themes" },
|
|
||||||
{ NULL, "/usr/local/share/themes" },
|
|
||||||
{ NULL, "opt/share/themes" },
|
|
||||||
{ NULL, NULL }
|
|
||||||
};
|
|
||||||
/* clang-format on */
|
|
||||||
|
|
||||||
static bool isdir(const char *path)
|
|
||||||
{
|
|
||||||
struct stat st;
|
|
||||||
return (!stat(path, &st) && S_ISDIR(st.st_mode));
|
|
||||||
}
|
|
||||||
|
|
||||||
char *theme_dir(const char *theme_name)
|
|
||||||
{
|
|
||||||
static char buf[4096] = { 0 };
|
|
||||||
if (buf[0] != '\0')
|
|
||||||
return buf;
|
|
||||||
|
|
||||||
for (int i = 0; theme_dirs[i].path; i++) {
|
|
||||||
struct dir d = theme_dirs[i];
|
|
||||||
if (!d.prefix) {
|
|
||||||
snprintf(buf, sizeof(buf), "%s/%s/openbox-3", d.path,
|
|
||||||
theme_name);
|
|
||||||
if (isdir(buf))
|
|
||||||
return buf;
|
|
||||||
} else {
|
|
||||||
char *prefix = getenv(d.prefix);
|
|
||||||
if (!prefix)
|
|
||||||
continue;
|
|
||||||
gchar **prefixes = g_strsplit(prefix, ":", -1);
|
|
||||||
for (gchar **p = prefixes; *p; p++) {
|
|
||||||
snprintf(buf, sizeof(buf),
|
|
||||||
"%s/%s/%s/openbox-3", *p, d.path,
|
|
||||||
theme_name);
|
|
||||||
if (isdir(buf))
|
|
||||||
return buf;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/* no config directory was found */
|
|
||||||
buf[0] = '.';
|
|
||||||
buf[1] = '\0';
|
|
||||||
return buf;
|
|
||||||
}
|
|
||||||
|
|
@ -7,7 +7,7 @@
|
||||||
#include <glib.h>
|
#include <glib.h>
|
||||||
|
|
||||||
#include "theme/theme.h"
|
#include "theme/theme.h"
|
||||||
#include "theme/theme-dir.h"
|
#include "common/dir.h"
|
||||||
|
|
||||||
static int hex_to_dec(char c)
|
static int hex_to_dec(char c)
|
||||||
{
|
{
|
||||||
|
|
|
||||||
|
|
@ -10,8 +10,8 @@
|
||||||
#include "theme/theme.h"
|
#include "theme/theme.h"
|
||||||
#include "theme/xbm/xbm.h"
|
#include "theme/xbm/xbm.h"
|
||||||
#include "theme/xbm/parse.h"
|
#include "theme/xbm/parse.h"
|
||||||
#include "theme/theme-dir.h"
|
|
||||||
#include "config/rcxml.h"
|
#include "config/rcxml.h"
|
||||||
|
#include "common/dir.h"
|
||||||
#include "common/grab-file.h"
|
#include "common/grab-file.h"
|
||||||
|
|
||||||
/* built-in 6x6 buttons */
|
/* built-in 6x6 buttons */
|
||||||
|
|
|
||||||
|
|
@ -3,7 +3,7 @@ rcxml_lib = static_library(
|
||||||
sources: files(
|
sources: files(
|
||||||
'../src/config/rcxml.c',
|
'../src/config/rcxml.c',
|
||||||
'../src/config/keybind.c',
|
'../src/config/keybind.c',
|
||||||
'../src/config/config-dir.c',
|
'../src/common/dir.c',
|
||||||
'../src/common/buf.c',
|
'../src/common/buf.c',
|
||||||
'../src/common/font.c',
|
'../src/common/font.c',
|
||||||
),
|
),
|
||||||
|
|
|
||||||
6
tools/dirs/Makefile
Normal file
6
tools/dirs/Makefile
Normal file
|
|
@ -0,0 +1,6 @@
|
||||||
|
CFLAGS += -g -Wall -I../../include
|
||||||
|
CFLAGS += `pkg-config --cflags glib-2.0`
|
||||||
|
LDFLAGS += `pkg-config --libs glib-2.0`
|
||||||
|
|
||||||
|
all:
|
||||||
|
$(CC) $(CFLAGS) -o dir-list dir-list.c ../../src/common/dir.c $(LDFLAGS)
|
||||||
BIN
tools/dirs/dir-list
Executable file
BIN
tools/dirs/dir-list
Executable file
Binary file not shown.
12
tools/dirs/dir-list.c
Normal file
12
tools/dirs/dir-list.c
Normal file
|
|
@ -0,0 +1,12 @@
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
#include "common/dir.h"
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
setenv("LABWC_DEBUG_DIR_CONFIG_AND_THEME", "1", 1);
|
||||||
|
setenv("XDG_CONFIG_HOME", "/a:/bbb:/ccccc:/etc/foo", 1);
|
||||||
|
printf("%s\n", config_dir());
|
||||||
|
printf("%s\n", theme_dir("Numix"));
|
||||||
|
}
|
||||||
|
|
@ -6,14 +6,15 @@ ASAN_FLAGS = -O0 -fsanitize=address -fno-common -fno-omit-frame-pointer -rdynami
|
||||||
CFLAGS += $(ASAN_FLAGS)
|
CFLAGS += $(ASAN_FLAGS)
|
||||||
LDFLAGS += $(ASAN_FLAGS) -fuse-ld=gold
|
LDFLAGS += $(ASAN_FLAGS) -fuse-ld=gold
|
||||||
LDFLAGS += `xml2-config --libs`
|
LDFLAGS += `xml2-config --libs`
|
||||||
LDFLAGS += `pkg-config --cflags --libs glib-2.0 wayland-server xkbcommon`
|
LDFLAGS += `pkg-config --cflags --libs glib-2.0 cairo pangocairo wayland-server xkbcommon`
|
||||||
|
|
||||||
PROGS = rcxml-print-nodenames
|
PROGS = rcxml-print-nodenames
|
||||||
SRC = \
|
SRC = \
|
||||||
rcxml-print-nodenames.c \
|
rcxml-print-nodenames.c \
|
||||||
../../src/config/rcxml.c \
|
../../src/config/rcxml.c \
|
||||||
../../src/config/config-dir.c \
|
../../src/common/dir.c \
|
||||||
../../src/common/buf.c \
|
../../src/common/buf.c \
|
||||||
|
../../src/common/font.c \
|
||||||
../../src/config/keybind.c
|
../../src/config/keybind.c
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -10,7 +10,7 @@ LDFLAGS += -DWLR_USE_UNSTABLE
|
||||||
SRCS = \
|
SRCS = \
|
||||||
theme-helper.c \
|
theme-helper.c \
|
||||||
../../src/theme/theme.c \
|
../../src/theme/theme.c \
|
||||||
../../src/theme/theme-dir.c
|
../../src/common/dir.c
|
||||||
|
|
||||||
all:
|
all:
|
||||||
gcc $(CFLAGS) -o theme-helper $(SRCS) $(LDFLAGS)
|
gcc $(CFLAGS) -o theme-helper $(SRCS) $(LDFLAGS)
|
||||||
|
|
|
||||||
|
|
@ -4,8 +4,14 @@ LDFLAGS += `pkg-config --cflags --libs cairo`
|
||||||
ASAN += -fsanitize=address
|
ASAN += -fsanitize=address
|
||||||
|
|
||||||
PROGS = xbm-tokenize xbm-parse
|
PROGS = xbm-tokenize xbm-parse
|
||||||
DEP_TOKENIZE = ../../src/common/buf.c ../../src/theme/xbm/tokenize.c
|
|
||||||
DEP_PARSE = $(DEP_TOKENIZE) ../../src/theme/xbm/parse.c
|
DEP_TOKENIZE = \
|
||||||
|
../../src/common/buf.c \
|
||||||
|
../../src/theme/xbm/tokenize.c
|
||||||
|
|
||||||
|
DEP_PARSE = $(DEP_TOKENIZE) \
|
||||||
|
../../src/theme/xbm/parse.c \
|
||||||
|
../../src/common/grab-file.c
|
||||||
|
|
||||||
all: $(PROGS)
|
all: $(PROGS)
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@
|
||||||
#include <cairo.h>
|
#include <cairo.h>
|
||||||
|
|
||||||
#include "theme/xbm/parse.h"
|
#include "theme/xbm/parse.h"
|
||||||
|
#include "common/grab-file.h"
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
|
|
@ -14,12 +15,12 @@ int main(int argc, char **argv)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *buffer = xbm_read_file(argv[1]);
|
char *buffer = grab_file(argv[1]);
|
||||||
if (!buffer)
|
if (!buffer)
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
tokens = xbm_tokenize(buffer);
|
tokens = tokenize_xbm(buffer);
|
||||||
free(buffer);
|
free(buffer);
|
||||||
struct pixmap pixmap = xbm_create_pixmap(tokens);
|
struct pixmap pixmap = parse_xbm_tokens(tokens);
|
||||||
free(tokens);
|
free(tokens);
|
||||||
|
|
||||||
cairo_surface_t *g_surface;
|
cairo_surface_t *g_surface;
|
||||||
|
|
|
||||||
|
|
@ -3,7 +3,7 @@
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include "buf.h"
|
#include "common/buf.h"
|
||||||
#include "theme/xbm/tokenize.h"
|
#include "theme/xbm/tokenize.h"
|
||||||
|
|
||||||
/* Read file into buffer, because it's easier to tokenize that way */
|
/* Read file into buffer, because it's easier to tokenize that way */
|
||||||
|
|
@ -41,7 +41,7 @@ int main(int argc, char **argv)
|
||||||
char *buffer = read_file(argv[1]);
|
char *buffer = read_file(argv[1]);
|
||||||
if (!buffer)
|
if (!buffer)
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
tokens = xbm_tokenize(buffer);
|
tokens = tokenize_xbm(buffer);
|
||||||
free(buffer);
|
free(buffer);
|
||||||
for (struct token *t = tokens; t->type; t++)
|
for (struct token *t = tokens; t->type; t++)
|
||||||
printf("%s\n", t->name);
|
printf("%s\n", t->name);
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue