From 63e1162d903fd06222f8e966d234f1b303aa0808 Mon Sep 17 00:00:00 2001 From: Anton Tananaev Date: Thu, 9 Jul 2020 22:48:54 -0700 Subject: Extract class loading method --- src/main/java/org/traccar/ServerManager.java | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/src/main/java/org/traccar/ServerManager.java b/src/main/java/org/traccar/ServerManager.java index 6a3273402..68b133c98 100644 --- a/src/main/java/org/traccar/ServerManager.java +++ b/src/main/java/org/traccar/ServerManager.java @@ -1,5 +1,5 @@ /* - * Copyright 2012 - 2018 Anton Tananaev (anton@traccar.org) + * Copyright 2012 - 2020 Anton Tananaev (anton@traccar.org) * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -19,8 +19,10 @@ import org.slf4j.Logger; import org.slf4j.LoggerFactory; import java.io.File; +import java.io.IOException; import java.net.BindException; import java.net.URI; +import java.net.URISyntaxException; import java.net.URL; import java.net.URLDecoder; import java.nio.charset.StandardCharsets; @@ -39,10 +41,9 @@ public class ServerManager { private final List serverList = new LinkedList<>(); private final Map protocolList = new ConcurrentHashMap<>(); - public ServerManager() throws Exception { + private void loadPackage(String packageName) throws IOException, URISyntaxException, ReflectiveOperationException { List names = new LinkedList<>(); - String packageName = "org.traccar.protocol"; String packagePath = packageName.replace('.', '/'); URL packageUrl = getClass().getClassLoader().getResource(packagePath); @@ -79,6 +80,10 @@ public class ServerManager { } } + public ServerManager() throws IOException, URISyntaxException, ReflectiveOperationException { + loadPackage("org.traccar.protocol"); + } + public BaseProtocol getProtocol(String name) { return protocolList.get(name); } -- cgit v1.2.3