mirror of
https://github.com/leahneukirchen/cwm.git
synced 2023-08-10 21:13:12 +03:00
simplify config file setup; with Tiago Cunha
This commit is contained in:
parent
479e9f769c
commit
b848a2b236
21
calmwm.c
21
calmwm.c
@ -62,7 +62,7 @@ int
|
|||||||
main(int argc, char **argv)
|
main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
const char *conf_file = NULL;
|
const char *conf_file = NULL;
|
||||||
char *display_name = NULL;
|
char *conf_path, *display_name = NULL;
|
||||||
int ch;
|
int ch;
|
||||||
struct passwd *pw;
|
struct passwd *pw;
|
||||||
|
|
||||||
@ -97,10 +97,25 @@ main(int argc, char **argv)
|
|||||||
homedir = "/";
|
homedir = "/";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (conf_file == NULL)
|
||||||
|
xasprintf(&conf_path, "%s/%s", homedir, CONFFILE);
|
||||||
|
else
|
||||||
|
conf_path = xstrdup(conf_file);
|
||||||
|
|
||||||
|
if (access(conf_path, R_OK) != 0) {
|
||||||
|
if (conf_file != NULL)
|
||||||
|
warn("%s", conf_file);
|
||||||
|
free(conf_path);
|
||||||
|
conf_path = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
dpy_init(display_name);
|
dpy_init(display_name);
|
||||||
|
|
||||||
bzero(&Conf, sizeof(Conf));
|
conf_init(&Conf);
|
||||||
conf_setup(&Conf, conf_file);
|
if (conf_path && (parse_config(conf_path, &Conf) == -1))
|
||||||
|
warnx("config file %s has errors, not loading", conf_path);
|
||||||
|
free(conf_path);
|
||||||
|
|
||||||
xu_getatoms();
|
xu_getatoms();
|
||||||
x_setup();
|
x_setup();
|
||||||
xev_loop();
|
xev_loop();
|
||||||
|
1
calmwm.h
1
calmwm.h
@ -448,7 +448,6 @@ void conf_grab(struct conf *, struct keybinding *);
|
|||||||
void conf_grab_mouse(struct client_ctx *);
|
void conf_grab_mouse(struct client_ctx *);
|
||||||
void conf_init(struct conf *);
|
void conf_init(struct conf *);
|
||||||
void conf_mousebind(struct conf *, char *, char *);
|
void conf_mousebind(struct conf *, char *, char *);
|
||||||
void conf_setup(struct conf *, const char *);
|
|
||||||
void conf_ungrab(struct conf *, struct keybinding *);
|
void conf_ungrab(struct conf *, struct keybinding *);
|
||||||
|
|
||||||
int font_ascent(struct screen_ctx *);
|
int font_ascent(struct screen_ctx *);
|
||||||
|
31
conf.c
31
conf.c
@ -166,7 +166,8 @@ conf_init(struct conf *c)
|
|||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
c->flags = 0;
|
bzero(c, sizeof(*c));
|
||||||
|
|
||||||
c->bwidth = CONF_BWIDTH;
|
c->bwidth = CONF_BWIDTH;
|
||||||
c->mamount = CONF_MAMOUNT;
|
c->mamount = CONF_MAMOUNT;
|
||||||
c->snapdist = CONF_SNAPDIST;
|
c->snapdist = CONF_SNAPDIST;
|
||||||
@ -242,34 +243,6 @@ conf_clear(struct conf *c)
|
|||||||
free(c->font);
|
free(c->font);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
|
||||||
conf_setup(struct conf *c, const char *conf_file)
|
|
||||||
{
|
|
||||||
char conf_path[MAXPATHLEN];
|
|
||||||
struct stat sb;
|
|
||||||
int parse = 0;
|
|
||||||
|
|
||||||
conf_init(c);
|
|
||||||
|
|
||||||
if (conf_file == NULL) {
|
|
||||||
(void)snprintf(conf_path, sizeof(conf_path), "%s/%s",
|
|
||||||
homedir, CONFFILE);
|
|
||||||
|
|
||||||
if (stat(conf_path, &sb) == 0 && (sb.st_mode & S_IFREG))
|
|
||||||
parse = 1;
|
|
||||||
} else {
|
|
||||||
if (stat(conf_file, &sb) == -1 || !(sb.st_mode & S_IFREG))
|
|
||||||
errx(1, "%s: %s", conf_file, strerror(errno));
|
|
||||||
else {
|
|
||||||
(void)strlcpy(conf_path, conf_file, sizeof(conf_path));
|
|
||||||
parse = 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (parse && (parse_config(conf_path, c) == -1))
|
|
||||||
warnx("config file %s has errors, not loading", conf_path);
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
void
|
||||||
conf_client(struct client_ctx *cc)
|
conf_client(struct client_ctx *cc)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user