On Wed, Aug 15, 2018 at 11:40:42AM +0530, Nikhil Rao wrote: > > -----Original Message----- > > From: Neil Horman [mailto:nhor...@tuxdriver.com] > > I was about to say that its because you've not got enough context to let the > > awk file figure out what your section name is, but that doesn't appear to be > > the case. Can you provide the exact command line you are running to do your > > symbol check, as well as the full patch that you are checking? I'd like to > > try > > recreate the issue here > > > > Best > > Neil > > > > Complete patch is below > >
Thanks, I think I made a mistake in how I detect section names in the awk script. The rule assumes that the entire section is getting added (i.e. we are adding the EXPERIMENTAL section as a whole unit, hence the starting a line with + to id the section name, and thats not the case here. I think the rule needs to be any line in a map file that ends with a { (based on our coding practice), is a section start, and the section name is the next to the last field in the line (i.e. $(NF-1) ). Please apply the patch below and confirm that this works for you. Best Neil diff --git a/devtools/check-symbol-change.sh b/devtools/check-symbol-change.sh index daaf45e14..cf9cfc745 100755 --- a/devtools/check-symbol-change.sh +++ b/devtools/check-symbol-change.sh @@ -25,14 +25,14 @@ build_map_changes() # supresses the subordonate rules below /[-+] a\/.*\.^(map)/ {in_map=0} - # Triggering this rule, which starts a line with a + and ends it + # Triggering this rule, which starts a line and ends it # with a { identifies a versioned section. The section name is # the rest of the line with the + and { symbols remvoed. # Triggering this rule sets in_sec to 1, which actives the # symbol rule below - /+.*{/ {gsub("+",""); + /^.*{/ { if (in_map == 1) { - sec=$1; in_sec=1; + sec=$(NF-1); in_sec=1; } }