{"id":"https://openalex.org/W2093807883","doi":"https://doi.org/10.1145/2508075.2508433","title":"Ultimate architecture enforcement","display_name":"Ultimate architecture enforcement","publication_year":2013,"publication_date":"2013-10-23","ids":{"openalex":"https://openalex.org/W2093807883","doi":"https://doi.org/10.1145/2508075.2508433","mag":"2093807883"},"language":"en","primary_location":{"id":"doi:10.1145/2508075.2508433","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2508075.2508433","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2013 companion publication for conference on Systems, programming, &amp; applications: software for humanity","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/A5045625992","display_name":"Paulo Merson","orcid":null},"institutions":[],"countries":[],"is_corresponding":true,"raw_author_name":"Paulo Merson","raw_affiliation_strings":["Federal Court of Accounts (TCU), Bras\u00edlia, Brazil"],"affiliations":[{"raw_affiliation_string":"Federal Court of Accounts (TCU), Bras\u00edlia, Brazil","institution_ids":[]}]}],"institutions":[],"countries_distinct_count":0,"institutions_distinct_count":1,"corresponding_author_ids":["https://openalex.org/A5045625992"],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":1.9236,"has_fulltext":false,"cited_by_count":7,"citation_normalized_percentile":{"value":0.88561801,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":89,"max":97},"biblio":{"volume":null,"issue":null,"first_page":"153","last_page":"160"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10639","display_name":"Advanced Software Engineering Methodologies","score":0.9997000098228455,"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"}},"topics":[{"id":"https://openalex.org/T10639","display_name":"Advanced Software Engineering Methodologies","score":0.9997000098228455,"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/T10260","display_name":"Software Engineering Research","score":0.9991000294685364,"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/T12490","display_name":"Software Engineering and Design Patterns","score":0.9983000159263611,"subfield":{"id":"https://openalex.org/subfields/3303","display_name":"Development"},"field":{"id":"https://openalex.org/fields/33","display_name":"Social Sciences"},"domain":{"id":"https://openalex.org/domains/2","display_name":"Social Sciences"}}],"keywords":[{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.7899522185325623},{"id":"https://openalex.org/keywords/software-engineering","display_name":"Software engineering","score":0.5746938586235046},{"id":"https://openalex.org/keywords/software-architecture","display_name":"Software architecture","score":0.5525045394897461},{"id":"https://openalex.org/keywords/commit","display_name":"Commit","score":0.5180885195732117},{"id":"https://openalex.org/keywords/codebase","display_name":"Codebase","score":0.5166038274765015},{"id":"https://openalex.org/keywords/reference-architecture","display_name":"Reference architecture","score":0.502711296081543},{"id":"https://openalex.org/keywords/static-program-analysis","display_name":"Static program analysis","score":0.5021803379058838},{"id":"https://openalex.org/keywords/eiffel","display_name":"Eiffel","score":0.49575313925743103},{"id":"https://openalex.org/keywords/architecture","display_name":"Architecture","score":0.49056047201156616},{"id":"https://openalex.org/keywords/applications-architecture","display_name":"Applications architecture","score":0.46346110105514526},{"id":"https://openalex.org/keywords/space-based-architecture","display_name":"Space-based architecture","score":0.4575083255767822},{"id":"https://openalex.org/keywords/software-architecture-description","display_name":"Software architecture description","score":0.452629953622818},{"id":"https://openalex.org/keywords/code-refactoring","display_name":"Code refactoring","score":0.45063912868499756},{"id":"https://openalex.org/keywords/java","display_name":"Java","score":0.44201144576072693},{"id":"https://openalex.org/keywords/resource-oriented-architecture","display_name":"Resource-oriented architecture","score":0.4191479980945587},{"id":"https://openalex.org/keywords/static-analysis","display_name":"Static analysis","score":0.41569778323173523},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.3790167272090912},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.34874629974365234},{"id":"https://openalex.org/keywords/operating-system","display_name":"Operating system","score":0.3304513692855835},{"id":"https://openalex.org/keywords/software-development","display_name":"Software development","score":0.3042784333229065},{"id":"https://openalex.org/keywords/software-construction","display_name":"Software construction","score":0.20626521110534668},{"id":"https://openalex.org/keywords/database","display_name":"Database","score":0.15105774998664856},{"id":"https://openalex.org/keywords/object-oriented-programming","display_name":"Object-oriented programming","score":0.12930825352668762}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7899522185325623},{"id":"https://openalex.org/C115903868","wikidata":"https://www.wikidata.org/wiki/Q80993","display_name":"Software engineering","level":1,"score":0.5746938586235046},{"id":"https://openalex.org/C35869016","wikidata":"https://www.wikidata.org/wiki/Q846636","display_name":"Software architecture","level":3,"score":0.5525045394897461},{"id":"https://openalex.org/C153180980","wikidata":"https://www.wikidata.org/wiki/Q19776675","display_name":"Commit","level":2,"score":0.5180885195732117},{"id":"https://openalex.org/C51929080","wikidata":"https://www.wikidata.org/wiki/Q2425187","display_name":"Codebase","level":3,"score":0.5166038274765015},{"id":"https://openalex.org/C55356503","wikidata":"https://www.wikidata.org/wiki/Q2136675","display_name":"Reference architecture","level":4,"score":0.502711296081543},{"id":"https://openalex.org/C137287247","wikidata":"https://www.wikidata.org/wiki/Q1329550","display_name":"Static program analysis","level":4,"score":0.5021803379058838},{"id":"https://openalex.org/C186362262","wikidata":"https://www.wikidata.org/wiki/Q732089","display_name":"Eiffel","level":3,"score":0.49575313925743103},{"id":"https://openalex.org/C123657996","wikidata":"https://www.wikidata.org/wiki/Q12271","display_name":"Architecture","level":2,"score":0.49056047201156616},{"id":"https://openalex.org/C41065761","wikidata":"https://www.wikidata.org/wiki/Q2193309","display_name":"Applications architecture","level":4,"score":0.46346110105514526},{"id":"https://openalex.org/C55627697","wikidata":"https://www.wikidata.org/wiki/Q7572175","display_name":"Space-based architecture","level":5,"score":0.4575083255767822},{"id":"https://openalex.org/C73219336","wikidata":"https://www.wikidata.org/wiki/Q7554254","display_name":"Software architecture description","level":5,"score":0.452629953622818},{"id":"https://openalex.org/C152752567","wikidata":"https://www.wikidata.org/wiki/Q116877","display_name":"Code refactoring","level":3,"score":0.45063912868499756},{"id":"https://openalex.org/C548217200","wikidata":"https://www.wikidata.org/wiki/Q251","display_name":"Java","level":2,"score":0.44201144576072693},{"id":"https://openalex.org/C97382630","wikidata":"https://www.wikidata.org/wiki/Q13501132","display_name":"Resource-oriented architecture","level":5,"score":0.4191479980945587},{"id":"https://openalex.org/C97686452","wikidata":"https://www.wikidata.org/wiki/Q7604153","display_name":"Static analysis","level":2,"score":0.41569778323173523},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.3790167272090912},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.34874629974365234},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.3304513692855835},{"id":"https://openalex.org/C529173508","wikidata":"https://www.wikidata.org/wiki/Q638608","display_name":"Software development","level":3,"score":0.3042784333229065},{"id":"https://openalex.org/C186846655","wikidata":"https://www.wikidata.org/wiki/Q3398377","display_name":"Software construction","level":4,"score":0.20626521110534668},{"id":"https://openalex.org/C77088390","wikidata":"https://www.wikidata.org/wiki/Q8513","display_name":"Database","level":1,"score":0.15105774998664856},{"id":"https://openalex.org/C73752529","wikidata":"https://www.wikidata.org/wiki/Q79872","display_name":"Object-oriented programming","level":2,"score":0.12930825352668762},{"id":"https://openalex.org/C153349607","wikidata":"https://www.wikidata.org/wiki/Q36649","display_name":"Visual arts","level":1,"score":0.0},{"id":"https://openalex.org/C142362112","wikidata":"https://www.wikidata.org/wiki/Q735","display_name":"Art","level":0,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/2508075.2508433","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2508075.2508433","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2013 companion publication for conference on Systems, programming, &amp; applications: software for humanity","raw_type":"proceedings-article"}],"best_oa_location":null,"sustainable_development_goals":[{"display_name":"Peace, Justice and strong institutions","score":0.5400000214576721,"id":"https://metadata.un.org/sdg/16"}],"awards":[],"funders":[{"id":"https://openalex.org/F4320334764","display_name":"Japan Society for the Promotion of Science","ror":"https://ror.org/00hhkn466"}],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":7,"referenced_works":["https://openalex.org/W64247878","https://openalex.org/W157052771","https://openalex.org/W1564594068","https://openalex.org/W1649645444","https://openalex.org/W1800478330","https://openalex.org/W2038476425","https://openalex.org/W2250227452"],"related_works":["https://openalex.org/W4238407057","https://openalex.org/W2108340160","https://openalex.org/W2976480616","https://openalex.org/W2354797847","https://openalex.org/W2742781925","https://openalex.org/W2902876962","https://openalex.org/W2372256883","https://openalex.org/W1152672851","https://openalex.org/W4289655526","https://openalex.org/W2132637830"],"abstract_inverted_index":{"Creating":[0],"a":[1,5,99,118,132,150,160,169,199,230,240],"software":[2,12,100,193,207],"architecture":[3,16,31,42,50,85,101,190,248,276],"is":[4,21,32,91,115,232,250],"critical":[6],"task":[7],"in":[8,26,52,228],"the":[9,15,27,30,40,45,48,53,77,92,110,128,140,189,205,220,225,237,245,257,266],"development":[10],"of":[11,80,117,191,263,265,274],"systems.":[13,194],"However,":[14,76],"discussed":[17],"and":[18,47,71,105,176,223,253,279],"carefully":[19],"created":[20,198],"often":[22,65,125],"not":[23,103,107],"entirely":[24],"followed":[25],"implementation.":[28],"Unless":[29],"communicated":[33],"effectively":[34],"to":[35,57,67,98,127,131,144,212,259,281],"all":[36],"developers,":[37],"divergence":[38],"between":[39],"intended":[41],"(created":[43],"by":[44,109,188],"architect)":[46],"actual":[49],"(found":[51],"source":[54,172],"code)":[55],"tends":[56],"gradually":[58],"increase.":[59],"Static":[60],"analysis":[61,82,122],"tools,":[62],"which":[63],"are":[64,102,124],"used":[66],"check":[68],"coding":[69],"conventions":[70],"best":[72],"practices,":[73],"can":[74,254],"help.":[75],"common":[78],"use":[79],"static":[81,121],"tools":[83,123],"for":[84,159,184],"enforcement":[86,277],"has":[87],"two":[88,157],"limitations.":[89],"One":[90],"fact":[93],"that":[94,201,235],"design":[95,185],"rules":[96],"specific":[97],"known":[104],"hence":[106],"enforced":[108],"tool.":[111],"The":[112,247],"other":[113],"limitation":[114],"more":[116,287],"practical":[119],"issue:":[120],"integrated":[126],"IDE":[129],"or":[130,284],"continuous":[133],"integration":[134],"environment;":[135],"they":[136],"report":[137,270],"violations":[138],"but":[139],"developers":[141],"may":[142],"choose":[143],"ignore":[145],"them.":[146],"This":[147,217,268],"paper":[148],"reports":[149],"successful":[151],"experience":[152,269],"where":[153],"we":[154,180,197],"addressed":[155],"these":[156],"limitations":[158],"large":[161],"codebase":[162],"comprising":[163],"over":[164],"50":[165],"Java":[166,178],"applications.":[167],"Using":[168],"free":[170],"open":[171],"tool":[173],"called":[174],"checkstyle":[175],"its":[177],"API,":[179],"implemented":[181],"custom":[182,221],"checks":[183,222],"constraints":[186],"specified":[187],"our":[192,275],"In":[195],"addition,":[196],"script":[200,218],"executes":[202],"automatically":[203],"on":[204],"Subversion":[206],"configuration":[208],"management":[209],"server":[210],"prior":[211],"any":[213,261],"code":[214],"commit":[215,226],"operation.":[216],"runs":[219],"denies":[224],"operation":[227],"case":[229],"violation":[231],"found.":[233],"When":[234],"happens,":[236],"developer":[238,258],"gets":[239],"clear":[241],"error":[242],"message":[243],"explaining":[244],"problem.":[246],"team":[249],"also":[251],"notified":[252],"proactively":[255],"contact":[256],"address":[260],"lack":[262],"understanding":[264],"architecture.":[267],"provides":[271],"technical":[272],"details":[273],"approach":[278],"recommendations":[280],"employ":[282],"this":[283],"similar":[285],"solutions":[286],"effectively.":[288]},"counts_by_year":[{"year":2020,"cited_by_count":1},{"year":2019,"cited_by_count":1},{"year":2017,"cited_by_count":1},{"year":2016,"cited_by_count":1},{"year":2015,"cited_by_count":3}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
