• Media type: E-Article
  • Title: Type inference for unique pattern matching
  • Contributor: Vansummeren, Stijn
  • Published: Association for Computing Machinery (ACM), 2006
  • Published in: ACM Transactions on Programming Languages and Systems, 28 (2006) 3, Seite 389-428
  • Language: English
  • DOI: 10.1145/1133651.1133652
  • ISSN: 0164-0925; 1558-4593
  • Keywords: Software
  • Origination:
  • Footnote:
  • Description: Regular expression patterns provide a natural, declarative way to express constraints on semistructured data and to extract relevant information from it. Indeed, it is a core feature of the programming language Perl, surfaces in various UNIX tools such as sed and awk, and has recently been proposed in the context of the XML programming language XDuce. Since regular expressions can be ambiguous in general, different disambiguation policies have been proposed to get a unique matching strategy. We formally define the matching semantics under both (1) the POSIX, and (2) the first and longest match disambiguation strategies. We show that the generally accepted method of defining the longest match in terms of the first match and recursion does not conform to the natural notion of longest match. We continue by solving the type inference problem for both disambiguation strategies, which consists of calculating the set of all subparts of input values a subexpression can match under the given policy.