-
Notifications
You must be signed in to change notification settings - Fork 22
How To Build
- Overview
- Console (very easy)
- Eclipse
- Project Structure
- Build Addons
- Build Translations
for the console build you can just download maven and compile from console and use whatever ide you like.
or you can use eclipse to run it directly from eclipse and also build using eclipse PDE system (graphical) but also using maven (m2e) which is already integrated as a plugin in eclipse-ee.
we skip running all tests for now as some fail because they need to be improved to work without external websites (which changed) and a failure would stop the build process.
-
download latest jdk 8 like from here: http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html
-
download source code from https://github.com/Xyrio/RSSOwlnix either using git or as zip.
-
if you intend to use eclipse make sure you have another dirtyable parent folder for the eclipse workspace like: C:\rssowlnixprj\RSSOwlnix\README.md
-
note: macos binaries seem to have the wrong folder/file structure, look at how 2.2.1 is packaged or the bundle_b for later releases as to how the folder/file structure should be. ( https://github.com/Xyrio/RSSOwlnix/issues/4 )
build from console using maven then run standalone
- download maven binaries: https://maven.apache.org/download.cgi
- add maven's bin folder to your path or use absolute path to mvn
- you must set JAVA_HOME environment variable to point to your JDK root folder like C:\Program Files\Java\jdk1.8.0_161
- open console in RSSOwlnix root folder
- compile with: mvn clean verify -Dmaven.test.skip=true
- you can build only for certain operating systems if you edit releng\configuration\pom.xml environments
- binaries can be found inside releng\product\target\products
- p2 repository for updating is at releng\product\target\repsitory
in eclipse you have 2 ways to build, using maven or with eclipse's PDE build system.
- download latest Eclipse IDE for Java EE Developers: https://www.eclipse.org/downloads/eclipse-packages/
- start eclipse and use C:\rssowlnixprj\ as your workspace folder.
menu: Window | Preferences | Java | Installed JREs
- remove the entry (jre...)
- click add...
- Standard VM
- set JRE home to like: C:\Program Files\Java\jdk1.8.0_161
- check jdk
- Apply and Close
- menu: File | Import... | General | Existing Project Into Workspace...
- directory: C:\rssowlnixprj\RSSOwlnix\
- check Search for nested projects
- finish with all checked
- first time setup: in file tree on the left open RSSOwlnix folder and right click pom.xml then Run As/Maven build...
- Goals: clean verify -Dmaven.test.skip=true
- Apply then Run
- to build again click the downward triangle right of the biggest green play icon then RSSOwlnix.
- you can build only for certain operating systems if you edit releng\configuration\pom.xml environments
- binaries can be found inside releng\product\target\products
- p2 repository is at releng\product\target\repsitory
- open releng\target_platform\target_platform.target (every time you show the target_platform like this it will do a refresh of the view, showing you the selected dependencies)
- at top right, click to set as active target platform (only visible if not aktive platform)
- click reload target platform (or changes to the dependencies will not be available sometimes. they are cached somewhere)
- close the target platform window
- open releng\product_manual_export\rssowlnix.product
- at top right click on the icon for "Export an Eclipse Product"
- Root directory: RSSOwlnix
- Synchronize before exporting: off
- Directory:
- Generate p2 repository: on (repository cannot be used to update RSSOwlnix itself when exported like this but is needed for RSSOwlnix to be built correct)
- Export for multiple platforms: check this for an aditional step (Next button enables) ...
- Allow for binary cycles in target platform: on
- click Finish (or Next if you enabled export for multiple platforms)
- note: a exported version like this is not updateable, you have to export again. addons and translations can be installed.
note: p2 updating does not work when started like this.
- menu: Window | Show Window | Other | General | Problems : open \
- you can ignore the following kind of errors when launching:
- ignorable errors: if they are in org.rssowl.lib.httpclient.p2 (Resource column)
- ignorable error: The value for attribute 'name' is not externalized. (in org.rssowl.ui\plugin.xml)
- you can ignore the following kind of errors when launching:
- right click org.rssowl.ui\Launch RSSOwl.launch | Run As | Launch RSSOwl
- "Errors Exist in Required Project" if only ignorable errors click Proceed
- "Do you really want to clear log file?" Clear unless you want to keep error messages from a previous launch.
- Cannot locate JRE definition: "jdk1.8.0_151". Launch aborted. (or some other version) \
- fast way: double click "Launch RSSOwl.launch" to open it as text. search for the wrong JRE definition and replace it with the right one (that you configured before, see Configuring Eclipse) like jdk1.8.0_161
- slow way: menu: Run | Run Configuration... then select Eclipse Application | Launch RSSOwl on tab Main select for Runtime JRE the JDK you want to use.
- menu: Help | Install New Software...
- choose the url that is for updates like: http://download.eclipse.org/eclipse/updates/4.7
- install plugin in eclipse "Eclipse Test Framework" to be able to run tests direclty from eclipse
- close any running RSSOwl or RSSOwlnix instance, event outside of eclipse or some tests may not work.
- right click the test file "Launch RSSOwl Tests.launch" Run As | Launch RSSOwl Tests
- note: for some tests to run you may have to close any running RSSOwl or RSSOwlnix instance, event outside of eclipse.
- find the test you want to run in org.rssowl.core.tests\src
- right click the test file: Run As | JUnit Plug-in Test
- feature: eclipse feature project, used to collect everything into one, makes updating easier. project doesnt contain code.
- plugin: eclipse plugins are the projects with code or ressources.
- org.rssowl.lib.* are plugin projects to make normal jars usable within eclipse rcp (osgi compatible).
Folder | Description |
---|---|
bundles | eclipse plugins (maven) |
features | eclipse features (maven) |
org.rssowl.core | core code with some dependencies on eclipse |
org.rssowl.core.tests | core tests with dependencies on eclipse |
org.rssowl.docs | old docs, plans and overviews. some may still be useful. |
org.rssowl.feature | collects stuff from this project |
org.rssowl.feature.dependencies | collects external dependencies |
org.rssowl.feature.dependencies.updater | collects external dependencies for the updater |
org.rssowl.feature.eclipse | collects stuff for installing as a plugin into eclipse official program (not tried yet after 2.2.1) |
org.rssowl.feature.tests | collects stuff for tests |
org.rssowl.lib.db4o | lib for the object database named db4o |
org.rssowl.lib.httpclient | lib for http* connections |
org.rssowl.lib.httpclient.p2 | helper project to easyly download http jars from maven repository and make them osgi compatible. they are then moved over to the other httpclient project. |
org.rssowl.lib.jdom | lib for understanding xml files |
org.rssowl.lib.lucene | lib for searching |
org.rssowl.ui | gui code for the program |
releng | release engeneering (maven) |
releng/configuration | configuration, has list of target operating systems to build for (maven) |
releng/product | product file (maven) |
releng/product_manual_export | product file for manual exporting the (eclipse way) |
releng/target_platform | defines which external dependencies to download (eclipse way) (used by maven tycho) |
releng/update | generates a repository for program updates (maven) |
RSSOwlnix | root (maven) |
- TODO
- TODO