Re: [PATCH 1/5] mcstrans: Fix Werror=shadow errors

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



This whole series applies on top of the splitpolicycoreutils branch.

On Wed, Nov 16, 2016 at 10:05:18PM +0800, Jason Zaman wrote:
> gcc -g3 -O0 -gdwarf-2 -fno-strict-aliasing -Wall -Wshadow -Werror -I../include -D_GNU_SOURCE -D_FILE_OFFSET_BITS=64 -fPIE -c -o mcstrans.o mcstrans.c
> mcstrans.c: In function ‘violates_constraints’:
> mcstrans.c:551:14: error: declaration of ‘common’ shadows a previous local [-Werror=shadow]
>     ebitmap_t common;
>               ^
> mcstrans.c:545:13: error: shadowed declaration is here [-Werror=shadow]
>    ebitmap_t common;
>              ^
> mcstrans.c: In function ‘build_regexps’:
> mcstrans.c:1048:7: error: declaration of ‘i’ shadows a previous local [-Werror=shadow]
>    int i=0;
>        ^
> mcstrans.c:993:15: error: shadowed declaration is here [-Werror=shadow]
>   size_t n_el, i;
>                ^
> mcstrans.c: In function ‘compute_raw_from_trans’:
> mcstrans.c:1166:9: error: declaration of ‘rc’ shadows a previous local [-Werror=shadow]
>      int rc = pcre_exec(g->prefix_regexp, 0, work, work_len, 0, 0, ovector, OVECCOUNT);
>          ^
> mcstrans.c:1123:6: error: shadowed declaration is here [-Werror=shadow]
>   int rc = pcre_exec(domain->base_classification_regexp, 0, work, work_len, 0, PCRE_ANCHORED, ovector, OVECCOUNT);
>       ^
> mcstrans.c:1174:9: error: declaration of ‘rc’ shadows a previous local [-Werror=shadow]
>      int rc = pcre_exec(g->suffix_regexp, 0, work, work_len, 0, 0, ovector, OVECCOUNT);
>          ^
> mcstrans.c:1123:6: error: shadowed declaration is here [-Werror=shadow]
>   int rc = pcre_exec(domain->base_classification_regexp, 0, work, work_len, 0, PCRE_ANCHORED, ovector, OVECCOUNT);
>       ^
> mcstrans.c:1189:9: error: declaration of ‘rc’ shadows a previous local [-Werror=shadow]
>      int rc = pcre_exec(g->word_regexp, 0, s, l, 0, 0, ovector, OVECCOUNT);
>          ^
> mcstrans.c:1123:6: error: shadowed declaration is here [-Werror=shadow]
>   int rc = pcre_exec(domain->base_classification_regexp, 0, work, work_len, 0, PCRE_ANCHORED, ovector, OVECCOUNT);
>       ^
> mcstrans.c: In function ‘compute_trans_from_raw’:
> mcstrans.c:1328:14: error: declaration of ‘unhandled’ shadows a previous local [-Werror=shadow]
>     ebitmap_t unhandled, orig_unhandled;
>               ^
> mcstrans.c:1291:49: error: shadowed declaration is here [-Werror=shadow]
>   ebitmap_t bit_diff, temp, handled, nothandled, unhandled, orig_unhandled;
>                                                  ^
> mcstrans.c:1328:25: error: declaration of ‘orig_unhandled’ shadows a previous local [-Werror=shadow]
>     ebitmap_t unhandled, orig_unhandled;
>                          ^
> mcstrans.c:1291:60: error: shadowed declaration is here [-Werror=shadow]
>   ebitmap_t bit_diff, temp, handled, nothandled, unhandled, orig_unhandled;
>                                                             ^
> mcstrans.c:1360:15: error: declaration of ‘handled’ shadows a previous local [-Werror=shadow]
>      ebitmap_t handled, nothandled;
>                ^
> mcstrans.c:1291:28: error: shadowed declaration is here [-Werror=shadow]
>   ebitmap_t bit_diff, temp, handled, nothandled, unhandled, orig_unhandled;
>                             ^
> mcstrans.c:1360:24: error: declaration of ‘nothandled’ shadows a previous local [-Werror=shadow]
>      ebitmap_t handled, nothandled;
>                         ^
> mcstrans.c:1291:37: error: shadowed declaration is here [-Werror=shadow]
>   ebitmap_t bit_diff, temp, handled, nothandled, unhandled, orig_unhandled;
>                                      ^
> mcstrans.c:1377:17: error: declaration of ‘temp’ shadows a previous local [-Werror=shadow]
>        ebitmap_t temp;
>                  ^
> mcstrans.c:1291:22: error: shadowed declaration is here [-Werror=shadow]
>   ebitmap_t bit_diff, temp, handled, nothandled, unhandled, orig_unhandled;
>                       ^
> mcstrans.c:1378:17: error: declaration of ‘bit_diff’ shadows a previous local [-Werror=shadow]
>        ebitmap_t bit_diff;
>                  ^
> mcstrans.c:1291:12: error: shadowed declaration is here [-Werror=shadow]
>   ebitmap_t bit_diff, temp, handled, nothandled, unhandled, orig_unhandled;
>             ^
> mcstrans.c:1403:16: error: declaration of ‘bit_diff’ shadows a previous local [-Werror=shadow]
>       ebitmap_t bit_diff;
>                 ^
> mcstrans.c:1291:12: error: shadowed declaration is here [-Werror=shadow]
>   ebitmap_t bit_diff, temp, handled, nothandled, unhandled, orig_unhandled;
>             ^
> mcstrans.c:1407:16: error: declaration of ‘temp’ shadows a previous local [-Werror=shadow]
>       ebitmap_t temp;
>                 ^
> mcstrans.c:1291:22: error: shadowed declaration is here [-Werror=shadow]
>   ebitmap_t bit_diff, temp, handled, nothandled, unhandled, orig_unhandled;
>                       ^
> mcstrans.c:1434:19: error: declaration of ‘g’ shadows a previous local [-Werror=shadow]
>      word_group_t *g;
>                    ^
> mcstrans.c:1335:18: error: shadowed declaration is here [-Werror=shadow]
>     word_group_t *g;
>                   ^
> cc1: all warnings being treated as errors
> Makefile:35: recipe for target 'mcstrans.o' failed
> make[2]: *** [mcstrans.o] Error 1
> 
> Signed-off-by: Jason Zaman <jason@xxxxxxxxxxxxx>
> ---
>  mcstrans/src/mcstrans.c | 24 ++++++++----------------
>  1 file changed, 8 insertions(+), 16 deletions(-)
> 
> diff --git a/mcstrans/src/mcstrans.c b/mcstrans/src/mcstrans.c
> index d7f094a..1b77d16 100644
> --- a/mcstrans/src/mcstrans.c
> +++ b/mcstrans/src/mcstrans.c
> @@ -525,9 +525,9 @@ int
>  violates_constraints(mls_level_t *l) {
>  	int nbits;
>  	sens_constraint_t *s;
> +	ebitmap_t common;
>  	for (s=sens_constraints; s; s=s->next) {
>  		if (s->sens == l->sens) {
> -			ebitmap_t common;
>  			if (ebitmap_and(&common, &s->cat, &l->cat) < 0)
>  				return 1;
>  			nbits = ebitmap_cardinality(&common);
> @@ -542,13 +542,11 @@ violates_constraints(mls_level_t *l) {
>  	}
>  	cat_constraint_t *c;
>  	for (c=cat_constraints; c; c=c->next) {
> -		ebitmap_t common;
>  		if (ebitmap_and(&common, &c->mask, &l->cat) < 0)
>  			return 1;
>  		nbits = ebitmap_cardinality(&common);
>  		ebitmap_destroy(&common);
>  		if (nbits > 0) {
> -			ebitmap_t common;
>  			if (ebitmap_and(&common, &c->cat, &l->cat) < 0)
>  				return 1;
>  			nbits = ebitmap_cardinality(&common);
> @@ -1045,7 +1043,7 @@ build_regexps(domain_t *domain) {
>  			return -1;
>  		}
>  
> -		int i=0;
> +		i=0;
>  		for (w = g->words; w; w = w->next)
>  			g->sword[i++]=w;
>  
> @@ -1094,6 +1092,7 @@ compute_raw_from_trans(const char *level, domain_t *domain) {
>  	gettimeofday(&startTime, 0);
>  #endif
>  
> +	int rc = 0;
>  	int ovector[OVECCOUNT];
>  	word_group_t *g = NULL;
>  	char *work = NULL;
> @@ -1120,7 +1119,7 @@ compute_raw_from_trans(const char *level, domain_t *domain) {
>  	if (!domain->base_classification_regexp)
>  		goto err;
>  	log_debug(" compute_raw_from_trans work = %s\n", work);
> -	int rc = pcre_exec(domain->base_classification_regexp, 0, work, work_len, 0, PCRE_ANCHORED, ovector, OVECCOUNT);
> +	rc = pcre_exec(domain->base_classification_regexp, 0, work, work_len, 0, PCRE_ANCHORED, ovector, OVECCOUNT);
>  	if (rc > 0) {
>  		match = NULL;
>  		pcre_get_substring(work, ovector, rc, 0, &match);
> @@ -1163,7 +1162,7 @@ compute_raw_from_trans(const char *level, domain_t *domain) {
>  			int prefix_offset = 0, prefix_len = 0;
>  			int suffix_offset = 0, suffix_len = 0;
>  			if (g->prefix_regexp) {
> -				int rc = pcre_exec(g->prefix_regexp, 0, work, work_len, 0, 0, ovector, OVECCOUNT);
> +				rc = pcre_exec(g->prefix_regexp, 0, work, work_len, 0, 0, ovector, OVECCOUNT);
>  				if (rc > 0) {
>  					prefix = 1;
>  					prefix_offset = ovector[0];
> @@ -1171,7 +1170,7 @@ compute_raw_from_trans(const char *level, domain_t *domain) {
>  				}
>  			}
>  			if (g->suffix_regexp) {
> -				int rc = pcre_exec(g->suffix_regexp, 0, work, work_len, 0, 0, ovector, OVECCOUNT);
> +				rc = pcre_exec(g->suffix_regexp, 0, work, work_len, 0, 0, ovector, OVECCOUNT);
>  				if (rc > 0) {
>  					suffix = 1;
>  					suffix_offset = ovector[0];
> @@ -1186,7 +1185,7 @@ compute_raw_from_trans(const char *level, domain_t *domain) {
>  			     g->word_regexp) {
>  				char *s = work + prefix_offset + prefix_len;
>  				int l = (suffix_len ? suffix_offset : work_len) - prefix_len - prefix_offset;
> -				int rc = pcre_exec(g->word_regexp, 0, s, l, 0, 0, ovector, OVECCOUNT);
> +				rc = pcre_exec(g->word_regexp, 0, s, l, 0, 0, ovector, OVECCOUNT);
>  				if (rc > 0) {
>  					match = NULL;
>  					pcre_get_substring(s, ovector, rc, 0, &match);
> @@ -1285,6 +1284,7 @@ compute_trans_from_raw(const char *level, domain_t *domain) {
>  	gettimeofday(&startTime, 0);
>  #endif
>  
> +	word_group_t *g;
>  	mls_level_t *l = NULL;
>  	char *rval = NULL;
>  	word_group_t *groups = NULL;
> @@ -1325,14 +1325,12 @@ compute_trans_from_raw(const char *level, domain_t *domain) {
>  				continue;
>  
>  			/* compute bits not consumed by base classification */
> -			ebitmap_t unhandled, orig_unhandled;
>  			if (ebitmap_xor(&unhandled, &l->cat, &bc->level->cat) < 0)
>  				goto err;
>  			if (ebitmap_cpy(&orig_unhandled, &unhandled) < 0)
>  				goto err;
>  
>  			/* prebuild groups */
> -			word_group_t *g;
>  			for (g = domain->groups; g; g = g->next) {
>  				word_group_t **t;
>  				for (t = &groups; *t; t = &(*t)->next)
> @@ -1357,7 +1355,6 @@ compute_trans_from_raw(const char *level, domain_t *domain) {
>  			for (loops = 50; ebitmap_cardinality(&unhandled) && loops > 0 && change; loops--) {
>  				change = 0;
>  				hamming = 10000;
> -				ebitmap_t handled, nothandled;
>  				if (ebitmap_xor(&handled, &unhandled, &orig_unhandled) < 0)
>  					goto err;
>  				if (ebitmap_not(&nothandled, &handled, maxbit) < 0)
> @@ -1374,8 +1371,6 @@ compute_trans_from_raw(const char *level, domain_t *domain) {
>  						}
>  
>  						/* if only unhandled bits are different */
> -						ebitmap_t temp;
> -						ebitmap_t bit_diff;
>  						if (ebitmap_or(&temp, &w->normal, &w->inverse) < 0)
>  							goto err;
>  						if (ebitmap_and(&bit_diff, &temp, &nothandled) < 0)
> @@ -1400,11 +1395,9 @@ compute_trans_from_raw(const char *level, domain_t *domain) {
>  				ebitmap_destroy(&nothandled);
>  
>  				if (currentWord) {
> -					ebitmap_t bit_diff;
>  					if (ebitmap_xor(&bit_diff, &currentWord->cat, &bc->level->cat) < 0)
>  						goto err;
>  
> -					ebitmap_t temp;
>  					if (ebitmap_cpy(&temp, &unhandled) < 0)
>  						goto err;
>  					ebitmap_destroy(&unhandled);
> @@ -1431,7 +1424,6 @@ compute_trans_from_raw(const char *level, domain_t *domain) {
>  				buffer[0] = 0;
>  				strcat(buffer, bc->trans);
>  				strcat(buffer, " ");
> -				word_group_t *g;
>  				for (g=groups; g; g = g->next) {
>  					if (g->words && g->prefixes) {
>  						strcat(buffer, g->prefixes->text);
> -- 
> 2.7.3
> 
_______________________________________________
Selinux mailing list
Selinux@xxxxxxxxxxxxx
To unsubscribe, send email to Selinux-leave@xxxxxxxxxxxxx.
To get help, send an email containing "help" to Selinux-request@xxxxxxxxxxxxx.




[Index of Archives]     [Selinux Refpolicy]     [Linux SGX]     [Fedora Users]     [Fedora Desktop]     [Yosemite Photos]     [Yosemite Camping]     [Yosemite Campsites]     [KDE Users]     [Gnome Users]

  Powered by Linux