mirror of
https://github.com/openhab/openhab-addons.git
synced 2025-01-10 15:11:59 +01:00
Updated readme, added how to generate i18n en properties file/kar files/use -pl option (#12757)
* Updated readme, added how to generate i18n en properties file/kar files/use -pl option - Also put command in blocks to make them stand out more in the readme. Signed-off-by: Hilbrand Bouwkamp <hilbrand@h72.nl>
This commit is contained in:
parent
688dad0be8
commit
4372c007cd
72
README.md
72
README.md
@ -63,7 +63,25 @@ You find the following repository structure:
|
|||||||
|
|
||||||
To build all add-ons from the command-line, type in:
|
To build all add-ons from the command-line, type in:
|
||||||
|
|
||||||
`mvn clean install`
|
```shell
|
||||||
|
mvn clean install
|
||||||
|
```
|
||||||
|
|
||||||
|
Most of the time you do not need to build all bindings, but only the binding you are working on.
|
||||||
|
To simply build only your binding use the `-pl` option.
|
||||||
|
For example to build only the astro binding:
|
||||||
|
|
||||||
|
```shell
|
||||||
|
mvn clean install -pl :org.openhab.binding.astro
|
||||||
|
```
|
||||||
|
|
||||||
|
If you have a binding that has dependencies that are dynamically as specified in the feature.xml you can create a `.kar` instead of a `.jar` file.
|
||||||
|
A `.kar` file will include the feature.xml and when added to openHAB will load and activate any dependencies specified in the feature.xml file.
|
||||||
|
To create a `.kar` file run maven with the goal `karaf:kar`:
|
||||||
|
|
||||||
|
```shell
|
||||||
|
mvn clean install karaf:kar -pl :org.openhab.binding.astro
|
||||||
|
```
|
||||||
|
|
||||||
To improve build times you can add the following options to the command:
|
To improve build times you can add the following options to the command:
|
||||||
|
|
||||||
@ -76,19 +94,63 @@ To improve build times you can add the following options to the command:
|
|||||||
| `-Dspotless.check.skip=true` | Skip the Spotless code style checks |
|
| `-Dspotless.check.skip=true` | Skip the Spotless code style checks |
|
||||||
| `-o` | Work offline so Maven does not download any updates |
|
| `-o` | Work offline so Maven does not download any updates |
|
||||||
| `-T 1C` | Build in parallel, using 1 thread per core |
|
| `-T 1C` | Build in parallel, using 1 thread per core |
|
||||||
|
| `-pl :<add-on directory>` | Build a single add-on |
|
||||||
|
|
||||||
For example you can skip checks and tests during development with:
|
For example you can skip checks and tests during development with:
|
||||||
|
|
||||||
`mvn clean install -DskipChecks -DskipTests`
|
```shell
|
||||||
|
mvn clean install -DskipChecks -DskipTests -pl :org.openhab.binding.astro
|
||||||
|
```
|
||||||
|
|
||||||
Adding these options improves the build time but could hide problems in your code.
|
Adding these options improves the build time but could hide problems in your code.
|
||||||
Parallel builds are also less easy to debug and the increased load may cause timing sensitive tests to fail.
|
Parallel builds are also less easy to debug and the increased load may cause timing sensitive tests to fail.
|
||||||
|
|
||||||
To check if your code is following the [code style](https://www.openhab.org/docs/developer/guidelines.html#b-code-formatting-rules-style) run: `mvn spotless:check`
|
#### Translations
|
||||||
To reformat your code so it conforms to the code style you can run: `mvn spotless:apply`
|
|
||||||
|
Add-on translations are managed via [Crowdin](https://crowdin.com/project/openhab-addons).
|
||||||
|
The English translation is taken from the openHAB-addons GitHub repo and automatically imported in Crowdin when changes are made to the English i18n properties file.
|
||||||
|
When translations are added or updated and approved in Crowdin, a pull request is automatically created by Crowdin.
|
||||||
|
Therefore translations should not be edited in the openHAB-addons repo, but only in Crowdin.
|
||||||
|
Otherwise translation are overridden by the automatic process.
|
||||||
|
|
||||||
|
To fill the English properties file run the following maven command on an add-on:
|
||||||
|
|
||||||
|
```shell
|
||||||
|
mvn i18n:generate-default-translations
|
||||||
|
```
|
||||||
|
|
||||||
|
This command can also update the file when things or channel are added or updated.
|
||||||
|
|
||||||
|
In some cases the command does not work, and requires the full plug-in name.
|
||||||
|
In that case use:
|
||||||
|
|
||||||
|
```shell
|
||||||
|
mvn org.openhab.core.tools:i18n-maven-plugin:3.2.0:generate-default-translations
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
#### Code Quality
|
||||||
|
|
||||||
|
To check if your code is following the [code style](https://www.openhab.org/docs/developer/guidelines.html#b-code-formatting-rules-style) run:
|
||||||
|
|
||||||
|
```shell
|
||||||
|
mvn spotless:check
|
||||||
|
```
|
||||||
|
|
||||||
|
To reformat your code so it conforms to the code style you can run:
|
||||||
|
|
||||||
|
```shell
|
||||||
|
mvn spotless:apply
|
||||||
|
```
|
||||||
|
|
||||||
|
### Integration Tests
|
||||||
|
|
||||||
When your add-on also has an integration test in the `itests` directory, you may need to update the runbundles in the `itest.bndrun` file when the Maven dependencies change.
|
When your add-on also has an integration test in the `itests` directory, you may need to update the runbundles in the `itest.bndrun` file when the Maven dependencies change.
|
||||||
Maven can resolve the integration test dependencies automatically by executing: `mvn clean install -DwithResolver -DskipChecks`
|
Maven can resolve the integration test dependencies automatically by executing:
|
||||||
|
|
||||||
|
```shell
|
||||||
|
mvn clean install -DwithResolver -DskipChecks
|
||||||
|
```
|
||||||
|
|
||||||
The build generates a `.jar` file per bundle in the respective bundle `/target` directory.
|
The build generates a `.jar` file per bundle in the respective bundle `/target` directory.
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user