mirror of
https://github.com/SELinuxProject/selinux
synced 2025-01-28 08:12:57 +00:00
libselinux: label_file: remove all typedefs
I hate them. They just indirectly you needlessly. Just use the struct definitions. Signed-off-by: Eric Paris <eparis@redhat.com>
This commit is contained in:
parent
091eb526dd
commit
dc1db39e28
@ -28,7 +28,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/* A file security context specification. */
|
/* A file security context specification. */
|
||||||
typedef struct spec {
|
struct spec {
|
||||||
struct selabel_lookup_rec lr; /* holds contexts for lookup result */
|
struct selabel_lookup_rec lr; /* holds contexts for lookup result */
|
||||||
char *regex_str; /* regular expession string for diagnostics */
|
char *regex_str; /* regular expession string for diagnostics */
|
||||||
char *type_str; /* type string for diagnostic messages */
|
char *type_str; /* type string for diagnostic messages */
|
||||||
@ -39,13 +39,13 @@ typedef struct spec {
|
|||||||
int matches; /* number of matching pathnames */
|
int matches; /* number of matching pathnames */
|
||||||
int hasMetaChars; /* regular expression has meta-chars */
|
int hasMetaChars; /* regular expression has meta-chars */
|
||||||
int stem_id; /* indicates which stem-compression item */
|
int stem_id; /* indicates which stem-compression item */
|
||||||
} spec_t;
|
};
|
||||||
|
|
||||||
/* A regular expression stem */
|
/* A regular expression stem */
|
||||||
typedef struct stem {
|
struct stem {
|
||||||
char *buf;
|
char *buf;
|
||||||
int len;
|
int len;
|
||||||
} stem_t;
|
};
|
||||||
|
|
||||||
/* Our stored configuration */
|
/* Our stored configuration */
|
||||||
struct saved_data {
|
struct saved_data {
|
||||||
@ -53,14 +53,14 @@ struct saved_data {
|
|||||||
* The array of specifications, initially in the same order as in
|
* The array of specifications, initially in the same order as in
|
||||||
* the specification file. Sorting occurs based on hasMetaChars.
|
* the specification file. Sorting occurs based on hasMetaChars.
|
||||||
*/
|
*/
|
||||||
spec_t *spec_arr;
|
struct spec *spec_arr;
|
||||||
unsigned int nspec;
|
unsigned int nspec;
|
||||||
unsigned int ncomp;
|
unsigned int ncomp;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The array of regular expression stems.
|
* The array of regular expression stems.
|
||||||
*/
|
*/
|
||||||
stem_t *stem_arr;
|
struct stem *stem_arr;
|
||||||
int num_stems;
|
int num_stems;
|
||||||
int alloc_stems;
|
int alloc_stems;
|
||||||
};
|
};
|
||||||
@ -108,10 +108,10 @@ static int find_stem_from_spec(struct saved_data *data, const char *buf)
|
|||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
if (data->alloc_stems == num) {
|
if (data->alloc_stems == num) {
|
||||||
stem_t *tmp_arr;
|
struct stem *tmp_arr;
|
||||||
data->alloc_stems = data->alloc_stems * 2 + 16;
|
data->alloc_stems = data->alloc_stems * 2 + 16;
|
||||||
tmp_arr = realloc(data->stem_arr,
|
tmp_arr = realloc(data->stem_arr,
|
||||||
sizeof(stem_t) * data->alloc_stems);
|
sizeof(*tmp_arr) * data->alloc_stems);
|
||||||
if (!tmp_arr)
|
if (!tmp_arr)
|
||||||
return -1;
|
return -1;
|
||||||
data->stem_arr = tmp_arr;
|
data->stem_arr = tmp_arr;
|
||||||
@ -224,11 +224,11 @@ static void spec_hasMetaChars(struct spec *spec)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int compile_regex(struct saved_data *data, spec_t *spec, const char **errbuf)
|
static int compile_regex(struct saved_data *data, struct spec *spec, const char **errbuf)
|
||||||
{
|
{
|
||||||
const char *tmperrbuf;
|
const char *tmperrbuf;
|
||||||
char *reg_buf, *anchored_regex, *cp;
|
char *reg_buf, *anchored_regex, *cp;
|
||||||
stem_t *stem_arr = data->stem_arr;
|
struct stem *stem_arr = data->stem_arr;
|
||||||
size_t len;
|
size_t len;
|
||||||
int erroff;
|
int erroff;
|
||||||
|
|
||||||
@ -284,7 +284,7 @@ static int process_line(struct selabel_handle *rec,
|
|||||||
int items, len;
|
int items, len;
|
||||||
char *buf_p, *regex, *type, *context;
|
char *buf_p, *regex, *type, *context;
|
||||||
struct saved_data *data = (struct saved_data *)rec->data;
|
struct saved_data *data = (struct saved_data *)rec->data;
|
||||||
spec_t *spec_arr = data->spec_arr;
|
struct spec *spec_arr = data->spec_arr;
|
||||||
unsigned int nspec = data->nspec;
|
unsigned int nspec = data->nspec;
|
||||||
|
|
||||||
len = strlen(line_buf);
|
len = strlen(line_buf);
|
||||||
@ -409,7 +409,7 @@ static int init(struct selabel_handle *rec, struct selinux_opt *opts,
|
|||||||
char *line_buf = NULL;
|
char *line_buf = NULL;
|
||||||
size_t line_len = 0;
|
size_t line_len = 0;
|
||||||
unsigned int lineno, pass, i, j, maxnspec;
|
unsigned int lineno, pass, i, j, maxnspec;
|
||||||
spec_t *spec_copy = NULL;
|
struct spec *spec_copy = NULL;
|
||||||
int status = -1, baseonly = 0;
|
int status = -1, baseonly = 0;
|
||||||
struct stat sb;
|
struct stat sb;
|
||||||
|
|
||||||
@ -474,7 +474,7 @@ static int init(struct selabel_handle *rec, struct selinux_opt *opts,
|
|||||||
* The second pass performs detailed validation of the input
|
* The second pass performs detailed validation of the input
|
||||||
* and fills in the spec array.
|
* and fills in the spec array.
|
||||||
*/
|
*/
|
||||||
maxnspec = UINT_MAX / sizeof(spec_t);
|
maxnspec = UINT_MAX / sizeof(struct spec);
|
||||||
for (pass = 0; pass < 2; pass++) {
|
for (pass = 0; pass < 2; pass++) {
|
||||||
data->nspec = 0;
|
data->nspec = 0;
|
||||||
data->ncomp = 0;
|
data->ncomp = 0;
|
||||||
@ -519,7 +519,7 @@ static int init(struct selabel_handle *rec, struct selinux_opt *opts,
|
|||||||
status = 0;
|
status = 0;
|
||||||
goto finish;
|
goto finish;
|
||||||
}
|
}
|
||||||
data->spec_arr = calloc(data->nspec, sizeof(spec_t));
|
data->spec_arr = calloc(data->nspec, sizeof(*data->spec_arr));
|
||||||
if (!data->spec_arr)
|
if (!data->spec_arr)
|
||||||
goto finish;
|
goto finish;
|
||||||
|
|
||||||
@ -534,18 +534,18 @@ static int init(struct selabel_handle *rec, struct selinux_opt *opts,
|
|||||||
free(line_buf);
|
free(line_buf);
|
||||||
|
|
||||||
/* Move exact pathname specifications to the end. */
|
/* Move exact pathname specifications to the end. */
|
||||||
spec_copy = malloc(sizeof(spec_t) * data->nspec);
|
spec_copy = malloc(sizeof(*spec_copy) * data->nspec);
|
||||||
if (!spec_copy)
|
if (!spec_copy)
|
||||||
goto finish;
|
goto finish;
|
||||||
j = 0;
|
j = 0;
|
||||||
for (i = 0; i < data->nspec; i++)
|
for (i = 0; i < data->nspec; i++)
|
||||||
if (data->spec_arr[i].hasMetaChars)
|
if (data->spec_arr[i].hasMetaChars)
|
||||||
memcpy(&spec_copy[j++],
|
memcpy(&spec_copy[j++],
|
||||||
&data->spec_arr[i], sizeof(spec_t));
|
&data->spec_arr[i], sizeof(spec_copy[j]));
|
||||||
for (i = 0; i < data->nspec; i++)
|
for (i = 0; i < data->nspec; i++)
|
||||||
if (!data->spec_arr[i].hasMetaChars)
|
if (!data->spec_arr[i].hasMetaChars)
|
||||||
memcpy(&spec_copy[j++],
|
memcpy(&spec_copy[j++],
|
||||||
&data->spec_arr[i], sizeof(spec_t));
|
&data->spec_arr[i], sizeof(spec_copy[j]));
|
||||||
free(data->spec_arr);
|
free(data->spec_arr);
|
||||||
data->spec_arr = spec_copy;
|
data->spec_arr = spec_copy;
|
||||||
|
|
||||||
@ -600,7 +600,7 @@ static struct selabel_lookup_rec *lookup(struct selabel_handle *rec,
|
|||||||
const char *key, int type)
|
const char *key, int type)
|
||||||
{
|
{
|
||||||
struct saved_data *data = (struct saved_data *)rec->data;
|
struct saved_data *data = (struct saved_data *)rec->data;
|
||||||
spec_t *spec_arr = data->spec_arr;
|
struct spec *spec_arr = data->spec_arr;
|
||||||
int i, rc, file_stem;
|
int i, rc, file_stem;
|
||||||
mode_t mode = (mode_t)type;
|
mode_t mode = (mode_t)type;
|
||||||
const char *buf;
|
const char *buf;
|
||||||
@ -639,7 +639,7 @@ static struct selabel_lookup_rec *lookup(struct selabel_handle *rec,
|
|||||||
* the last matching specification is used.
|
* the last matching specification is used.
|
||||||
*/
|
*/
|
||||||
for (i = data->nspec - 1; i >= 0; i--) {
|
for (i = data->nspec - 1; i >= 0; i--) {
|
||||||
spec_t *spec = &spec_arr[i];
|
struct spec *spec = &spec_arr[i];
|
||||||
/* if the spec in question matches no stem or has the same
|
/* if the spec in question matches no stem or has the same
|
||||||
* stem as the file AND if the spec in question has no mode
|
* stem as the file AND if the spec in question has no mode
|
||||||
* specified or if the mode matches the file mode then we do
|
* specified or if the mode matches the file mode then we do
|
||||||
@ -680,7 +680,7 @@ static void stats(struct selabel_handle *rec)
|
|||||||
{
|
{
|
||||||
struct saved_data *data = (struct saved_data *)rec->data;
|
struct saved_data *data = (struct saved_data *)rec->data;
|
||||||
unsigned int i, nspec = data->nspec;
|
unsigned int i, nspec = data->nspec;
|
||||||
spec_t *spec_arr = data->spec_arr;
|
struct spec *spec_arr = data->spec_arr;
|
||||||
|
|
||||||
for (i = 0; i < nspec; i++) {
|
for (i = 0; i < nspec; i++) {
|
||||||
if (spec_arr[i].matches == 0) {
|
if (spec_arr[i].matches == 0) {
|
||||||
|
Loading…
Reference in New Issue
Block a user