{"id":"https://openalex.org/W4308643057","doi":"https://doi.org/10.1145/3540250.3559081","title":"Improving IDE code inspections with tree automata","display_name":"Improving IDE code inspections with tree automata","publication_year":2022,"publication_date":"2022-11-07","ids":{"openalex":"https://openalex.org/W4308643057","doi":"https://doi.org/10.1145/3540250.3559081"},"language":"en","primary_location":{"id":"doi:10.1145/3540250.3559081","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3540250.3559081","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3540250.3559081","source":{"id":"https://openalex.org/S4363608883","display_name":"Proceedings of the 30th ACM Joint European Software Engineering Conference and Symposium on the Foundations of Software Engineering","issn_l":null,"issn":null,"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":"conference"},"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 30th ACM Joint European Software Engineering Conference and Symposium on the Foundations of Software Engineering","raw_type":"proceedings-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"hybrid","oa_url":"https://dl.acm.org/doi/pdf/10.1145/3540250.3559081","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5101697978","display_name":"Yun-Jeong Lee","orcid":null},"institutions":[{"id":"https://openalex.org/I165932596","display_name":"National University of Singapore","ror":"https://ror.org/01tgyzw49","country_code":"SG","type":"education","lineage":["https://openalex.org/I165932596"]}],"countries":["SG"],"is_corresponding":true,"raw_author_name":"Yunjeong Lee","raw_affiliation_strings":["National University of Singapore, Singapore"],"affiliations":[{"raw_affiliation_string":"National University of Singapore, Singapore","institution_ids":["https://openalex.org/I165932596"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":1,"corresponding_author_ids":["https://openalex.org/A5101697978"],"corresponding_institution_ids":["https://openalex.org/I165932596"],"apc_list":null,"apc_paid":null,"fwci":0.0,"has_fulltext":true,"cited_by_count":0,"citation_normalized_percentile":{"value":0.18938515,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":null,"biblio":{"volume":null,"issue":null,"first_page":"1814","last_page":"1815"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10260","display_name":"Software Engineering Research","score":0.9998999834060669,"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.9998999834060669,"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/T10743","display_name":"Software Testing and Debugging Techniques","score":0.9990000128746033,"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"}},{"id":"https://openalex.org/T11450","display_name":"Model-Driven Software Engineering Techniques","score":0.9951000213623047,"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/code-refactoring","display_name":"Code refactoring","score":0.8532028794288635},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8286857604980469},{"id":"https://openalex.org/keywords/codebase","display_name":"Codebase","score":0.7458879947662354},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6924931406974792},{"id":"https://openalex.org/keywords/code","display_name":"Code (set theory)","score":0.6316905617713928},{"id":"https://openalex.org/keywords/heuristics","display_name":"Heuristics","score":0.5828258991241455},{"id":"https://openalex.org/keywords/data-flow-analysis","display_name":"Data-flow analysis","score":0.5272366404533386},{"id":"https://openalex.org/keywords/tree","display_name":"Tree (set theory)","score":0.5131867527961731},{"id":"https://openalex.org/keywords/code-review","display_name":"Code review","score":0.5056948661804199},{"id":"https://openalex.org/keywords/set","display_name":"Set (abstract data type)","score":0.47722700238227844},{"id":"https://openalex.org/keywords/automaton","display_name":"Automaton","score":0.4656442403793335},{"id":"https://openalex.org/keywords/static-analysis","display_name":"Static analysis","score":0.45560070872306824},{"id":"https://openalex.org/keywords/source-code","display_name":"Source code","score":0.453940212726593},{"id":"https://openalex.org/keywords/static-program-analysis","display_name":"Static program analysis","score":0.42227593064308167},{"id":"https://openalex.org/keywords/data-flow-diagram","display_name":"Data flow diagram","score":0.4069671630859375},{"id":"https://openalex.org/keywords/database","display_name":"Database","score":0.282311350107193},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.2315056324005127},{"id":"https://openalex.org/keywords/operating-system","display_name":"Operating system","score":0.20918065309524536},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.20600679516792297},{"id":"https://openalex.org/keywords/software-development","display_name":"Software development","score":0.17190736532211304}],"concepts":[{"id":"https://openalex.org/C152752567","wikidata":"https://www.wikidata.org/wiki/Q116877","display_name":"Code refactoring","level":3,"score":0.8532028794288635},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8286857604980469},{"id":"https://openalex.org/C51929080","wikidata":"https://www.wikidata.org/wiki/Q2425187","display_name":"Codebase","level":3,"score":0.7458879947662354},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6924931406974792},{"id":"https://openalex.org/C2776760102","wikidata":"https://www.wikidata.org/wiki/Q5139990","display_name":"Code (set theory)","level":3,"score":0.6316905617713928},{"id":"https://openalex.org/C127705205","wikidata":"https://www.wikidata.org/wiki/Q5748245","display_name":"Heuristics","level":2,"score":0.5828258991241455},{"id":"https://openalex.org/C88468194","wikidata":"https://www.wikidata.org/wiki/Q1172416","display_name":"Data-flow analysis","level":3,"score":0.5272366404533386},{"id":"https://openalex.org/C113174947","wikidata":"https://www.wikidata.org/wiki/Q2859736","display_name":"Tree (set theory)","level":2,"score":0.5131867527961731},{"id":"https://openalex.org/C150292731","wikidata":"https://www.wikidata.org/wiki/Q1342704","display_name":"Code review","level":5,"score":0.5056948661804199},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.47722700238227844},{"id":"https://openalex.org/C112505250","wikidata":"https://www.wikidata.org/wiki/Q787116","display_name":"Automaton","level":2,"score":0.4656442403793335},{"id":"https://openalex.org/C97686452","wikidata":"https://www.wikidata.org/wiki/Q7604153","display_name":"Static analysis","level":2,"score":0.45560070872306824},{"id":"https://openalex.org/C43126263","wikidata":"https://www.wikidata.org/wiki/Q128751","display_name":"Source code","level":2,"score":0.453940212726593},{"id":"https://openalex.org/C137287247","wikidata":"https://www.wikidata.org/wiki/Q1329550","display_name":"Static program analysis","level":4,"score":0.42227593064308167},{"id":"https://openalex.org/C489000","wikidata":"https://www.wikidata.org/wiki/Q747385","display_name":"Data flow diagram","level":2,"score":0.4069671630859375},{"id":"https://openalex.org/C77088390","wikidata":"https://www.wikidata.org/wiki/Q8513","display_name":"Database","level":1,"score":0.282311350107193},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.2315056324005127},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.20918065309524536},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.20600679516792297},{"id":"https://openalex.org/C529173508","wikidata":"https://www.wikidata.org/wiki/Q638608","display_name":"Software development","level":3,"score":0.17190736532211304},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.0},{"id":"https://openalex.org/C134306372","wikidata":"https://www.wikidata.org/wiki/Q7754","display_name":"Mathematical analysis","level":1,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/3540250.3559081","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3540250.3559081","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3540250.3559081","source":{"id":"https://openalex.org/S4363608883","display_name":"Proceedings of the 30th ACM Joint European Software Engineering Conference and Symposium on the Foundations of Software Engineering","issn_l":null,"issn":null,"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":"conference"},"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 30th ACM Joint European Software Engineering Conference and Symposium on the Foundations of Software Engineering","raw_type":"proceedings-article"}],"best_oa_location":{"id":"doi:10.1145/3540250.3559081","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3540250.3559081","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3540250.3559081","source":{"id":"https://openalex.org/S4363608883","display_name":"Proceedings of the 30th ACM Joint European Software Engineering Conference and Symposium on the Foundations of Software Engineering","issn_l":null,"issn":null,"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":"conference"},"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 30th ACM Joint European Software Engineering Conference and Symposium on the Foundations of Software Engineering","raw_type":"proceedings-article"},"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":true,"pdf":true},"content_urls":{"pdf":"https://content.openalex.org/works/W4308643057.pdf","grobid_xml":"https://content.openalex.org/works/W4308643057.grobid-xml"},"referenced_works_count":5,"referenced_works":["https://openalex.org/W1568320863","https://openalex.org/W1856962451","https://openalex.org/W2731197199","https://openalex.org/W2761696525","https://openalex.org/W6723284578"],"related_works":["https://openalex.org/W3194341934","https://openalex.org/W656101134","https://openalex.org/W2969257295","https://openalex.org/W167779242","https://openalex.org/W2159712408","https://openalex.org/W2140368099","https://openalex.org/W2151229769","https://openalex.org/W2155919214","https://openalex.org/W3176933264","https://openalex.org/W1486326303"],"abstract_inverted_index":{"Integrated":[0],"development":[1],"environments":[2],"(IDEs)":[3],"are":[4,41,50,67],"equipped":[5],"with":[6,111],"code":[7,16,32,38,101,154],"inspections":[8,33],"to":[9,45,78,94,131],"warn":[10],"developers":[11],"of":[12,59,76,114],"malformed":[13],"or":[14,66],"incorrect":[15],"by":[17,29],"analyzing":[18],"the":[19,24,30,56,62,79,100,103,107,115],"code's":[20],"data":[21,25,80],"flow.":[22],"However,":[23],"flow":[26,81],"analysis":[27],"performed":[28],"IDE":[31,126,150],"may":[34],"issue":[35],"warnings":[36,40,49,60,97],"in":[37,61,98,124,134,148],"where":[39],"irrelevant.":[42],"Existing":[43],"methods":[44],"prevent":[46],"any":[47],"bogus":[48,96],"either":[51],"too":[52],"conservative":[53],"---":[54,65],"suppressing":[55],"same":[57,104],"type":[58],"entire":[63],"codebase":[64],"not":[68],"sustainable":[69],"as":[70,106,153],"they":[71],"require":[72],"adding":[73],"a":[74,85,112,132,135],"set":[75],"heuristics":[77],"analysis.":[82],"We":[83],"propose":[84],"programming-by-example":[86],"(PBE)":[87],"framework":[88,116],"that":[89,118],"synthesizes":[90],"tree":[91],"automata":[92],"(TAs)":[93],"suppress":[95],"all":[99],"containing":[102],"patterns":[105,121],"user-provided":[108],"examples.":[109],"Experiments":[110],"prototype":[113],"demonstrate":[117],"several":[119],"real-world":[120],"heuristically":[122],"suppressed":[123],"production":[125],"can":[127,145],"be":[128,146],"mechanically":[129],"translated":[130],"TA":[133],"systematic":[136],"way.":[137],"Furthermore,":[138],"we":[139],"briefly":[140],"discuss":[141],"how":[142],"TA-based":[143],"solution":[144],"useful":[147],"other":[149],"features":[151],"such":[152],"refactoring.":[155]},"counts_by_year":[],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
