Go to file
Holger Friedrich 673da56ad1
Java 21 for OH5 development (#2426)
* Java 21 for OH5 development

Signed-off-by: Holger Friedrich <mail@holger-friedrich.de>

* rework after OH5 release

Signed-off-by: Holger Friedrich <mail@holger-friedrich.de>

* review comment

Signed-off-by: Holger Friedrich <mail@holger-friedrich.de>

---------

Signed-off-by: Holger Friedrich <mail@holger-friedrich.de>
2025-01-09 13:03:55 +01:00
.github add markdown info for contribution, reformat (#2162) 2023-11-19 18:09:44 +01:00
.vuepress Update doc preview infrastructure (#2444) 2025-01-06 12:16:05 +01:00
addons Updates the iOS documentation (#2331) 2024-07-16 22:05:19 +02:00
administration Link to Java 21 documentation (#2433) 2024-12-22 11:35:06 +01:00
appendix Fix markdownlint (#2322) 2024-06-26 22:58:24 +02:00
community Remove redundant/outdated content (#271) 2017-01-25 15:11:56 +01:00
concepts Add documentation for new units (#2420) 2024-12-08 10:20:55 +01:00
configuration Java 21 for OH5 development (#2426) 2025-01-09 13:03:55 +01:00
developers Java 21 for OH5 development (#2426) 2025-01-09 13:03:55 +01:00
images [huesync][binding][logo] Add logo for huesync binding to repository (#2408) 2024-12-08 12:16:52 +01:00
installation Java 21 for OH5 development (#2426) 2025-01-09 13:03:55 +01:00
mainui Main UI Setting: Document dirty indicator (#2345) 2024-08-06 15:46:57 +02:00
tutorials Fixed RulesDSL broken link (#2441) 2025-01-05 09:09:25 +01:00
ui Link to Java 21 documentation (#2433) 2024-12-22 11:35:06 +01:00
.editorconfig Fix .editorconfig (#1992) 2023-01-27 10:07:16 +01:00
.gitignore Update and improve quality of a few addon logos (#1549) 2021-04-21 20:09:23 +02:00
.markdownlint.yaml Improve markdown linting (#1906) 2022-11-03 18:43:14 +01:00
.nvmrc Update doc preview infrastructure (#2444) 2025-01-06 12:16:05 +01:00
.ruby-version Update doc preview infrastructure (#2444) 2025-01-06 12:16:05 +01:00
LICENSE Create LICENSE (#796) 2018-10-23 09:45:46 +02:00
README.md Update doc preview infrastructure (#2444) 2025-01-06 12:16:05 +01:00
favicon.ico added a round white background to the favicon 2017-10-27 17:59:20 +02:00
introduction.md Use SVG openHAB logo (#2305) 2024-06-06 07:47:10 +02:00
netlify.toml [CI/CD] - The preview link created by the pipeline point to an empty page (#2271) 2024-03-08 18:43:03 +01:00
package-lock.json Update doc preview infrastructure (#2444) 2025-01-06 12:16:05 +01:00
package.json Update doc preview infrastructure (#2444) 2025-01-06 12:16:05 +01:00
prepare-docs.rb Update doc preview infrastructure (#2444) 2025-01-06 12:16:05 +01:00
styleguide.md [Enhancement] - Simplify local builds to lower bar for beginners #2215 (#2218) 2024-03-02 11:03:26 +01:00

README.md

openHAB Documentation Project

Introduction

This repository contains the documentation for openHAB.x.

The result is available at https://openhab.org/docs/ and https://openhab.org/addons/.

How it works

In this repo you can find and improve all general documentation contents. In fact, that is all you can see in the main branch. There are other read-only branches, which hold external content like the add-ons and concepts documentation, which is explained in more details below.

So I cannot improve an add-on article here?

Correct, this is done in the original repository of the add-on. You may want to know how to find the right file in all of those repos? This is fairly easy: on most of the documentation pages on https://openhab.org/, you will find the following link at the bottom, which will point you directly to the file you want to improve.

Contribution link to a specific page

When your improvement has been made and merged, we will get the updated article automatically through our build mechanism. This happens mostly once a day. Afterwards your change is included in the next build of the openHAB website.

Contributing to the Documentation

The documentation is a community effort, so everyone is welcome to suggest changes, add new sections and fix bugs. This is done exactly the same way as for the code repositories, simply through pull requests against this repo. When editing a page through the "Edit this page on GitHub" link on the website, you will be given the opportunity to create a pull request directly from GitHub. Please read our contribution guidelines and try to follow them as best as you can before submitting a change for review - but don't worry if you don't understand all of them, we will help you to get it right.

So what are the other branches for?

We use them to bring together all relevant articles or to archive versioned content. Mostly those branches will get updated automatically through our continuous integration builds. You can read a bit more below about our external resources and how we get them.

Automatically Generated Parts

Those parts include all add-on documentation files, no matter if they are from the openhab-core repo, the openhab-addons repo or any special binding repo like habmin, zwave or the alexa skill.

We are keeping all those files at their original location, because it simply doesn't make sense to keep them here. Imagine you want to do an improvement of the zwave binding and have to update the readme file in a completely different place. That's twice the effort and also we would have to coordinate two Pull Requests. So we are saving time for everyone by keeping those files at their original location along with the code.

How the documentation build works

We have set up our build server to do the magic automatically. There are several triggers (mostly time based), which will then gather the external contents and move them to our final branch. You can find this migrated external content in the final branch under:

  • _addons_*
  • concepts

You can even have a look at how this works in detail. The external content is updated by the following toolchain:

  • update-external-resources.shpom.xmlprocess_addons.groovy

Everything that gets updated in the master branch will be also merged over to the final branch automatically. Afterwards we will redeploy the website with the latest content from the final branch at regular intervals.

Build triggers investigated

There are two triggers available currently. The merge docs job is triggered after something has been added to the documentation through this repository. The gather external docs job is started with a successful build of the openhab-distribution. A successful distribution build will include all the latest changes that have been made to external sources like add-ons. So when a distribution build is successful, it will trigger the gathering of all external sources.

When one of these jobs is finished, it will then notify our website hosting service to start a new website build. This is recognized due to new commits in the final branch of this repository. The new build will include all the latest changes in the code repository and in all external repositories.

How to build the documentation locally

It is possible to build a preview version of the documentation on your local machine. The following software is required:

We recommend to use Node Version Manager as well as Ruby Version Manager to easily allow using multiple versions of NodeJS and Ruby for multiple projects. If you don't do that, you can simply start by only installing the above mentioned versions.

When using nvm and/or rvm, setup the NodeJS and/or Ruby version:

nvm use
rvm use

If nvm and/or rvm complain about the required versions not being installed, you can install them as following:

nvm install 16.20.1
rvm install ruby-3.3.2

Next, you can build & serve the documentation preview:

npm run serve-preview

The local preview is available under the following URLs:

This will also allow you to preview how the page renders on different devices using the respective browser tools:

local preview

Documentation Versioning

Just as openHAB is released in versions, the documentation website provides fixed versions of the documentation articles, e.g., https://www.openhab.org/v2.2/installation/linux.html

Please see this issue for all details regarding the tagging and branching approach. In short, the following has to be considered:

  • Versions like "2.1.0" are marked by git tags.
  • Based on tags branches like "2.1-patch" are created, to include later discovered changes (like fixed links).

When a version is tagged (or updated), a static version of the website has to be generated and copied into the correct sub-folder, this is currently a manual operation described succinctly here: https://github.com/openhab/website/issues/72