{"id":"https://openalex.org/W2003113483","doi":"https://doi.org/10.1145/1960275.1960299","title":"Analyzing the discipline of preprocessor annotations in 30 million lines of C code","display_name":"Analyzing the discipline of preprocessor annotations in 30 million lines of C code","publication_year":2011,"publication_date":"2011-03-21","ids":{"openalex":"https://openalex.org/W2003113483","doi":"https://doi.org/10.1145/1960275.1960299","mag":"2003113483"},"language":"en","primary_location":{"id":"doi:10.1145/1960275.1960299","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1960275.1960299","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the tenth international conference on Aspect-oriented software development","raw_type":"proceedings-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":false,"oa_status":"closed","oa_url":null,"any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5004461302","display_name":"J\u00f6rg Liebig","orcid":null},"institutions":[{"id":"https://openalex.org/I186354981","display_name":"University of Passau","ror":"https://ror.org/05ydjnb78","country_code":"DE","type":"education","lineage":["https://openalex.org/I186354981"]}],"countries":["DE"],"is_corresponding":true,"raw_author_name":"J\u00f6rg Liebig","raw_affiliation_strings":["University of Passau, Passau, Germany",", University of Passau, Passau, Germany"],"affiliations":[{"raw_affiliation_string":"University of Passau, Passau, Germany","institution_ids":["https://openalex.org/I186354981"]},{"raw_affiliation_string":", University of Passau, Passau, Germany","institution_ids":["https://openalex.org/I186354981"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5067467896","display_name":"Christian K\u00e4stner","orcid":"https://orcid.org/0000-0002-4450-4572"},"institutions":[{"id":"https://openalex.org/I161103922","display_name":"Philipps University of Marburg","ror":"https://ror.org/01rdrb571","country_code":"DE","type":"education","lineage":["https://openalex.org/I161103922"]}],"countries":["DE"],"is_corresponding":false,"raw_author_name":"Christian K\u00e4stner","raw_affiliation_strings":["Philipps-University Marburg, Marburg, Germany"],"affiliations":[{"raw_affiliation_string":"Philipps-University Marburg, Marburg, Germany","institution_ids":["https://openalex.org/I161103922"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5054951840","display_name":"Sven Apel","orcid":"https://orcid.org/0000-0003-3687-2233"},"institutions":[{"id":"https://openalex.org/I186354981","display_name":"University of Passau","ror":"https://ror.org/05ydjnb78","country_code":"DE","type":"education","lineage":["https://openalex.org/I186354981"]}],"countries":["DE"],"is_corresponding":false,"raw_author_name":"Sven Apel","raw_affiliation_strings":["University of Passau, Passau, Germany",", University of Passau, Passau, Germany"],"affiliations":[{"raw_affiliation_string":"University of Passau, Passau, Germany","institution_ids":["https://openalex.org/I186354981"]},{"raw_affiliation_string":", University of Passau, Passau, Germany","institution_ids":["https://openalex.org/I186354981"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5004461302"],"corresponding_institution_ids":["https://openalex.org/I186354981"],"apc_list":null,"apc_paid":null,"fwci":29.0259,"has_fulltext":false,"cited_by_count":140,"citation_normalized_percentile":{"value":0.99488388,"is_in_top_1_percent":true,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":94,"max":100},"biblio":{"volume":null,"issue":null,"first_page":"191","last_page":"202"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10260","display_name":"Software Engineering Research","score":0.9998999834060669,"subfield":{"id":"https://openalex.org/subfields/1710","display_name":"Information Systems"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},"topics":[{"id":"https://openalex.org/T10260","display_name":"Software Engineering Research","score":0.9998999834060669,"subfield":{"id":"https://openalex.org/subfields/1710","display_name":"Information Systems"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T10639","display_name":"Advanced Software Engineering Methodologies","score":0.9990000128746033,"subfield":{"id":"https://openalex.org/subfields/1702","display_name":"Artificial Intelligence"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T10126","display_name":"Logic, programming, and type systems","score":0.9986000061035156,"subfield":{"id":"https://openalex.org/subfields/1702","display_name":"Artificial Intelligence"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}}],"keywords":[{"id":"https://openalex.org/keywords/preprocessor","display_name":"Preprocessor","score":0.7948524951934814},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.7615410685539246},{"id":"https://openalex.org/keywords/code","display_name":"Code (set theory)","score":0.6526825428009033},{"id":"https://openalex.org/keywords/source-lines-of-code","display_name":"Source lines of code","score":0.5735657215118408},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.5487856864929199},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.10643771290779114}],"concepts":[{"id":"https://openalex.org/C34736171","wikidata":"https://www.wikidata.org/wiki/Q918333","display_name":"Preprocessor","level":2,"score":0.7948524951934814},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7615410685539246},{"id":"https://openalex.org/C2776760102","wikidata":"https://www.wikidata.org/wiki/Q5139990","display_name":"Code (set theory)","level":3,"score":0.6526825428009033},{"id":"https://openalex.org/C199519371","wikidata":"https://www.wikidata.org/wiki/Q942695","display_name":"Source lines of code","level":3,"score":0.5735657215118408},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.5487856864929199},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.10643771290779114},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.0}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/1960275.1960299","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1960275.1960299","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the tenth international conference on Aspect-oriented software development","raw_type":"proceedings-article"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.232.3818","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.232.3818","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.informatik.uni-marburg.de/%7Ekaestner/AOSD11.pdf","raw_type":"text"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[{"id":"https://openalex.org/F4320320879","display_name":"Deutsche Forschungsgemeinschaft","ror":"https://ror.org/018mejw64"}],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":40,"referenced_works":["https://openalex.org/W1520520259","https://openalex.org/W1525606436","https://openalex.org/W1585231177","https://openalex.org/W1625440377","https://openalex.org/W1976020328","https://openalex.org/W2006617204","https://openalex.org/W2016954568","https://openalex.org/W2017765016","https://openalex.org/W2022929031","https://openalex.org/W2036134187","https://openalex.org/W2055818134","https://openalex.org/W2090432523","https://openalex.org/W2097355277","https://openalex.org/W2106185005","https://openalex.org/W2112594421","https://openalex.org/W2117352154","https://openalex.org/W2119838293","https://openalex.org/W2119887272","https://openalex.org/W2120789318","https://openalex.org/W2121771606","https://openalex.org/W2130195901","https://openalex.org/W2133494720","https://openalex.org/W2133675710","https://openalex.org/W2134826995","https://openalex.org/W2134949927","https://openalex.org/W2136694367","https://openalex.org/W2144258665","https://openalex.org/W2144498941","https://openalex.org/W2146146776","https://openalex.org/W2148305550","https://openalex.org/W2157151174","https://openalex.org/W2161345821","https://openalex.org/W2161565163","https://openalex.org/W2165448973","https://openalex.org/W2166182667","https://openalex.org/W2298313545","https://openalex.org/W2611598995","https://openalex.org/W3104103145","https://openalex.org/W3174107850","https://openalex.org/W6737467347"],"related_works":["https://openalex.org/W4243252198","https://openalex.org/W2118300983","https://openalex.org/W2112962394","https://openalex.org/W3137189469","https://openalex.org/W4235530921","https://openalex.org/W2382928216","https://openalex.org/W2382501300","https://openalex.org/W2018297885","https://openalex.org/W4311134623","https://openalex.org/W2183928278"],"abstract_inverted_index":{"The":[0,30],"C":[1,31,168],"preprocessor":[2,32],"cpp":[3,176],"is":[4,39,54,131],"a":[5,149,179,208],"widely":[6],"used":[7],"tool":[8,114,141],"for":[9],"implementing":[10],"variable":[11,18],"software.":[12],"It":[13],"enables":[14],"programmers":[15,58,124,146,174],"to":[16,75,133,136,139,144,147,166,204],"express":[17],"code":[19,73],"(which":[20],"may":[21],"even":[22],"crosscut":[23],"the":[24,42,66,97,109,119,155,188,195],"entire":[25],"implementation)":[26],"with":[27,96,108],"conditional":[28],"compilation.":[29],"relies":[33],"on":[34],"simple":[35],"text":[36,52],"processing":[37,53],"and":[38,48,56,85,101,111,128,143,201],"independent":[40],"of":[41,63,68,121,152,160,163,184],"host":[43],"language":[44],"(C,":[45],"C++,":[46],"Java,":[47],"so":[49],"on).":[50],"Languageindependent":[51],"powerful":[55],"expressive\u2014":[57],"can":[59,70],"make":[60],"all":[61,185],"kinds":[62],"annotations":[64,127,138,186],"in":[65,154,178],"form":[67],"#ifdefs\u2014but":[69],"render":[71],"unpreprocessed":[72],"difficult":[74],"process":[76],"automatically":[77],"by":[78],"tools,":[79],"such":[80],"as":[81],"refactoring,":[82],"concern":[83],"management,":[84],"variability-aware":[86],"type":[87],"checking.":[88],"We":[89],"distinguish":[90],"between":[91],"disciplined":[92,137,180,209],"annotations,":[93,103,198],"which":[94,104],"align":[95,107],"underlying":[98,189],"source-code":[99,190],"structure,":[100],"undisciplined":[102,126,197],"do":[105],"not":[106],"structure":[110],"hence":[112],"complicate":[113],"development.":[115],"This":[116],"distinction":[117],"raises":[118],"question":[120],"how":[122,203],"frequently":[123],"use":[125,148,175],"whether":[129],"it":[130],"feasible":[132],"change":[134],"them":[135,206],"simplify":[140],"development":[142],"enable":[145],"wide":[150],"variety":[151],"tools":[153],"first":[156],"place.":[157],"By":[158],"means":[159],"an":[161],"analysis":[162],"40":[164],"medium-sized":[165],"large-sized":[167],"programs,":[169],"we":[170,193],"show":[171],"empirically":[172],"that":[173],"mostly":[177],"way:":[181],"about":[182],"84%":[183],"respect":[187],"structure.":[191],"Furthermore,":[192],"analyze":[194],"remaining":[196],"identify":[199],"patterns,":[200],"discuss":[202],"transform":[205],"into":[207],"form.":[210]},"counts_by_year":[{"year":2026,"cited_by_count":31},{"year":2025,"cited_by_count":2},{"year":2024,"cited_by_count":2},{"year":2023,"cited_by_count":4},{"year":2022,"cited_by_count":3},{"year":2021,"cited_by_count":6},{"year":2020,"cited_by_count":9},{"year":2019,"cited_by_count":3},{"year":2018,"cited_by_count":8},{"year":2017,"cited_by_count":12},{"year":2016,"cited_by_count":10},{"year":2015,"cited_by_count":12},{"year":2014,"cited_by_count":9},{"year":2013,"cited_by_count":15},{"year":2012,"cited_by_count":9}],"updated_date":"2026-04-04T16:13:02.066488","created_date":"2025-10-10T00:00:00"}
