9 | | == Recommended options == |
10 | | |
11 | | [[Image(source:trunk/images/openlocation.png, valign=middle, link=[download/josm.jnlp])]] **Start [/download/josm.jnlp josm.jnlp]** (newest tested version) [[br]] |
12 | | Recommended version, all platforms, automatic update to the newest ''tested version'' monthly ([#Webstart how to start]). [[br]] |
13 | | [[br]] |
14 | | |
15 | | [[Image(source:trunk/images/download.png, valign=middle, link=[/josm-tested.jar])]] **Download [/josm-tested.jar josm-tested.jar]** (tested version [[Version(tested)]]) [[br]] |
16 | | All platforms ([#Java how to run]). [[br]] |
17 | | [[br]] |
| 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 | |
30 | | |
31 | | ||= =||||= For all operating systems =|||||||||| |
32 | | ||=Version =||= Web Start =||= Download =||= Windows =||= Apple Mac =||= Ubuntu, Debian… =||= openSUSE =|| |
33 | | ||tested [[Version(tested)]] || \ |
34 | | || [/download/josm.jnlp josm.jnlp] || \ |
35 | | || [/josm-tested.jar] || \ |
36 | | || [[br]] [/download/windows/josm-setup.exe setup.exe] [[br]]''([#Mswindowswrapper see below])'' || \ |
37 | | || [[br]] [/download/macosx/josm-macosx.zip package.zip] [[br]]''([#Macoserrors see below])'' || \ |
38 | | || ''[#Ubuntu see below]'' || \ |
39 | | || ''[#Opensuse see below]'' || |
40 | | ||latest [[Version(latest)]] || \ |
41 | | || [/download/josm-latest.jnlp latest.jnlp] || \ |
42 | | || [/josm-latest.jar] || \ |
43 | | || || || ''[#Ubuntu see below]'' || || |
44 | | ||=older =|| || [/download/ download/] || || || [/apt/dists/ dists/] || || |
45 | | |
46 | | When running scripts please first check on [/latest latest], [/tested tested] or [/version both] to reduce download bandwidth. |
| 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. |
51 | | == Repositories == |
52 | | |
53 | | === openSUSE ===#Opensuse |
54 | | [=#openSUSE] |
55 | | The tested version of JOSM is available in the Application:Geo repository. |
56 | | |
57 | | First add as root user in yast or with zypper the repository (replace the version in the URL with the one you are using): |
58 | | {{{ |
59 | | zypper ar -f https://download.opensuse.org/repositories/Application:/Geo/openSUSE_Leap_15.0 Application:Geo |
60 | | }}} |
61 | | |
62 | | Then simply install ''josm'' and ''josm-fonts'' package. |
63 | | |
64 | | === Ubuntu ===#Ubuntu |
65 | | |
66 | | This is a 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. |
| 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. |
69 | | * ''josm'' – Provides the tested version (stable). Replaces the package from the official Ubuntu repository. |
70 | | * ''josm-latest'' – The latest version (nightly). Can be installed parallel to the josm package. The default preference folder is {{{~/.josm-latest}}}. |
71 | | |
72 | | In addition to the regular procedure described below, older DEBs can be manually downloaded from the [https://josm.openstreetmap.de/apt/pool/universe/j/ archives]. |
| 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]. |
85 | | {{{ |
86 | | #!sh |
87 | | deb https://josm.openstreetmap.de/apt trusty universe |
88 | | deb https://josm.openstreetmap.de/apt xenial universe |
89 | | deb https://josm.openstreetmap.de/apt artful universe |
| 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 | |
91 | | deb https://josm.openstreetmap.de/apt alldist universe |
92 | | }}} |
93 | | |
94 | | Alternatively, this can be done with the following one-liner in Ubuntu: |
95 | | {{{ |
96 | | echo deb https://josm.openstreetmap.de/apt $(lsb_release -sc) universe | ↩ |
97 | | ↪sudo tee /etc/apt/sources.list.d/josm.list > /dev/null |
| 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 |
103 | | ` |
104 | | deb https://josm.openstreetmap.de/apt VERSION universe |
105 | | ` |
106 | | }}} |
107 | | |
108 | | Download and register the [[/josm-apt.key|public key]]: |
109 | | {{{ |
110 | | #!sh |
111 | | wget -q https://josm.openstreetmap.de/josm-apt.key -O- | sudo apt-key add - |
112 | | }}} |
113 | | |
114 | | Now refresh your sources (you may need to install `sudo apt-get install apt-transport-https`) |
115 | | {{{ |
116 | | #!sh |
| 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 |
| 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 | |
134 | | [=#Doubleclickonafiledoesnothing When you double-click on a jar file and nothing happens] in most cases this means Java isn't installed. |
135 | | |
136 | | JOSM is tested with Oracles variant, so we recommend to get Java from their pages for [https://www.java.com/download/manual.jsp manual] downloads or [http://www.oracle.com/technetwork/java/javase/downloads/jre8-downloads-2133155.html intermediate] versions. But first give the Java already distributed with the operating system a try, [https://en.wikipedia.org/wiki/OpenJDK for example]. |
| 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 | |
186 | | Check that there's no other javawebstart in {{{\Windows\SysWow64}}}. The Java control panel will not detect it and you can safely delete it. Perfom cleanup and only keep the latest versions of each JRE (One or the 32-bit mode, another one for the 64-bit mode). |
187 | | |
188 | | 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!) |
| 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!) |
199 | | * Puts the files `josm-tested.jar` and `josm.exe` in directory chosen by the user, default is `C:\Program Files (86)\JOSM\` |
200 | | * Suggests to register josm.exe as target for the file extensions `*.osm` and `*.gpx`. |
201 | | * Suggests to place JOSM shortcut icons on the Desktop and in the Start Menu (Currently they are placed for an admin [ticket:11398 only] and can be copied from there). |
202 | | * Asks if the Plug-Ins Imagery offset database and Turn restrictions should be provided. |
| 227 | * Puts two executable files `JOSM.exe` and `HWConsole.exe` in directory `%LOCALAPPDATA%\JOSM` |
| 228 | * Registers JOSM.exe as target for the file extensions `*.osm`, `*.geojson`, `*.gpx`, `*.jos` and `*.joz`. |
| 229 | * Places JOSM shortcut icons on the Desktop and in the Start Menu. |
205 | | When starting, josm.exe searches its directory for the jar file and runs the command `\path\to\javaw.exe -Xms128m -Xmx1024m -jar \path\to\josm-tested.jar`. |
206 | | Josm.exe acts as a ''wrapper'' and is [wikitr:/USB_Stick portable]. |
207 | | |
208 | | When josm.exe finds the argument `--l4j-debug`, it writes the log file `launch4j.log` into the current directory if that is writeable. Some other [http://launch4j.sourceforge.net/docs.html#Runtime_options options] are possible and all usual [wikitr:/Help/CommandLineOptions#Programarguments JOSM Program arguments] too. See example: |
| 232 | When starting, JOSM.exe starts JOSM with an embedded version of Java maintained by JOSM developers, based on Azul Zulu. |
| 233 | JOSM.exe acts as a ''wrapper'' and is [wikitr:/USB_Stick portable]. |
| 234 | |
| 235 | HWConsole.exe is similar to JOSM.exe but start JOSM while keeping open a Windows console displaying JOSM standard output (logs). |
| 236 | |
| 237 | JOSM.exe accepts all usual [wikitr:/Help/CommandLineOptions#Programarguments JOSM Program arguments]. See example: |
212 | | # Write a log while starting JOSM and load OSM data |
213 | | josm.exe --l4j-debug https://www.osm.org/way/476702262 |
214 | | }}} |
215 | | |
216 | | |
217 | | === MacOS Errors ===#Macoserrors |
218 | | [=#MacOSErrors][=#MacOSXMountainLionErrors] |
| 241 | # Load OSM data |
| 242 | josm.exe https://www.osm.org/way/476702262 |
| 243 | }}} |
| 244 | |
| 245 | For giving [wikitr:/Help/CommandLineOptions#Javaoptions Java options] to the Java VM, JOSM.exe uses the configuration file `JOSM.cfg` in its app sub-directory. In this file, each option must be on a separate line. |
| 246 | |
| 247 | For example, to change memory allocation, open `%LOCALAPPDATA%\JOSM\app\JOSM.cfg` and add `java-options=-Xmx8192m` (for 8 GB) to a new line under the `[JavaOptions]` header. |
| 248 | |
| 249 | ==== Graphics ====#MicrosoftWindowsGraphics |
| 250 | Some Windows installations have graphics driver issues (see #23784 for an example). This may exhibit symptoms such as: |
| 251 | * Black bars in JOSM toolbars |
| 252 | * Flickering |
| 253 | * Other unexpected user interface issues |
| 254 | |
| 255 | 1. Download and install Display Driver Uninstaller (DDU, [https://github.com/Wagnard/display-drivers-uninstaller source]) from the official mirror => https://www.wagnardsoft.com/display-driver-uninstaller-DDU- |
| 256 | 2. From the "Device Type" drop-down on the right, select "GPU". DDU will automatically detect the GPU you're using. |
| 257 | 3. Click on "Clean and Restart" at the top. This will uninstall the graphics drivers and restart your PC. |
| 258 | 4. Reinstall the drivers. |
| 259 | |
| 260 | //**WARNING: Create a backup of your PC before using DDU. Although it creates a recovery point by itself, it's ideal to make one yourself just in case.**// |
| 261 | |
| 262 | === macOS ===#macOS |
| 263 | [=#MacOSErrors][=#MacOSXMountainLionErrors][=#Macoserrors] |
224 | | Apple has two mechanisms to ''protect'' you from using JOSM: [https://support.apple.com//HT201940 File Quarantine] and [https://support.apple.com//HT202491 Gatekeeper]. |
225 | | |
226 | | ==== Downloaded from the internet ==== |
227 | | If you get an error saying "'JOSM.app' is an application downloaded from the internet." you can bypass this by **right-clicking on JOSM.app** or josm.jnlp and selecting 'open'. You should then see the same message but this time with an option to "Open" regardless. This is only necessary on the first run of JOSM. |
228 | | |
229 | | ==== Damaged ==== |
230 | | [[Image(#8787:damaged_josm_app.png,width=300,align=right,margin-top=-50,margin-left=30)]] |
231 | | If you get an error saying "'JOSM.app' is damaged and can't be opened. You should move it to the Trash", then you need to temporarily disable Gatekeeper. |
232 | | |
233 | | Open System Preferences and the 'Security & Privacy' options. Set 'Allow applications downloaded from:' to 'Anywhere'. |
234 | | |
235 | | If that radio button is missing from the Security & Privacy preferences panel, open the Terminal window. The following command may become the radio button to appear. [[Image(SecurityPrivacy.png,align=right,float=left,width=300)]] |
236 | | {{{ |
237 | | sudo spctl --master-disable |
238 | | }}} |
239 | | |
| 269 | ==== Using brew ====#brew |
| 270 | macOS users may use the [https://brew.sh/ homebrew] package manager to install and update their JOSM instance. |
| 271 | |
| 272 | In Terminal, run the `brew install --cask josm` to install or `brew upgrade --cask josm` to upgrade to the current tested version of JOSM. |
| 273 | |
| 274 | === Linux ===#linux |
| 275 | ==== Arch Linux ==== |
| 276 | Using AUR you can install [https://aur.archlinux.org/packages/openwebstart-bin openwebstart-bin]. |
| 277 | |
| 278 | If you use [https://archlinux.org/packages/extra/x86_64/icedtea-web/ icedtea-web] instead of the recommended openwebstart you will get an error with the newest java. java-17-openjdk is known to work, but java-22-openjdk do not. |
243 | | |
244 | | Not closed issues about ...: |
245 | | * [https://josm.openstreetmap.de/query?status=!closed&type=defect&keywords=~java Java issues] - some of the bugs lead to blockers in Oracle JVM (covered at [[JavaBugs]]). |
246 | | * [https://josm.openstreetmap.de/query?status=assigned&type=defect&status=needinfo&status=new&status=reopened&keywords=~linux&order=priority Linux] |
247 | | * [https://josm.openstreetmap.de/query?status=assigned&type=defect&status=needinfo&status=new&status=reopened&keywords=~ubuntu&order=priority Ubuntu] |
248 | | * [https://josm.openstreetmap.de/query?status=assigned&type=defect&status=needinfo&status=new&status=reopened&keywords=~macos&order=priority MacOS] |
249 | | * [https://josm.openstreetmap.de/query?status=assigned&type=defect&status=needinfo&status=new&status=reopened&keywords=~windows&order=priority Windows] |
| 282 | Not closed issues about …: |
| 283 | * [/query?status=!closed&type=defect&keywords=~java Java issues] - some of the bugs lead to blockers in Oracle JVM (covered at [wiki:JavaBugs JavaBugs]). |
| 284 | * [/query?status=assigned&type=defect&status=needinfo&status=new&status=reopened&keywords=~linux&order=priority Linux] |
| 285 | * [/query?status=assigned&type=defect&status=needinfo&status=new&status=reopened&keywords=~ubuntu&order=priority Ubuntu] |
| 286 | * [/query?status=assigned&type=defect&status=needinfo&status=new&status=reopened&keywords=~macos&order=priority macOS] |
| 287 | * [/query?status=assigned&type=defect&status=needinfo&status=new&status=reopened&keywords=~windows&order=priority Windows] |