remove awesome-check, move that to an -k option to awesome
This commit is contained in:
parent
0c8f75b26b
commit
f2e64adb59
|
@ -154,14 +154,6 @@ awesome_message_SOURCES = \
|
|||
|
||||
awesome_message_LDADD = $(XFT_LIBS) $(X_LIBS) $(CAIRO_LIBS)
|
||||
|
||||
bin_PROGRAMS += awesome-check
|
||||
awesome_check_SOURCES = \
|
||||
awesome-check.c common/configopts.h \
|
||||
common/util.h common/util.c \
|
||||
common/awesome-version.h common/awesome-version.c
|
||||
|
||||
awesome_check_LDADD = $(CONFUSE_LIBS)
|
||||
|
||||
EXTRA_DIST += awesome.1.txt
|
||||
man_MANS += awesome.1
|
||||
|
||||
|
|
|
@ -1,97 +0,0 @@
|
|||
/*
|
||||
* awesome-check.c - awesome configuration file testing
|
||||
*
|
||||
* Copyright © 2008 Julien Danjou <julien@danjou.info>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License along
|
||||
* with this program; if not, write to the Free Software Foundation, Inc.,
|
||||
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
*/
|
||||
|
||||
#include <confuse.h>
|
||||
|
||||
#include "common/awesome-version.h"
|
||||
#include "common/util.h"
|
||||
#include "common/configopts.h"
|
||||
|
||||
#define PROGNAME "awesome-check"
|
||||
|
||||
/** Print help and exit(2) with given exit_code.
|
||||
*/
|
||||
static void __attribute__ ((noreturn))
|
||||
exit_help(int exit_code)
|
||||
{
|
||||
FILE *outfile = (exit_code == EXIT_SUCCESS) ? stdout : stderr;
|
||||
fprintf(outfile, "Usage: %s [-v | -h | -c configfile]\n", PROGNAME);
|
||||
exit(exit_code);
|
||||
}
|
||||
|
||||
int
|
||||
main(int argc, char *argv[])
|
||||
{
|
||||
cfg_t *cfg;
|
||||
char *confpath = NULL;
|
||||
const char *homedir = NULL;
|
||||
int args_ok = 1, ret;
|
||||
ssize_t confpath_len;
|
||||
|
||||
/* check args */
|
||||
if(argc >= 2)
|
||||
{
|
||||
args_ok = 0;
|
||||
if(!a_strcmp("-v", argv[1]) || !a_strcmp("--version", argv[1]))
|
||||
eprint_version(PROGNAME);
|
||||
else if(!a_strcmp("-h", argv[1]) || !a_strcmp("--help", argv[1]))
|
||||
exit_help(EXIT_SUCCESS);
|
||||
else if(!a_strcmp("-c", argv[1]))
|
||||
{
|
||||
if(a_strlen(argv[2]))
|
||||
confpath = argv[2], args_ok = 1;
|
||||
else
|
||||
eprint("-c option requires a file name\n");
|
||||
}
|
||||
else
|
||||
exit_help(EXIT_FAILURE);
|
||||
}
|
||||
if(!args_ok)
|
||||
exit_help(EXIT_FAILURE);
|
||||
|
||||
if(!confpath)
|
||||
{
|
||||
homedir = getenv("HOME");
|
||||
confpath_len = a_strlen(homedir) + a_strlen(AWESOME_CONFIG_FILE) + 2;
|
||||
confpath = p_new(char, confpath_len);
|
||||
a_strcpy(confpath, confpath_len, homedir);
|
||||
a_strcat(confpath, confpath_len, "/");
|
||||
a_strcat(confpath, confpath_len, AWESOME_CONFIG_FILE);
|
||||
}
|
||||
|
||||
cfg = cfg_init(opts, CFGF_NONE);
|
||||
|
||||
switch((ret = cfg_parse(cfg, confpath)))
|
||||
{
|
||||
case CFG_FILE_ERROR:
|
||||
perror("awesome: parsing configuration file failed");
|
||||
break;
|
||||
case CFG_PARSE_ERROR:
|
||||
cfg_error(cfg, "awesome: parsing configuration file %s failed.\n", confpath);
|
||||
break;
|
||||
case CFG_SUCCESS:
|
||||
printf("Configuration file OK.\n");
|
||||
break;
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
// vim: filetype=c:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=80
|
|
@ -43,8 +43,12 @@ OPTIONS
|
|||
-------
|
||||
-v | --version::
|
||||
prints version information to standard output, then exits.
|
||||
-h | --help::
|
||||
prints help information, then exits.
|
||||
-c::
|
||||
use an alternate configuration file instead of $HOME/.awesomerc.
|
||||
-k::
|
||||
check configuration file syntax.
|
||||
|
||||
DEFAULTS MOUSE BINDINGS
|
||||
-----------------------
|
||||
|
|
|
@ -189,7 +189,7 @@ static void __attribute__ ((noreturn))
|
|||
exit_help(int exit_code)
|
||||
{
|
||||
FILE *outfile = (exit_code == EXIT_SUCCESS) ? stdout : stderr;
|
||||
fprintf(outfile, "Usage: awesome [-v | -h | -c configfile]\n");
|
||||
fprintf(outfile, "Usage: awesome [ -v | -h | -c configfile | -k ]\n");
|
||||
exit(exit_code);
|
||||
}
|
||||
|
||||
|
@ -216,6 +216,7 @@ main(int argc, char *argv[])
|
|||
int args_ok = 1;
|
||||
|
||||
/* check args */
|
||||
/* XXX switch to getopt */
|
||||
if(argc >= 2)
|
||||
{
|
||||
args_ok = 0;
|
||||
|
@ -230,6 +231,8 @@ main(int argc, char *argv[])
|
|||
else
|
||||
eprint("-c option requires a file name\n");
|
||||
}
|
||||
else if(!a_strcmp("-k", argv[1]))
|
||||
return config_check(confpath);
|
||||
else
|
||||
exit_help(EXIT_FAILURE);
|
||||
}
|
||||
|
|
60
config.c
60
config.c
|
@ -428,6 +428,55 @@ config_parse_screen(cfg_t *cfg, int screen)
|
|||
virtscreen->padding.right = cfg_getint(cfg_padding, "right");
|
||||
}
|
||||
|
||||
static char *
|
||||
config_file(void)
|
||||
{
|
||||
const char *homedir;
|
||||
char * confpath;
|
||||
ssize_t confpath_len;
|
||||
|
||||
homedir = getenv("HOME");
|
||||
confpath_len = a_strlen(homedir) + a_strlen(AWESOME_CONFIG_FILE) + 2;
|
||||
confpath = p_new(char, confpath_len);
|
||||
a_strcpy(confpath, confpath_len, homedir);
|
||||
a_strcat(confpath, confpath_len, "/");
|
||||
a_strcat(confpath, confpath_len, AWESOME_CONFIG_FILE);
|
||||
|
||||
return confpath;
|
||||
}
|
||||
|
||||
int
|
||||
config_check(const char *confpatharg)
|
||||
{
|
||||
cfg_t *cfg;
|
||||
int ret;
|
||||
char *confpath;
|
||||
|
||||
cfg = cfg_init(opts, CFGF_NONE);
|
||||
|
||||
if(confpatharg)
|
||||
confpath = a_strdup(confpatharg);
|
||||
else
|
||||
confpath = config_file();
|
||||
|
||||
switch((ret = cfg_parse(cfg, confpath)))
|
||||
{
|
||||
case CFG_FILE_ERROR:
|
||||
perror("awesome: parsing configuration file failed");
|
||||
break;
|
||||
case CFG_PARSE_ERROR:
|
||||
cfg_error(cfg, "awesome: parsing configuration file %s failed.\n", confpath);
|
||||
break;
|
||||
case CFG_SUCCESS:
|
||||
printf("Configuration file OK.\n");
|
||||
break;
|
||||
}
|
||||
|
||||
p_delete(&confpath);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
/** Parse configuration file and initialize some stuff
|
||||
* \param confpatharg Path to configuration file
|
||||
*/
|
||||
|
@ -436,23 +485,14 @@ config_parse(const char *confpatharg)
|
|||
{
|
||||
cfg_t *cfg, *cfg_rules, *cfg_keys, *cfg_mouse, *cfgsectmp;
|
||||
int ret, screen, i;
|
||||
const char *homedir;
|
||||
char *confpath;
|
||||
ssize_t confpath_len;
|
||||
Rule *rule = NULL;
|
||||
FILE *defconfig = NULL;
|
||||
|
||||
if(confpatharg)
|
||||
confpath = a_strdup(confpatharg);
|
||||
else
|
||||
{
|
||||
homedir = getenv("HOME");
|
||||
confpath_len = a_strlen(homedir) + a_strlen(AWESOME_CONFIG_FILE) + 2;
|
||||
confpath = p_new(char, confpath_len);
|
||||
a_strcpy(confpath, confpath_len, homedir);
|
||||
a_strcat(confpath, confpath_len, "/");
|
||||
a_strcat(confpath, confpath_len, AWESOME_CONFIG_FILE);
|
||||
}
|
||||
confpath = config_file();
|
||||
|
||||
globalconf.configpath = a_strdup(confpath);
|
||||
|
||||
|
|
Loading…
Reference in New Issue