4 | | == Overview == |
5 | | |
6 | | || ||= OS Independent =||= [http://www.java.com/en/download/faq/java_webstart.xml Web Start] =||= Windows =||= Mac OS X =||= Ubuntu, … =|| |
7 | | ||= **tested** [[Version(tested)]] =|| **[/josm-tested.jar jar ]** || [/download/josm.jnlp jnlp] || [/download/windows/josm-setup.exe setup.exe] ([wiki:USB_Stick portable]) || [/download/macosx/josm-macosx.zip package.zip] || ''[#Ubuntu see below]'' || |
8 | | ||= latest [[Version(latest)]] =|| [/josm-latest.jar jar] || [/download/josm-latest.jnlp jnlp] || || || ''[#Ubuntu see below]'' || |
9 | | ||= older =|| [/download/ download/] || || || || || |
10 | | |
11 | | * **Which version should I use?** (see also: [wiki:Releases release system]) |
12 | | * ''tested'' is released approx. monthly and shouldn't contain severe bugs |
13 | | * ''latest'' is released daily, may have more errors |
14 | | * If possible, use the Web Start version in order to automatically update. |
15 | | |
16 | | ---- |
17 | | |
18 | | * **Note that there are fairly regular updates, so always try running a recent version (and also recent plugins).** |
19 | | * Access [/download/josm.jnlp JOSM-WebStart] without installation |
20 | | * Download the **[/josm-tested.jar tested JOSM ]** version [[Version(tested)]] |
21 | | * Download the [/download/windows/josm-setup.exe Windows JOSM installer] version [[Version(windows)]] |
22 | | * Download the [/download/macosx/josm-macosx.zip Mac OS X JOSM package] version [[Version(macos)]] |
23 | | * Prepare a [wiki:USB_Stick USB flash drive] to use JOSM on any foreign Windows machine. |
24 | | * For download scripts use version check for [/latest latest] and [/tested tested] (or [/version both]) to reduce download bandwith |
25 | | * If download size is an issue for you, you may append `?lang=..` to the download link for both releases to strip all unused translations (e.g. `?lang=de` would download JOSM in German language only). |
26 | | |
27 | | == Development Version == |
28 | | |
29 | | * Download the **[/josm-latest.jar latest JOSM]** version [[Version(latest)]] (may have more errors than "tested", be careful with this one). |
30 | | |
31 | | == Applet == |
32 | | |
33 | | * Try **[/applet JOSM applet]** after reading the [wiki:Applet applet description]. |
34 | | |
35 | | == Source == |
36 | | |
37 | | * Get the source: |
38 | | * From the official Subversion repository (recommended): {{{svn co http://josm.openstreetmap.de/svn/trunk}}} |
39 | | * From the unofficial [http://github.com/openstreetmap/josm GitHub mirror]: {{{git clone git://github.com/openstreetmap/josm.git}}} |
40 | | * From the official OSM Subversion repository (including plugins): {{{svn co http://svn.openstreetmap.org/applications/editors/josm josm}}} |
41 | | |
42 | | == Ubuntu repository ==#Ubuntu |
43 | | |
44 | | The repository for Ubuntu contains two packages: |
45 | | {{{josm}}}:: ''The tested version''[[br]] |
46 | | Replaces the package from the official Ubuntu repository. |
47 | | {{{josm-latest}}}:: ''The development version (nightly build)''[[br]] |
48 | | Can be installed parallel to the {{{josm}}} package. The default preference folder is {{{~/.josm-latest}}}. |
49 | | === Installation === |
50 | | Depending on your Ubuntu-Version, add one of the following lines to your {{{/etc/apt/sources.list}}}: |
| 6 | This page provides basic JOSM installation steps and troubleshooting information. |
| 7 | To start working with JOSM please see the [wikitr:/Introduction] and the [wikitr:/Help] pages. |
| 8 | And for very complex issues see [wikitr:/InstallNotes Installation Notes]. |
| 9 | |
| 10 | == Recommended options ==#Recommendedoptions |
| 11 | [[JOSMImage(openlocation, valign=middle, link=[download/josm.jnlp])]] **Start [/download/josm.jnlp josm.jnlp]** (newest tested version) \\ |
| 12 | Recommended version, all platforms, automatic update to the newest ''tested version'' monthly ([#Webstart how to start]). \\ \\ |
| 13 | |
| 14 | [[JOSMImage(download, valign=middle, link=[/josm-tested.jar])]] **Download [/josm-tested.jar josm-tested.jar]** (tested version [[Version(tested)]]) \\ |
| 15 | All platforms ([#Java how to run]). \\ \\ |
| 16 | |
| 17 | |
| 18 | == All download options ==#Moredownloadoptions |
| 19 | Every [/roadmap month] the team of JOSM [wikitr:/Releases releases] a **tested version** for download. |
| 20 | The MS Windows and Apple macOS variants are built on this tested version. |
| 21 | When you click on josm.jnlp to launch JOSM you will always get the newest tested version. Java's [wikitr:/InstallNotes#Webstart Web Start] is the mechanism behind this. |
| 22 | |
| 23 | [=#DevelopmentVersion] |
| 24 | Every [/log/josm/?verbose=on&limit=20 night] the build systems generate a **latest version**. |
| 25 | These versions might have severe errors. But mostly they work well, too. |
| 26 | For the latest version is also a Web Start variant available. |
| 27 | |
| 28 | ||= =||||= **For all operating systems** =|||||||| ||= **Development** =|| |
| 29 | ||=**Version** =||= **Web Start** =||= **Download** =||= **Windows** =||= **Apple macOS** =||= **Ubuntu, Debian…** =||= **openSUSE** =||= **Jar / Javadoc / Source** =|| |
| 30 | ||**tested [[Version(tested)]]** || \ |
| 31 | || [/download/josm.jnlp josm.jnlp] || \ |
| 32 | || [/josm-tested.jar] || \ |
| 33 | || \\ [/download/windows/josm-setup.exe josm-setup.exe] \\ [/download/windows/josm-setup.msi josm-setup.msi] \\ [https://apps.microsoft.com/store/detail/josm/XPFCG1GV0WWGZX Microsoft Store]\\ ''([#Mswindowswrapper see below])'' || \ |
| 34 | || \\ [/download/macosx/josm-macosx.zip JOSM macOS .zip package] \\ ''or ([#macOS homebrew])'' || \ |
| 35 | || ''[#Ubuntu see below]'' || \ |
| 36 | || ''[#Opensuse see below]'' || \ |
| 37 | || [/nexus/content/groups/public/org/openstreetmap/josm/josm/ josm]:[[Version(tested)]] || |
| 38 | ||**latest [[Version(latest)]]** || \ |
| 39 | || [/download/josm-latest.jnlp latest.jnlp] || \ |
| 40 | || [/josm-latest.jar] || \ |
| 41 | || ''see [https://github.com/openstreetmap/josm/releases releases on github] || \ |
| 42 | || ''see [https://github.com/openstreetmap/josm/releases releases on github] || \ |
| 43 | || ''[#Ubuntu see below]'' || || \ |
| 44 | || [/nexus/content/groups/public/org/openstreetmap/josm/josm/SNAPSHOT/ Use snapshots] || |
| 45 | ||=''**older**'' =|| || \ |
| 46 | || [/download/ download/] || \ |
| 47 | || ''see [https://github.com/openstreetmap/josm/releases releases on github] || \ |
| 48 | || ''see [https://github.com/openstreetmap/josm/releases releases on github] || \ |
| 49 | || [/apt/pool/universe/j/ pool/] || || \ |
| 50 | || [/nexus/content/groups/public/org/openstreetmap/josm/josm/ tested versions] || |
| 51 | |
| 52 | When running scripts please first check on [/latest latest], [/tested tested] or [/version all] to reduce download bandwidth. |
| 53 | |
| 54 | ** Strip translations **[=#Striptranslations] \\ |
| 55 | If download size is an issue, smaller files of the tested version are available. For downloads containing only English append [/josm-tested.jar?lang=en ?lang=en] to the URL. To include one translation replace `en` with the [wikitr:/TracLanguages language code] you want (lowercase first character, supported languages only). You can further reduce the file size by stripping the signing information off with appending [/josm-tested.jar?lang=en&unsigned=1 ?unsigned=1]. |
| 56 | |
| 57 | |
| 58 | == Linux Repositories == |
| 59 | === JOSM's Debian based mainly for Ubuntu ===#Ubuntu |
| 60 | This is our own package repository primarily for Ubuntu. It should also work with other Debian based (especially Ubuntu based) distributions, but we do not actively test and maintain any distributions other than Ubuntu. |
| 61 | |
| 62 | The repository contains two packages: |
| 63 | * ''josm'' – Provides the tested version (stable). Replaces the package from the official repository of your distribution. The default JOSM directories name is set to `JOSM`. |
| 64 | * ''josm-latest'' – The latest version (nightly). Can be installed in parallel to the josm package, therefore the default JOSM directories name is set to `JOSM-latest`. |
| 65 | Both packages provide `/etc/default/josm` respectively `/etc/default/josm-latest` as config file for [wikitr:Help/CommandLineOptions#Javaoptions java options]. |
| 66 | |
| 67 | In addition to the regular procedure described below, older DEBs can be manually downloaded from the [/apt/pool/universe/j/ archives]. |
| 68 | |
| 69 | ==== Installation ==== |
| 70 | Edit the package resource list `/etc/apt/sources.list.d/josm.list`: |
| 71 | {{{#!sh |
| 72 | sudo editor /etc/apt/sources.list.d/josm.list |
| 73 | }}} |
| 74 | {{{#!comment |
| 75 | ### below does not work on GNU Debian systems |
| 76 | `sudo $EDITOR /etc/apt/sources.list.d/josm.list` |
| 77 | }}} |
| 78 | |
| 79 | and add one of the following lines according to your Ubuntu-Version: |
| 80 | |
| 81 | {{{#!sh |
| 82 | deb [signed-by=/usr/local/share/keyrings/josm-apt.gpg] https://josm.openstreetmap.de/apt plucky universe |
| 83 | deb [signed-by=/usr/local/share/keyrings/josm-apt.gpg] https://josm.openstreetmap.de/apt oracular universe |
| 84 | deb [signed-by=/usr/local/share/keyrings/josm-apt.gpg] https://josm.openstreetmap.de/apt noble universe |
| 85 | deb [signed-by=/usr/local/share/keyrings/josm-apt.gpg] https://josm.openstreetmap.de/apt jammy universe |
| 86 | deb [signed-by=/usr/local/share/keyrings/josm-apt.gpg] https://josm.openstreetmap.de/apt focal universe |
| 87 | deb [signed-by=/usr/local/share/keyrings/josm-apt.gpg] https://josm.openstreetmap.de/apt bionic universe |
| 88 | |
| 89 | # For other Debian based distributions add: |
| 90 | deb [signed-by=/usr/local/share/keyrings/josm-apt.gpg] https://josm.openstreetmap.de/apt alldist universe |
| 91 | }}} |
| 92 | |
| 93 | Alternatively, this can be done with the following one-liner in Ubuntu (not for Ubuntu based distributions like Linux Mint): |
| 94 | {{{#!sh |
| 95 | echo "deb [signed-by=/usr/local/share/keyrings/josm-apt.gpg] https://josm.openstreetmap.de/apt $(lsb_release -sc) universe" | sudo tee /etc/apt/sources.list.d/josm.list > /dev/null |
| 96 | }}} |
| 97 | or for Linux Mint: |
| 98 | {{{#!sh |
| 99 | echo "deb [signed-by=/usr/local/share/keyrings/josm-apt.gpg] https://josm.openstreetmap.de/apt $(grep ^DISTRIB_CODENAME= /etc/upstream-release/lsb-release| awk -F = '{print $(2)}') universe" | sudo tee /etc/apt/sources.list.d/josm.list > /dev/null |
| 100 | }}} |
| 101 | |
| 102 | {{{#!comment |
| 103 | ### below did not work on all systems |
| 104 | and add the following line: |
| 105 | {{{#!sh |
| 106 | `deb [signed-by=/usr/local/share/keyrings/josm-apt.gpg] https://josm.openstreetmap.de/apt VERSION universe` |
| 107 | }}} |
| 108 | }}} |
| 109 | |
| 110 | Download the [/josm-apt.key public key]: |
| 111 | {{{#!sh |
| 112 | # Create the directory for manually downloaded keys if it was not already created |
| 113 | sudo mkdir -p /usr/local/share/keyrings |
| 114 | # Download the key |
| 115 | wget -q https://josm.openstreetmap.de/josm-apt.key -O- | sudo gpg --dearmor -o /usr/local/share/keyrings/josm-apt.gpg |
| 116 | }}} |
| 117 | In the past, instructions used `apt-key`. If the key was added to system's keyring, following line will remove it: |
| 118 | {{{#!sh |
| 119 | sudo apt-key del $(apt-key list | grep -B1 "<josm-dev@openstreetmap.org>" | sed '$d' | cut -b 48-51,53-57) |
| 120 | }}} |
| 121 | |
| 122 | Now refresh your sources: |
| 123 | {{{#!sh |
| 124 | # You may need to install ssl support for apt in advance: |
| 125 | sudo apt-get install apt-transport-https |
| 126 | # Refresh sources |
| 127 | sudo apt-get update |
| 128 | }}} |
| 129 | |
| 130 | and install: |
| 131 | {{{#!sh |
| 132 | # You can skip this first line if these packages were not installed before. |
| 133 | sudo apt-get remove josm josm-plugins |
| 134 | |
| 135 | # For the tested version |
| 136 | sudo apt-get install josm |
| 137 | # For the development version |
| 138 | sudo apt-get install josm-latest |
| 139 | }}} |
| 140 | |
| 141 | |
| 142 | === GNU Debian ===#GNUDebian |
| 143 | Our own Ubuntu packages, [#Ubuntu above], work on Debian and we recommend to use them. Depending on the setup of `sudo`, some instruction will not work as "normal" user but only as `root`. |
| 144 | |
| 145 | The tested version of [https://packages.debian.org/stable/josm JOSM] is available under **''main''** in section **''utils''**, but the version is usually quite old. \\ |
| 146 | Please, use the [https://backports.debian.org backports repository] to get a more up-to-date version, see [https://backports.debian.org/Instructions Instructions]. This version might still be older than our own packages. |
| 147 | |
| 148 | Since Debian 11 (bullseye) the [https://packages.debian.org/stable/josm-installer josm-installer] is available under **''main''** in section **''utils''**. It downloads the current .jar file from this site and updates it if necessary. |
| 149 | |
| 150 | === openSUSE ===#Opensuse |
| 151 | The tested version of JOSM is available in the Application:Geo repository.[=#openSUSE] |
| 152 | |
| 153 | First add as root user in yast or with zypper the repository (for Tumbleweed replace **$releasever** with **openSUSE_Tumbleweed**): |
| 154 | {{{#!sh |
| 155 | zypper ar -f 'https://download.opensuse.org/repositories/Application:/Geo/$releasever' Application:Geo |
| 156 | }}} |
| 157 | |
| 158 | Then simply install ''josm'' and ''josm-fonts'' package. |
| 159 | |
| 160 | |
| 161 | == Troubleshooting == |
| 162 | === Java ===#Java |
| 163 | When you double-click on a jar file and nothing happens in most cases this means Java isn't installed. |
| 164 | |
| 165 | JOSM now recommends [https://www.azul.com/downloads/?version=java-21-lts&package=jdk-fx#zulu Azul] or [https://bell-sw.com/pages/downloads/?package=jre-full#mn Bellsoft Liberica] JDK's. Generally speaking, the current Java LTS should be preferred (at time of writing, that would be Java 17), but Java 11 will work. See the [source:/trunk/README README] for current recommendations. But first give the Java already distributed with the operating system a try, [https://en.wikipedia.org/wiki/OpenJDK for example]. |
| 166 | |
| 167 | |
| 168 | When choosing a download keep in mind: |
| 169 | * A Java Plug-in for web browsers is **not** needed to run JOSM. Therefore results from pages like www.java.com/en/download/installed8.jsp are not relevant. |
| 170 | * A Java variant with 64 bit is recommended for JOSM. The operating systems architecture is important for deciding between 32 bit Java or 64 bit Java. Because JOSM is **not** affected by the web browsers architecture most recommendations on this page www.java.com/en/download/faq/java_win64bit.xml are not relevant. |
| 171 | * Avoid pages like www.java.com/en/download which intent to place Java Plug-ins in web browsers. And this is **not** important for JOSM. |
| 172 | |
| 173 | For further information visit the [InstallNotes Installation Notes] and [https://www.java.com/en/download/help/troubleshoot_java.xml troubleshooting] pages. |
| 174 | ''Java'' in this section means a JRE (Java Runtime Engine) which provides a JVM (Java Virtual Machine) to run JOSM, a Java program that is developed using JDK (Java Development Kit) and sometimes launched with the JNLP (Java Network Launch Protocol aka Web Start and successor of Java Plug-ins). |
| 175 | |
| 176 | ==== Testing Java ====#JavaTest |
| 177 | [=#Troubleshootingjarfile] Checks if Java is installed and why JOSM does not start (example mainly for MS Windows). |
| 178 | 1. Download [/josm-tested.jar josm-tested.jar] to your desktop. |
| 179 | 1. Open a Command Prompt aka Terminal |
| 180 | 1. Type `cd %homepath%`⏎ and type `cd Desktop`⏎ |
| 181 | 1. Type `java -version `⏎ Three lines with the version data should appear. If you see something else then Java is not properly installed. |
| 182 | 1. Type `java -jar josm-tested.jar`⏎. Now JOSM should run, started from the [wikitr:/Help/CommandLineOptions Command Line]. |
| 183 | 1. Quit JOSM. |
| 184 | 1. Type `josm-tested.jar`⏎. If JOSM starts again, the Windows Explorer is ready for double clicks on jar files. |
| 185 | |
| 186 | |
| 187 | === Web Start ===#Webstart |
| 188 | [=#Troubleshootingjhlplink] |
| 189 | You need to install [https://openwebstart.com/ OpenWebStart] first. It will download and run Java by itself. Please use the 64 bit (`x64`) version of OpenWebStart if you are on Microsoft Windows. The transition from Oracle WebStart to OpenWebStart is still in progress, so in case of issue please create a [/newticket new ticket] or post a comment to #17858. |
| 190 | |
| 191 | You may need to update the default application for opening JNLP files if you previously used Oracle WebStart. See [https://openwebstart.com/docs/OWSGuide.html#_jnlp_file_association jnlp file association] for instructions on setting OpenWebStart as the default program for jnlp files. |
| 192 | |
| 193 | ==== Testing Web Start ====#Webstarttest |
| 194 | 1. Download [/download/josm.jnlp josm.jnlp] to your desktop. |
| 195 | 1. Open a Terminal and move to the Desktop as above |
| 196 | 1. Type `javaws josm.jnlp`⏎. This should initially download JOSM, show a security dialog and then launch JOSM. |
| 197 | 1. If that fails, then type `javaws -verbose josm.jnlp`⏎. This should first show a dialog with information about the JVM and then launch JOSM. |
| 198 | |
| 199 | |
| 200 | === Virtual Machine ===#Troubleshootingjvm |
| 201 | ==== Out of memory ==== |
| 202 | Nowadays manually controlling Javas memory is seldom needed because available RAM on computers has grown. |
| 203 | Wrongly chosen values can decrease JOSM performance. |
| 204 | |
| 205 | For some tasks, JOSM has a large appetite for memory. On the one hand, it may be necessary to configure a memory size that supports more plugins and features. On the other hand can slow machines be stabilized by restricting Javas memory use. |
| 206 | If needed, use the [wikitr:/Help/CommandLineOptions command line] to set the [https://docs.oracle.com/en/java/javase/11/tools/java.html#GUID-3B1CE181-CD30-4178-9602-230B800D4FAE__BABHDABI Java Option] -Xmx…m, for example `-Xmx512m` or `-Xmx1536m`. In Debian/Ubuntu you can edit the file `/etc/default/josm` respectively `/etc/default/josm-latest`. \\ |
| 207 | Formerly older java programs accepted `-Xmx=512m` or even `-Xmx 512m`. Now those malformed arguments throw error messages. |
| 208 | |
| 209 | ==== VM selection ====#VMselectiononWindowsx64 |
| 210 | On current versions of MS Windows by default Java is installed mainly in the `C:\Program Files\Java\` directory. Additional parts are placed in `C:\Program Files\Oracle\Java\`. There is a `.\javapath\` directory as target for the PATH environment variable. It is the home for the three virtual files `java.exe`, `javaw.exe` and `javaws.exe`. This files are symbolic links form the current Java installations. |
| 211 | |
| 212 | On older versions of 64 bit Windows sometimes the 32 bit mode JRE was additionally installed. Also some browsers brought their own JVM with limited capabilities. In those cases a Web Start from the browser would not use your Java installation but that from the browser. |
| 213 | |
| 214 | Check that there's no other javawebstart in `\Windows\SysWow64`. The Java control panel will not detect it and you can safely delete it. Perform cleanup and only keep the latest versions of each JRE (One or the 32-bit mode, another one for the 64-bit mode). |
| 215 | |
| 216 | For shortcuts created on the desktop for JNLP and running the Javawebstart launcher , make sure to pass VM parameters prefixed with -J and no intermediate space before the VM option. If you have installed both the 32-bit and 64-bit version, you should pass the option "`-d64`" if you want to select the preferred 64-bit VM. Note that some Oracle documentation pages indicate the option "-D64" with the incorrect capitalization!) |
| 217 | |
| 218 | Example of an edited command line for a shortcut on the windows desktop: |