source: josm/trunk/src/org/openstreetmap/josm/gui/MainInitialization.java@ 14903

Last change on this file since 14903 was 14480, checked in by Don-vip, 5 years ago

fix #16937 - Support user logins ending by " !"

  • Property svn:eol-style set to native
File size: 7.6 KB
Line 
1// License: GPL. For details, see LICENSE file.
2package org.openstreetmap.josm.gui;
3
4import static org.openstreetmap.josm.tools.I18n.tr;
5
6import java.awt.BorderLayout;
7import java.awt.event.KeyEvent;
8import java.util.Arrays;
9import java.util.Collection;
10import java.util.List;
11import java.util.Objects;
12import java.util.concurrent.Callable;
13
14import org.openstreetmap.gui.jmapviewer.FeatureAdapter;
15import org.openstreetmap.josm.data.UndoRedoHandler;
16import org.openstreetmap.josm.data.coor.conversion.CoordinateFormatManager;
17import org.openstreetmap.josm.data.coor.conversion.DecimalDegreesCoordinateFormat;
18import org.openstreetmap.josm.data.coor.conversion.ICoordinateFormat;
19import org.openstreetmap.josm.data.validation.OsmValidator;
20import org.openstreetmap.josm.gui.layer.ImageryLayer;
21import org.openstreetmap.josm.gui.layer.Layer;
22import org.openstreetmap.josm.gui.layer.TMSLayer;
23import org.openstreetmap.josm.gui.preferences.imagery.ImageryPreference;
24import org.openstreetmap.josm.gui.preferences.map.MapPaintPreference;
25import org.openstreetmap.josm.gui.tagging.presets.TaggingPresets;
26import org.openstreetmap.josm.gui.util.GuiHelper;
27import org.openstreetmap.josm.io.FileWatcher;
28import org.openstreetmap.josm.io.OsmApi;
29import org.openstreetmap.josm.io.OsmApiInitializationException;
30import org.openstreetmap.josm.io.OsmTransferCanceledException;
31import org.openstreetmap.josm.spi.lifecycle.InitializationSequence;
32import org.openstreetmap.josm.spi.lifecycle.InitializationTask;
33import org.openstreetmap.josm.spi.preferences.Config;
34import org.openstreetmap.josm.tools.I18n;
35import org.openstreetmap.josm.tools.ImageProvider;
36import org.openstreetmap.josm.tools.Logging;
37import org.openstreetmap.josm.tools.OpenBrowser;
38import org.openstreetmap.josm.tools.OverpassTurboQueryWizard;
39import org.openstreetmap.josm.tools.PlatformManager;
40import org.openstreetmap.josm.tools.RightAndLefthandTraffic;
41import org.openstreetmap.josm.tools.Shortcut;
42import org.openstreetmap.josm.tools.Territories;
43import org.openstreetmap.josm.tools.Utils;
44
45/**
46 * JOSM initialization sequence.
47 * @since 14139
48 */
49public class MainInitialization implements InitializationSequence {
50
51 private final MainApplication application;
52
53 /**
54 * Constructs a new {@code MainInitialization}
55 * @param application Main application. Must not be null
56 */
57 public MainInitialization(MainApplication application) {
58 this.application = Objects.requireNonNull(application);
59 }
60
61 @Override
62 public List<InitializationTask> beforeInitializationTasks() {
63 return Arrays.asList(
64 new InitializationTask(tr("Initializing coordinate format"), () -> {
65 ICoordinateFormat fmt = CoordinateFormatManager.getCoordinateFormat(Config.getPref().get("coordinates"));
66 if (fmt == null) {
67 fmt = DecimalDegreesCoordinateFormat.INSTANCE;
68 }
69 CoordinateFormatManager.setCoordinateFormat(fmt);
70 }),
71 new InitializationTask(tr("Starting file watcher"), FileWatcher.getDefaultInstance()::start),
72 new InitializationTask(tr("Executing platform startup hook"),
73 () -> PlatformManager.getPlatform().startupHook(MainApplication::askUpdateJava)),
74 new InitializationTask(tr("Building main menu"), application::initializeMainWindow),
75 new InitializationTask(tr("Updating user interface"), () -> {
76 UndoRedoHandler.getInstance().addCommandQueueListener(application.redoUndoListener);
77 // creating toolbar
78 GuiHelper.runInEDTAndWait(() -> MainApplication.contentPanePrivate.add(MainApplication.toolbar.control, BorderLayout.NORTH));
79 // help shortcut
80 MainApplication.registerActionShortcut(MainApplication.menu.help,
81 Shortcut.registerShortcut("system:help", tr("Help"), KeyEvent.VK_F1, Shortcut.DIRECT));
82 }),
83 // This needs to be done before RightAndLefthandTraffic::initialize is called
84 new InitializationTask(tr("Initializing internal boundaries data"), Territories::initialize)
85 );
86 }
87
88 @Override
89 public Collection<InitializationTask> parallelInitializationTasks() {
90 return Arrays.asList(
91 new InitializationTask(tr("Initializing OSM API"), () -> {
92 OsmApi.addOsmApiInitializationListener(api -> {
93 // This checks if there are any layers currently displayed that are now on the blacklist, and removes them.
94 // This is a rare situation - probably only occurs if the user changes the API URL in the preferences menu.
95 // Otherwise they would not have been able to load the layers in the first place because they would have been disabled
96 if (MainApplication.isDisplayingMapView()) {
97 for (Layer l : MainApplication.getLayerManager().getLayersOfType(ImageryLayer.class)) {
98 if (((ImageryLayer) l).getInfo().isBlacklisted()) {
99 Logging.info(tr("Removed layer {0} because it is not allowed by the configured API.", l.getName()));
100 MainApplication.getLayerManager().removeLayer(l);
101 }
102 }
103 }
104 });
105 // We try to establish an API connection early, so that any API
106 // capabilities are already known to the editor instance. However
107 // if it goes wrong that's not critical at this stage.
108 try {
109 OsmApi.getOsmApi().initialize(null, true);
110 } catch (OsmTransferCanceledException | OsmApiInitializationException | SecurityException e) {
111 Logging.warn(Logging.getErrorMessage(Utils.getRootCause(e)));
112 }
113 }),
114 new InitializationTask(tr("Initializing internal traffic data"), RightAndLefthandTraffic::initialize),
115 new InitializationTask(tr("Initializing validator"), OsmValidator::initialize),
116 new InitializationTask(tr("Initializing presets"), TaggingPresets::initialize),
117 new InitializationTask(tr("Initializing map styles"), MapPaintPreference::initialize),
118 new InitializationTask(tr("Loading imagery preferences"), ImageryPreference::initialize)
119 );
120 }
121
122 @Override
123 public List<Callable<?>> asynchronousCallableTasks() {
124 return Arrays.asList(
125 OverpassTurboQueryWizard::getInstance
126 );
127 }
128
129 @Override
130 public List<Runnable> asynchronousRunnableTasks() {
131 return Arrays.asList(
132 TMSLayer::getCache,
133 OsmValidator::initializeTests
134 );
135 }
136
137 @Override
138 public List<InitializationTask> afterInitializationTasks() {
139 return Arrays.asList(
140 new InitializationTask(tr("Updating user interface"), () -> GuiHelper.runInEDTAndWait(() -> {
141 // hooks for the jmapviewer component
142 FeatureAdapter.registerBrowserAdapter(OpenBrowser::displayUrl);
143 FeatureAdapter.registerImageAdapter(ImageProvider::read);
144 FeatureAdapter.registerTranslationAdapter(I18n::tr);
145 FeatureAdapter.registerLoggingAdapter(name -> Logging.getLogger());
146 // UI update
147 MainApplication.toolbar.refreshToolbarControl();
148 MainApplication.toolbar.control.updateUI();
149 MainApplication.contentPanePrivate.updateUI();
150 }))
151 );
152 }
153}
Note: See TracBrowser for help on using the repository browser.