{"id":"https://openalex.org/W3207026105","doi":"https://doi.org/10.1145/3485522","title":"Modular specification and verification of closures in Rust","display_name":"Modular specification and verification of closures in Rust","publication_year":2021,"publication_date":"2021-10-15","ids":{"openalex":"https://openalex.org/W3207026105","doi":"https://doi.org/10.1145/3485522","mag":"3207026105"},"language":"en","primary_location":{"id":"doi:10.1145/3485522","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3485522","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3485522","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","datacite"],"open_access":{"is_oa":true,"oa_status":"diamond","oa_url":"https://dl.acm.org/doi/pdf/10.1145/3485522","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5057365170","display_name":"Fabian Wolff","orcid":null},"institutions":[{"id":"https://openalex.org/I35440088","display_name":"ETH Zurich","ror":"https://ror.org/05a28rw58","country_code":"CH","type":"education","lineage":["https://openalex.org/I2799323385","https://openalex.org/I35440088"]}],"countries":["CH"],"is_corresponding":true,"raw_author_name":"Fabian Wolff","raw_affiliation_strings":["ETH Zurich, Switzerland"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"ETH Zurich, Switzerland","institution_ids":["https://openalex.org/I35440088"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5041305763","display_name":"Aurel B\u00edl\u00fd","orcid":"https://orcid.org/0000-0002-9284-9161"},"institutions":[{"id":"https://openalex.org/I35440088","display_name":"ETH Zurich","ror":"https://ror.org/05a28rw58","country_code":"CH","type":"education","lineage":["https://openalex.org/I2799323385","https://openalex.org/I35440088"]}],"countries":["CH"],"is_corresponding":false,"raw_author_name":"Aurel B\u00edl\u00fd","raw_affiliation_strings":["ETH Zurich, Switzerland"],"raw_orcid":"https://orcid.org/0000-0002-9284-9161","affiliations":[{"raw_affiliation_string":"ETH Zurich, Switzerland","institution_ids":["https://openalex.org/I35440088"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5089189715","display_name":"Christoph Matheja","orcid":"https://orcid.org/0000-0001-9151-0441"},"institutions":[{"id":"https://openalex.org/I35440088","display_name":"ETH Zurich","ror":"https://ror.org/05a28rw58","country_code":"CH","type":"education","lineage":["https://openalex.org/I2799323385","https://openalex.org/I35440088"]}],"countries":["CH"],"is_corresponding":false,"raw_author_name":"Christoph Matheja","raw_affiliation_strings":["ETH Zurich, Switzerland"],"raw_orcid":"https://orcid.org/0000-0001-9151-0441","affiliations":[{"raw_affiliation_string":"ETH Zurich, Switzerland","institution_ids":["https://openalex.org/I35440088"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5073853337","display_name":"P\u00e9ter M\u00fcller","orcid":"https://orcid.org/0000-0001-7001-2566"},"institutions":[{"id":"https://openalex.org/I35440088","display_name":"ETH Zurich","ror":"https://ror.org/05a28rw58","country_code":"CH","type":"education","lineage":["https://openalex.org/I2799323385","https://openalex.org/I35440088"]}],"countries":["CH"],"is_corresponding":false,"raw_author_name":"Peter M\u00fcller","raw_affiliation_strings":["ETH Zurich, Switzerland"],"raw_orcid":"https://orcid.org/0000-0001-7001-2566","affiliations":[{"raw_affiliation_string":"ETH Zurich, Switzerland","institution_ids":["https://openalex.org/I35440088"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5080556886","display_name":"Alexander J. Summers","orcid":"https://orcid.org/0000-0001-5554-9381"},"institutions":[{"id":"https://openalex.org/I141945490","display_name":"University of British Columbia","ror":"https://ror.org/03rmrcq20","country_code":"CA","type":"education","lineage":["https://openalex.org/I141945490"]}],"countries":["CA"],"is_corresponding":false,"raw_author_name":"Alexander J. Summers","raw_affiliation_strings":["University of British Columbia, Canada"],"raw_orcid":"https://orcid.org/0000-0001-5554-9381","affiliations":[{"raw_affiliation_string":"University of British Columbia, Canada","institution_ids":["https://openalex.org/I141945490"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":5,"corresponding_author_ids":["https://openalex.org/A5057365170"],"corresponding_institution_ids":["https://openalex.org/I35440088"],"apc_list":null,"apc_paid":null,"fwci":2.6597,"has_fulltext":true,"cited_by_count":23,"citation_normalized_percentile":{"value":0.91694459,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":96,"max":99},"biblio":{"volume":"5","issue":"OOPSLA","first_page":"1","last_page":"29"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10126","display_name":"Logic, programming, and type systems","score":0.9998000264167786,"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/T10126","display_name":"Logic, programming, and type systems","score":0.9998000264167786,"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/T10142","display_name":"Formal Methods in Verification","score":0.9995999932289124,"subfield":{"id":"https://openalex.org/subfields/1703","display_name":"Computational Theory and Mathematics"},"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/T10743","display_name":"Software Testing and Debugging Techniques","score":0.9983999729156494,"subfield":{"id":"https://openalex.org/subfields/1712","display_name":"Software"},"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/programming-language","display_name":"Programming language","score":0.7863923907279968},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.7717905640602112},{"id":"https://openalex.org/keywords/modular-design","display_name":"Modular design","score":0.6549540162086487},{"id":"https://openalex.org/keywords/closure","display_name":"Closure (psychology)","score":0.6152434349060059},{"id":"https://openalex.org/keywords/formal-verification","display_name":"Formal verification","score":0.46098193526268005},{"id":"https://openalex.org/keywords/rust","display_name":"Rust (programming language)","score":0.45457926392555237},{"id":"https://openalex.org/keywords/code","display_name":"Code (set theory)","score":0.43249616026878357},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.35330531001091003}],"concepts":[{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.7863923907279968},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7717905640602112},{"id":"https://openalex.org/C101468663","wikidata":"https://www.wikidata.org/wiki/Q1620158","display_name":"Modular design","level":2,"score":0.6549540162086487},{"id":"https://openalex.org/C146834321","wikidata":"https://www.wikidata.org/wiki/Q2979672","display_name":"Closure (psychology)","level":2,"score":0.6152434349060059},{"id":"https://openalex.org/C111498074","wikidata":"https://www.wikidata.org/wiki/Q173326","display_name":"Formal verification","level":2,"score":0.46098193526268005},{"id":"https://openalex.org/C197781089","wikidata":"https://www.wikidata.org/wiki/Q575650","display_name":"Rust (programming language)","level":2,"score":0.45457926392555237},{"id":"https://openalex.org/C2776760102","wikidata":"https://www.wikidata.org/wiki/Q5139990","display_name":"Code (set theory)","level":3,"score":0.43249616026878357},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.35330531001091003},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.0},{"id":"https://openalex.org/C162324750","wikidata":"https://www.wikidata.org/wiki/Q8134","display_name":"Economics","level":0,"score":0.0},{"id":"https://openalex.org/C34447519","wikidata":"https://www.wikidata.org/wiki/Q179522","display_name":"Market economy","level":1,"score":0.0}],"mesh":[],"locations_count":3,"locations":[{"id":"doi:10.1145/3485522","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3485522","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3485522","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:www.research-collection.ethz.ch:20.500.11850/512454","is_oa":true,"landing_page_url":"http://hdl.handle.net/20.500.11850/512454","pdf_url":null,"source":{"id":"https://openalex.org/S4306402302","display_name":"Repository for Publications and Research Data (ETH Zurich)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I35440088","host_organization_name":"ETH Zurich","host_organization_lineage":["https://openalex.org/I35440088"],"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":"Proceedings of the ACM on Programming Languages, 5 (OOPSLA)","raw_type":"info:eu-repo/semantics/conferenceObject"},{"id":"doi:10.3929/ethz-b-000512454","is_oa":true,"landing_page_url":"https://doi.org/10.3929/ethz-b-000512454","pdf_url":null,"source":{"id":"https://openalex.org/S7407051236","display_name":"ETH Z\u00fcrich Research Collection","issn_l":null,"issn":[],"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"repository"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":null,"is_accepted":false,"is_published":null,"raw_source_name":null,"raw_type":"article-journal"}],"best_oa_location":{"id":"doi:10.1145/3485522","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3485522","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3485522","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":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W3207026105.pdf","grobid_xml":"https://content.openalex.org/works/W3207026105.grobid-xml"},"referenced_works_count":38,"referenced_works":["https://openalex.org/W1480522639","https://openalex.org/W1495368328","https://openalex.org/W1505565262","https://openalex.org/W1519921373","https://openalex.org/W1552077729","https://openalex.org/W1553421328","https://openalex.org/W1565541828","https://openalex.org/W1571072431","https://openalex.org/W1590844387","https://openalex.org/W1606177908","https://openalex.org/W1788459607","https://openalex.org/W1807498156","https://openalex.org/W1827297117","https://openalex.org/W1965109565","https://openalex.org/W1979191543","https://openalex.org/W1990409169","https://openalex.org/W1995008247","https://openalex.org/W2044507549","https://openalex.org/W2074285438","https://openalex.org/W2113757735","https://openalex.org/W2128303158","https://openalex.org/W2130427425","https://openalex.org/W2294722445","https://openalex.org/W2764146461","https://openalex.org/W2913530642","https://openalex.org/W3031966213","https://openalex.org/W3039784053","https://openalex.org/W3092351997","https://openalex.org/W3099830904","https://openalex.org/W3109383821","https://openalex.org/W3211574141","https://openalex.org/W4211017683","https://openalex.org/W4211125366","https://openalex.org/W4241006348","https://openalex.org/W4241892188","https://openalex.org/W4245524452","https://openalex.org/W4247510043","https://openalex.org/W6893873908"],"related_works":["https://openalex.org/W315394019","https://openalex.org/W2923398117","https://openalex.org/W4309585848","https://openalex.org/W2265383332","https://openalex.org/W4328130279","https://openalex.org/W4313657047","https://openalex.org/W2002342158","https://openalex.org/W2378076731","https://openalex.org/W2105009749","https://openalex.org/W4299387245"],"abstract_inverted_index":{"Closures":[0,33],"are":[1,34],"a":[2,61,99],"language":[3],"feature":[4],"supported":[5],"by":[6],"many":[7,126],"mainstream":[8],"languages,":[9],"combining":[10],"the":[11,21,27,30,51,65,116],"ability":[12],"to":[13,17,86],"package":[14],"up":[15],"references":[16],"code":[18,72],"blocks":[19],"with":[20,120],"possibility":[22],"of":[23,29,70,90,115,129],"capturing":[24],"state":[25,53],"from":[26,50,55],"environment":[28],"closure's":[31],"declaration.":[32],"powerful,":[35],"but":[36],"complicate":[37],"understanding":[38],"and":[39,68,82],"formal":[40,88],"reasoning,":[41],"especially":[42],"when":[43],"closure":[44,56,130],"invocations":[45],"may":[46],"mutate":[47],"objects":[48],"reachable":[49],"captured":[52],"or":[54],"arguments.":[57],"This":[58],"paper":[59],"presents":[60],"novel":[62,83],"technique":[63,76,109],"for":[64],"modular":[66],"specification":[67,84],"verification":[69,89],"closure-manipulating":[71],"in":[73],"Rust.":[74],"Our":[75,108],"combines":[77],"Rust's":[78],"type":[79],"system":[80],"guarantees":[81],"features":[85],"enable":[87],"rich":[91],"functional":[92],"properties.":[93],"It":[94],"encodes":[95],"higher-order":[96],"concerns":[97],"into":[98],"first-order":[100],"logic,":[101],"which":[102,121],"enables":[103],"automation":[104],"via":[105],"SMT":[106],"solvers.":[107],"is":[110],"implemented":[111],"as":[112],"an":[113],"extension":[114],"deductive":[117],"verifier":[118],"Prusti,":[119],"we":[122],"have":[123],"successfully":[124],"verified":[125],"common":[127],"idioms":[128],"usage.":[131]},"counts_by_year":[{"year":2026,"cited_by_count":1},{"year":2025,"cited_by_count":3},{"year":2024,"cited_by_count":8},{"year":2023,"cited_by_count":5},{"year":2022,"cited_by_count":6}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
