Merge pull request #19 from shootingatshadow/fc_sort

fc_sort: strip whitespace errors
This commit is contained in:
Chris PeBenito 2016-01-07 12:57:09 -05:00
commit f6d55aad04

View File

@ -1,13 +1,13 @@
/* Copyright 2005,2013 Tresys Technology /* Copyright 2005,2013 Tresys Technology
* *
* Some parts of this came from matchpathcon.c in libselinux * Some parts of this came from matchpathcon.c in libselinux
*/ */
/* PURPOSE OF THIS PROGRAM /* PURPOSE OF THIS PROGRAM
* The original setfiles sorting algorithm did not take into * The original setfiles sorting algorithm did not take into
* account regular expression specificity. With the current * account regular expression specificity. With the current
* strict and targeted policies this is not an issue because * strict and targeted policies this is not an issue because
* the file contexts are partially hand sorted and concatenated * the file contexts are partially hand sorted and concatenated
* in the right order so that the matches are generally correct. * in the right order so that the matches are generally correct.
* The way reference policy and loadable policy modules handle * The way reference policy and loadable policy modules handle
* file contexts makes them come out in an unpredictable order * file contexts makes them come out in an unpredictable order
@ -27,7 +27,7 @@ typedef unsigned char bool_t;
/* file_context_node /* file_context_node
* A node used in a linked list of file contexts.c * A node used in a linked list of file contexts.c
* Each node contains the regular expression, the type and * Each node contains the regular expression, the type and
* the context, as well as information about the regular * the context, as well as information about the regular
* expression. The regular expression data (meta, stem_len * expression. The regular expression data (meta, stem_len
* and str_len) can be filled in by using the fc_fill_data * and str_len) can be filled in by using the fc_fill_data
@ -114,7 +114,7 @@ int fc_compare(file_context_node_t *a, file_context_node_t *b)
if (!b->file_type && a->file_type) if (!b->file_type && a->file_type)
return 1; return 1;
/* If none of the above conditions were satisfied, /* If none of the above conditions were satisfied,
* then a and b are equally specific. */ * then a and b are equally specific. */
return 0; return 0;
} }
@ -251,7 +251,7 @@ void fc_merge_sort(file_context_bucket_t *master)
/* fc_fill_data /* fc_fill_data
* This processes a regular expression in a file context * This processes a regular expression in a file context
* and sets the data held in file_context_node, namely * and sets the data held in file_context_node, namely
* meta, str_len and stem_len. * meta, str_len and stem_len.
* The following changes are made to fc_node after the * The following changes are made to fc_node after the
* the completion of the function: * the completion of the function:
* fc_node->meta = 1 if path has a meta character, 0 if not. * fc_node->meta = 1 if path has a meta character, 0 if not.
@ -332,7 +332,7 @@ int main(int argc, char *argv[])
fprintf(stderr, "Usage: %s <infile> [<outfile>]\n",argv[0]); fprintf(stderr, "Usage: %s <infile> [<outfile>]\n",argv[0]);
return 1; return 1;
} }
input_name = argv[1]; input_name = argv[1];
output_name = (argc >= 3) ? argv[2] : NULL; output_name = (argc >= 3) ? argv[2] : NULL;
@ -395,7 +395,7 @@ int main(int argc, char *argv[])
continue; continue;
} }
temp->path = (char*)strndup(&line_buf[start], regex_len); temp->path = (char*)strndup(&line_buf[start], regex_len);
if (!temp->path) { if (!temp->path) {
file_context_node_destroy(temp); file_context_node_destroy(temp);
@ -409,7 +409,7 @@ int main(int argc, char *argv[])
if (!isspace(line_buf[i])) if (!isspace(line_buf[i]))
break; break;
} }
if (i == line_len) { if (i == line_len) {
file_context_node_destroy(temp); file_context_node_destroy(temp);
@ -417,7 +417,7 @@ int main(int argc, char *argv[])
continue; continue;
} }
/* Parse out the type from the line (if it /* Parse out the type from the line (if it
* is there). */ * is there). */
if (line_buf[i] == '-') { if (line_buf[i] == '-') {
temp->file_type = (char *)malloc(sizeof(char) * 3); temp->file_type = (char *)malloc(sizeof(char) * 3);