Publication | Closed Access
Type checking higher-order polymorphic multi-methods
71
Citations
26
References
1997
Year
Unknown Venue
Ml≤ Type SystemEngineeringGeneric ProgrammingAutomated ReasoningProgram AnalysisType TheoryVerificationPolymorphism (Computer Science)Formal MethodsSoftware AnalysisDependently Typed ProgrammingHigher-order Polymorphic Multi-methodsComputer ScienceDecidable Type SystemType SystemParametric PolymorphismFormal Verification
We present a new predicative and decidable type system, called ML≤, suitable for languages that integrate functional programming and parametric polymorphism in the tradition of ML [21, 28], and class-based object-oriented programming and higher-order multimethods in the tradition of CLOS [12]. Instead of using extensible records as a foundation for object-oriented extensions of functional languages, we propose to reinterpret ML datatype declarations as abstract and concrete class declarations, and to replace pattern matching on run-time values by dynamic dispatch on run-time types. ML≤ is based on universally quantified polymorphic constrained types. Constraints are conjunctions of inequalities between monotypes built from type constructors organized into extensible and partially ordered classes. We give type checking rules for a small, explicitly typed functional language á la XML [20] with multi-methods, show that the resulting system has decidable minimal types, and discuss subject reduction. Finally, we propose a new object-oriented programming language based on the ML≤ type system.
| Year | Citations | |
|---|---|---|
Page 1
Page 1