Type Errors for the IDE with Xtext and Xsemantics Perience and Contributes to the Adoption of That Language

Total Page:16

File Type:pdf, Size:1020Kb

Type Errors for the IDE with Xtext and Xsemantics Perience and Contributes to the Adoption of That Language Open Comput. Sci. 2019; 9:52–79 Research Article Open Access Lorenzo Bettini* Type errors for the IDE with Xtext and Xsemantics https://doi.org/10.1515/comp-2019-0003 perience and contributes to the adoption of that language. Received June 29, 2018; accepted February 11, 2019 However, developing a compiler and an IDE for a language from scratch is usually time consuming. Language work- Abstract: Providing IDE support for a programming lan- benches, a term coined by Martin Fowler in 2005 [1], are guage or a DSL (Domain Specific Language) helps the users software development tools designed to easily implement of the language to be more productive and to have an im- languages together with their IDE support. Xtext [2] is one mediate feedback on possible errors in a program. Static of the most popular language workbench. Starting from a types can drive IDE mechanisms such as the content as- grammar definition Xtext generates a parser, an abstract sist to propose sensible completions in a given program syntax tree (AST), and typical IDE mechanisms. While the context. Types can also be used to enrich other typical IDE main target of Xtext is Eclipse, a language developed with parts such as the Outline and the Hovering pop-ups. In this Xtext can be easily ported to other IDEs and editors. Xtext paper, we focus on statically typed imperative languages, comes with good defaults for all the above artifacts, di- adopting some form of type inference. We present a few rectly inferred from the grammar definition, and the lan- general patterns for implementing efficient type systems, guage developer can easily customize them all. focusing on type error recovery. This way, the type system Statically typed languages provide good IDE support. is able to type as many parts of the program as possible, Indeed, given an expression and its static type, the editor keeping a good IDE experience. Type error messages will can provide useful completion proposals that make sense be placed on the important parts of the program, avoid- in that program context. The same holds for other typical ing cascading errors that can confuse the user. We show IDE features, e.g., navigation to declaration, hovering and two case studies: we apply the presented patterns to imple- outline. In spite of the ease of implementing a language ment the type system of two statically typed DSLs, a sim- and its IDE support with a language workbench like Xtext, ple expression language and a reduced Java-like language, the implementation of the type system requires some effort with OOP features. We use Xtext as the language work- and careful tweaking: bench for implementing the compiler and the IDE sup- – The type system should type as many parts of a pro- port and Xsemantics, a DSL for implementing type systems gram as possible, so that the IDE can provide mean- using a syntax that mimics formal systems. The patterns ingful code completions even in the presence of an in- shown in the paper can be reused also for implementing complete and invalid program. languages with other language frameworks. – Type error messages should be placed on the impor- Keywords: language implementation, type system, IDE tant parts of the program, helping the user to quickly understand and fix the errors, avoiding cascading er- rors that would only confuse the user. 1 Introduction – Type computation should be performed quickly, in or- der to keep the IDE responsive. Integrated Development Environments (IDEs) help pro- In this paper we concentrate on mechanisms related to the grammers with mechanisms like syntax aware editor (syn- implementation of type systems addressing the above is- tax highlighting), immediate error reporting, code comple- sues, focusing on type errors and IDE support. The contri- tion (also known as content assist) and easy navigation butions of the paper are: to declarations. Providing IDE support for a language or – We describe some general implementation patterns a DSL (Domain Specific Language) enhances the user ex- for implementing type systems that aim at reporting only the important errors, with useful error messages, keeping the IDE responsive. In particular, we concen- *Corresponding Author: Lorenzo Bettini: Dipartimento di Statis- trate on imperative languages, adopting some form of tica, Informatica, Applicazioni, Università di Firenze, Italy; type inference. E-mail: [email protected] Open Access. © 2019 Lorenzo Bettini, published by De Gruyter. This work is licensed under the Creative Commons Attribution alone 4.0 License Type errors for the IDE with Xtext and Xsemantics Ë 53 – We then demonstrate the benefits of such patterns first case study, showing the implementation of thetype by implementing two example DSLs in Xtext: a sim- system for the Expressions DSL. Section 5 shows our sec- ple “Expressions DSL” (with arithmetic, string and ond case study, that is, the implementation of the type boolean expressions) and a reduced version of Java, system of an OO language, Featherweight Java. Section 6 based on Featherweight Java (FJ) [3], a well-known for- discusses further improvements to the type system imple- mal framework for studying properties of the Java lan- mentations of the two DSLs. Section 7 discusses a few re- guage and for introducing extensions to Java. lated works. Section 8 concludes the paper. – For both examples, we show the benefits of applying the described patterns, in terms of the user experi- ence. 2 General implementation patterns Both languages¹ are simple languages but their type sys- A crucial issue to keep in mind when implementing type tems are complex enough to help us investigate best prac- systems is error recovery. This is similar to error recovery in tices in type system implementation. We implement the parser implementations [5]: a parser should be able to han- type system of the first DSL manually, while for FJ we use dle possible parsing errors and carry on parsing as much Xsemantics [4], a DSL for implementing type systems for of the rest of the input as possible, avoiding or minimizing Xtext languages. Xsemantics provides many features for additional cascading errors. The same holds for the type implementing complex type systems, like the one of FJ (in system: it should be able to type and check as many parts spite of its simplicity, the type system of FJ formalizes the of a program as possible, even in the presence of type er- main parts of the Java type system). Moreover, Xsemantics rors. Thus, the type system should avoid throwing cascad- provides a syntax that is close to formal type systems and ing errors due to previously failed type computations. This this makes it suitable to implement type systems that have is important in a command line compiler, but in the IDE it been formalized, like FJ’s type system [3]. The syntax of is even more crucial: we should minimize the portions of the two example DSLs is partly inspired by our previous the edited file marked with errors. This way, the user can work [2, 4], but the implementations shown in this paper easily understand the errors and quickly fix them. In par- are new. ticular, the type system will be continuously used by the The patterns presented in the paper are not strictly de- IDE while the user is editing the program. Thus, the pro- pendent on Xtext, Xsemantics and Eclipse: these are the gram that is examined by the type system will be an in- frameworks that are used in the paper to present our case complete program most of the time. studies. The same patterns could be applied to other lan- In this section we present some general implementa- guage workbenches. The basic idea of the implementation tion patterns for implementing type systems that aim at patterns will be given independently from these frame- reporting only the important errors, with useful messages works. and at providing a good user experience in the IDE. The intended audience of the paper is developers of We consider the implementation of a type system as statically typed languages and DSLs with IDE support. In the synergy of two main components: the type inference, particular, we will use Xtext as the language workbench that is, the mechanism responsible of computing the types and Eclipse as the target IDE. A basic knowledge of lan- of the program elements, and the type checker, that is, the guage implementation and type systems is advisable. We mechanism responsible of validating the program with re- will provide enough details on Xtext in order to make the spect to types. These two components will also have to co- examples understandable even by readers who are not fa- operate with the mechanism for cross reference resolution. miliar with Xtext. The paper is structured as follows. Section 2 motivates Infer a type as quickly as possible. Given a compos- our work and presents our general implementation pat- ite expression, if its type can be computed independently terns for type systems. Section 3 provides a brief introduc- from its subexpressions, the subexpressions should not tion to Xtext and its main mechanisms using the Expres- be inspected recursively. This has the benefit of improv- sions DSL as a running example. Section 4 illustrates our ing error recovery and the type inference performance. For example, let us consider an arithmetic expression of the shape e1 * e2². We can infer that the type of the expres- 1 The source code of the implemented DSLs presented in this pa- per can be found at: https://github.com/LorenzoBettini/xtext-type- errors-examples. 2 Where * is assumed to be the standard multiplication operator. 54 Ë Lorenzo Bettini sion is numeric, independently from the types of subex- pression will not be marked with an error.
Recommended publications
  • How to Develop Your Own Dsls in Eclipse Using Xtend and Xtext ?
    How to develop your own DSLs in Eclipse using Xtend and Xtext ? Daniel Strmečki | Software Developer 19.05.2016. BUSINESS WEB APPLICATIONS HOW TO DEVELOP YOUR OWN DSLS IN ECLIPSE USING XTEXT AND XTEND? Content 1. DSLs › What are DSLs? › Kinds of DSLs? › Their usage and benefits… 2. Xtend › What kind of language is Xtend? › What are its benefits compared to classic Java? 3. Xtext › What is a language development framework? › How to develop you own DSL? 4. Short demo 5. Conclusion 2 | 19.05.2016. BUSINESS WEB APPLICATIONS | [email protected] | www.evolva.hr HOW TO DEVELOP YOUR OWN DSLS IN ECLIPSE USING XTEXT AND XTEND? DSL acronym Not in a Telecommunications context: Digital Subscriber Line But in a Software Engineering context: Domain Specific Languages 3 | 19.05.2016. BUSINESS WEB APPLICATIONS | [email protected] | www.evolva.hr HOW TO DEVELOP YOUR OWN DSLS IN ECLIPSE USING XTEXT AND XTEND? Domain Specific Languages General-Purpose Languages (GPLs) › Languages broadly applicable across application domains › Lack specialized features for a particular domain › XML, UML, Java , C++, Python, PHP… Domain specific languages (DSLs) › Languages tailored to for an application in a specific domain › Provide substantial gains in expressiveness and ease of use in their domain of application › SQL, HTML, CSS, Logo, Mathematica, Marcos, Regular expressions, Unix shell scripts, MediaWiki, LaTeX… 4 | 19.05.2016. BUSINESS WEB APPLICATIONS | [email protected] | www.evolva.hr HOW TO DEVELOP YOUR OWN DSLS IN ECLIPSE USING XTEXT AND XTEND? Domain Specific Languages A novelty in software development › DSL for programming numerically controlled machine tools, was developed in 1957–1958 › BNF dates back to 1959 (M.
    [Show full text]
  • Expressive and Efficient Model Transformation with an Internal DSL
    Expressive and Efficient Model Transformation with an Internal DSL of Xtend Artur Boronat Department of Informatics, University of Leicester, UK [email protected] ABSTRACT 1 INTRODUCTION Model transformation (MT) of very large models (VLMs), with mil- Over the past decade the application of MDE technology in indus- lions of elements, is a challenging cornerstone for applying Model- try has led to the emergence of very large models (VLMs), with Driven Engineering (MDE) technology in industry. Recent research millions of elements, that may need to be updated using model efforts that tackle this problem have been directed at distributing transformation (MT). This situation is characterized by important MT on the Cloud, either directly, by managing clusters explicitly, or challenges [26], starting from model persistence using XMI serial- indirectly, via external NoSQL data stores. In this paper, we draw at- ization with the Eclipse Modeling Framework (EMF) [31] to scalable tention back to improving efficiency of model transformations that approaches to apply model updates. use EMF natively and that run on non-distributed environments, An important research effort to tackle these challenges was showing that substantial performance gains can still be reaped on performed in the European project MONDO [19] by scaling out that ground. efficient model query and MT engines, such as VIATRA[3] and We present Yet Another Model Transformation Language (YAMTL), ATL/EMFTVM [46], building on Cloud technology either directly, a new internal domain-specific language (DSL) of Xtend for defin- by using distributed clusters of servers explicitly, or indirectly, by ing declarative MT, and its execution engine.
    [Show full text]
  • On Modularity and Performances of External Domain-Specific Language Implementations Manuel Leduc
    On modularity and performances of external domain-specific language implementations Manuel Leduc To cite this version: Manuel Leduc. On modularity and performances of external domain-specific language implementa- tions. Software Engineering [cs.SE]. Université Rennes 1, 2019. English. NNT : 2019REN1S112. tel-02972666 HAL Id: tel-02972666 https://tel.archives-ouvertes.fr/tel-02972666 Submitted on 20 Oct 2020 HAL is a multi-disciplinary open access L’archive ouverte pluridisciplinaire HAL, est archive for the deposit and dissemination of sci- destinée au dépôt et à la diffusion de documents entific research documents, whether they are pub- scientifiques de niveau recherche, publiés ou non, lished or not. The documents may come from émanant des établissements d’enseignement et de teaching and research institutions in France or recherche français ou étrangers, des laboratoires abroad, or from public or private research centers. publics ou privés. THÈSE DE DOCTORAT DE L’UNIVERSITE DE RENNES 1 COMUE UNIVERSITE BRETAGNE LOIRE Ecole Doctorale N°601 Mathèmatique et Sciences et Technologies de l’Information et de la Communication Spécialité : Informatique Par Manuel LEDUC On modularity and performance of External Domain-Specific Language im- plementations Thèse présentée et soutenue à RENNES , le 18 Décembre 2019 Unité de recherche : Equipe DiverSE, IRISA Rapporteurs avant soutenance : Paul Klint, Professeur, CWI, Amsterdam, Pays-Bas Juan De Lara, Professeur, Université autonome de Madrid, Madrid, Espagne Composition du jury : Président : Olivier Ridoux, Professeur, Université de Rennes 1, Rennes, France Examinateurs : Nelly Bencomo, Lecturer in Computer Science, Aston University, Birmingham, Royaume-Uni Jean-Remy Falleri, Maître de conférences HDR, Université de Bordeaux, Bordeaux, France Gurvan Le Guernic, Ingénieur de recherche, DGA, Rennes, France Dir.
    [Show full text]
  • Open Source and Third Party Documentation
    Open Source and Third Party Documentation Verint.com Twitter.com/verint Facebook.com/verint Blog.verint.com Content Introduction.....................2 Licenses..........................3 Page 1 Open Source Attribution Certain components of this Software or software contained in this Product (collectively, "Software") may be covered by so-called "free or open source" software licenses ("Open Source Components"), which includes any software licenses approved as open source licenses by the Open Source Initiative or any similar licenses, including without limitation any license that, as a condition of distribution of the Open Source Components licensed, requires that the distributor make the Open Source Components available in source code format. A license in each Open Source Component is provided to you in accordance with the specific license terms specified in their respective license terms. EXCEPT WITH REGARD TO ANY WARRANTIES OR OTHER RIGHTS AND OBLIGATIONS EXPRESSLY PROVIDED DIRECTLY TO YOU FROM VERINT, ALL OPEN SOURCE COMPONENTS ARE PROVIDED "AS IS" AND ANY EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. Any third party technology that may be appropriate or necessary for use with the Verint Product is licensed to you only for use with the Verint Product under the terms of the third party license agreement specified in the Documentation, the Software or as provided online at http://verint.com/thirdpartylicense. You may not take any action that would separate the third party technology from the Verint Product. Unless otherwise permitted under the terms of the third party license agreement, you agree to only use the third party technology in conjunction with the Verint Product.
    [Show full text]
  • Handcrafting a Triple Graph Transformation System to Realize Round-Trip Engineering Between UML Class Models and Java Source Code
    Handcrafting a Triple Graph Transformation System to Realize Round-trip Engineering Between UML Class Models and Java Source Code Thomas Buchmann and Sandra Greiner Chair of Applied Computer Science I, University of Bayreuth, Universitätsstrasse 30, 95440, Bayreuth, Germany Keywords: Round-trip Engineering, Model-driven Development, Xtend, Triple Graph Transformation Systems. Abstract: Model transformations are a mandatory requirement for model-driven development, a software engineering discipline, which has become more and more popular during the last decade. Over the years, the concept of unidirectional model transformations and corresponding tool support reached maturity since these kind of transformations are widely used in model-driven engineering, mainly for forward engineering and code generation. In incremental and iterative software engineering processes, forward engineering may be too restrictive since it resembles waterfall-like processes. Thus, bidirectional transformations are required, which aim to provide support for (incrementally) transforming one or more source model to one or more target model and vice versa from only one transformation description. However, they seem to be rarely used in model- driven software development as adequate tool support is missing. On the other hand, programming languages nowadays provide support for higher-level features like closures or lambda expressions which allow to describe transformation patterns in a declarative way. In this paper, we present an approach for round-trip engineering between UML class models and Java source code, which is realized with a triple graph transformation system written in the Xtend programming language. 1 INTRODUCTION and accompanying tools have emerged (Czarnecki and Helsen, 2006). We observe tools, which sup- During the last few years, model-driven software en- port unidirectional batch transformations, e.g.
    [Show full text]
  • Xtend Programming Language Agenda
    Agile Software Development Produced Eamonn de Leastar ([email protected]) by Department of Computing, Maths & Physics Waterford Institute of Technology http://www.wit.ie http://elearning.wit.ie Xtend Programming Language Agenda • Subtitle 3 4 Features (1) • Extension methods - enhance closed types with new functionality • Lambda Expressions - concise syntax for anonymous function literals • ActiveAnnotations - annotation processing on steroids • Operator overloading - make your libraries even more expressive • Powerful switch expressions - type based switching with implicit casts • Multiple dispatch - a.k.a. polymorphic method invocation 5 Features (2) • Template expressions - with intelligent white space handling • No statements - everything is an expression • Properties - shorthands for accessing and defining getters and setter • Type inference - you rarely need to write down type signatures anymore • Full support for Java generics - including all conformance and conversion rules • Translates to Java not bytecode - understand what is going on and use your code for platforms such as Android or GWT 6 Hello World xtend java class HelloWorld public class HelloWorld { { def static void main(String[] args) public static void main(String[] args) { { println("Hello World") System.out.println("Hello World"); } } } } 7 Selected Key Features • Java Interoperability • Expressions • Annotations • Type Inference • Literals • @Data • Conversion Rules • Casts • Classes • Field access & method invocation • Constructors • Constructor call • Fields • Lambda Expressions • Methods • If expression • Override • switch Expression • Inferred return types • return expression 8 Java Interoperability 9 Type inference • Xtend, like Java, is a statically typed language. • It completely supports Java's type system, including the primitive types like int or boolean, arrays and all the Java classes, interfaces, enums and annotations that reside on the class path.
    [Show full text]
  • Xtext User Guide
    Xtext User Guide Xtext User Guide Heiko Behrens, Michael Clay, Sven Efftinge, Moritz Eysholdt, Peter Friese, Jan Köhnlein, Knut Wannheden, Sebastian Zarnekow and contributors Copyright 2008 - 2010 Xtext 1.0 1 1. Overview .................................................................................................................... 1 1.1. What is Xtext? ................................................................................................... 1 1.2. How Does It Work? ............................................................................................ 1 1.3. Xtext is Highly Configurable ................................................................................ 1 1.4. Who Uses Xtext? ................................................................................................ 1 1.5. Who is Behind Xtext? ......................................................................................... 1 1.6. What is a Domain-Specific Language ..................................................................... 2 2. Getting Started ............................................................................................................ 3 2.1. Creating a DSL .................................................................................................. 3 2.1.1. Create an Xtext Project ............................................................................. 3 2.1.2. Project Layout ......................................................................................... 4 2.1.3. Build Your Own Grammar ........................................................................
    [Show full text]
  • Script Alapú Járműbusz-Szimuláció
    SZAKDOLGOZAT-FELADAT Sándi Tamás (SMNQCY) szigorló villamosmérnök hallgató részére Script alapú járműbusz-szimuláció Napjaink prémium kategóriás személyautóinak működésében közel száz elektronikus vezérlőegység (ECU) játszik szerepet. Ezek között a kommunikáció szabványos autóipari protokollokon zajlik (CAN, FlexRay, LIN). Az így kapott összetett elosztott rendszer fejlesztésének elengedhetetlen részét képezi a vezérlőegységek kimerítő tesztelése. A tesztelés során a tesztelendő alkatrész által elvárt kommunikációs jeleket szimuláljuk. A tesztszekvenciák előállítására rendelkezésre áll a vállalatnál egy saját fejlesztésű kommunikációs eszköz (Gateway). Az eszköz számos szolgáltatást nyújt a felhasználó felé (CAN, FlexRay és LIN kommunikációs csatornák, valamint GPIO és A/D portok). A hallgató feladata egy olyan Eclipse alapú szoftvereszköz elkészítése, melynek segítségével a felhasználó egy erre a célra definiált szkriptnyelvben fogalmazhatja meg a Gateway által szimulálandó bonyolult kommunikációs szekvenciákat. Az eszköznek képesnek kell lennie továbbá az elkészített szkript alapján a Gatewayen futtatható kód generálására, valamint a hardverre való letöltése után annak futtatására is. A hallgató feladatának a következőkre kell kiterjednie: • Gyűjtse össze a gyakori használati eseteket (use case analízis), majd ezek alapján definiáljon egy kényelmesen használható domainspecifikus nyelvet a felmerülő igények kielégítésére. A szkriptnek lehetőséget kell nyújtania eseményvezérelt szekvenciák megfogalmazására is (pl.: üzenetek megérkezésére,
    [Show full text]
  • Xtend User Guide
    Xtend User Guide September 10, 2014 Contents I. Getting Started 5 1. Introduction 6 2. Hello World 7 3. The Movies Example 9 3.1. The Data . .9 3.2. Parsing The Data . 10 3.3. Answering Some Questions . 11 3.3.1. Question 1 : What Is The Number Of Action Movies? . 11 3.3.2. Question 2 : What Is The Year The Best Movie From The 80's Was Released? . 12 3.3.3. Question 3 : What Is The The Sum Of All Votes Of The Top Two Movies?................................. 13 II. Reference Documentation 14 4. Java Interoperability 15 4.1. Type Inference . 15 4.2. Conversion Rules . 15 4.3. Interoperability with Java . 16 5. Classes and Members 17 5.1. Package Declaration . 17 5.2. Imports . 17 5.3. Class Declaration . 18 5.4. Constructors . 19 5.5. Fields . 19 5.6. Methods . 20 5.6.1. Abstract Methods . 20 5.6.2. Overriding Methods . 21 5.6.3. Declared Exceptions . 21 5.6.4. Inferred Return Types . 21 5.6.5. Generic Methods . 22 2 5.6.6. Operator Declarations . 22 5.6.7. Dispatch Methods . 23 5.6.8. Create Methods . 26 5.7. Annotations . 28 5.8. Extension Methods . 29 5.8.1. Extensions from the Library . 29 5.8.2. Local Extension Methods . 30 5.8.3. Extension Imports . 30 5.8.4. Extension Provider . 31 5.9. Interface Declaration . 32 5.10. Annotation Type Declaration . 32 5.11. Enum Type Declaration . 32 5.12. Nested Type Declarations . 32 6. Expressions 34 6.1.
    [Show full text]
  • Xtext Documentation.Pdf
    Xtext Documentation September 26, 2014 Contents I. Getting Started 9 1. 5 Minutes Tutorial 10 1.1. Creating A New Xtext Project . 10 1.2. Generating The Language Infrastructure . 10 1.3. Try The Editor . 11 1.4. Conclusion . 12 2. 15 Minutes Tutorial 14 2.1. Create A New Xtext Project . 14 2.2. Write Your Own Grammar . 16 2.3. Generate Language Artifacts . 19 2.4. Run the Generated IDE Plug-in . 20 2.5. Second Iteration: Adding Packages and Imports . 20 3. 15 Minutes Tutorial - Extended 27 3.1. Writing a Code Generator With Xtend . 29 3.2. Unit Testing the Language . 34 3.3. Creating Custom Validation Rules . 35 4. Five simple steps to your JVM language 37 4.1. Step One: Create A New Xtext Project . 38 4.2. Step Two: Write the Grammar . 38 4.3. Step Three: Generate Language Artifacts . 43 4.4. Step Four: Define the Mapping to JVM Concepts . 43 4.5. Step Five : Try the Editor! . 48 II. Seven JVM Languages Built With Xbase 50 5. Introduction 51 5.1. Write the Grammar . 51 5.2. Map to Java . 51 5.3. CAUTION: This is Provisional API . 52 5.4. Common Requirements . 52 5.5. Getting the Code . 53 2 5.6. A Short Xtend Primer . 53 6. Scripting Language 57 6.1. Overview . 57 6.2. Running the Example . 58 6.3. Grammar . 58 6.4. Translation to Java . 59 7. Build Language 61 7.1. Overview . 61 7.2. Running the Example . 62 7.3. Grammar . 62 7.4.
    [Show full text]
  • Kotlin Срещу Scala – Сравнителен Анализ
    Computer and communications engineering, Vol. 14, No. 1/2020 Kotlin срещу Scala – сравнителен анализ Петко Данов Резюме: Представен само преди няколко години, Kotlin е един от многото езици, които използват виртуалната машина на Java, но в този кратък период придобива популярност. Scala е чист обектно-ориентиран език за програмиране, обединяващ в себе си предимствата на високо мащабируемите функционални езици за програмиране. Целта на настоящия документ е да сравни структурно двата езика и да идентифицира предимствата и недостатъците на всеки от тях. Ключови думи: Котлин, Скала, Програмни езици Kotlin vs Scala – а comparative study Petko Danov Abstract: Introduced just a few years ago, Kotlin is one of many languages that use the Java virtual machine, but it is gaining popularity in this short period. Scala is a pure object-oriented programming language that combines the advantages of highly scalable functional programming languages. The purpose of this paper is to compare the two languages structurally and to identify the advantages and disadvantages of each. Key words: Kotlin; Scala; Programming languages. 1. INTRODUCTION component-based applications [4]. Scala uses the so- called "actor model" to maintain modern parallelism. The development of the Kotlin programming This programming language also supports the so- language was started in 2010 by Jet Brains. The first called "lazy evaluation". With the inclusion of macros, stable version was released in February 2016, and in Scala is also distinguished by the creation of complex May 2017, Google included Kotlin in Android Studio internal domain-specific DSL languages. Scala also 3.0. Although it uses a JVM, it can also be compiled supports first-order operations and allows the use of into JavaScript and machine code [1].
    [Show full text]
  • Xtend User Guide
    Xtend User Guide June 28, 2012 Contents I. Getting Started 5 1. Introduction 6 2. Hello World 7 3. The Movies Example 9 3.1. The Data . .9 3.2. Parsing The Data . 10 3.3. Answering Some Questions . 11 3.3.1. Question 1 : What Is The Number Of Action Movies? . 11 3.3.2. Question 2 : What Is The Year The Best Movie From The 80's Was Released? . 12 3.3.3. Question 3 : What Is The The Sum Of All Votes Of The Top Two Movies?................................. 13 II. Reference Documentation 14 4. Java Interoperability 15 4.1. Type Inference . 15 4.2. Conversion Rules . 15 4.3. Interoperability with Java . 16 5. Classes and Members 17 5.1. Package Declaration . 17 5.2. Imports . 17 5.3. Class Declaration . 18 5.4. Constructors . 19 5.5. Fields . 19 5.6. Methods . 20 5.6.1. Abstract Methods . 20 5.6.2. Overriding Methods . 20 5.6.3. Declared Exceptions . 21 5.6.4. Inferred Return Types . 21 5.6.5. Generic Methods . 22 2 5.6.6. Dispatch Methods . 22 5.7. Annotations . 26 5.8. Extension Methods . 26 5.8.1. Extensions From The Library . 27 5.8.2. Local Extension Methods . 28 5.8.3. Extension Imports . 28 5.8.4. Extension Fields . 28 6. Expressions 30 6.1. Literals . 30 6.1.1. String Literals . 30 6.1.2. Number Literals . 31 6.1.3. Boolean Literals . 31 6.1.4. Null Literal . 31 6.1.5. Type Literals . 31 6.2. Type Casts .
    [Show full text]