{"id":"https://openalex.org/W2884404716","doi":"https://doi.org/10.1145/3194793.3194794","title":"Non-atomic refactoring and software sustainability","display_name":"Non-atomic refactoring and software sustainability","publication_year":2018,"publication_date":"2018-06-02","ids":{"openalex":"https://openalex.org/W2884404716","doi":"https://doi.org/10.1145/3194793.3194794","mag":"2884404716"},"language":"en","primary_location":{"id":"doi:10.1145/3194793.3194794","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3194793.3194794","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3194793.3194794","source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2nd International Workshop on API Usage and Evolution","raw_type":"proceedings-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"gold","oa_url":"https://dl.acm.org/doi/pdf/10.1145/3194793.3194794","any_repository_has_fulltext":null},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5026597953","display_name":"Titus Winters","orcid":"https://orcid.org/0000-0001-6973-8482"},"institutions":[{"id":"https://openalex.org/I1291425158","display_name":"Google (United States)","ror":"https://ror.org/00njsd438","country_code":"US","type":"company","lineage":["https://openalex.org/I1291425158","https://openalex.org/I4210128969"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Titus Winters","raw_affiliation_strings":["Google, Inc"],"affiliations":[{"raw_affiliation_string":"Google, Inc","institution_ids":["https://openalex.org/I1291425158"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":1,"corresponding_author_ids":["https://openalex.org/A5026597953"],"corresponding_institution_ids":["https://openalex.org/I1291425158"],"apc_list":null,"apc_paid":null,"fwci":2.3561,"has_fulltext":true,"cited_by_count":9,"citation_normalized_percentile":{"value":0.91398146,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":96},"biblio":{"volume":null,"issue":null,"first_page":"2","last_page":"5"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10260","display_name":"Software Engineering Research","score":0.9994000196456909,"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.9994000196456909,"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.9983999729156494,"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/T12127","display_name":"Software System Performance and Reliability","score":0.9950000047683716,"subfield":{"id":"https://openalex.org/subfields/1705","display_name":"Computer Networks and Communications"},"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/code-refactoring","display_name":"Code refactoring","score":0.9538639783859253},{"id":"https://openalex.org/keywords/codebase","display_name":"Codebase","score":0.8180786371231079},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.748542070388794},{"id":"https://openalex.org/keywords/software-engineering","display_name":"Software engineering","score":0.6622657179832458},{"id":"https://openalex.org/keywords/sustainability","display_name":"Sustainability","score":0.6589643955230713},{"id":"https://openalex.org/keywords/software-development","display_name":"Software development","score":0.49322932958602905},{"id":"https://openalex.org/keywords/set","display_name":"Set (abstract data type)","score":0.4810076653957367},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.4713049829006195},{"id":"https://openalex.org/keywords/work","display_name":"Work (physics)","score":0.45096850395202637},{"id":"https://openalex.org/keywords/software-maintenance","display_name":"Software maintenance","score":0.4227205812931061},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.34942978620529175},{"id":"https://openalex.org/keywords/engineering","display_name":"Engineering","score":0.13825520873069763}],"concepts":[{"id":"https://openalex.org/C152752567","wikidata":"https://www.wikidata.org/wiki/Q116877","display_name":"Code refactoring","level":3,"score":0.9538639783859253},{"id":"https://openalex.org/C51929080","wikidata":"https://www.wikidata.org/wiki/Q2425187","display_name":"Codebase","level":3,"score":0.8180786371231079},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.748542070388794},{"id":"https://openalex.org/C115903868","wikidata":"https://www.wikidata.org/wiki/Q80993","display_name":"Software engineering","level":1,"score":0.6622657179832458},{"id":"https://openalex.org/C66204764","wikidata":"https://www.wikidata.org/wiki/Q219416","display_name":"Sustainability","level":2,"score":0.6589643955230713},{"id":"https://openalex.org/C529173508","wikidata":"https://www.wikidata.org/wiki/Q638608","display_name":"Software development","level":3,"score":0.49322932958602905},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.4810076653957367},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.4713049829006195},{"id":"https://openalex.org/C18762648","wikidata":"https://www.wikidata.org/wiki/Q42213","display_name":"Work (physics)","level":2,"score":0.45096850395202637},{"id":"https://openalex.org/C101317890","wikidata":"https://www.wikidata.org/wiki/Q940053","display_name":"Software maintenance","level":4,"score":0.4227205812931061},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.34942978620529175},{"id":"https://openalex.org/C127413603","wikidata":"https://www.wikidata.org/wiki/Q11023","display_name":"Engineering","level":0,"score":0.13825520873069763},{"id":"https://openalex.org/C18903297","wikidata":"https://www.wikidata.org/wiki/Q7150","display_name":"Ecology","level":1,"score":0.0},{"id":"https://openalex.org/C78519656","wikidata":"https://www.wikidata.org/wiki/Q101333","display_name":"Mechanical engineering","level":1,"score":0.0},{"id":"https://openalex.org/C86803240","wikidata":"https://www.wikidata.org/wiki/Q420","display_name":"Biology","level":0,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/3194793.3194794","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3194793.3194794","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3194793.3194794","source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2nd International Workshop on API Usage and Evolution","raw_type":"proceedings-article"}],"best_oa_location":{"id":"doi:10.1145/3194793.3194794","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3194793.3194794","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3194793.3194794","source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2nd International Workshop on API Usage and Evolution","raw_type":"proceedings-article"},"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2884404716.pdf","grobid_xml":"https://content.openalex.org/works/W2884404716.grobid-xml"},"referenced_works_count":2,"referenced_works":["https://openalex.org/W2056024552","https://openalex.org/W2239505015"],"related_works":["https://openalex.org/W4312691020","https://openalex.org/W2597601979","https://openalex.org/W2186150085","https://openalex.org/W4287330506","https://openalex.org/W2010680342","https://openalex.org/W4226265053","https://openalex.org/W2069073539","https://openalex.org/W4221160381","https://openalex.org/W1985559452","https://openalex.org/W2027488246"],"abstract_inverted_index":{"Sustainability":[0],"is":[1,168],"the":[2,42,95,110,113,116],"ability":[3],"of":[4,35,58,104,112,128,195],"a":[5,21,101,121,133,158,192],"project":[6],"/":[7,9],"codebase":[8],"organization":[10],"to":[11,13,84,89,108,124,146,174,176,190],"react":[12],"necessary":[14],"changes":[15,65,88,145],"over":[16,92],"its":[17],"expected":[18,173],"lifespan.":[19],"At":[20],"large":[22],"enough":[23,27],"scale,":[24],"or":[25,135],"with":[26],"disconnect":[28],"between":[29],"dependencies,":[30],"sustainability":[31],"comes":[32],"from":[33],"application":[34],"both":[36],"technical":[37,43],"and":[38,56,76,82,170],"non-technical":[39,96],"approaches.":[40],"On":[41,94],"side,":[44,97],"I":[45,98,188],"advocate":[46],"for":[47,100,115],"restraint":[48],"among":[49],"API":[50,148],"providers":[51],"on":[52],"making":[53],"arbitrary":[54],"changes,":[55],"use":[57],"non-atomic":[59],"refactoring":[60],"techniques":[61,69],"when":[62,197],"more":[63,86],"invasive":[64],"are":[66,70,142,150],"required;":[67],"such":[68],"employed":[71],"in":[72,77],"many":[73,139],"Google":[74],"projects,":[75],"programming":[78,136],"languages":[79],"like":[80],"Go":[81],"C++,":[83],"allow":[85],"flexible":[87],"language":[90],"standards":[91],"time.":[93],"argue":[99],"clear":[102],"separation":[103],"responsibilities":[105],"(providers":[106],"need":[107,123],"do":[109],"bulk":[111],"work":[114,177],"update),":[117],"as":[118,120],"well":[119],"growing":[122],"document":[125],"acceptable":[126],"usage":[127],"an":[129,147],"API,":[130],"be":[131,172,191],"it":[132,167],"library":[134],"language.":[137],"In":[138],"languages,":[140],"there":[141],"very":[143],"few":[144],"that":[149,166],"provably":[151],"safe":[152],"without":[153],"this":[154],"idea:":[155],"just":[156],"because":[157],"user's":[159],"code":[160],"currently":[161],"works":[162],"does":[163],"not":[164],"mean":[165],"supported":[169],"can":[171],"continue":[175],"indefinitely":[178],"under":[179],"maintenance.":[180],"Taken":[181],"together,":[182],"these":[183],"two":[184],"approaches":[185],"form":[186],"what":[187],"believe":[189],"minimum":[193],"set":[194],"requirements":[196],"approaching":[198],"software":[199],"sustainability.":[200]},"counts_by_year":[{"year":2023,"cited_by_count":1},{"year":2022,"cited_by_count":2},{"year":2021,"cited_by_count":2},{"year":2020,"cited_by_count":2},{"year":2019,"cited_by_count":1},{"year":2018,"cited_by_count":1}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
