libsemanage: constify read only parameters and variables

Signed-off-by: Christian Göttsche <cgzones@googlemail.com>
Acked-by: James Carter <jwcart2@gmail.com>
This commit is contained in:
Christian Göttsche 2024-11-11 15:16:48 +01:00 committed by James Carter
parent c23fdfa06f
commit 198e43a8ec
21 changed files with 46 additions and 44 deletions

View File

@ -51,7 +51,7 @@ enum semanage_connect_type {
* It must be called after semanage_handle_create but before
* semanage_connect. The argument should be the full path to the store.
*/
extern void semanage_select_store(semanage_handle_t * handle, char *path,
extern void semanage_select_store(semanage_handle_t * handle, const char *path,
enum semanage_connect_type storetype);
/* Just reload the policy */
@ -74,7 +74,7 @@ extern void semanage_set_check_ext_changes(semanage_handle_t * handle, int do_ch
/* Fills *compiler_path with the location of the hll compiler sh->conf->compiler_directory_path
* corresponding to lang_ext.
* Upon success returns 0, -1 on error. */
extern int semanage_get_hll_compiler_path(semanage_handle_t *sh, char *lang_ext, char **compiler_path);
extern int semanage_get_hll_compiler_path(semanage_handle_t *sh, const char *lang_ext, char **compiler_path);
/* create the store if it does not exist, this only has an effect on
* direct connections and must be called before semanage_connect

View File

@ -21,7 +21,7 @@ typedef struct dbase_file dbase_t;
#include "debug.h"
static int bool_print(semanage_handle_t * handle,
semanage_bool_t * boolean, FILE * str)
const semanage_bool_t * boolean, FILE * str)
{
const char *name = semanage_bool_get_name(boolean);

View File

@ -6,7 +6,7 @@
#include "database.h"
#include "debug.h"
static int assert_init(semanage_handle_t * handle, dbase_config_t * dconfig)
static int assert_init(semanage_handle_t * handle, const dbase_config_t * dconfig)
{
if (dconfig->dtable == NULL) {

View File

@ -22,7 +22,7 @@ typedef struct record_file_table {
/* Print record to stream */
int (*print) (semanage_handle_t * handle,
record_t * record, FILE * str);
const record_t * record, FILE * str);
} record_file_table_t;

View File

@ -69,14 +69,14 @@ static inline void dbase_llist_set_modified(dbase_llist_t * dbase, int status)
/* LLIST - cache/transactions */
extern void dbase_llist_drop_cache(dbase_llist_t * dbase);
static inline int dbase_llist_is_modified(dbase_llist_t * dbase)
static inline int dbase_llist_is_modified(const dbase_llist_t * dbase)
{
return dbase->modified;
}
/* LLIST - polymorphism */
static inline const record_table_t *dbase_llist_get_rtable(dbase_llist_t * dbase)
static inline const record_table_t *dbase_llist_get_rtable(const dbase_llist_t * dbase)
{
return dbase->rtable;
}

View File

@ -618,7 +618,7 @@ static int read_from_pipe_to_data(semanage_handle_t *sh, size_t initial_len, int
return 0;
}
static int semanage_pipe_data(semanage_handle_t *sh, char *path, char *in_data, size_t in_data_len, char **out_data, size_t *out_data_len, char **err_data, size_t *err_data_len)
static int semanage_pipe_data(semanage_handle_t *sh, const char *path, const char *in_data, size_t in_data_len, char **out_data, size_t *out_data_len, char **err_data, size_t *err_data_len)
{
int input_fd[2] = {-1, -1};
int output_fd[2] = {-1, -1};
@ -1721,8 +1721,8 @@ static int semanage_direct_install_file(semanage_handle_t * sh,
int retval = -1;
char *path = NULL;
char *filename;
char *lang_ext = NULL;
const char *filename;
const char *lang_ext = NULL;
char *module_name = NULL;
char *separator;
char *version = NULL;
@ -2214,7 +2214,7 @@ static int semanage_direct_get_module_info(semanage_handle_t *sh,
semanage_module_info_t *modinfos = NULL;
int modinfos_len = 0;
semanage_module_info_t *highest = NULL;
const semanage_module_info_t *highest = NULL;
/* check module name */
ret = semanage_module_validate_name(modkey->name);

View File

@ -43,7 +43,7 @@ static const char *type_str(int type)
}
static int fcontext_print(semanage_handle_t * handle,
semanage_fcontext_t * fcontext, FILE * str)
const semanage_fcontext_t * fcontext, FILE * str)
{
char *con_str = NULL;

View File

@ -170,7 +170,7 @@ err:
}
static int ignore(const char *homedir) {
ignoredir_t *ptr = ignore_head;
const ignoredir_t *ptr = ignore_head;
while (ptr) {
if (strcmp(ptr->dir, homedir) == 0) {
return 1;
@ -683,7 +683,7 @@ fail:
static int write_home_dir_context(genhomedircon_settings_t * s, FILE * out,
semanage_list_t * tpl, const genhomedircon_user_entry_t *user)
{
replacement_pair_t repl[] = {
const replacement_pair_t repl[] = {
{.search_for = TEMPLATE_HOME_DIR,.replace_with = user->home},
{.search_for = TEMPLATE_ROLE,.replace_with = user->prefix},
{NULL, NULL}
@ -701,9 +701,9 @@ static int write_home_dir_context(genhomedircon_settings_t * s, FILE * out,
}
static int write_home_root_context(genhomedircon_settings_t * s, FILE * out,
semanage_list_t * tpl, char *homedir)
semanage_list_t * tpl, const char *homedir)
{
replacement_pair_t repl[] = {
const replacement_pair_t repl[] = {
{.search_for = TEMPLATE_HOME_ROOT,.replace_with = homedir},
{NULL, NULL}
};
@ -715,7 +715,7 @@ static int write_username_context(genhomedircon_settings_t * s, FILE * out,
semanage_list_t * tpl,
const genhomedircon_user_entry_t *user)
{
replacement_pair_t repl[] = {
const replacement_pair_t repl[] = {
{.search_for = TEMPLATE_USERNAME,.replace_with = user->name},
{.search_for = TEMPLATE_USERID,.replace_with = user->uid},
{.search_for = TEMPLATE_ROLE,.replace_with = user->prefix},
@ -728,7 +728,7 @@ static int write_username_context(genhomedircon_settings_t * s, FILE * out,
static int write_user_context(genhomedircon_settings_t * s, FILE * out,
semanage_list_t * tpl, const genhomedircon_user_entry_t *user)
{
replacement_pair_t repl[] = {
const replacement_pair_t repl[] = {
{.search_for = TEMPLATE_USER,.replace_with = user->name},
{.search_for = TEMPLATE_ROLE,.replace_with = user->prefix},
{NULL, NULL}

View File

@ -138,7 +138,7 @@ void semanage_set_check_ext_changes(semanage_handle_t * sh, int do_check)
}
int semanage_get_hll_compiler_path(semanage_handle_t *sh,
char *lang_ext,
const char *lang_ext,
char **compiler_path)
{
assert(sh != NULL);
@ -272,7 +272,7 @@ int semanage_is_connected(semanage_handle_t * sh)
return sh->is_connected;
}
void semanage_select_store(semanage_handle_t * sh, char *storename,
void semanage_select_store(semanage_handle_t * sh, const char *storename,
enum semanage_connect_type storetype)
{

View File

@ -20,9 +20,10 @@ typedef struct dbase_file dbase_t;
#include "debug.h"
static int ibendport_print(semanage_handle_t *handle,
semanage_ibendport_t *ibendport,
const semanage_ibendport_t *ibendport,
FILE *str)
{
const semanage_context_t *con;
char *con_str = NULL;
char *ibdev_name_str = NULL;
int port = semanage_ibendport_get_port(ibendport);
@ -30,7 +31,7 @@ static int ibendport_print(semanage_handle_t *handle,
if (semanage_ibendport_get_ibdev_name(handle, ibendport, &ibdev_name_str) != 0)
goto err;
semanage_context_t *con = semanage_ibendport_get_con(ibendport);
con = semanage_ibendport_get_con(ibendport);
if (fprintf(str, "ibendportcon %s ", ibdev_name_str) < 0)
goto err;

View File

@ -20,8 +20,9 @@ typedef struct dbase_file dbase_t;
#include "debug.h"
static int ibpkey_print(semanage_handle_t *handle,
semanage_ibpkey_t *ibpkey, FILE *str)
const semanage_ibpkey_t *ibpkey, FILE *str)
{
const semanage_context_t *con;
char *con_str = NULL;
char *subnet_prefix_str = NULL;
@ -31,7 +32,7 @@ static int ibpkey_print(semanage_handle_t *handle,
if (semanage_ibpkey_get_subnet_prefix(handle, ibpkey, &subnet_prefix_str) != 0)
goto err;
semanage_context_t *con = semanage_ibpkey_get_con(ibpkey);
con = semanage_ibpkey_get_con(ibpkey);
if (fprintf(str, "ibpkeycon %s ", subnet_prefix_str) < 0)
goto err;

View File

@ -19,7 +19,7 @@ typedef struct dbase_file dbase_t;
#include "debug.h"
static int iface_print(semanage_handle_t * handle,
semanage_iface_t * iface, FILE * str)
const semanage_iface_t * iface, FILE * str)
{
char *con_str = NULL;

View File

@ -20,7 +20,7 @@ typedef struct dbase_file dbase_t;
#include "debug.h"
static int node_print(semanage_handle_t * handle,
semanage_node_t * node, FILE * str)
const semanage_node_t * node, FILE * str)
{
char *con_str = NULL;

View File

@ -270,7 +270,7 @@ int parse_fetch_string(semanage_handle_t * handle,
parse_info_t * info, char **str, char delim, int allow_spaces)
{
char *start = info->ptr;
const char *start = info->ptr;
int len = 0;
char *tmp_str = NULL;

View File

@ -115,7 +115,7 @@ int semanage_base_merge_components(semanage_handle_t * handle)
/* Order is important here - change things carefully.
* System components first, local next. Verify runs with
* mutual dependencies are ran after everything is merged */
load_table_t components[] = {
const load_table_t components[] = {
{semanage_user_base_dbase_local(handle),
semanage_user_base_dbase_policy(handle), MODE_MODIFY},
@ -210,7 +210,7 @@ int semanage_commit_components(semanage_handle_t * handle)
{
int i;
dbase_config_t *components[] = {
const dbase_config_t *components[] = {
semanage_iface_dbase_local(handle),
semanage_bool_dbase_local(handle),
semanage_user_base_dbase_local(handle),

View File

@ -20,7 +20,7 @@ typedef struct dbase_file dbase_t;
#include "debug.h"
static int port_print(semanage_handle_t * handle,
semanage_port_t * port, FILE * str)
const semanage_port_t * port, FILE * str)
{
char *con_str = NULL;

View File

@ -78,13 +78,13 @@ static char *semanage_files[SEMANAGE_NUM_FILES] = { NULL };
static int semanage_paths_initialized = 0;
/* These are paths relative to the bottom of the module store */
static const char *semanage_relative_files[SEMANAGE_NUM_FILES] = {
static const char *const semanage_relative_files[SEMANAGE_NUM_FILES] = {
"",
"/semanage.trans.LOCK",
"/semanage.read.LOCK"
};
static const char *semanage_store_paths[SEMANAGE_NUM_STORES] = {
static const char *const semanage_store_paths[SEMANAGE_NUM_STORES] = {
"/active",
"/previous",
"/tmp"
@ -92,7 +92,7 @@ static const char *semanage_store_paths[SEMANAGE_NUM_STORES] = {
/* relative path names to enum sandbox_paths for special files within
* a sandbox */
static const char *semanage_sandbox_paths[SEMANAGE_STORE_NUM_PATHS] = {
static const char *const semanage_sandbox_paths[SEMANAGE_STORE_NUM_PATHS] = {
"",
"/modules",
"/policy.linked",
@ -1152,7 +1152,7 @@ int semanage_get_active_modules(semanage_handle_t * sh,
int j = 0;
semanage_list_t *list = NULL;
semanage_list_t *found = NULL;
const semanage_list_t *found = NULL;
semanage_module_info_t *all_modinfos = NULL;
int all_modinfos_len = 0;
@ -2091,7 +2091,7 @@ int semanage_direct_get_serial(semanage_handle_t * sh)
int semanage_load_files(semanage_handle_t * sh, cil_db_t *cildb, char **filenames, int numfiles)
{
int i, retval;
char *filename;
const char *filename;
struct file_contents contents = {};
for (i = 0; i < numfiles; i++) {
@ -2216,7 +2216,7 @@ int semanage_verify_modules(semanage_handle_t * sh,
return 0;
}
for (i = 0; i < num_modules; i++) {
char *module = module_filenames[i];
const char *module = module_filenames[i];
external_prog_t *e;
for (e = conf->mod_prog; e != NULL; e = e->next) {
if (semanage_exec_prog(sh, e, module, "$<") != 0) {
@ -2329,8 +2329,8 @@ static void semanage_fc_bucket_list_destroy(semanage_file_context_bucket_t * x)
* now. A proper comparison would determine which (if either)
* regular expression is a subset of the other.
*/
static int semanage_fc_compare(semanage_file_context_node_t * a,
semanage_file_context_node_t * b)
static int semanage_fc_compare(const semanage_file_context_node_t * a,
const semanage_file_context_node_t * b)
{
int a_has_meta = (a->meta >= 0);
int b_has_meta = (b->meta >= 0);

View File

@ -20,7 +20,7 @@ typedef struct dbase_file dbase_t;
#include "handle.h"
static int seuser_print(semanage_handle_t * handle,
semanage_seuser_t * seuser, FILE * str)
const semanage_seuser_t * seuser, FILE * str)
{
const char *name = semanage_seuser_get_name(seuser);

View File

@ -21,7 +21,7 @@ typedef struct dbase_file dbase_t;
#include "debug.h"
static int user_base_print(semanage_handle_t * handle,
semanage_user_base_t * user, FILE * str)
const semanage_user_base_t * user, FILE * str)
{
const char **roles = NULL;
@ -68,7 +68,7 @@ static int user_base_parse(semanage_handle_t * handle,
int islist;
char *str = NULL;
char *start;
const char *start;
char *name_str = NULL;
if (parse_skip_space(handle, info) < 0)

View File

@ -21,7 +21,7 @@ typedef struct dbase_file dbase_t;
#include "handle.h"
static int user_extra_print(semanage_handle_t * handle,
semanage_user_extra_t * user_extra, FILE * str)
const semanage_user_extra_t * user_extra, FILE * str)
{
const char *name = semanage_user_extra_get_name(user_extra);

View File

@ -73,7 +73,7 @@ int semanage_is_prefix(const char *str, const char *prefix)
char *semanage_split_on_space(const char *str)
{
/* as per the man page, these are the isspace() chars */
const char *seps = "\f\n\r\t\v ";
const char *const seps = "\f\n\r\t\v ";
size_t off = 0;
if (!str)
@ -88,7 +88,7 @@ char *semanage_split_on_space(const char *str)
char *semanage_split(const char *str, const char *delim)
{
char *retval;
const char *retval;
if (!str)
return NULL;