Practical Type Inference for the GADT Type System

Total Page:16

File Type:pdf, Size:1020Kb

Practical Type Inference for the GADT Type System View metadata, citation and similar papers at core.ac.uk brought to you by CORE provided by PDXScholar Portland State University PDXScholar Dissertations and Theses Dissertations and Theses 1-1-2010 Practical Type Inference for the GADT Type System Chuan-kai Lin Portland State University Follow this and additional works at: https://pdxscholar.library.pdx.edu/open_access_etds Let us know how access to this document benefits ou.y Recommended Citation Lin, Chuan-kai, "Practical Type Inference for the GADT Type System" (2010). Dissertations and Theses. Paper 367. 10.15760/etd.367 This Dissertation is brought to you for free and open access. It has been accepted for inclusion in Dissertations and Theses by an authorized administrator of PDXScholar. For more information, please contact [email protected]. Practical Type Inference for the GADT Type System by Chuan-kai Lin A dissertation submitted in partial fulfillment of the requirements for the degree of Doctor of Philosophy in Computer Science Dissertation Committee: Tim Sheard, Chair Andrew P. Black James Hook Mark P. Jones Andrew Tolmach Douglas V. Hall Portland State University © 2010 i ABSTRACT Generalized algebraic data types (GADTs) are a type system extension to alge- braic data types that allows the type of an algebraic data value to vary with its shape. The GADT type system allows programmers to express detailed program properties as types (for example, that a function should return a list of the same length as its input), and a general-purpose type checker will automatically check those properties at compile time. Type inference for the GADT type system and the properties of the type system are both currently areas of active research. In this dissertation, I attack both problems simultaneously by exploiting the symbiosis between type system research and type inference research. Deficiencies of GADT type inference algorithms motivate research on specific aspects of the type system, and discoveries about the type system bring in new insights that lead to improved GADT type inference algorithms. The technical contributions of this dissertation are therefore twofold: in addition to new GADT type system properties (such as the prevalence of pointwise type information flow in GADT patterns, a generalized notion of existential types, and the effects of enforcing the GADT branch reachability requirement), I will also present a new GADT type inference algorithm that is significantly more powerful than existing algorithms. These contributions should help programmers use the GADT type system more effectively, and they should also enable language implementers to provide better support for the GADT type system. ii DEDICATION To my wife Hwa-yi, Who, like Powdermilk Biscuits, Gives me the strength to get up And do what needs to be done. iii ACKNOWLEDGMENTS The work I present in this dissertation is entirely my own, but I could not have done it without the assistance and support of many others. I would like to take this opportunity to express my everlasting gratitude. Tim Sheard is a wonderful advisor. He believes that students should be free to pursue their own interests, and his support was invaluable during the difficult period when I kept digging and nothing turned up. We do not always agree on technical issues, but, after giving me his honest opinion, he always let me take the research in the direction of my choosing. He has a real talent for identifying important ideas, and we spent many hours sitting in his office trying to find the key sentence that was left unsaid in my confused writing. He worked as hard as I did in the months leading up to my defense, reading and marking up drafts at an incredible pace. I hope the end result makes him proud. Andrew P. Black took me under his wings when I first started my graduate studies and taught me how to do research. I still remember when he told me \Chuan-kai, you stuttered because you put too many words on your slides, and you were having trouble finding different words to say the same things." That was quite a revelation. The members of my dissertation committee | James Hook, Mark P. Jones, and Andrew Tolmach | worked diligently to help me improve this dissertation. Aaron Stump and Dimitrios Vytiniotis also provided useful feedback on a draft. This dissertation would certainly be a lot poorer without their insight. iv I feel extremely lucky to have shared a cubicle with Emerson Murphy-Hill during pretty much the entirety of his doctoral studies. His can-do spirit and un- orthodox wit are positively contagious, and his generous and engaging personality inspired me to be a better person. I am proud and honored to call Emerson my friend, and I spend much time wondering how much better the world would be if only there are more people like him. I met Nancy Murphy when Emerson invited me to his family Thanksgiving gathering in 2004. She treats me like her own child, and her home becomes my favorite sanctuary whenever I feel weary and discouraged. She gave me a family in this foreign land, which, because of her, is now a much less foreign place with very many happy memories. I am indebted to my parents in many different ways. Though they rarely knew what I was up to (or so I thought), they always supported my interests and my decisions without reservation. It was only with their support that I had an opportunity to develop my interests in computer science and to pursue graduate studies in the United States. Thanks Mom and Dad. I love you. Above all, I want to thank my wife Hwa-yi Tang for her love, sacrifice, and encouragement. Maintaining a long-distance relationship takes a lot of hard work, but she took it in stride because she knows how much I love research. She makes my life complete and gives me the strength to do what needs to be done. Academic research relies on the support of a stable, mature, and resourceful society, and I feel privileged to enjoy such support. Many people before me have worked hard to make the world a better place, and, one way or the other, they all contributed to the birth of this dissertation. Seven years. It was an amazing adventure, and I treasure every moment of it. v CONTENTS Abstract ::::::::::::::::::::::::::::::::::::: i Dedication :::::::::::::::::::::::::::::::::::: ii Acknowledgments ::::::::::::::::::::::::::::::: iii List of Figures ::::::::::::::::::::::::::::::::: ix 1 Introduction ::::::::::::::::::::::::::::::::: 1 1.1 Type Systems . .1 1.2 Type System Incompleteness . .5 1.3 Generalized Algebraic Data Types . 10 1.4 Type Inference . 12 1.5 Technical Challenges . 14 1.6 Contributions . 15 1.7 Outline . 16 2 Background ::::::::::::::::::::::::::::::::: 19 2.1 Notation and Syntax . 19 2.2 Algebraic Data Types . 22 2.2.1 Constructing algebraic data . 23 2.2.2 Destructing algebraic data . 25 2.2.3 Type system . 26 2.3 Generalized Algebraic Data Types . 30 2.3.1 Previous work . 31 2.3.2 Features . 33 2.3.3 Type system . 37 2.4 Inference for the GADT Type System . 40 2.4.1 Technical challenges . 40 2.4.2 Computational decidability . 43 2.4.3 Previous work . 44 vi 2.5 Types in GADT Pattern-Matching Branches . 48 2.5.1 Identifying attributes . 49 2.5.2 Decomposing ALT-GADT . 50 2.5.3 Symmetry in type roles . 52 3 The Pointwise GADT Type System :::::::::::::::::: 57 3.1 Types in GADT Patterns . 57 3.1.1 Pointwise type information flow . 57 3.1.2 Unrestricted type information flow . 61 3.2 Type System . 66 3.2.1 Pointwise unifiers . 66 3.2.2 Pointwise unification . 74 3.2.3 Formal definition . 79 3.3 Expressiveness . 81 3.3.1 Case studies . 81 3.3.2 Rejected programs . 83 3.3.3 Workarounds . 89 3.4 Summary . 90 4 The Non-Dependent GADT Type System :::::::::::::: 92 4.1 GADT without Type Refinements . 92 4.1.1 Examples . 93 4.1.2 Type inference testing . 95 4.1.3 Type system . 98 4.2 Generalizing Existential Types . 101 4.2.1 Existential types . 102 4.2.2 Generalized existential types . 103 4.2.3 Inferring scrutinee types . 113 4.3 Summary . 117 5 Simplifications to Complications :::::::::::::::::::: 119 5.1 GADT Branch Reachability Requirement . 120 5.1.1 GADT and branch reachability . 120 5.1.2 Restricting reachability enforcement . 124 5.1.3 Consequences of enforcing reachability . 128 5.1.4 Type inference . 130 5.2 Pointwise Branch Reachability . 133 vii 5.2.1 Not pointwise, but unifiable . 133 5.2.2 Interaction with let expressions . 138 5.2.3 Type inference . 142 5.3 Nested Non-Dependent GADT Branches . 143 5.4 Summary . 147 6 GADT Type Inference with Algorithm P :::::::::::::: 149 6.1 Overall Structure . 149 6.1.1 Foundation . 150 6.1.2 Compositionality . 153 6.1.3 Branch reachability . 156 6.2 Branch Type Inference . 159 6.2.1 Single-branch type inference . 162 6.2.2 Scrutinee-type specialization . 165 6.3 GADT Type Refinements . 170 6.3.1 Tabulating branch types . 171 6.3.2 Applying type refinements . 174 6.4 Summary . 183 7 Algorithm P by Example ::::::::::::::::::::::::: 185 7.1 Algorithm Implementation . 186 7.2 Non-Dependent Programs . 189 7.2.1 Type refinement aversion . 190 7.2.2 Type equality witnesses . 191 7.2.3 Generalized existential types . 194 7.3 GADT Type Refinements . 195 7.3.1 Generalized existential type escape . 196 7.3.2 Contextual type information . 197 7.3.3 Opposable thumbs . 199 7.4 Polymorphic Recursion . 201 7.5 Algorithm Limitations . 206 7.5.1 Local type reconciliation . 208 7.5.2 Compositionality . 211 7.5.3 Lack of backtracking search .
Recommended publications
  • A Model of Inheritance for Declarative Visual Programming Languages
    An Abstract Of The Dissertation Of Rebecca Djang for the degree of Doctor of Philosophy in Computer Science presented on December 17, 1998. Title: Similarity Inheritance: A Model of Inheritance for Declarative Visual Programming Languages. Abstract approved: Margaret M. Burnett Declarative visual programming languages (VPLs), including spreadsheets, make up a large portion of both research and commercial VPLs. Spreadsheets in particular enjoy a wide audience, including end users. Unfortunately, spreadsheets and most other declarative VPLs still suffer from some of the problems that have been solved in other languages, such as ad-hoc (cut-and-paste) reuse of code which has been remedied in object-oriented languages, for example, through the code-reuse mechanism of inheritance. We believe spreadsheets and other declarative VPLs can benefit from the addition of an inheritance-like mechanism for fine-grained code reuse. This dissertation first examines the opportunities for supporting reuse inherent in declarative VPLs, and then introduces similarity inheritance and describes a prototype of this model in the research spreadsheet language Forms/3. Similarity inheritance is very flexible, allowing multiple granularities of code sharing and even mutual inheritance; it includes explicit representations of inherited code and all sharing relationships, and it subsumes the current spreadsheet mechanisms for formula propagation, providing a gradual migration from simple formula reuse to more sophisticated uses of inheritance among objects. Since the inheritance model separates inheritance from types, we investigate what notion of types is appropriate to support reuse of functions on different types (operation polymorphism). Because it is important to us that immediate feedback, which is characteristic of many VPLs, be preserved, including feedback with respect to type errors, we introduce a model of types suitable for static type inference in the presence of operation polymorphism with similarity inheritance.
    [Show full text]
  • Methodology Stereotypes
    UML/MARTE Methodology for Heterogeneous System design May, 2016 Microelectronics Engineering Group TEISA Dpt. , University of Cantabria Authors: P. Peñil Revisions : F. Herrera Author Date Description FeHe 26/05/2015 Polishing of the Architectural View section FeHe 28/05/2015 Polishing on the Application View section including some restructuring FeHe 25/06/2015 Polishing of section 5.3 FeHe 15/05/2016 Polishing of section 5.1 Index: 1 MODEL VIEW SPECIFICATION ....................................................... 11 PIM VIEWS .............................................................................................. 12 2 DATA VIEW ....................................................................................... 12 2.1 Enumeration Data type .................................................................................................... 12 2.2 Primitive Data type ........................................................................................................... 12 2.3 Derived Data type ............................................................................................................. 13 2.3.1 Structure Data type ................................................................................................... 13 2.3.2 Array Data type.......................................................................................................... 13 2.4 Specifying data types ........................................................................................................ 14 2.5 Generalization of DataTypes
    [Show full text]
  • Polymorphic Type Inference and Assignment
    Proc. 18th Symp. Principles of Programming Languages, 1991, pages 291{302. Polymorphic type inference and assignment Xavier Leroy¤ Pierre Weis¤ Ecole Normale Sup¶erieure INRIA Rocquencourt Abstract that physical modi¯cation of data compromises type safety, since it can invalidate static typing assumptions. We present a new approach to the polymorphic typing As demonstrated here, the use of polymorphic mu- of data accepting in-place modi¯cation in ML-like lan- table data (that is, data structures that can be mod- guages. This approach is based on restrictions over type i¯ed in place) must be restricted. An obvious way to generalization, and a re¯ned typing of functions. The tackle this problem, used in early implementations of type system given here leads to a better integration of ML [3], is to require all such data to have monomor- imperative programming style with the purely applica- phic, statically-known types. This restriction trivially tive kernel of ML. In particular, generic functions that solves the problem, but it also makes it impossible to allocate mutable data can safely be given fully polymor- write polymorphic functions that create mutable values. phic types. We show the soundness of this type system, This fact has unfortunate consequences. and give a type reconstruction algorithm. A ¯rst drawback is that it is not possible to provide generic, e±cient implementations of most data struc- tures (vectors, hash tables, graphs, B-trees, ::: ), as 1 Introduction they require physical modi¯cation. Even a trivial func- Polymorphic type disciplines originate in the study of ¸- tion such as taking a vector of an arbitrary type and calculus and its connections to constructive logic [7, 14], returning a copy of it is not well-typed with the policy so it is no surprise it ¯ts very nicely within purely above, since it creates a vector with a statically un- applicative languages, without side e®ects.
    [Show full text]
  • 1St Workshop on Refactoring Tools (WRT'07)
    Forschungsberichte der Fakultät IV – Elektrotechnik und Informatik 1st Workshop on Refactoring Tools (WRT'07) Proceedings July 31, 2007, TU Berlin, Germany Danny Dig, Michael Cebulla (Eds.) Bericht-Nr. 2007 – 8 ISSN 1436-9915 Table of Contents WRT’07 Organization …………………………………………………….v Proceedings …………………………………………………………………. • KABA: Automated Refactoring for Improved Cohesion ……………………..1 G. Snelting, M. Streckenbach (Universitat Passau) • Automation of Refactoring and Refactoring Suggestions for TTCN-3 Test Suites. The TRex TTCN-3 Refactoring and Metrics Tool ……………..…………3 H. Neukirchen, B. Zeiss (University of Gottingen) • A visual interface for type-related refactorings ……………………………….5 P. Mayer (Ludwig-Maximilians-Universität), A. Meißner (Fernuniversität in Hagen), F. Steimann (Fernuniversität in Hagen) • ITCORE: A Type Inference Package for Refactoring Tools …………………7 H. Kegel (ej-technologies GmbH), F. Steimann (Fernuniversität in Hagen) • Flexible Transformation Language …………………………………………….9 A. A. Santos, L. Menezes, and M. Cornélio (UPE) • A Refactoring Discovering Tool based on Graph Transformation …………11 J. Perez, Y. Crespo (Universidad de Valladolid) • Refactoring with Contracts ……………………………………………………13 Y. A. Feldman, M. Goldstein (IBM Haifa Research Lab), S. Tyszberowicz (The Academic College of Tel-Aviv Yaffo) • Synchronizing Refactored UML Class Diagrams and OCL Constraints ……………………………………………………………...15 S. Markovic, T. Baar (Ecole Polytechnique Federale de Lausanne) • Code Analyses for Refactoring by Source Code Patterns and Logical Queries ……………………………………………………...17 D. Speicher, M. Appeltauer, G. Kniesel (University of Bonn) • Reuse Based Refactoring Tools ………………………………………………..21 R. Marticorena, C. Lopez (University of Burgos), Y. Crespo, J. Perez (University of Valladolid) i • SORMASA: A tool for Suggesting Model Refactoring Actions by Metrics-led Genetic Algorithm ………………………………………….……..23 T. Bodhuin, G. Canfora, L. Troiano (University of Sannio) • Model-driven Software Refactoring …………………………………………..25 T.
    [Show full text]
  • Declared Type Generalization Checker: an Eclipse Plug-In for Systematic Programming with More General Types
    Declared Type Generalization Checker: An Eclipse Plug-In for Systematic Programming with More General Types Markus Bach, Florian Forster, and Friedrich Steimann Lehrgebiet Programmiersysteme Fernuniversität in Hagen D-58084 Hagen [email protected], [email protected], [email protected] Abstract. The Declared Type Generalization Checker is a plug-in for Eclipse’s Java Development Tools (JDT) that supports developers in systematically find- ing and using better fitting types in their programs. A type A is considered to fit better than a type B for a declaration element (variable) d if A is more general than B, that is, if A provides fewer members unneeded for the use of d. Our support comes in the form of warnings generated in the Problem View of Eclipse, and associated Quick Fixes allowing elements to be re-declared auto- matically. Due to the use of Eclipse extension points, the algorithm used to compute more general types is easily exchangeable. Currently our tool can use two publicly available algorithms, one considering only supertypes already pre- sent in a project, and one computing new, perfectly fitting types. 1 The Problem: Too Strong Coupling Due to Overly Specific Types A class C is coupled to a type B if one or more declaration elements of C (i.e., fields, formal parameters, local variables, or methods with non-void return types) are de- clared with B as their type. Even though coupling between types cannot be eliminated completely (because without any coupling a type would be isolated from the rest of the system and therefore useless [1]), there is often a certain amount of unnecessary coupling which can be reduced in many cases by using a more general type than B.
    [Show full text]
  • Programming by Numbers: a Programming Method for Novices
    Programming by Numbers: A Programming Method for Novices HUGH GLASER,PIETER H. HARTEL AND PAUL W. GARRATT Department of Electronics and Computer Science, University of Southampton, S017 1BJ Southampton, UK Email: [email protected] Students often have difficulty with the minutiae of program construction. We introduce the idea of ‘Programming by Numbers’, which breaks some of the programming process down into smaller steps, giving such students a way into the process of Programming in the Small. Programming by Numbers does not add intellectual difficulty to learning programming, as it does not require the student to learn additional tools or theory. In fact it can be done with pencil and paper or the normal editor, and only requires the student to remember (and understand) seven simple steps. Programming by Numbers works best with languages that offer pattern matching, such as ML, or data-directed dispatching, such as Java. Received 24 August, 1998; revised 22 June, 2000 1. INTRODUCTION right from the start, because recursion is so fundamental to programming in a functional language. In the Java-based Programming in the Small is easy for experienced course Programming by Numbers is introduced later, when programmers. First they think about how to do it (The Idea), discussing recursion in connection with abstract classes, and then they write the solution down in the language of their sub-classing and data-directed dispatching. choice. This step from a solution in some form, to a solution Programming by Numbers is intended to help the student in a form acceptable as input to a computer is an essential get started on a problem.
    [Show full text]
  • Redesign of UML Class Diagrams: a Formal Approach Piotr Kosiuczenko
    Redesign of UML Class Diagrams: A Formal Approach Piotr Kosiuczenko Department of Computer Science University of Leicester, LE1 7RH, UK e-mail: [email protected], tel: 0043 116 2522025 Regular Paper Abstract: Contracts provide a precise way of specifying object-oriented systems. When a class structure is modified, the corresponding contracts must be modified accordingly. This paper presents a method of transforming contracts, which allows the extension of a mapping defined on a few model elements, to - what we call - an interpretation function, and to use this function to automatically translate OCL-constraints. Interestingly, such functions preserve reasoning using prepositional calculi, resolution, equations, and induc- tion. Interpretation functions can be used to trace model elements throughout multiple redesigns of UML class diagrams in both the forward, and the backward direction. The applicability of our approach is demonstrated in several examples, including some of Fowler’s refactoring patterns. Keywords: UML, OCL, formal methods, refactoring, requirements tracing. 1 Introduction Object-oriented modelling languages provide textual, and diagrammatic means for system specification (cf. [UML05]). An object-oriented system and its real-world environment are modelled using abstractions such as class, association, generalization, operation, and prop- erty. Class diagrams specify a common structure, and relationships between objects; they are often detailed by constraints. System specification, design, and implementation occur in a series of steps. There exist different software engineering approaches which detail how those steps can be performed. In the 80’s, and early 90’s, the waterfall model prevailed in software engineering. In this process, one has to begin with fixed requirement specifica- tion, design the system, and then implement the design specification.
    [Show full text]
  • Transformation of Structure-Shy Programs Applied to Xpath Queries and Strategic Functions
    Transformation of Structure-Shy Programs Applied to XPath Queries and Strategic Functions Alcino Cunha Joost Visser DI-CCTC, Universidade do Minho, Portugal {alcino,joost.visser}@di.uminho.pt Abstract focusing on the essence of the algorithm rather than oozing with Various programming languages allow the construction of structure- boilerplate code. This reduces development time and improves shy programs. Such programs are defined generically for many understandability. Also, structure-shy programs are only loosely different datatypes and only specify specific behavior for a few rel- bound to the data structures on which they operate. As a result, evant subtypes. Typical examples are XML query languages that they do not necessarily need adaptation when those data structures allow selection of subdocuments without exhaustively specifying evolve, and they may be reusable for different data structures. intermediate element tags. Other examples are languages and li- The flip side of these benefits is that structure-shy programs braries for polytypic or strategic functional programming and for have potentially worse space and time behaviour than equivalent adaptive object-oriented programming. structure-sensitive programs. A source of performance loss, gener- In this paper, we present an algebraic approach to transforma- ally by a factor linear in the input size, are dynamic checks em- tion of declarative structure-shy programs, in particular for strate- ployed in the execution of structure-shy programs to determine at gic functions and XML queries. We formulate a rich set of alge- each data node whether to apply specific or generic behaviour. An- braic laws, not just for transformation of structure-shy programs, other source of inefficiency is that algorithmic optimizations, such but also for their conversion into structure-sensitive programs and as cutting off traversal into certain substructures, cannot be ex- vice versa.
    [Show full text]
  • Java SE 7 Programming Course Details
    5 Days Java SE 7 Programming The Java SE 7 Programming training lays emphasis on the core Application Programming Interfaces (API) that are widely used to design and code object-oriented applications with Java. Through this training, individuals learn to write database programs with JDBC, manipulate files, and identify best practices to build strong java applications Completion of this training course will enable candidates to: Create Java technology applications with the latest JDK 7 Technology and the NetBeans Integrated Development Environment (IDE). Create Class, Subclass, Abstract Classes and Interfaces Create high-performance, multi-threaded applications. Identify good practices in the use of the language to create robust Java applications. Learn Object Oriented Programming Skills Work with database applications such as SQL through JDBC. Properly use exceptions and the Collections framework. Develop applications that manipulate files, directories and file systems. Course Benefits: Attaining this course helps individuals to enhance the productivity, communication, and collaboration of their organization. This course will equip you with the right knowledge and skill set to minimize the cost of application ownership through more efficient deployment and development techniques. Earn Your Java Certification This course develops the essential skills with Java language. This training is an important pre-requisite for individuals who are preparing for the Oracle Certified Professional, Java SE 7 Programmer Exam. Course Details ___________________ Course Outline 1. Java Platform Overview Introductions Course Schedule Java Platforms Overview Open JDK Licensing The Java Community Process Java in Server Environments 2. Java Syntax and Class Review Simple Java classes Java fields, constructors, and methods Package and import statements Model objects using Java classes 3.
    [Show full text]
  • Subtyping with Generics: a Unified Approach
    University of Massachusetts Amherst ScholarWorks@UMass Amherst Doctoral Dissertations Dissertations and Theses Summer November 2014 Subtyping with Generics: A Unified Approach John G. Altidor University of Massachusetts Amherst Follow this and additional works at: https://scholarworks.umass.edu/dissertations_2 Part of the Programming Languages and Compilers Commons, Software Engineering Commons, and the Theory and Algorithms Commons Recommended Citation Altidor, John G., "Subtyping with Generics: A Unified Approach" (2014). Doctoral Dissertations. 153. https://doi.org/10.7275/6056894.0 https://scholarworks.umass.edu/dissertations_2/153 This Open Access Dissertation is brought to you for free and open access by the Dissertations and Theses at ScholarWorks@UMass Amherst. It has been accepted for inclusion in Doctoral Dissertations by an authorized administrator of ScholarWorks@UMass Amherst. For more information, please contact [email protected]. SUBTYPING WITH GENERICS: A UNIFIED APPROACH A Dissertation Presented by JOHN G. ALTIDOR Submitted to the Graduate School of the University of Massachusetts Amherst in partial fulfillment of the requirements for the degree of DOCTOR OF PHILOSOPHY September 2014 School of Computer Science c Copyright by John G. Altidor 2014 All Rights Reserved SUBTYPING WITH GENERICS: A UNIFIED APPROACH A Dissertation Presented by JOHN G. ALTIDOR Approved as to style and content by: Yannis Smaragdakis, Chair Jack C. Wileden, Member Neil Immerman, Member Ian Grosse, Member Lori Clarke, Department Chair School of Computer Science ACKNOWLEDGMENTS First, I thank Yannis Smaragdakis and Jack Wileden who have taught me a great deal about programming languages. In addition, they have stressed the importance of communicating ideas clearly, motivating work, and justifying claims.
    [Show full text]
  • The Infer Type Refactoring and Its Use for Interface-Based Programming
    JOURNAL OF OBJECT TECHNOLOGY Online at http://www.jot.fm. Published by ETH Zurich, Chair of Software Engineering ©JOT, 2007 Vol. 6, No. 2, Special Issue OOPS Track at SAC 2006, February 2007 The Infer Type Refactoring and its Use for Interface-Based Programming Friedrich Steimann, Fernuniversität in Hagen, Germany Abstract Interface-based programming, i.e. the systematic use of interface types in variable dec- larations, serves the decoupling of classes and increases a program’s changeability. To maximize this effect, interfaces should contain as few elements as possible. For the de- sign of minimal (i.e., maximally general) interfaces, an in-depth analysis of the protocol needed from objects in a given context is required. However, currently available refac- torings for the creation of such interfaces (such as Extract Interface) leave programmers alone with the decision what to include or, more importantly, what to omit: they let them choose manually from the protocol of a class, and only then offer the use of the new in- terface where (if) possible. To end this trial and error process, we have developed a new refactoring named Infer Type that, using type inference, completely automates the construction of new, context-specific interfaces and their use in variable declarations, thus supporting greater decoupling and access protection of code, serving the goals of interface-based programming. 1 INTRODUCTION Interface-based programming is an object-oriented programming technique by which ob- ject references (variables and methods with return values) are statically typed with ab- stract interfaces rather than concrete classes. These interfaces are typically context- specific [Steimann & Mayer 2005], i.e., they contain only the protocol needed from the referenced objects as accessed through the references setting up the context.
    [Show full text]
  • MATHEMATICS TEACHING for the FUTURE Editors: Margita Pavleković, Zdenka Kolar-Begović, Ružica Kolar-Šuper
    MATHEMATICS TEACHING FOR THE FUTURE MATHEMATICS Editors: Margita Pavleković, Zdenka Kolar-Begović, Ružica Kolar-Šuper MATHEMATICS TEACHING FOR THE FUTURE Editors: Margita Pavleković Zdenka Kolar-Begović Ružica Kolar-Šuper ISBN 978-953-197-583-4 Josip Juraj Strossmayer University of Osijek Faculty of Teacher Education and Department of Mathematics Sveuciliˇ steˇ Josipa Jurja Strossmayera u Osijeku Uciteljskiˇ fakultet i Odjel za matematiku MATHEMATICS TEACHING FOR THE FUTURE POUCAVANJEˇ MATEMATIKE ZA BUDUCNOST´ monography / monografija Editors / Urednice: Margita Pavlekovic´ Zdenka Kolar-Begovic´ Ruzicaˇ Kolar-Superˇ Zagreb, 2013 Josip Juraj Strossmayer University of Osijek / Sveuciliˇ steˇ Josipa Jurja Strossmayera u Osijeku Mirta Bensiˇ c´ Radoslav Galic´ Zdenka Kolar-Begovic´ Ruzicaˇ Kolar-Superˇ Ivan Matic´ Margita Pavlekovic´ Rudolf Scitovski Nenad Suvakˇ Simeˇ Ungar Marijana Zekic-Su´ sacˇ University of Zagreb / Sveuciliˇ steˇ u Zagrebu Blazenkaˇ Divjak Sibe Mardesiˇ c,´ academician Zeljkaˇ Milin Sipuˇ sˇ Mirko Polonijo Vladimir Volenec Foreign universities / Sveuciliˇ staˇ izvan Hrvatske Sefketˇ Arslanagic´ (Bosnia and Herzegovina / Bosna i Hercegovina) Mara Coticˇ (Slovenia / Slovenija) Darjo Felda (Slovenia/Slovenija) Eva´ Kopasz (Hungary/Madarska) Emil Molnar´ (Hungary/Madarska) Marta Takacˇ (Serbia/Srbija) Monograph referees / Recenzenti monografije: Sibe Mardesiˇ c,´ academician (Croatia / Hrvatska) Simeˇ Ungar (Croatia / Hrvatska) Eva´ Kopasz (Hungary / Madarska) Mara Coticˇ (Slovenia / Slovenija) A Word from the Editors The overall social turmoil of the present times, especially in the area of econ- omy and finance, is reflected in science, education and culture. The leadership of many countries is seeking the way out of the global crisis by stimulating the development of science and education. It is expected of scientists and teams of educationists to create new solutions by means of which to tackle the problems of shaken existence within the layers of contemporary social reality.
    [Show full text]