Haxe

Haxe
Paradigm Multi-paradigm
Developer Haxe Foundation
First appeared 2005
Stable release 3.2.1 / October 11, 2015 (2015-10-11)
Typing discipline Static
Implementation language OCaml
Platform IA-32, x86-64
OS Windows, OS X, Linux
License GPL v2, library: MIT
Filename extensions .hx .hxml
Website haxe.org
Influenced by
ActionScript, OCaml, Java

Haxe is an open source high-level multi-platform programming language and compiler that can produce applications and source code for many different platforms from a single code-base.[1][2][3][4]

Haxe includes a set of common functionality that is supported across all platforms, such as numeric data types, text, arrays, binary and some common file formats.[2][5] Haxe also includes platform-specific API for Adobe Flash, C++, PHP and other languages.[2][6]

Code written in the Haxe language can be source-to-source compiled into ActionScript 3 code, JavaScript programs, Java, C#, C++ standalone applications, Python, PHP, Apache CGI, and Node.js server-side applications.[2][5][7]

Haxe is also a full-featured ActionScript 3-compatible Adobe Flash compiler, that can compile a SWF file directly from Haxe code.[2][8] Haxe can also compile to Neko applications, built by the same developer.

Major users of Haxe include TiVo, Prezi, Nickelodeon, Disney, Mattel, Hasbro, Coca Cola, Toyota and BBC.[9][10] OpenFL and Flambe are popular Haxe frameworks that enable the creation of multi-platform content from a single codebase.[10] With HTML5 dominating over Adobe Flash in recent years, Haxe, Unity and other cross-platform tools are increasingly necessary to target modern platforms while providing backward compatibility with Adobe Flash Player.[10][11]

Architecture

Unified language

The most unique aspect of the Haxe architecture was the decision to support Flash, JavaScript and the server with a single unified language.[12][13] In typical web development projects, developers must use many different languages to build an integrated web application:[12][13]

Haxe originated with the idea of creating all such aspects in a single language, and simplifying the communication logic between aspects.[12][13][14]

In a book authored by Nicolas Cannasse (the founder of the Haxe project), he states that the original goals of Haxe as the following:[12]

Compiler

The Haxe compiler is separated into one frontend and multiple backends. The frontend is responsible for parsing and type-checking the input language, applying macros, general optimizations, various transformations, and for producing the intermediate representation of the code, the typed abstract syntax tree (AST). Each of the backends is responsible for translating that AST into either source code or bytecode for the respective target.

The compiler is written in OCaml. It can be run in server-mode to provide code completion for IDEs and maintain a cache, to speed up compilation even more.[15]

Targets

In Haxe, supported platforms are known as "targets", which are Haxe modules that provide access to core-APIs (language and bytecode targets), for the compiler-backends that are responsible for generating the respective code, and for runtimes with specific APIs that go beyond the core language support (platform-targets).

Performance

The Haxe compiler is an optimizing compiler, and uses function inlining, constant folding and dead code elimination (DCE) to optimize the run-time performance of compiled programs.

The run-time performance of Haxe programs varies depending on the target platform:

Development

Development of Haxe was started in October 2005[20] and the first beta version was released in February 2006. Haxe 1.0 was released in April 2006, with support for Adobe Flash, Javascript, and Neko programs.

Haxe was developed by Nicolas Cannasse and other contributors, and was originally named haXe because it was short, simple, and "has an X inside", which the author humorously asserts is necessary to make any new technology a success.[21]

Haxe is the successor to the open-source ActionScript 2 compiler MTASC, also built by Nicolas Cannasse,[12][22] and is released under the GNU General Public License version 2 or later.[23]

Haxe has much in common with ActionScript 3. The Haxe compiler is developed in the OCaml language. No knowledge of OCaml is necessary to develop applications using Haxe.

Advantages to using Haxe include:

Source code

The recommended IDE for Haxe development is FlashDevelop,[12] which supports ActionScript 2, 3 and Haxe as first-class languages with syntax highlighting, code completion, and other features.[12][25] Code folding, code refactoring and interactive debugging is also supported within the IDE.[26]

To help leverage existing code, the open-source community has created source code converters for:

To help build applications in various platforms, or to help convert Haxe code into other languages, the Haxe compiler can compile:

Platform support

The Haxe language can compile into bytecode for different virtual machines such as the Adobe Flash Player and Neko, and can generate source code in ActionScript 3, JavaScript, and includes experimental support for C++ and C#.

This strategy of "compiling" to multiple source code languages is inspired by the write once, run anywhere paradigm. It also allows the programmer to choose the best platform for the job.

The following table documents platform/language support in Haxe. Most Haxe programs will function without changes in any given language, although Haxe programs that use platform-specific API will function only in the given platform.

Code generator Output Platform Usage Since Haxe version
AVM1[5] byte code Adobe Flash Player 6+ Desktop, browser 2005 (alpha)
AVM2[5] byte code Adobe Flash Player 9+, Adobe AIR, Tamarin VM Desktop, browser, server 2005 (alpha)
ActionScript 3[5] source Adobe Flash Player 9+ Server, desktop 2007 (1.12)
C++ (hxcpp)[5] source Windows, Linux, OS X Server, desktop, CLI 2009 (2.04)
C++ source Android,[35] Apple iOS,[7] Palm webOS[36] Mobile 2009 (2.04)
C#[5] source .NET Framework Server, desktop, mobile 2012 (2.10)
Java[5] source Java Server, desktop 2012 (2.10)
JavaScript[5] source HTML 5, NodeJS, PhoneGap Server, desktop, browser, mobile 2006 (beta)
Neko[5] byte code NekoVM Server, desktop, CLI 2005 (alpha)
PHP[5] source PHP Server 2008 (2.0)
Python[5] source python CLI, web, desktop 2014 (3.2)

Language

Haxe is a general-purpose language with object-oriented programming, exceptions, and type inference with class parameters. Generic classes, reflectivity, iterators, and functional programming are built-in functionality of the language and libraries.[37] Unusual among programming languages, Haxe contains a type system which is both strong and dynamic. The compiler will check types implicitly and give compile-time errors, but it also enables the programmer to bypass type-checking and rely on the target platform's dynamic type-handling.

Haxe is similar to ECMAScript, although almost no ECMAScript code will run on Haxe without modifications. Unlike ECMAScript, Haxe is a compiled language. Haxe is inspired by ActionScript, Java, and OCaml.[13]

Since Haxe had its origins in ActionScript 3, all of the existing Flash API can be used, although Haxe requires better-formed code and programming standards than Adobe compilers (for example, with regard to scoping and data typing).

Type system

Haxe is statically typed. It has a rich type system that offers classes, interfaces, function/method types, anonymous types, algebraic data types (ADTs, called enum in Haxe), abstract types. Classes, ADTs and function types allow parametric polymorphism based on type erasure, sometimes also called Generics in object-oriented programming languages.

Bounded quantification is also part of the feature set: type parameters can be constrained to a set of zero or more types.

Haxe doesn't offer variance annotations for type parameters, the type constructors are always invariant in their parameter types.

Subtype polymorphism is supported via standard, single-inheritance.

Further, Haxe supports both structural typing and nominal typing. To ease the burden on the programmer, without sacrificing type safety, Haxe supports type-inference, which in many cases alleviates the need to write out types explicitly.

Classes

Classes (keyword "class") in Haxe are similar to those in Java or ActionScript 3. Their fields can be either methods, variables or properties, each static or per instance respectively. Haxe supports the accessors "public" and "private", as well as more advanced methods for access control (ACL, link), that are denoted using annotations. Methods and static variables of constant values can be inlined using the "inline" keyword.

Interfaces in Haxe are very similar to those in, for example, Java.

interface ICreature {
    public var birth:Date;
    public var name:String;

    public function age():Int;
}

class Fly implements ICreature {
    public var birth:Date;
    public var name:String;
	
    public function age():Int return Date.now().getFullYear() - birth.getFullYear();
}

Enumerated types

Enumerated types are a key feature of the language; they can have parameters of their own and can be recursive.[38] They are similar to algebraic data types (ADT) in languages like ML or Haskell. Technically speaking, they are proper sum types, with the provision that the product types they include must be defined within them. This means they are not simply indexed "magic-number" values as in most languages, and can be used to elegantly solve complex programming problems:

enum Color {
    red;
    green;
    blue;
    rgb( r : Int, g : Int, b : Int );
}

class Colors {
    static function toInt ( c : Color ) : Int {
        return switch ( c ) {
            case red: 0xFF0000;
            case green: 0x00FF00;
            case blue: 0x0000FF;
            case rgb(r, g, b): (r << 16) | (g << 8) | b;
        }
    }
    static function validCalls() {
        var redint = toInt(Color.red);
        var rgbint = toInt(Color.rgb(100, 100, 100));
    }
}

Haxe also supports parametrised enums types. Examples of this include Haxe standard library types Option[39] and Either:[40]

enum Option<T> {
    Some(v:T);
    None;
}

enum Either<L, R> {
    Left(v:L);
    Right(v:R);
}

Haxe also supports generalized algebraic data types (GADTs).[41][42]

Anonymous types

Anonymous types are defined by denoting their structure explicitly, they can be given an alias by using a type definition (keyword "typedef"):

typedef Anon = { a:Int, b:String, c:Float->Void };

Function types

Functions are first-class values in Haxe. Their type is denoted by using arrows between argument types, and the argument type(s) and return type respectively, as common in many functional languages. However, unlike in prominent examples like Haskell or the ML-family of languages, not all functions are unary functions (functions with one argument only), and in Haxe, functions can't be partially applied per default. Therefore, the following type signatures have different semantics than in the aforementioned languages. The type F is a function that takes an Int and a String as arguments, and returns a value of type Float.

The same notation in a language with unary functions only, would refer to a function that takes an Int as argument, and returns a function of Type String->Float.

Types F2 and F3 denote the same type. Both are binary functions that return a binary function of type F. For F3 the syntax to declare a function type within a function type is used.

typedef F = Int->String->Float;

typedef F2 = Int->String->F;
typedef F3 = Int->String->(Int->String->Float);

Abstract types

A concept called abstract types is the latest addition to the Haxe type system. They allow to reuse existing types for specific purposes, like implementing types for units of measurement, to greatly reduce the risk of mixing up values of the same underlying type, but with different meanings (e.g. miles vs. km). The term "abstract type" as it is used in Haxe refer to something different from a conventional abstract type.

The following example assumes that the metric system is the default, while a conversion to miles is necessary for legacy data. Haxe is able to automatically convert miles to kilometers, but not in the opposite direction.

abstract Kilometer(Float) {
    public function new(v:Float) this = v;
}
 
abstract Mile(Float) {
    public function new(v:Float) this = v;
    @:to public inline function toKilometer():Kilometer return (new Kilometer(this / 0.62137));
}
 
class Test {
  static var km:Kilometer;
  static function main(){
    var one100Miles = new Mile(100);
    km = one100Miles;
 
    trace(km); // 160.935
  }
}

As the example shows, no explicit conversion is required for the assignment "km = one100Miles;" to do the right thing.

Structural typing

Structural typing plays a major role in many functional programming languages, and only to a much lesser extent in common OOP languages. Unlike in (exclusively) nominative type systems, the equality of two types isn't established by some kind of name tag, but rather by the structure of a type. Structural types can be thought of as implicit interfaces:

class FooBar {

   public var foo:Int;
   public var bar:String;

   public function new(){ foo=1; bar="2";}

   function anyFooBar(v:{foo:Int,bar:String}) trace(v.foo);

   static function test(){
        var fb = new FooBar();
        fb.anyFooBar(fb);
        fb.anyFooBar({foo:123,bar:"456"});
   }
}

See also

Also on the Haxe platform:

Other languages that compile to JavaScript:

Other multi-platform languages:

References

  1. "Nicolas' announcement of spelling change on Haxe official mail list".
  2. 1 2 3 4 5 Ponticelli, Franco (2008-02-11). Professional haXe and Neko. Wiley. ISBN 0470122137.
  3. Ivanov, Michael (2011-05-24). Away3D 3.6 Cookbook. Packt Publishing Ltd. ISBN 1849512817.
  4. Doucet, Lars (2015-06-03). "Haxe/OpenFL for home game consoles". Gamasutra.
  5. 1 2 3 4 5 6 7 8 9 10 11 12 Introduction to the Haxe Standard Library, Haxe Docs
  6. Target Specific APIs, Introduction to the Haxe Standard Library, Haxe Docs
  7. 1 2 Haxe, iPhone & C++ At Last, GameHaxe website
  8. Dasnois, Benjamin (2011-07-26). HaXe 2 Beginner's Guide. Packt Publishing Ltd. ISBN 1849512574.
  9. Companies using Haxe, Haxe Docs
  10. 1 2 3 Doucet, Lars (2014-06-24). "Dear Adobe: Support Haxe, save your Tools". Gamasutra.
  11. Doucet, Lars (2014-03-18). "Flash is dead, long live OpenFL!". Gamasutra.
  12. 1 2 3 4 5 6 7 Grden, John; Mineault, Patrick; Balkan, Aral; Hughes, Marc; Arnold, Wade (2008-07-16). The Essential Guide to Open Source Flash Development. Apress. p. Chapter 9 (Using Haxe). ISBN 1430209941.
  13. 1 2 3 4 "Haxe Interview". Io Programmo. 2009-04-01: 1–6.
  14. Fisher, Matt (2013-01-01). HTML5 for Flash Developers. Packt Publishing Ltd. ISBN 1849693331.
  15. Server mode command-line : haxe --wait [host:]port
  16. AS3 vs haXe performance, SplashDust website
  17. AS3 Performance Optimization, Starling Wiki
  18. 1 2 Vadim Dyachenko (2013-12-05). "On "You can’t make good HTML5 games in Haxe"". Yellow After Life.
  19. Kaya, Talha (2014-07-04). "OpenFL & Haxe, A Bumpy Start". Gamasutra.
  20. "Haxe 3.2 Release". Github.
  21. "Haxe mailing list post on naming".
  22. MTASC Compiler, MTASC website
  23. "Haxe license page".
  24. "Haxe introduction page".
  25. Main Page, FlashDevelop Wiki, "first class support for Flash ActionScript (AS2 and AS3) and Haxe development"
  26. Haxe Support, FlashDevelop Wiki
  27. as3hx, AS3 to Haxe converter, Haxe source code repository
  28. CS2HX - C# to haXe converter, CodePlex project hosting
  29. Haxe Compiler Targets, Haxe docs, "ActionScript 3, Source"
  30. Haxe Compiler Targets, Haxe docs, "PHP, Source"
  31. Haxe Compiler Targets, Haxe docs, "C++, Source"
  32. Haxe Compiler Targets, Haxe docs, "Java, Source"
  33. Haxe Compiler Targets, Haxe docs, "C#, Source"
  34. Haxe Compiler Targets, Haxe docs, "Python, Source"
  35. "Blog post mentioning Android port progress".
  36. "How to get started with Haxe 2.06 and the webOS PDK [archived on WayBackMachine]".
  37. "Haxe language reference".
  38. "Haxe reference detailing the use of enum".
  39. "haxe/Option.hx at development · HaxeFoundation/haxe". Github.
  40. "haxe/Either.hx at development · HaxeFoundation/haxe". Github.
  41. "Language Features". Haxe - The Cross-platform Toolkit. Haxe Foundation. Retrieved 30 April 2015.
  42. "haxe/TestGADT.hx at development · HaxeFoundation/haxe". Github.
  43. "A Scala to JavaScript compiler".

External links

This article is issued from Wikipedia - version of the Sunday, January 24, 2016. The text is available under the Creative Commons Attribution/Share Alike but additional terms may apply for the media files.