Getting started with haxe

Other topics

Remarks:

Haxe is an open source toolkit that is capable of compiling to many different target languages and platforms.

It consists of:

  • the Haxe programming language - a modern, high-level, and strictly typed programming language
  • the Haxe standard library - a collection of general purpose, system, and target-specific APIs
  • the Haxe compiler - a fast, optimising cross-compiler with metadata support, dead code elimination (DCE), completion mode, resource embedding, runtime type information (RTTI), static analyzer, macros, and more

Haxe has been used to create games, web, mobile, desktop, and command-line applications, as well as cross-platform APIs.

As of Haxe 3.3.0-rc.1, Haxe can compile to sources / bytecode of the following languages: ActionScript 3, C#, C++, Flash, HL, Lua, Java, JavaScript, Neko, PHP, and Python.

Haxe has a package manager, Haxelib, which is bundled with Haxe. It also has a custom build file format, .hxml, which offers an easier way of passing arguments passed to the Haxe compiler.

References

Installation

Haxe is available on Windows, Linux, and OS X. It is distributed in two forms:

  • as an installer, providing an optional Neko VM dependency and configuring haxe and haxelib environment variables;
  • as binaries, providing only the Haxe compiler and package manager.

Windows

Installer and binaries are available from the Haxe website.

Linux

Binaries (32-bit and 64-bit) are available from the Haxe website.

The Haxe Foundation also officially participates in the maintenance of Haxe and Neko packages for popular Linux distributions. It is recommended to use those packages if available.

Ubuntu

It is recommended to use the Haxe PPA which provides latest Haxe and Neko releases for all currently supported Ubuntu versions. The PPA can also be used for Ubuntu-based distributions.

sudo add-apt-repository ppa:haxe/releases -y
sudo apt-get update
sudo apt-get install haxe -y
mkdir ~/haxelib && haxelib setup ~/haxelib

Note that Neko is installed as a dependency of Haxe.

Debian

To install the currently available stable versions, run the following commands:

sudo apt-get install haxe -y
mkdir ~/haxelib && haxelib setup ~/haxelib

Note that Neko will be installed as a dependency of Haxe.

To install newer releases from the unstable channel, do the following:

  1. In /etc/apt/sources.list, add

    deb http://httpredir.debian.org/debian unstable main contrib non-free

  2. In /etc/apt/preferences.d/, create a new file named unstable with the following content:

    Package: *
    Pin: release a=unstable
    Pin-Priority: 100
    
    Package: haxe neko libneko*
    Pin: release a=unstable
    Pin-Priority: 999
    
  3. Pull package index files from the newly added source:

    sudo apt-get update

  4. Install Haxe (and Neko):

    sudo apt-get install haxe -y

Fedora

The Haxe Foundation maintains the Haxe and Neko RPM packages in the Fedora repository. The packages are up-to-date most of the time. However, when a new version of Haxe is released, it will take a few days, up to 2 weeks, to push an updated package to the stable releases of Fedora. The update activities can be tracked in the Bodhi Fedora Update System.

To install the currently available versions of Haxe and Neko, run the following commands:

sudo dnf install haxe -y
mkdir ~/haxelib && haxelib setup ~/haxelib

Note that Neko is installed as a dependency of Haxe.

openSuse

The Haxe Foundation maintains the Haxe and Neko RPM packages in the openSUSE:Factory repository. The packages are up-to-date most of the time. However, when a new version of Haxe is released, it will take a few days, up to 2 weeks, to be accepted by openSUSE:Factory.

To install currently available versions of Haxe and Neko, run the following commands:

sudo zypper install haxe
mkdir ~/haxelib && haxelib setup ~/haxelib

Note that Neko is installed as a dependency of Haxe.

To get the lastest Haxe version that may not available to openSUSE:Factory or an openSUSE release, use the devel:languages:haxe project in the openSUSE Build Service. Visit the Haxe package page, click "Download package" at the top-right corner and follow the instructions. Again, Neko will also be installed as a dependency of Haxe.

Arch Linux

There are Haxe and Neko packages in the Arch Linux community repository. The Haxe Foundation will continue to help keep the packages up-to-date. However, when a new version of Haxe is released, it will take time to update the package, depended on the availability of the package maintainer.

For currently available versions of Haxe and Neko, check the following pages:

To install the currently available versions of Haxe and Neko, run the following commands:

sudo pacman -S haxe
mkdir ~/haxelib && haxelib setup ~/haxelib

Note that Neko is installed as a dependency of Haxe.

OS X

Installer and binaries are available from the Haxe website.

It is also possible to install the current stable Haxe version through the Brew package manager.

brew install haxe

References

Hello World

Requirements

  1. A version of the Haxe toolkit must be installed
  2. Haxe must be present in your system path
  3. Command line must be accessible

Code

Navigate to a desired project directory and create a Test.hx source file with the following content:

class Test {
    static function main() {
        trace("Hello world");
    }
}

Haxe source files are called modules. A module should define a type (abstract, class, enum, interface, or typedef) with the same identifier as the module name - in this case the Test class. Once that requirement is met, a module can define an arbitrary number of different types.

Haxe programs require an entry point, as denoted by the static main function. The class implementing the entry point is the startup class or main class. Again, in this case the main class is the Test class.

The trace() function is a general purpose logging function exposed to the global namespace for the sake of convenience. It outputs to the target language's standard output handle (e.g. browser console for JavaScript, command line for C++). See the API documentation for more information.

Execution

Navigate to the project folder from your command line. Test to see if Haxe is configured in your environment by calling:

haxe --help

The Haxe interpreter can be used to test code that does not rely on any specific target language API. Use the interpreter by calling:

haxe -main Test --interp

Remember, the Test module contains the Test startup class, which is why -main Test is passed to the compiler.

Haxe sources can compile (transpile) to sources / bytecodes of several different languages. The following table displays the target language, compiler flag, argument type, and compilation result. Use it by calling:

haxe -main Test [flag] [argument].

LanguageFlagArgumentResult
ActionScript 3-as3DirectorySource
C#-csDirectorySource + optional bytecode (.exe)
C++-cppDirectorySource + optional binary (native)
Flash-swfFileBytecode (.swf)
HL-hlFileSource
Lua-luaFileSource
Java-javaDirectorySource + optional bytecode (.jar)
JavaScript-jsFileSource
Neko-nekoFileBytecode (.n)
PHP-phpDirectorySource
Python-pythonFileSource
HashLink-hlFileBytecode (.hl)

Note that the path arguments here are relative to the path haxe was called from. The optional bytecode/binary outputs can be opt-outed by adding the -D no-compilation flags, in order to avoid an additional compilation step involving calling the target language's compiler.

References

Contributors

Topic Id: 2593

Example Ids: 8591,11285

This site is not affiliated with any of the contributors.