Home > Uncategorized > Using Coccinelle to match if sequences

Using Coccinelle to match if sequences

August 31st, 2009 Derek-Jones

I have been using Coccinelle to obtain measurements of various properties of C if and switch statements. It is rare to find a tool that does exactly what is desired but it is often possible to combine various tools to achieve the desired result.

I am interested in measuring sequences of if-else-if statements and one of the things I wanted to know was how many sequences of a given length occurred. Writing a pattern for each possible sequence was the obvious solution, but what is the longest sequence I should search for? A better solution is to use a pattern that matches short sequences and writes out the position (line/column number) where they occur in the code, as in the following Coccinelle pattern:

@ if_else_if_else @
expression E_1, E_2; 
statement S_1, S_2, S_3;
position p_1, p_2;
@@
if@p_1 (E_1)
   S_1
else if@p_2 (E_2)
   S_2
else
   S_3
@
script:python @ expr_1 << if_else_if_else.E_1;
                expr_2 << if_else_if_else.E_2;
                loc_1 << if_else_if_else.p_1;
                loc_2 << if_else_if_else.p_2;
              @@
print "--- ifelseifelse"
print loc_1[0].line, " ", loc_1[0].column, " ", expr_1
print loc_2[0].line, " ", loc_2[0].column, " ", expr_2

noting that in a sequence of source such as:

if (x == 1)
   stmt_1;
else
   if (x == 2)
      stmt_2;
   else
      if (x == 3)
         stmt_3;

the tokens if (x == 2) will be matched twice, the first setting the position metavariable p_2 and then setting p_1. An awk script was written to read the Coccinelle output and merge together adjacent pairs of matches that were part of a longer if-else-if sequence.

The first pattern did not concern itself with the form of the controlling expression, it simply wrote it out. A second set of patterns was used to match those forms of controlling expression I was interested in, but first I had to convert the output into syntactically correct C so that it could be processed by Coccinelle. Again awk came to the rescue, converting the output:

--- ifelseifelse
186   2   op == FFEBLD_opSUBRREF
191   7   op == FFEBLD_opFUNCREF
--- ifelseifelse
1094   3   anynum && commit
1111   8   ( c [ colon + 1 ] == '*' ) && commit

into a separate function for each matched sequence:

void f_1(void) {
// --- ifelseifelse
/* 186   2 */   op == FFEBLD_opSUBRREF ;
/* 191   7 */   op == FFEBLD_opFUNCREF ;
}
void f_2(void) {
// --- ifelseifelse
/* 1094   3 */   anynum && commit ;
/* 1111   8 */   ( c [ colon + 1 ] == '*' ) && commit ;
}

The Coccinelle pattern:

@ if_eq_1 @
expression E_1;
constant C_1, C_2;
position p_1, p_2;
@@
 
E_1 == C_1@p_1 ;
E_1 == C_2@p_2 ;
 
@
script:python @ expr_1<< if_eq_1.E_1;
                const_1 << if_eq_1.C_1;
                const_2 << if_eq_1.C_2;
                loc_1 << if_eq_1.p_1;
                loc_2 << if_eq_1.p_2;
              @@
print loc_1[0].line, " ", loc_1[0].column, " 3 ", expr_1, " == ", const_1
print loc_2[0].line, " ", loc_2[0].column, " 2 ", expr_1, " == ", const_2

matches a sequence of two statements which consist of an expression being compared for equality against a constant, with the expression being identical in both statements. Again positions were written out for post-processing, i.e., joining together matched sequences.

I was interested in any sequence of if-else-if that could be converted to an equivalent switch-statement. Equality tests against a constant is just one form of controlling expression that meets this requirement, another is the between operation. Separate patterns could be written and run over the generated C source containing the extracted controlling expressions.

Breaking down the measuring process into smaller steps reduced the amount of time needed to get a final result (with Coccinelle 0.1.19 the first pattern takes round 70 minutes, thanks to Julia Lawall’s work to speed things up, an overhead that only has to occur once) and allows the same controlling expression patterns to be run against the output of both the if-else-if and if-if patterns.

At the end of this process I ended up with a list information (line numbers in source code and form of controlling expression) on if-statement sequences that could be rewritten as a switch-statement.

Comments are closed.
www.wenn.com
FireStats icon Powered by FireStatswww.tinynibbles.com canadian pharmacy

cheapest propecia prescription

canadian pharmacies cialis

how to get viagra

cialis alternative

canada meds viagra

discount levitra rx

buy propecia cheap

lowest priced propecia

buy propecia online

buy cialis in usa

levitra prescription

buy viagra china

get propecia online pharmacy

cheap levitra prescription

buy discount viagra

lowest cost levitra

buy propecia canada

levitra order prescription

buy cialis canada

generic viagra online

brand viagra over the net

how much to buy viagra in pounds

buying propecia online

lowest price propecia best

buy propecia online pharmacy

cheapest viagra usa

buy cialis for daily use

mexico levitra

generic propecia online pharmacy

cheap levitra

cialis on women

cheap viagra canada or india

lowest price levitra

cialis delivered overnight

next day viagra

info levitra

cheap cialis

once a day viagra

online levitra

buy cheap generic levitra

cialis 20 mg

generic cialis sale

buy generic propecia

levitra cost

buy cialis online uk

online propecia uk

herbal propecia

buy cialis without prescription

canada propecia prescription

cheap viagra online

generic levitra purchase

cialis from canada

50 mg cialis

order prescription propecia

buy dosages levitra

hydrochlorothiazide cialis

online propecia prescriptions

cialis soft pills

canadian healthcare pharmacy

buy cheap levitra

buy levitra online from canada

generic viagra canada

cialis woman

brand viagra professional

get cialis

discount generic propecia

buy propecia on line

cialis headaches

canadian viagra and healthcare

buy real viagra online

combine cialis and levitra

canada viagra pharmacies scam

indian generic levitra

cialis refractory

cheap prescription propecia

mail order levitra

cialis uk

generic propecia alternative

cialis tablets

brand name cialis

best price levitra

5 mg original brand cialis

buy cialis online canada

discount levitra online

levitra now online

cialis profesional

cialis fast delivery

brand cialis for sale

levitra canadian

canada cheap propecia

generic viagra india

cialis quick shipment

next day delivery cialis

cialis fast delivery usa

for sale levitra

levitra in canada

cialis one a day

canada levitra

cheapest viagra

levitra pill

cialis pharmacy

does generic cialis work

online pharmacy propecia viagra

buy levitra overnight

canadian propecia rx

best price generic propecia

best price for propecia

genuine cialis pills

gele viagra

buying cialis soft tabs 100 mg

drug generic propecia

bio viagra herbal

buy viagra online

lowest propecia prices in canada

cialis 5 mg

overnight delivery cialis

low cost propecia

cialis strenght mg

cialis purchase

fda levitra

cheapest overnight cialis

generic cialis soft tabs

discount propecia propecia

buy prescription propecia without

cialis and diarrhea

buy viagra

buying cialis next day delivery

buy cheap levitra online

best price propecia

canadian online pharmacy cialis

discount drug propecia

cialis daily in canada

buying cialis

cheap levitra without prescription

cheap cialis soft

best viagra

levitra next day delivery

cialis 5 mg italia

order propecia

buying propecia

cost of daily cialis

online cheap viagra

cialis daily

cialis professional 100 mg

cialis discounts

generic propecia sale

cheap viagra from uk

china viagra

cheap levitra uk

ordering propecia online

brand name cialis overnight

cheapest propecia uk

buy canada levitra

generic propecia for sale

get levitra online

cialis 5 mg buy

order cheap propecia

buy 5 mg cialis

levitra online no prescription

cheap propecia 5mg

canadian viagra

cost of propecia

buy levitra uk

buy cheap generic propecia

buy propecia online from usa pharmacy

buy viagra online cheap us

cheapest viagra online

cialis by mail

levitra viagra cialis

getting cialis from canada

cheap fast levitra

cialis price in canada

buy online prescription propecia

canada generic propecia

levitra online overnight delivery

best price cialis

cialis en mexico

cialis 100 mg

cialis overnight

order cheapest propecia online

buy cialis cannada

levitra sales uk

levitra where to buy

buy propecia prescriptions online

how to get cialis in canada

cialis price

get cialis online

cheap canadian viagra

buy generic viagra india rx

low cost canadian viagra

indian viagra

buy levitra online viagra

overnight delivery viagra

levitra tabs

buy propecia without prescription

cialis overnight delivery

female viagra pills

buy cialis once daily

cialis generic 100 mg

how much does cialis cost

lowest propecia prices

daily dosage cialis

cialis cheap us pharmacy

buy generic levitra

cialis buy overnight

mexico pharmacy cialis

generic viagra made in usa

cialis and canada custom

generic viagra 100 mg

buy levitra online no prescription

generic viagra made in india

buying generic propecia

cialis next day delivery

buy real cialis

can i get viagra in mexico

cheapest prices for viagra

5 mg daily cialis

cheap propecia uk

obtain viagra without prescription

levitra buy online

levitra online prescription

how to buy cialis in canada

online cialis

generic propecia fda approved

canadian pharmacy discount code viagra

cialis professional no prescription

cialis and ketoconazole

canada online pharmacy levitra

generic levitra canada

buy levitra vardenafil

once daily cialis

mail order propecia

levitra mg

mail online order propecia

cialis vs levitra

how much cialis

cialis 100 mg generic

canadian pharmacy cialis

generic levitra vardenafil

canadian viagra india

levitra online

name brand cialis

cialis tablets foreign

online ordering propecia

cheapest price propecia cheap

natural viagra

buy viagra germany canadian meds

buy viagra on line

levitra cheap fast

lowest price on non generic levitra

generic propecia 5mg

buy propecia where

buy propecia in the uk

generic propecia finasteride

buy can from i propecia who

cialis no prescription

ordering cialis gel

generic levitra online

discount propecia online

low cost levitra

cheap propecia online prescription

canadian healthcare viagra

levitra online sales

cialis discount

canadian drugs propecia

levitra low price

online generic cialis 100 mg

cheapest propecia sale uk

cheap propecia online

canada viagra

internet pharmacy propecia

buying viagra in canada

how strong is 5 mg of cialis

generic propecia effective

cialis from mexico

i need to buy propecia

order cheap levitra

cheap discount levitra

indian cialis generic

levitra discount

how much is viagra

cialis transdermal

online propecia prescription

buy branded viagra

lowest price for propecia

generic levitra overnight delivery

buy now propecia

cheap order prescription propecia

cialis price 100 mg

indian cialis

low price levitra

levitra viagra online

discount levitra purchase

healthcare canadian pharmacy

lowest propecia 1 mg

canadian healthcare

buy generic cialis

cheap propecia no prescription

cheap levitra tablets