mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Define POSIX macro to have strdup
98c38dc6d6
sets C99 as standard.
strdup() is not part of C99.
For now set `-D_POSIX_C_SOURCE=200809L` macro to have strdup() in C99.
Using `gnu99` instead would be another option.
We should take more care to use glib functions whenever possible.
Regards https://github.com/profanity-im/profanity/issues/1357
This commit is contained in:
parent
f1141932fc
commit
74e061165a
@ -354,7 +354,7 @@ AC_CHECK_HEADERS([ncursesw/ncurses.h], [], [])
|
|||||||
AC_CHECK_HEADERS([ncurses.h], [], [])
|
AC_CHECK_HEADERS([ncurses.h], [], [])
|
||||||
|
|
||||||
### Default parameters
|
### Default parameters
|
||||||
AM_CFLAGS="-Wall -Wno-deprecated-declarations -std=c99"
|
AM_CFLAGS="-Wall -Wno-deprecated-declarations -std=c99 -D_POSIX_C_SOURCE=200809L"
|
||||||
AS_IF([test "x$PACKAGE_STATUS" = xdevelopment],
|
AS_IF([test "x$PACKAGE_STATUS" = xdevelopment],
|
||||||
[AM_CFLAGS="$AM_CFLAGS -Wunused -Werror"])
|
[AM_CFLAGS="$AM_CFLAGS -Wunused -Werror"])
|
||||||
AS_IF([test "x$PLATFORM" = xosx],
|
AS_IF([test "x$PLATFORM" = xosx],
|
||||||
|
@ -91,7 +91,7 @@ files_create_directories(void)
|
|||||||
g_free(xdg_data);
|
g_free(xdg_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
char*
|
gchar*
|
||||||
files_get_inputrc_file(void)
|
files_get_inputrc_file(void)
|
||||||
{
|
{
|
||||||
gchar *xdg_config = _files_get_xdg_config_home();
|
gchar *xdg_config = _files_get_xdg_config_home();
|
||||||
@ -101,7 +101,7 @@ files_get_inputrc_file(void)
|
|||||||
g_string_append(inputrc_file, "/profanity/inputrc");
|
g_string_append(inputrc_file, "/profanity/inputrc");
|
||||||
|
|
||||||
if (g_file_test(inputrc_file->str, G_FILE_TEST_IS_REGULAR)) {
|
if (g_file_test(inputrc_file->str, G_FILE_TEST_IS_REGULAR)) {
|
||||||
char *result = strdup(inputrc_file->str);
|
gchar *result = g_strdup(inputrc_file->str);
|
||||||
g_string_free(inputrc_file, TRUE);
|
g_string_free(inputrc_file, TRUE);
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
@ -131,7 +131,7 @@ files_get_log_file(char *log_file)
|
|||||||
|
|
||||||
g_string_append(logfile, ".log");
|
g_string_append(logfile, ".log");
|
||||||
|
|
||||||
char *result = strdup(logfile->str);
|
char *result = g_strdup(logfile->str);
|
||||||
|
|
||||||
free(xdg_data);
|
free(xdg_data);
|
||||||
g_string_free(logfile, TRUE);
|
g_string_free(logfile, TRUE);
|
||||||
@ -139,28 +139,28 @@ files_get_log_file(char *log_file)
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
char*
|
gchar*
|
||||||
files_get_config_path(char *config_base)
|
files_get_config_path(char *config_base)
|
||||||
{
|
{
|
||||||
gchar *xdg_config = _files_get_xdg_config_home();
|
gchar *xdg_config = _files_get_xdg_config_home();
|
||||||
GString *file_str = g_string_new(xdg_config);
|
GString *file_str = g_string_new(xdg_config);
|
||||||
g_string_append(file_str, "/profanity/");
|
g_string_append(file_str, "/profanity/");
|
||||||
g_string_append(file_str, config_base);
|
g_string_append(file_str, config_base);
|
||||||
char *result = strdup(file_str->str);
|
gchar *result = g_strdup(file_str->str);
|
||||||
g_free(xdg_config);
|
g_free(xdg_config);
|
||||||
g_string_free(file_str, TRUE);
|
g_string_free(file_str, TRUE);
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
char*
|
gchar*
|
||||||
files_get_data_path(char *data_base)
|
files_get_data_path(char *data_base)
|
||||||
{
|
{
|
||||||
gchar *xdg_data = _files_get_xdg_data_home();
|
gchar *xdg_data = _files_get_xdg_data_home();
|
||||||
GString *file_str = g_string_new(xdg_data);
|
GString *file_str = g_string_new(xdg_data);
|
||||||
g_string_append(file_str, "/profanity/");
|
g_string_append(file_str, "/profanity/");
|
||||||
g_string_append(file_str, data_base);
|
g_string_append(file_str, data_base);
|
||||||
char *result = strdup(file_str->str);
|
gchar *result = g_strdup(file_str->str);
|
||||||
g_free(xdg_data);
|
g_free(xdg_data);
|
||||||
g_string_free(file_str, TRUE);
|
g_string_free(file_str, TRUE);
|
||||||
|
|
||||||
|
@ -60,10 +60,10 @@
|
|||||||
|
|
||||||
void files_create_directories(void);
|
void files_create_directories(void);
|
||||||
|
|
||||||
char* files_get_config_path(char *config_base);
|
gchar* files_get_config_path(char *config_base);
|
||||||
char* files_get_data_path(char *data_base);
|
gchar* files_get_data_path(char *data_base);
|
||||||
|
|
||||||
char* files_get_log_file(char *log_file);
|
gchar* files_get_log_file(char *log_file);
|
||||||
char* files_get_inputrc_file(void);
|
gchar* files_get_inputrc_file(void);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -67,7 +67,7 @@
|
|||||||
|
|
||||||
#define INPBLOCK_DEFAULT 1000
|
#define INPBLOCK_DEFAULT 1000
|
||||||
|
|
||||||
static char *prefs_loc;
|
static gchar *prefs_loc;
|
||||||
static GKeyFile *prefs;
|
static GKeyFile *prefs;
|
||||||
gint log_maxsize = 0;
|
gint log_maxsize = 0;
|
||||||
|
|
||||||
@ -209,7 +209,7 @@ prefs_load(char *config_file)
|
|||||||
if (config_file == NULL) {
|
if (config_file == NULL) {
|
||||||
prefs_loc = files_get_config_path(FILE_PROFRC);
|
prefs_loc = files_get_config_path(FILE_PROFRC);
|
||||||
} else {
|
} else {
|
||||||
prefs_loc = strdup(config_file);
|
prefs_loc = g_strdup(config_file);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (g_file_test(prefs_loc, G_FILE_TEST_EXISTS)) {
|
if (g_file_test(prefs_loc, G_FILE_TEST_EXISTS)) {
|
||||||
@ -236,7 +236,7 @@ prefs_close(void)
|
|||||||
g_key_file_free(prefs);
|
g_key_file_free(prefs);
|
||||||
prefs = NULL;
|
prefs = NULL;
|
||||||
|
|
||||||
free(prefs_loc);
|
g_free(prefs_loc);
|
||||||
prefs_loc = NULL;
|
prefs_loc = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -230,10 +230,11 @@ GSList*
|
|||||||
theme_list(void)
|
theme_list(void)
|
||||||
{
|
{
|
||||||
GSList *result = NULL;
|
GSList *result = NULL;
|
||||||
char *themes_dir = files_get_config_path(DIR_THEMES);
|
gchar *themes_dir = files_get_config_path(DIR_THEMES);
|
||||||
|
|
||||||
_theme_list_dir(themes_dir, &result);
|
_theme_list_dir(themes_dir, &result);
|
||||||
free(themes_dir);
|
g_free(themes_dir);
|
||||||
|
|
||||||
#ifdef THEMES_PATH
|
#ifdef THEMES_PATH
|
||||||
_theme_list_dir(THEMES_PATH, &result);
|
_theme_list_dir(THEMES_PATH, &result);
|
||||||
#endif
|
#endif
|
||||||
@ -532,11 +533,11 @@ static GString*
|
|||||||
_theme_find(const char *const theme_name)
|
_theme_find(const char *const theme_name)
|
||||||
{
|
{
|
||||||
GString *path = NULL;
|
GString *path = NULL;
|
||||||
char *themes_dir = files_get_config_path(DIR_THEMES);
|
gchar *themes_dir = files_get_config_path(DIR_THEMES);
|
||||||
|
|
||||||
if (themes_dir) {
|
if (themes_dir) {
|
||||||
path = g_string_new(themes_dir);
|
path = g_string_new(themes_dir);
|
||||||
free(themes_dir);
|
g_free(themes_dir);
|
||||||
g_string_append(path, "/");
|
g_string_append(path, "/");
|
||||||
g_string_append(path, theme_name);
|
g_string_append(path, theme_name);
|
||||||
if (!g_file_test(path->str, G_FILE_TEST_EXISTS)) {
|
if (!g_file_test(path->str, G_FILE_TEST_EXISTS)) {
|
||||||
|
@ -149,13 +149,13 @@ log_init(log_level_t filter, char *log_file)
|
|||||||
level_filter = filter;
|
level_filter = filter;
|
||||||
tz = g_time_zone_new_local();
|
tz = g_time_zone_new_local();
|
||||||
|
|
||||||
char *lf;
|
gchar *lf;
|
||||||
lf = files_get_log_file(log_file);
|
lf = files_get_log_file(log_file);
|
||||||
|
|
||||||
logp = fopen(lf, "a");
|
logp = fopen(lf, "a");
|
||||||
g_chmod(lf, S_IRUSR | S_IWUSR);
|
g_chmod(lf, S_IRUSR | S_IWUSR);
|
||||||
mainlogfile = g_string_new(lf);
|
mainlogfile = g_string_new(lf);
|
||||||
free(lf);
|
g_free(lf);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -503,10 +503,10 @@ _inp_rl_startup_hook(void)
|
|||||||
rl_variable_bind("disable-completion", "on");
|
rl_variable_bind("disable-completion", "on");
|
||||||
|
|
||||||
// check for and load ~/.config/profanity/inputrc
|
// check for and load ~/.config/profanity/inputrc
|
||||||
char *inputrc = files_get_inputrc_file();
|
gchar *inputrc = files_get_inputrc_file();
|
||||||
if (inputrc) {
|
if (inputrc) {
|
||||||
rl_read_init_file(inputrc);
|
rl_read_init_file(inputrc);
|
||||||
free(inputrc);
|
g_free(inputrc);
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -79,13 +79,15 @@ _get_icons(void)
|
|||||||
|
|
||||||
#endif /* ICONS_PATH */
|
#endif /* ICONS_PATH */
|
||||||
|
|
||||||
char *icons_dir_s = files_get_config_path(DIR_ICONS);
|
gchar *icons_dir_s = files_get_config_path(DIR_ICONS);
|
||||||
icons_dir = g_string_new(icons_dir_s);
|
icons_dir = g_string_new(icons_dir_s);
|
||||||
free(icons_dir_s);
|
g_free(icons_dir_s);
|
||||||
GError *err = NULL;
|
GError *err = NULL;
|
||||||
|
|
||||||
if (!g_file_test(icons_dir->str, G_FILE_TEST_IS_DIR)) {
|
if (!g_file_test(icons_dir->str, G_FILE_TEST_IS_DIR)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
GDir *dir = g_dir_open(icons_dir->str, 0, &err);
|
GDir *dir = g_dir_open(icons_dir->str, 0, &err);
|
||||||
if (dir) {
|
if (dir) {
|
||||||
GString *name = g_string_new(g_dir_read_name(dir));
|
GString *name = g_string_new(g_dir_read_name(dir));
|
||||||
|
Loading…
Reference in New Issue
Block a user