{"id":"https://openalex.org/W2093927510","doi":"https://doi.org/10.1145/2814270.2814316","title":"A sound and optimal incremental build system with dynamic dependencies","display_name":"A sound and optimal incremental build system with dynamic dependencies","publication_year":2015,"publication_date":"2015-10-23","ids":{"openalex":"https://openalex.org/W2093927510","doi":"https://doi.org/10.1145/2814270.2814316","mag":"2093927510"},"language":"en","primary_location":{"id":"doi:10.1145/2814270.2814316","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2814270.2814316","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2015 ACM SIGPLAN International Conference on Object-Oriented Programming, Systems, Languages, and Applications","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/A5059992246","display_name":"Sebastian Erdweg","orcid":"https://orcid.org/0000-0002-1974-5956"},"institutions":[{"id":"https://openalex.org/I31512782","display_name":"Technical University of Darmstadt","ror":"https://ror.org/05n911h24","country_code":"DE","type":"education","lineage":["https://openalex.org/I31512782"]}],"countries":["DE"],"is_corresponding":true,"raw_author_name":"Sebastian Erdweg","raw_affiliation_strings":["TU Darmstadt, Germany","[TU, Darmstadt, Germany]"],"affiliations":[{"raw_affiliation_string":"TU Darmstadt, Germany","institution_ids":["https://openalex.org/I31512782"]},{"raw_affiliation_string":"[TU, Darmstadt, Germany]","institution_ids":["https://openalex.org/I31512782"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5050723678","display_name":"Moritz Lichter","orcid":"https://orcid.org/0000-0001-5437-8074"},"institutions":[{"id":"https://openalex.org/I31512782","display_name":"Technical University of Darmstadt","ror":"https://ror.org/05n911h24","country_code":"DE","type":"education","lineage":["https://openalex.org/I31512782"]}],"countries":["DE"],"is_corresponding":false,"raw_author_name":"Moritz Lichter","raw_affiliation_strings":["TU Darmstadt, Germany","[TU, Darmstadt, Germany]"],"affiliations":[{"raw_affiliation_string":"TU Darmstadt, Germany","institution_ids":["https://openalex.org/I31512782"]},{"raw_affiliation_string":"[TU, Darmstadt, Germany]","institution_ids":["https://openalex.org/I31512782"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5060878524","display_name":"Manuel Weiel","orcid":null},"institutions":[{"id":"https://openalex.org/I31512782","display_name":"Technical University of Darmstadt","ror":"https://ror.org/05n911h24","country_code":"DE","type":"education","lineage":["https://openalex.org/I31512782"]}],"countries":["DE"],"is_corresponding":false,"raw_author_name":"Manuel Weiel","raw_affiliation_strings":["TU Darmstadt, Germany","[TU, Darmstadt, Germany]"],"affiliations":[{"raw_affiliation_string":"TU Darmstadt, Germany","institution_ids":["https://openalex.org/I31512782"]},{"raw_affiliation_string":"[TU, Darmstadt, Germany]","institution_ids":["https://openalex.org/I31512782"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5059992246"],"corresponding_institution_ids":["https://openalex.org/I31512782"],"apc_list":null,"apc_paid":null,"fwci":12.3509,"has_fulltext":false,"cited_by_count":32,"citation_normalized_percentile":{"value":0.98364201,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":94,"max":99},"biblio":{"volume":null,"issue":null,"first_page":"89","last_page":"106"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10260","display_name":"Software Engineering Research","score":0.9991999864578247,"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.9991999864578247,"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/T12127","display_name":"Software System Performance and Reliability","score":0.9965999722480774,"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"}},{"id":"https://openalex.org/T10639","display_name":"Advanced Software Engineering Methodologies","score":0.9961000084877014,"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/computer-science","display_name":"Computer science","score":0.8615620136260986},{"id":"https://openalex.org/keywords/dependency-graph","display_name":"Dependency graph","score":0.6153591871261597},{"id":"https://openalex.org/keywords/java","display_name":"Java","score":0.5690417289733887},{"id":"https://openalex.org/keywords/dependency","display_name":"Dependency (UML)","score":0.5614629983901978},{"id":"https://openalex.org/keywords/pluto","display_name":"Pluto","score":0.46396055817604065},{"id":"https://openalex.org/keywords/parameterized-complexity","display_name":"Parameterized complexity","score":0.42811688780784607},{"id":"https://openalex.org/keywords/file-system","display_name":"File system","score":0.4194236099720001},{"id":"https://openalex.org/keywords/database","display_name":"Database","score":0.3940492868423462},{"id":"https://openalex.org/keywords/distributed-computing","display_name":"Distributed computing","score":0.3825274705886841},{"id":"https://openalex.org/keywords/operating-system","display_name":"Operating system","score":0.35642194747924805},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.3425664007663727},{"id":"https://openalex.org/keywords/software-engineering","display_name":"Software engineering","score":0.24895158410072327},{"id":"https://openalex.org/keywords/algorithm","display_name":"Algorithm","score":0.1245972216129303}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8615620136260986},{"id":"https://openalex.org/C16311509","wikidata":"https://www.wikidata.org/wiki/Q4148050","display_name":"Dependency graph","level":3,"score":0.6153591871261597},{"id":"https://openalex.org/C548217200","wikidata":"https://www.wikidata.org/wiki/Q251","display_name":"Java","level":2,"score":0.5690417289733887},{"id":"https://openalex.org/C19768560","wikidata":"https://www.wikidata.org/wiki/Q320727","display_name":"Dependency (UML)","level":2,"score":0.5614629983901978},{"id":"https://openalex.org/C2780263841","wikidata":"https://www.wikidata.org/wiki/Q339","display_name":"Pluto","level":2,"score":0.46396055817604065},{"id":"https://openalex.org/C165464430","wikidata":"https://www.wikidata.org/wiki/Q1570441","display_name":"Parameterized complexity","level":2,"score":0.42811688780784607},{"id":"https://openalex.org/C2780940931","wikidata":"https://www.wikidata.org/wiki/Q174989","display_name":"File system","level":2,"score":0.4194236099720001},{"id":"https://openalex.org/C77088390","wikidata":"https://www.wikidata.org/wiki/Q8513","display_name":"Database","level":1,"score":0.3940492868423462},{"id":"https://openalex.org/C120314980","wikidata":"https://www.wikidata.org/wiki/Q180634","display_name":"Distributed computing","level":1,"score":0.3825274705886841},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.35642194747924805},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.3425664007663727},{"id":"https://openalex.org/C115903868","wikidata":"https://www.wikidata.org/wiki/Q80993","display_name":"Software engineering","level":1,"score":0.24895158410072327},{"id":"https://openalex.org/C11413529","wikidata":"https://www.wikidata.org/wiki/Q8366","display_name":"Algorithm","level":1,"score":0.1245972216129303},{"id":"https://openalex.org/C121332964","wikidata":"https://www.wikidata.org/wiki/Q413","display_name":"Physics","level":0,"score":0.0},{"id":"https://openalex.org/C87355193","wikidata":"https://www.wikidata.org/wiki/Q411","display_name":"Astrobiology","level":1,"score":0.0}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/2814270.2814316","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2814270.2814316","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2015 ACM SIGPLAN International Conference on Object-Oriented Programming, Systems, Languages, and Applications","raw_type":"proceedings-article"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.725.6063","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.725.6063","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/%7Eseba/publications/pluto-incremental-build.pdf","raw_type":"text"}],"best_oa_location":null,"sustainable_development_goals":[{"id":"https://metadata.un.org/sdg/9","score":0.49000000953674316,"display_name":"Industry, innovation and infrastructure"}],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":14,"referenced_works":["https://openalex.org/W1495324919","https://openalex.org/W1495453491","https://openalex.org/W1966725513","https://openalex.org/W1978948468","https://openalex.org/W2012058332","https://openalex.org/W2022744394","https://openalex.org/W2073065242","https://openalex.org/W2103030845","https://openalex.org/W2117699092","https://openalex.org/W2132251340","https://openalex.org/W2150395559","https://openalex.org/W2151073063","https://openalex.org/W2171379071","https://openalex.org/W2904205446"],"related_works":["https://openalex.org/W2327631927","https://openalex.org/W2093568763","https://openalex.org/W1985166372","https://openalex.org/W2003096546","https://openalex.org/W2430210575","https://openalex.org/W4289354592","https://openalex.org/W2165069859","https://openalex.org/W2099112646","https://openalex.org/W2626477053","https://openalex.org/W2342550845"],"abstract_inverted_index":{"Build":[0],"systems":[1,55],"are":[2,106],"used":[3,193],"in":[4,21,145],"all":[5],"but":[6],"the":[7,13,18,22,38,77,89,115,135,177,216],"smallest":[8],"software":[9],"projects":[10],"to":[11,121,124,152,195,212],"invoke":[12],"right":[14,19,23],"build":[15,26,49,54,71,90,147,210,218],"tools":[16],"on":[17,129,176],"files":[20,35,97],"order.":[24],"A":[25],"system":[27,72,91],"must":[28],"be":[29],"sound":[30,155],"(after":[31],"a":[32,70,86,130,140,146,181,189,207],"build,":[33],"generated":[34],"consistently":[36],"reflect":[37],"latest":[39],"source":[40],"files)":[41],"and":[42,45,95,137,156,170,173,192,214],"efficient":[43],"(recheck":[44],"rebuild":[46,165],"as":[47,51,98,100,188],"few":[48],"units":[50],"possible).":[52],"Contemporary":[53],"provide":[56],"limited":[57],"efficiency":[58],"because":[59],"they":[60],"lack":[61],"support":[62,109,161],"for":[63],"expressing":[64],"fine-grained":[65,110],"file":[66,111],"dependencies.":[67],"We":[68,184,201],"present":[69],"called":[73],"pluto":[74,133,151,187,213],"that":[75],"supports":[76],"definition":[78],"of":[79,118,139],"reusable,":[80],"parameterized,":[81],"interconnected":[82],"builders.":[83,200],"When":[84],"run,":[85],"builder":[87,141,171],"notifies":[88],"about":[92,101],"dynamically":[93],"required":[94],"produced":[96],"well":[99],"other":[102],"builders":[103,123],"whose":[104],"results":[105],"needed.":[107],"To":[108,160],"dependencies,":[112,163],"we":[113],"generalize":[114],"traditional":[116],"notion":[117],"time":[119],"stamps":[120,144],"allow":[122],"declare":[125],"their":[126,143],"actual":[127],"requirements":[128,136],"file's":[131],"content.":[132],"collects":[134],"products":[138],"with":[142,205],"summary.":[148],"This":[149],"enables":[150],"provides":[153],"provably":[154],"optimal":[157],"incremental":[158],"rebuilding.":[159],"dynamic":[162,182],"our":[164,203],"algorithm":[166],"interleaves":[167],"dependency":[168,178],"analysis":[169],"execution":[172],"enforces":[174],"invariants":[175],"graph":[179],"through":[180],"analysis.":[183],"have":[185],"developed":[186],"Java":[190],"API":[191],"it":[194],"implement":[196],"more":[197],"than":[198],"25":[199],"describe":[202],"experience":[204],"migrating":[206],"larger":[208],"Ant":[209],"script":[211],"compare":[215],"respective":[217],"times.":[219]},"counts_by_year":[{"year":2026,"cited_by_count":1},{"year":2024,"cited_by_count":2},{"year":2022,"cited_by_count":2},{"year":2021,"cited_by_count":2},{"year":2020,"cited_by_count":8},{"year":2019,"cited_by_count":2},{"year":2018,"cited_by_count":5},{"year":2017,"cited_by_count":3},{"year":2016,"cited_by_count":7}],"updated_date":"2026-04-05T17:49:38.594831","created_date":"2025-10-10T00:00:00"}
