# Eclipse IDE

Eclipse is the development environment used since the inception of openHAB. To make development easier an out-of-the-box setup is available that completely configures Eclipse to easily develop for the openHAB projects. This guide describes the steps to setup Eclipse and how to debug an add-on in Eclipse.

# Eclipse IDE Setup

  1. Install the Java 8 JDK if you did not have it installed.

    Attention

    openHAB development requires Java JDK version 8.

  2. Download the "Eclipse Installer": can be downloaded from the Eclipse web site

  3. Launch the Installer and on the menu on the top right (3 bars)

    installer

  4. Select ADVANCED MODE...

    installer

  5. Select Eclipse IDE for Java Developers. Select Next >.

    select

  6. Under GitHub Projects > openHAB select openHAB Development and any desired option from openHAB Add-ons (includes all add-ons from openhab-addons repo), openHAB ZigBee Binding or openHAB Z-Wave Binding.

    select projects

    Selection Install if Branches
    openHAB Development Debug/Demo Environment (Required) 2.5.x, 3.0
    openHAB Add-ons Add-ons Development 2.5.x, 3.0
    openHAB ZigBee Binding ZigBee Binding Development 2.5.x, 3.0
    openHAB Z-Wave Binding Z-Wave Binding Development 2.5.x, 3.0
    openHAB BACNet Binding BACNet Binding Development
    openHAB Web UIs Web UIs Development 2.5.x, 3.0
    openHAB Core Framework Core Framework Development 3.0

    Attention

    Select 2.5.x if you want to develop for 2.5.x. The Core Framework only has a master branch (3.0 development).

  7. Click Next>, verify/modify Root and install folder name. Click on Show all variables to open the window shown below.

    variables

    Explanation of some of the variables

    • Root install folder: The base folder where the Installation folder will be placed.
    • Installation folder name: This is the directory in the root install folder everything will be installed in.
    • GitHub user ID: This is your GitHub user name used to configure the cloned Git projects.
  8. Click Next> and Finish to start installation.

    During install accept licence agreement, "Unsigned Content" for Bndtools, and Eclipse Foundation certificates when requested to complete IDE installation.

  9. At this point the Eclipse installer is finished and the Eclipse IDE is automatically launched to continue the installation process.

    Attention

    It is important, during the first Eclipse IDE launch, to leave Eclipse open until all openHAB related initial Setup tasks / Download sources / Builds are completed.

    Setup tasks will personalize the IDE with openHAB code formatting tools, configurations and a demo app. Setup tasks will also download openHAB latest projects you have selected during installation. Like openhab-distro and the add-ons openhab-addons project if you have selected it.

    Click bottom right button in the IDE for Progress.

    startup tasks finished

  10. After all tasks are finished you are ready to start developing.

    TIP

    The Maven build system is configured to download the SNAPSHOT version daily. As a result when you restart Eclipse the other day. It may take some time as it updates all SNAPSHOT versions of openHAB.

  11. If you have selected openHAB Add-ons the installer will clone the openHAB Add-ons repository. To get an existing binding project into Eclipse import it as a Maven project. Goto File -> Import... -> Maven -> Existing Maven projects and follow the wizard to select the directory of the binding or bindings to import.

  12. If you want to develop a new binding. Read about the Skeleton Script to generate the base for your binding, creating all required files.

  13. If you need additional libraries see the Build System documentation. For other libraries supported out-of-the-box check the Default Libraries on the guidelines page.

# Debugging an Add-on

To test your binding you can build the add-on on the command line with Maven and drop the jar file in an addons/ folder of an existing installation. But to easily debug an add-on the openHAB Development setup installs and imports a demo project that contains a complete openHAB environment to run and debug an add-on.

Under Infrastructure you will find the project org.openhab.demo.app. This project contains the full configuration to start a debug sessions. The following files are of interest for the debug environment:

|- org.openhab.demo.app
|--- runtime
|------- conf             Here you configure the manual text files
|------- userdata         Here is the openHAB user data
|------- logback.xml      XML file for logging options
|--- app.bndrun           The file to start a debug session
|--- pom.xml              The pom file with all dependencies for the demo project
  1. Import the add-on in Eclipse. Either it is an existing add-on or a new binding created with the skeleton script. Import the add-on project via File > Import... > General > Existing Projects into Workspace. Importing an add-on is necessary if you want to modify or debug the add-on. It is also possible to run existing add-ons part of the SNAPSHOT release in the demo project without having it imported in Eclipse. Simply follow the next step to add the add-on.

  2. To let the demo project know about the add-on, the add-on must be added to the demo project pom.xml. Here is an example for the astro binding:

        <dependency>
        <groupId>org.openhab.addons.bundles</groupId>
        <artifactId>org.openhab.binding.astro</artifactId>
        <version>${project.version}</version>
        <scope>runtime</scope>
        </dependency>
    

    TIP

    To only run a binding in the demo you don't need to import the binding in Eclipse. Add the binding to the pom.xml and follow the steps below and you will be able to use that binding in the demo.

  3. To debug the add-on with the app.bndrun run configuration. Double click to open app.bndrun file (takes a few seconds):

    Bndtools

  4. Under Browse Repos search for the binding you want to run/debug (astro in our case) and add it to the Run Requirements list using drag&drop from the Browse Repos list:

    TIP

    If you cannot find the binding you want run/debug in the Browse Repos list, or the list is empty, then it is likely either the pom.xml of the demo project contains an error or there is a build problem with your project. Check if your project has no compile errors. Or run Maven on the command line to check if it reports any errors.

    app.bndrun

  5. Save and click "Resolve": a window with the list of resolved bundles will be shown. Click Finish and save the file.

    Now the IDE is ready to start openHAB with a minimum set of the openHAB core bindings, UIs and the selected binding you want to run/debug.

  6. Start openHAB from the IDE clicking "Run OSGi" or "Debug OSGi" (upper right of the app.bndrun window)

  7. You can check openHAB is running going with your browser to: http://localhost:8080/paperui/ (the last / is important!)

  8. Check the chosen binding is active in Paper UI > Configuration > Bindings

# From start to debug in a single animation

Debug Animation