2012-10-21 15:02:20 -04:00
|
|
|
/*
|
2012-05-19 16:56:23 -04:00
|
|
|
* common.h
|
2019-11-13 06:11:05 -05:00
|
|
|
* vim: expandtab:ts=4:sts=4:sw=4
|
2012-05-19 16:56:23 -04:00
|
|
|
*
|
2019-01-22 05:31:45 -05:00
|
|
|
* Copyright (C) 2012 - 2019 James Booth <boothj5@gmail.com>
|
2012-10-21 15:02:20 -04:00
|
|
|
*
|
2012-05-19 16:56:23 -04:00
|
|
|
* This file is part of Profanity.
|
|
|
|
*
|
|
|
|
* Profanity 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 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* Profanity 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
|
2016-07-23 20:14:49 -04:00
|
|
|
* along with Profanity. If not, see <https://www.gnu.org/licenses/>.
|
2012-05-19 16:56:23 -04:00
|
|
|
*
|
2014-08-24 15:57:39 -04:00
|
|
|
* In addition, as a special exception, the copyright holders give permission to
|
|
|
|
* link the code of portions of this program with the OpenSSL library under
|
|
|
|
* certain conditions as described in each individual source file, and
|
|
|
|
* distribute linked combinations including the two.
|
|
|
|
*
|
|
|
|
* You must obey the GNU General Public License in all respects for all of the
|
|
|
|
* code used other than OpenSSL. If you modify file(s) with this exception, you
|
|
|
|
* may extend this exception to your version of the file(s), but you are not
|
|
|
|
* obligated to do so. If you do not wish to do so, delete this exception
|
|
|
|
* statement from your version. If you delete this exception statement from all
|
|
|
|
* source files in the program, then also delete it here.
|
|
|
|
*
|
2023-07-13 11:04:59 -04:00
|
|
|
* @file common.h
|
|
|
|
*
|
|
|
|
* @brief Common utilities for the project.
|
2012-05-19 16:56:23 -04:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef COMMON_H
|
|
|
|
#define COMMON_H
|
|
|
|
|
2012-11-17 21:31:32 -05:00
|
|
|
#include <stdio.h>
|
2015-01-18 17:55:51 -05:00
|
|
|
#include <wchar.h>
|
|
|
|
|
2012-05-19 16:56:23 -04:00
|
|
|
#include <glib.h>
|
|
|
|
|
2012-06-28 19:47:14 -04:00
|
|
|
#ifndef NOTIFY_CHECK_VERSION
|
|
|
|
#define notify_notification_new(summary, body, icon) notify_notification_new(summary, body, icon, NULL)
|
|
|
|
#endif
|
|
|
|
|
2020-07-07 08:18:57 -04:00
|
|
|
#define ARRAY_SIZE(x) (sizeof(x) / sizeof(x[0]))
|
2012-08-10 18:18:02 -04:00
|
|
|
|
2023-05-11 06:00:15 -04:00
|
|
|
#define PROF_STRINGIFY_(n) #n
|
|
|
|
#define PROF_STRINGIFY(n) PROF_STRINGIFY_(n)
|
|
|
|
|
2022-12-05 04:25:57 -05:00
|
|
|
void auto_free_gchar(gchar** str);
|
2023-07-13 10:46:24 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Macro for automatically freeing a gchar* string when it goes out of scope.
|
|
|
|
*
|
|
|
|
* Example usage:
|
|
|
|
* ```
|
|
|
|
* auto_gchar gchar* myString = g_strdup("Hello, world!");
|
|
|
|
* ```
|
|
|
|
*/
|
2022-12-05 04:25:57 -05:00
|
|
|
#define auto_gchar __attribute__((__cleanup__(auto_free_gchar)))
|
2023-07-13 10:46:24 -04:00
|
|
|
|
2023-01-18 10:43:53 -05:00
|
|
|
void auto_free_gcharv(gchar*** args);
|
2023-07-13 10:46:24 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Macro for automatically freeing a gchar** string array when it goes out of scope.
|
|
|
|
*
|
|
|
|
* Example usage:
|
|
|
|
* ```
|
|
|
|
* auto_gcharv gchar** stringArray = g_strsplit("Hello, world!", " ", -1);
|
|
|
|
* ```
|
|
|
|
*/
|
2023-01-18 10:43:53 -05:00
|
|
|
#define auto_gcharv __attribute__((__cleanup__(auto_free_gcharv)))
|
2023-07-13 10:46:24 -04:00
|
|
|
|
2022-12-05 04:25:57 -05:00
|
|
|
void auto_free_char(char** str);
|
2023-07-13 10:46:24 -04:00
|
|
|
|
2023-07-13 11:04:59 -04:00
|
|
|
/**
|
2023-07-13 10:46:24 -04:00
|
|
|
* Macro for automatically freeing a char* string when it goes out of scope.
|
2023-07-13 11:04:59 -04:00
|
|
|
*
|
2023-07-13 10:46:24 -04:00
|
|
|
* Example usage:
|
|
|
|
* ```
|
|
|
|
* auto_char char* myString = strdup("Hello, world!");
|
|
|
|
* ```
|
2023-07-13 11:04:59 -04:00
|
|
|
*/
|
2023-07-13 10:46:24 -04:00
|
|
|
#define auto_char __attribute__((__cleanup__(auto_free_char)))
|
|
|
|
|
2023-07-13 11:04:59 -04:00
|
|
|
void auto_free_guchar(guchar** str);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Macro for automatically freeing a guchar* string when it goes out of scope.
|
|
|
|
*
|
|
|
|
* This macro is used to automatically free a guchar* string when it goes out of scope.
|
|
|
|
* It utilizes the `auto_free_guchar` function and should be placed before the variable declaration.
|
|
|
|
*
|
|
|
|
* Example usage:
|
|
|
|
* ```
|
|
|
|
* auto_guchar guchar* myString = g_base64_decode("SGVsbG8sIHdvcmxkIQ==", NULL);
|
|
|
|
* ```
|
|
|
|
*/
|
|
|
|
#define auto_guchar __attribute__((__cleanup__(auto_free_guchar)))
|
2022-12-05 04:25:57 -05:00
|
|
|
|
2023-01-09 11:58:01 -05:00
|
|
|
#if defined(__OpenBSD__)
|
2023-01-19 02:47:35 -05:00
|
|
|
#define STR_MAYBE_NULL(p) (p) ?: "(null)"
|
2023-01-09 11:58:01 -05:00
|
|
|
#else
|
|
|
|
#define STR_MAYBE_NULL(p) (p)
|
|
|
|
#endif
|
|
|
|
|
2023-08-29 07:46:07 -04:00
|
|
|
typedef struct prof_keyfile_t
|
|
|
|
{
|
|
|
|
gchar* filename;
|
|
|
|
GKeyFile* keyfile;
|
|
|
|
} prof_keyfile_t;
|
|
|
|
|
|
|
|
gboolean
|
|
|
|
load_data_keyfile(prof_keyfile_t* keyfile, const char* filename);
|
|
|
|
gboolean
|
|
|
|
load_config_keyfile(prof_keyfile_t* keyfile, const char* filename);
|
|
|
|
gboolean
|
|
|
|
load_custom_keyfile(prof_keyfile_t* keyfile, gchar* filename);
|
|
|
|
gboolean
|
|
|
|
save_keyfile(prof_keyfile_t* keyfile);
|
|
|
|
void
|
|
|
|
free_keyfile(prof_keyfile_t* keyfile);
|
|
|
|
|
2023-05-11 05:20:52 -04:00
|
|
|
/* Our own define of MB_CUR_MAX but this time at compile time */
|
|
|
|
#define PROF_MB_CUR_MAX 8
|
|
|
|
|
2015-01-07 22:37:35 -05:00
|
|
|
// assume malloc stores at most 8 bytes for size of allocated memory
|
|
|
|
// and page size is at least 4KB
|
|
|
|
#define READ_BUF_SIZE 4088
|
|
|
|
|
2013-01-12 20:43:18 -05:00
|
|
|
#define FREE_SET_NULL(resource) \
|
2020-07-07 08:18:57 -04:00
|
|
|
do { \
|
|
|
|
free(resource); \
|
|
|
|
resource = NULL; \
|
|
|
|
} while (0)
|
2013-01-12 20:43:18 -05:00
|
|
|
|
2013-01-22 19:21:05 -05:00
|
|
|
#define GFREE_SET_NULL(resource) \
|
2020-07-07 08:18:57 -04:00
|
|
|
do { \
|
|
|
|
g_free(resource); \
|
|
|
|
resource = NULL; \
|
|
|
|
} while (0)
|
2013-01-22 19:21:05 -05:00
|
|
|
|
2013-01-30 19:01:38 -05:00
|
|
|
typedef enum {
|
2013-02-10 12:13:19 -05:00
|
|
|
CONTACT_OFFLINE,
|
|
|
|
CONTACT_ONLINE,
|
|
|
|
CONTACT_AWAY,
|
|
|
|
CONTACT_DND,
|
|
|
|
CONTACT_CHAT,
|
|
|
|
CONTACT_XA
|
|
|
|
} contact_presence_t;
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
RESOURCE_ONLINE,
|
|
|
|
RESOURCE_AWAY,
|
|
|
|
RESOURCE_DND,
|
|
|
|
RESOURCE_CHAT,
|
|
|
|
RESOURCE_XA
|
|
|
|
} resource_presence_t;
|
2013-01-30 19:01:38 -05:00
|
|
|
|
2022-12-05 04:25:57 -05:00
|
|
|
gboolean string_to_verbosity(const char* cmd, int* verbosity, gchar** err_msg);
|
|
|
|
|
2022-03-13 07:02:59 -04:00
|
|
|
gboolean create_dir(const char* name);
|
2020-07-07 08:18:57 -04:00
|
|
|
gboolean copy_file(const char* const src, const char* const target, const gboolean overwrite_existing);
|
|
|
|
char* str_replace(const char* string, const char* substr, const char* replacement);
|
2022-12-05 04:25:57 -05:00
|
|
|
gboolean strtoi_range(const char* str, int* saveptr, int min, int max, char** err_msg);
|
2020-07-07 08:18:57 -04:00
|
|
|
int utf8_display_len(const char* const str);
|
2016-07-24 12:02:09 -04:00
|
|
|
|
2013-01-28 15:07:25 -05:00
|
|
|
char* release_get_latest(void);
|
2020-07-07 08:18:57 -04:00
|
|
|
gboolean release_is_new(char* found_version);
|
2012-05-19 16:56:23 -04:00
|
|
|
|
2020-07-07 08:18:57 -04:00
|
|
|
char* strip_arg_quotes(const char* const input);
|
2015-10-09 05:50:21 -04:00
|
|
|
gboolean is_notify_enabled(void);
|
2014-10-26 16:43:05 -04:00
|
|
|
|
2020-07-07 08:18:57 -04:00
|
|
|
GSList* prof_occurrences(const char* const needle, const char* const haystack, int offset, gboolean whole_word,
|
|
|
|
GSList** result);
|
|
|
|
GSList* get_mentions(gboolean whole_word, gboolean case_sensitive, const char* const message, const char* const nick);
|
2016-04-03 17:30:24 -04:00
|
|
|
|
2020-07-07 08:18:57 -04:00
|
|
|
int is_regular_file(const char* path);
|
|
|
|
int is_dir(const char* path);
|
|
|
|
void get_file_paths_recursive(const char* directory, GSList** contents);
|
2017-02-05 16:09:03 -05:00
|
|
|
|
2019-10-16 04:39:35 -04:00
|
|
|
char* get_random_string(int length);
|
|
|
|
|
2022-09-26 07:29:14 -04:00
|
|
|
gboolean call_external(gchar** argv);
|
2020-12-03 10:43:07 -05:00
|
|
|
gchar** format_call_external_argv(const char* template, const char* url, const char* filename);
|
2020-05-20 04:36:02 -04:00
|
|
|
|
2020-12-04 10:13:13 -05:00
|
|
|
gchar* unique_filename_from_url(const char* url, const char* path);
|
2020-12-11 09:51:01 -05:00
|
|
|
gchar* get_expanded_path(const char* path);
|
2020-12-04 10:13:13 -05:00
|
|
|
|
2023-04-19 08:19:47 -04:00
|
|
|
char* basename_from_url(const char* url);
|
2022-12-27 17:17:33 -05:00
|
|
|
|
2023-07-25 14:58:15 -04:00
|
|
|
gchar* prof_get_version(void);
|
|
|
|
|
2012-05-19 16:56:23 -04:00
|
|
|
#endif
|