Skip to Main content Skip to Navigation
Theses

PARAMETRIC POLYMORPHISM FOR XML PROCESSING LANGUAGES

Zhiwu Xu 1
1 PL
PPS - Preuves, Programmes et Systèmes
Abstract : XML (eXtensible Markup Language) is a current standard format for exchanging semi-structured data, which has been applied to web services, database, research on formal methods, and so on. For a better processing of XML, recently there emerge many statically typed functional languages, such as XDuce, CDuce, XJ, XTatic, XACT, XHaskell, OCamlDuce and so on. But most of these languages lack parametric polymorphism or present it in a limited form. While parametric polymorphism is needed by XML processing, and it has repeatedly been requested to and discussed in various working groups of standards (e.g., RELAX NG and XQuery). We study in this thesis the techniques to extend parametric polymorphism into XML processing languages. Our solution consists of two parts: a definition of a polymorphic semantic subtyping relation and a definition of a polymorphic calculus. In the first part, we define and study a polymorphic semantic subtyping relation for a type system with recursive, product and arrow types and set-theoretic type connectives (i.e., union, intersection and negation). We introduce the notion of "convexity" on which our solution is built up and prove there exists at least one model that satisfies convexity. We also propose a sound, complete and decidable subtyping algorithm. The second part is devoted to the theoretical definition of a polymorphic calculus, which takes advance of the subtyping relation. The novelty of the polymorphic calculus is to decorate lambda-abstractions with sets of type-substitutions and to lazily propagate type-substitutions at the moment of the reduction. The second part also explores a semi-decidable local inference algorithm to infer the set of type substitutions as well as the compilation of the polymorphic calculus into a variety of CDuce.
Document type :
Theses
Complete list of metadatas

Cited literature [74 references]  Display  Hide  Download

https://tel.archives-ouvertes.fr/tel-00858744
Contributor : Zhiwu Xu <>
Submitted on : Friday, September 6, 2013 - 6:42:16 AM
Last modification on : Saturday, March 28, 2020 - 2:17:54 AM
Long-term archiving on: : Saturday, December 7, 2013 - 4:16:04 AM

Identifiers

  • HAL Id : tel-00858744, version 1

Collections

Citation

Zhiwu Xu. PARAMETRIC POLYMORPHISM FOR XML PROCESSING LANGUAGES. Programming Languages [cs.PL]. Université Paris-Diderot - Paris VII, 2013. English. ⟨tel-00858744⟩

Share

Metrics

Record views

583

Files downloads

642