{"id":"https://openalex.org/W4307886855","doi":"https://doi.org/10.1145/3563303","title":"Incremental type-checking for free: using scope graphs to derive incremental type-checkers","display_name":"Incremental type-checking for free: using scope graphs to derive incremental type-checkers","publication_year":2022,"publication_date":"2022-10-31","ids":{"openalex":"https://openalex.org/W4307886855","doi":"https://doi.org/10.1145/3563303"},"language":"en","primary_location":{"id":"doi:10.1145/3563303","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3563303","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3563303","source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":true,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319798","host_organization_name":"Association for Computing Machinery","host_organization_lineage":["https://openalex.org/P4310319798"],"host_organization_lineage_names":["Association for Computing Machinery"],"type":"journal"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"diamond","oa_url":"https://dl.acm.org/doi/pdf/10.1145/3563303","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5064233942","display_name":"Aron Zwaan","orcid":"https://orcid.org/0000-0002-1818-4245"},"institutions":[{"id":"https://openalex.org/I98358874","display_name":"Delft University of Technology","ror":"https://ror.org/02e2c7k09","country_code":"NL","type":"education","lineage":["https://openalex.org/I98358874"]}],"countries":["NL"],"is_corresponding":true,"raw_author_name":"Aron Zwaan","raw_affiliation_strings":["Delft University of Technology, Netherlands"],"affiliations":[{"raw_affiliation_string":"Delft University of Technology, Netherlands","institution_ids":["https://openalex.org/I98358874"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5086247961","display_name":"Hendrik van Antwerpen","orcid":"https://orcid.org/0000-0001-5117-0921"},"institutions":[{"id":"https://openalex.org/I98358874","display_name":"Delft University of Technology","ror":"https://ror.org/02e2c7k09","country_code":"NL","type":"education","lineage":["https://openalex.org/I98358874"]}],"countries":["NL"],"is_corresponding":false,"raw_author_name":"Hendrik van Antwerpen","raw_affiliation_strings":["Delft University of Technology, Netherlands"],"affiliations":[{"raw_affiliation_string":"Delft University of Technology, Netherlands","institution_ids":["https://openalex.org/I98358874"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5072923235","display_name":"Eelco Visser","orcid":"https://orcid.org/0000-0002-7384-3370"},"institutions":[{"id":"https://openalex.org/I98358874","display_name":"Delft University of Technology","ror":"https://ror.org/02e2c7k09","country_code":"NL","type":"education","lineage":["https://openalex.org/I98358874"]}],"countries":["NL"],"is_corresponding":false,"raw_author_name":"Eelco Visser","raw_affiliation_strings":["Delft University of Technology, Netherlands"],"affiliations":[{"raw_affiliation_string":"Delft University of Technology, Netherlands","institution_ids":["https://openalex.org/I98358874"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5064233942"],"corresponding_institution_ids":["https://openalex.org/I98358874"],"apc_list":null,"apc_paid":null,"fwci":0.9554,"has_fulltext":true,"cited_by_count":3,"citation_normalized_percentile":{"value":0.811503,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":90,"max":96},"biblio":{"volume":"6","issue":"OOPSLA2","first_page":"424","last_page":"448"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10260","display_name":"Software Engineering Research","score":0.9987000226974487,"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.9987000226974487,"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/T10126","display_name":"Logic, programming, and type systems","score":0.9955999851226807,"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/T11424","display_name":"Security and Verification in Computing","score":0.9922000169754028,"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.8482183218002319},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.5625534057617188},{"id":"https://openalex.org/keywords/scalability","display_name":"Scalability","score":0.560167133808136},{"id":"https://openalex.org/keywords/context","display_name":"Context (archaeology)","score":0.553875744342804},{"id":"https://openalex.org/keywords/scope","display_name":"Scope (computer science)","score":0.5429667234420776},{"id":"https://openalex.org/keywords/type-inference","display_name":"Type inference","score":0.4967847168445587},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.40751853585243225},{"id":"https://openalex.org/keywords/inference","display_name":"Inference","score":0.17601779103279114},{"id":"https://openalex.org/keywords/database","display_name":"Database","score":0.17085301876068115},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.16626739501953125}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8482183218002319},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.5625534057617188},{"id":"https://openalex.org/C48044578","wikidata":"https://www.wikidata.org/wiki/Q727490","display_name":"Scalability","level":2,"score":0.560167133808136},{"id":"https://openalex.org/C2779343474","wikidata":"https://www.wikidata.org/wiki/Q3109175","display_name":"Context (archaeology)","level":2,"score":0.553875744342804},{"id":"https://openalex.org/C2778012447","wikidata":"https://www.wikidata.org/wiki/Q1034415","display_name":"Scope (computer science)","level":2,"score":0.5429667234420776},{"id":"https://openalex.org/C198370458","wikidata":"https://www.wikidata.org/wiki/Q586459","display_name":"Type inference","level":3,"score":0.4967847168445587},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.40751853585243225},{"id":"https://openalex.org/C2776214188","wikidata":"https://www.wikidata.org/wiki/Q408386","display_name":"Inference","level":2,"score":0.17601779103279114},{"id":"https://openalex.org/C77088390","wikidata":"https://www.wikidata.org/wiki/Q8513","display_name":"Database","level":1,"score":0.17085301876068115},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.16626739501953125},{"id":"https://openalex.org/C86803240","wikidata":"https://www.wikidata.org/wiki/Q420","display_name":"Biology","level":0,"score":0.0},{"id":"https://openalex.org/C151730666","wikidata":"https://www.wikidata.org/wiki/Q7205","display_name":"Paleontology","level":1,"score":0.0}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/3563303","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3563303","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3563303","source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":true,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319798","host_organization_name":"Association for Computing Machinery","host_organization_lineage":["https://openalex.org/P4310319798"],"host_organization_lineage_names":["Association for Computing Machinery"],"type":"journal"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},{"id":"pmh:oai:tudelft.nl:uuid:e668432d-3881-4e19-9862-36f0d4b42226","is_oa":true,"landing_page_url":"http://resolver.tudelft.nl/uuid:e668432d-3881-4e19-9862-36f0d4b42226","pdf_url":null,"source":{"id":"https://openalex.org/S4306400906","display_name":"Research Repository (Delft University of Technology)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I98358874","host_organization_name":"Delft University of Technology","host_organization_lineage":["https://openalex.org/I98358874"],"host_organization_lineage_names":[],"type":"repository"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":"journal article"}],"best_oa_location":{"id":"doi:10.1145/3563303","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3563303","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3563303","source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":true,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319798","host_organization_name":"Association for Computing Machinery","host_organization_lineage":["https://openalex.org/P4310319798"],"host_organization_lineage_names":["Association for Computing Machinery"],"type":"journal"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":true,"pdf":true},"content_urls":{"pdf":"https://content.openalex.org/works/W4307886855.pdf","grobid_xml":"https://content.openalex.org/works/W4307886855.grobid-xml"},"referenced_works_count":36,"referenced_works":["https://openalex.org/W372741891","https://openalex.org/W781995223","https://openalex.org/W1573418128","https://openalex.org/W1769237108","https://openalex.org/W1989092049","https://openalex.org/W1990529626","https://openalex.org/W2005221219","https://openalex.org/W2022744394","https://openalex.org/W2026794345","https://openalex.org/W2045058623","https://openalex.org/W2051716170","https://openalex.org/W2069718764","https://openalex.org/W2072794470","https://openalex.org/W2092284332","https://openalex.org/W2106656979","https://openalex.org/W2118567331","https://openalex.org/W2131752612","https://openalex.org/W2135785452","https://openalex.org/W2143777056","https://openalex.org/W2145945984","https://openalex.org/W2156429182","https://openalex.org/W2513927163","https://openalex.org/W2885728120","https://openalex.org/W2888590305","https://openalex.org/W2898547734","https://openalex.org/W2909261754","https://openalex.org/W2911225697","https://openalex.org/W2962829798","https://openalex.org/W3089462636","https://openalex.org/W3093996209","https://openalex.org/W3098470576","https://openalex.org/W3107077096","https://openalex.org/W3174779340","https://openalex.org/W3185021159","https://openalex.org/W4225153514","https://openalex.org/W6931780509"],"related_works":["https://openalex.org/W2189052291","https://openalex.org/W2067607302","https://openalex.org/W102335353","https://openalex.org/W4247404391","https://openalex.org/W2924405342","https://openalex.org/W1851310281","https://openalex.org/W1978871081","https://openalex.org/W2051876501","https://openalex.org/W2395886377","https://openalex.org/W2355315340"],"abstract_inverted_index":{"Fast":[0],"analysis":[1],"response":[2],"times":[3],"in":[4,18,71,80,90,114],"IDEs":[5],"are":[6,25],"essential":[7],"for":[8,105,159],"a":[9,19,48,59,138,141,147],"good":[10],"editor":[11],"experience.":[12],"Incremental":[13],"type-checking":[14,47,135,198],"can":[15,194],"provide":[16,195],"that":[17,61,191],"scalable":[20],"fashion.":[21],"However,":[22],"existing":[23],"techniques":[24],"not":[26],"reusable":[27],"between":[28,95],"languages.":[29],"Moreover,":[30],"mutual":[31,152],"and":[32,140,144,177],"dynamic":[33],"dependencies":[34,94],"preclude":[35],"traditional":[36],"approaches":[37,44],"to":[38,45,92,111,150,164,172,179,199],"incrementality.":[39],"This":[40,154,189],"makes":[41],"finding":[42],"automatic":[43],"incremental":[46,64,157,197],"challenging":[49],"but":[50],"important":[51],"open":[52],"question.":[53],"In":[54],"this":[55,127],"paper,":[56],"we":[57,168],"present":[58],"technique":[60],"automatically":[62,155],"derives":[63],"type-checkers":[65,158],"from":[66],"type":[67],"system":[68],"specifications":[69],"written":[70],"the":[72,107,115,134,200],"Statix":[73,161],"meta-DSL.":[74],"We":[75],"use":[76],"name":[77,87],"resolution":[78],"queries":[79,104,121],"scope":[81],"graphs":[82],"(a":[83],"generic":[84,148],"model":[85],"of":[86,126,203],"binding":[88],"embedded":[89],"Statix)":[91],"derive":[93],"compilation":[96],"units.":[97],"A":[98],"novel":[99],"query":[100],"confirmation":[101],"algorithm":[102,128],"finds":[103],"which":[106],"answer":[108],"changed":[109],"due":[110],"an":[112],"edit":[113],"program.":[116],"Only":[117],"units":[118],"with":[119,184],"such":[120],"require":[122],"reanalysis.":[123],"The":[124],"effectiveness":[125],"is":[129],"improved":[130],"by":[131,206],"(1)":[132],"splitting":[133],"task":[136],"into":[137],"context-free":[139],"context-sensitive":[142],"part,":[143],"(2)":[145],"reusing":[146],"mechanism":[149],"resolve":[151],"dependencies.":[153],"yields":[156],"any":[160],"specification.":[162],"Compared":[163],"non-incremental":[165],"parallel":[166],"execution,":[167],"achieve":[169],"speedups":[170],"up":[171,178],"147x":[173],"on":[174,181],"synthetic":[175],"benchmarks,":[176],"21x":[180],"real-world":[182],"projects,":[183],"initial":[185],"overheads":[186],"below":[187],"10%.":[188],"suggests":[190],"our":[192],"framework":[193],"efficient":[196],"wide":[201],"range":[202],"languages":[204],"supported":[205],"Statix.":[207]},"counts_by_year":[{"year":2025,"cited_by_count":2},{"year":2024,"cited_by_count":1}],"updated_date":"2026-03-10T16:38:18.471706","created_date":"2025-10-10T00:00:00"}
