Use protected modifier with constructor of abstract classes (#4010)

Abstract classes should not have public constructors.
Constructors of abstract classes can only be called in constructors of their subclasses.
So there is no point in making them public.
The protected modifier should be enough.

Signed-off-by: Wouter Born <github@maindrain.net>
pull/4011/head
Wouter Born 2024-01-03 16:17:14 +01:00 committed by GitHub
parent 81a91ee9ae
commit 6fc7700ea6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
33 changed files with 44 additions and 42 deletions

View File

@ -83,7 +83,7 @@ public abstract class AbstractRemoteAddonService implements AddonService {
private final Logger logger = LoggerFactory.getLogger(AbstractRemoteAddonService.class);
public AbstractRemoteAddonService(EventPublisher eventPublisher, ConfigurationAdmin configurationAdmin,
protected AbstractRemoteAddonService(EventPublisher eventPublisher, ConfigurationAdmin configurationAdmin,
StorageService storageService, AddonInfoRegistry addonInfoRegistry, String servicePid) {
this.addonInfoRegistry = addonInfoRegistry;
this.eventPublisher = eventPublisher;

View File

@ -52,7 +52,7 @@ public abstract class AbstractScriptDependencyTracker
private final BidiSetBag<String, String> scriptToLibs = new BidiSetBag<>();
private final WatchService watchService;
public AbstractScriptDependencyTracker(WatchService watchService, final String fileDirectory) {
protected AbstractScriptDependencyTracker(WatchService watchService, final String fileDirectory) {
this.watchService = watchService;
this.libraryPath = watchService.getWatchPath().resolve(fileDirectory);

View File

@ -96,7 +96,7 @@ public abstract class AbstractScriptFileWatcher implements WatchService.WatchEve
private volatile int currentStartLevel;
public AbstractScriptFileWatcher(final WatchService watchService, final ScriptEngineManager manager,
protected AbstractScriptFileWatcher(final WatchService watchService, final ScriptEngineManager manager,
final ReadyService readyService, final StartLevelService startLevelService, final String fileDirectory,
boolean watchSubDirectories) {
this.watchService = watchService;

View File

@ -59,7 +59,7 @@ public abstract class AbstractScriptModuleHandler<T extends Module> extends Base
protected final String ruleUID;
public AbstractScriptModuleHandler(T module, String ruleUID, ScriptEngineManager scriptEngineManager) {
protected AbstractScriptModuleHandler(T module, String ruleUID, ScriptEngineManager scriptEngineManager) {
super(module);
this.scriptEngineManager = scriptEngineManager;
this.ruleUID = ruleUID;

View File

@ -36,7 +36,7 @@ public abstract class AbstractRuleRegistryEvent extends AbstractEvent {
* @param source the source of the event
* @param rule the rule for which this event is created
*/
public AbstractRuleRegistryEvent(String topic, String payload, @Nullable String source, RuleDTO rule) {
protected AbstractRuleRegistryEvent(String topic, String payload, @Nullable String source, RuleDTO rule) {
super(topic, payload, source);
this.rule = rule;
}

View File

@ -94,7 +94,7 @@ public abstract class AbstractCommandProvider<@NonNull E> implements ServiceTrac
* @param context is the {@link BundleContext}, used for creating a tracker for {@link Parser} services.
*/
@SuppressWarnings("unchecked")
public AbstractCommandProvider(BundleContext context) {
protected AbstractCommandProvider(BundleContext context) {
this.bundleContext = context;
parserTracker = new ServiceTracker(context, Parser.class.getName(), this);
parserTracker.open();

View File

@ -67,7 +67,8 @@ public abstract class AbstractCompositeModuleHandler<M extends Module, MT extend
* @param mapModuleToHandler map containing pairs of child modules instances (defined by module type) and their
* handlers
*/
public AbstractCompositeModuleHandler(M module, MT moduleType, LinkedHashMap<M, @Nullable H> mapModuleToHandler) {
protected AbstractCompositeModuleHandler(M module, MT moduleType,
LinkedHashMap<M, @Nullable H> mapModuleToHandler) {
this.module = module;
this.moduleType = moduleType;
this.moduleHandlerMap = mapModuleToHandler;

View File

@ -70,7 +70,7 @@ import org.slf4j.LoggerFactory;
@NonNullByDefault
public abstract class AbstractResourceBundleProvider<@NonNull E> {
public AbstractResourceBundleProvider(String path) {
protected AbstractResourceBundleProvider(String path) {
this.path = path;
}

View File

@ -86,7 +86,7 @@ public abstract class AbstractFileProvider<@NonNull E> implements Provider<E> {
private final Map<String, List<URL>> urls = new ConcurrentHashMap<>();
private final List<ProviderChangeListener<E>> listeners = new ArrayList<>();
public AbstractFileProvider(String root) {
protected AbstractFileProvider(String root) {
this.rootSubdirectory = root;
configurationRoots = new String[] { OpenHAB.getConfigFolder() + File.separator + "automation" };
}

View File

@ -86,7 +86,7 @@ public abstract class AbstractDiscoveryService implements DiscoveryService {
* enable background discovery or not.
* @throws IllegalArgumentException if {@code timeout < 0}
*/
public AbstractDiscoveryService(@Nullable Set<ThingTypeUID> supportedThingTypes, int timeout,
protected AbstractDiscoveryService(@Nullable Set<ThingTypeUID> supportedThingTypes, int timeout,
boolean backgroundDiscoveryEnabledByDefault) throws IllegalArgumentException {
if (timeout < 0) {
throw new IllegalArgumentException("The timeout must be >= 0!");
@ -105,7 +105,7 @@ public abstract class AbstractDiscoveryService implements DiscoveryService {
* If set to 0, disables the automatic stop.
* @throws IllegalArgumentException if {@code timeout < 0}
*/
public AbstractDiscoveryService(@Nullable Set<ThingTypeUID> supportedThingTypes, int timeout)
protected AbstractDiscoveryService(@Nullable Set<ThingTypeUID> supportedThingTypes, int timeout)
throws IllegalArgumentException {
this(supportedThingTypes, timeout, true);
}
@ -118,7 +118,7 @@ public abstract class AbstractDiscoveryService implements DiscoveryService {
* If set to 0, disables the automatic stop.
* @throws IllegalArgumentException if {@code timeout < 0}
*/
public AbstractDiscoveryService(int timeout) throws IllegalArgumentException {
protected AbstractDiscoveryService(int timeout) throws IllegalArgumentException {
this(null, timeout);
}

View File

@ -35,7 +35,7 @@ public abstract class AbstractInboxEvent extends AbstractEvent {
* @param payload the payload
* @param discoveryResult the discovery-result data transfer object
*/
public AbstractInboxEvent(String topic, String payload, DiscoveryResultDTO discoveryResult) {
protected AbstractInboxEvent(String topic, String payload, DiscoveryResultDTO discoveryResult) {
super(topic, payload, null);
this.discoveryResult = discoveryResult;
}

View File

@ -32,7 +32,7 @@ public abstract class AbstractConsoleCommandExtension implements ConsoleCommandE
* @param cmd The command the extension is used for.
* @param desc The description what this extension is handling.
*/
public AbstractConsoleCommandExtension(final String cmd, final String desc) {
protected AbstractConsoleCommandExtension(final String cmd, final String desc) {
this.cmd = cmd;
this.desc = desc;
}

View File

@ -67,7 +67,7 @@ public abstract class AbstractAuthPageServlet extends HttpServlet {
protected String pageTemplate;
public AbstractAuthPageServlet(BundleContext bundleContext, @Reference UserRegistry userRegistry,
protected AbstractAuthPageServlet(BundleContext bundleContext, @Reference UserRegistry userRegistry,
@Reference AuthenticationProvider authProvider, @Reference LocaleProvider localeProvider) {
this.userRegistry = userRegistry;
this.authProvider = authProvider;

View File

@ -29,7 +29,7 @@ abstract class AbstractRequestComparer<T extends ModbusWriteRequestBlueprint> ex
private ModbusWriteFunctionCode expectedFunctionCode;
private int expectedMaxTries;
public AbstractRequestComparer(int expectedUnitId, int expectedAddress,
protected AbstractRequestComparer(int expectedUnitId, int expectedAddress,
ModbusWriteFunctionCode expectedFunctionCode, int expectedMaxTries) {
this.expectedUnitId = expectedUnitId;
this.expectedAddress = expectedAddress;

View File

@ -75,7 +75,7 @@ public abstract class AbstractStorageBasedTypeProvider
*
* @param storageService a persistent {@link StorageService}
*/
public AbstractStorageBasedTypeProvider(StorageService storageService) {
protected AbstractStorageBasedTypeProvider(StorageService storageService) {
String thingTypeStorageName = getClass().getName() + "-ThingType";
String channelTypeStorageName = getClass().getName() + "-ChannelType";
String channelGroupTypeStorageName = getClass().getName() + "-ChannelGroupType";

View File

@ -33,7 +33,7 @@ public abstract class AbstractThingDTO {
public String thingTypeUID;
public String location;
public AbstractThingDTO() {
protected AbstractThingDTO() {
}
protected AbstractThingDTO(String thingTypeUID, String uid, String label, String bridgeUID,

View File

@ -41,7 +41,7 @@ public abstract class AbstractTransformingChannelHandler implements ChannelHandl
protected final ChannelValueConverterConfig channelConfig;
public AbstractTransformingChannelHandler(Consumer<State> updateState, Consumer<Command> postCommand,
protected AbstractTransformingChannelHandler(Consumer<State> updateState, Consumer<Command> postCommand,
@Nullable Consumer<String> sendValue, ChannelTransformation stateTransformations,
ChannelTransformation commandTransformations, ChannelValueConverterConfig channelConfig) {
this.updateState = updateState;

View File

@ -45,12 +45,12 @@ public abstract class AbstractLink implements Identifiable<String> {
* @param itemName the item name for the link
* @throws IllegalArgumentException if the item name is invalid
*/
public AbstractLink(String itemName) {
protected AbstractLink(String itemName) {
ItemUtil.assertValidItemName(itemName);
this.itemName = itemName;
}
AbstractLink() {
protected AbstractLink() {
this.itemName = null;
}

View File

@ -27,7 +27,7 @@ public abstract class AbstractLinkDTO {
protected AbstractLinkDTO() {
}
public AbstractLinkDTO(String itemName) {
protected AbstractLinkDTO(String itemName) {
this.itemName = itemName;
}
}

View File

@ -26,7 +26,7 @@ public abstract class AbstractItemChannelLinkRegistryEvent extends AbstractEvent
private final ItemChannelLinkDTO link;
public AbstractItemChannelLinkRegistryEvent(String topic, String payload, ItemChannelLinkDTO link) {
protected AbstractItemChannelLinkRegistryEvent(String topic, String payload, ItemChannelLinkDTO link) {
super(topic, payload, null);
this.link = link;
}

View File

@ -49,7 +49,7 @@ public abstract class AbstractDescriptionType implements Identifiable<UID> {
* @param configDescriptionURI the {@link URI} that references the {@link ConfigDescription} of this type
* @throws IllegalArgumentException if the UID is null, or the label is null or empty
*/
public AbstractDescriptionType(UID uid, String label, @Nullable String description,
protected AbstractDescriptionType(UID uid, String label, @Nullable String description,
@Nullable URI configDescriptionURI) throws IllegalArgumentException {
if (label.isEmpty()) {
throw new IllegalArgumentException("The label must neither be null nor empty!");

View File

@ -54,7 +54,7 @@ public abstract class AbstractDescriptionTypeConverter<T> extends GenericUnmarsh
* @param clazz the class of the result type (must not be null)
* @param type the name of the type (e.g. "thing-type", "channel-type")
*/
public AbstractDescriptionTypeConverter(Class<T> clazz, String type) {
protected AbstractDescriptionTypeConverter(Class<T> clazz, String type) {
super(clazz);
this.type = type;
this.attributeMapValidator = new ConverterAttributeMapValidator(new String[][] { { "id", "true" } });

View File

@ -45,7 +45,7 @@ public abstract class AbstractResourceIconProvider implements IconProvider {
protected final TranslationProvider i18nProvider;
public AbstractResourceIconProvider(final TranslationProvider i18nProvider) {
protected AbstractResourceIconProvider(final TranslationProvider i18nProvider) {
this.i18nProvider = i18nProvider;
}

View File

@ -32,7 +32,7 @@ public abstract class AbstractCachedTTSService implements CachedTTSService {
private final TTSCache ttsCache;
public AbstractCachedTTSService(final @Reference TTSCache ttsCache) {
protected AbstractCachedTTSService(final @Reference TTSCache ttsCache) {
this.ttsCache = ttsCache;
}

View File

@ -161,7 +161,7 @@ public abstract class AbstractRuleBasedInterpreter implements HumanLanguageInter
}
};
public AbstractRuleBasedInterpreter(final EventPublisher eventPublisher, final ItemRegistry itemRegistry,
protected AbstractRuleBasedInterpreter(final EventPublisher eventPublisher, final ItemRegistry itemRegistry,
final MetadataRegistry metadataRegistry) {
this.eventPublisher = eventPublisher;
this.itemRegistry = itemRegistry;

View File

@ -32,9 +32,9 @@ public abstract class AbstractUID {
private String uid = "";
/**
* Constructor must be public, otherwise it can not be called by subclasses from another package.
* Constructor must be protected, otherwise it can not be called by subclasses from another package.
*/
public AbstractUID() {
protected AbstractUID() {
segments = List.of();
}
@ -44,7 +44,7 @@ public abstract class AbstractUID {
*
* @param uid uid in form a string
*/
public AbstractUID(String uid) {
protected AbstractUID(String uid) {
this(splitToSegments(uid));
this.uid = uid;
}
@ -54,7 +54,7 @@ public abstract class AbstractUID {
*
* @param segments the id segments
*/
public AbstractUID(final String... segments) {
protected AbstractUID(final String... segments) {
this(Arrays.asList(segments));
}
@ -63,7 +63,7 @@ public abstract class AbstractUID {
*
* @param segments segments
*/
public AbstractUID(List<String> segments) {
protected AbstractUID(List<String> segments) {
int minNumberOfSegments = getMinimalNumberOfSegments();
int numberOfSegments = segments.size();
if (numberOfSegments < minNumberOfSegments) {

View File

@ -50,7 +50,7 @@ public abstract class AbstractManagedProvider<@NonNull E extends Identifiable<K>
protected final Logger logger = LoggerFactory.getLogger(AbstractManagedProvider.class);
public AbstractManagedProvider(final StorageService storageService) {
protected AbstractManagedProvider(final StorageService storageService) {
storage = storageService.getStorage(getStorageName(), this.getClass().getClassLoader());
}

View File

@ -36,7 +36,7 @@ public abstract class AbstractEvent implements Event {
* @param payload the payload
* @param source the source
*/
public AbstractEvent(String topic, String payload, @Nullable String source) {
protected AbstractEvent(String topic, String payload, @Nullable String source) {
this.topic = topic;
this.payload = payload;
this.source = source;

View File

@ -38,7 +38,7 @@ public abstract class AbstractEventFactory implements EventFactory {
*
* @param supportedEventTypes the supported event types
*/
public AbstractEventFactory(Set<String> supportedEventTypes) {
protected AbstractEventFactory(Set<String> supportedEventTypes) {
this.supportedEventTypes = Set.copyOf(supportedEventTypes);
}

View File

@ -37,7 +37,7 @@ public abstract class AbstractI18nException extends RuntimeException {
* @param message the exception message; use "@text/key" to reference "key" entry in the properties file
* @param msgParams the optional arguments of the message defined in the properties file
*/
public AbstractI18nException(String message, @Nullable Object @Nullable... msgParams) {
protected AbstractI18nException(String message, @Nullable Object @Nullable... msgParams) {
this(message, null, msgParams);
}
@ -48,7 +48,8 @@ public abstract class AbstractI18nException extends RuntimeException {
* and indicates that the cause is nonexistent or unknown.
* @param msgParams the optional arguments of the message defined in the properties file
*/
public AbstractI18nException(String message, @Nullable Throwable cause, @Nullable Object @Nullable... msgParams) {
protected AbstractI18nException(String message, @Nullable Throwable cause,
@Nullable Object @Nullable... msgParams) {
super(I18nUtil.isConstant(message) ? null : message, cause);
if (I18nUtil.isConstant(message)) {
this.msgKey = I18nUtil.stripConstant(message);
@ -62,7 +63,7 @@ public abstract class AbstractI18nException extends RuntimeException {
*
* @param cause the cause (which is saved for later retrieval by the getCause() method).
*/
public AbstractI18nException(Throwable cause) {
protected AbstractI18nException(Throwable cause) {
super(cause);
this.msgKey = "";
}

View File

@ -317,7 +317,7 @@ public class ThingStatusInfoI18nLocalizationServiceOSGiTest extends JavaOSGiTest
}
private abstract static class AbstractThingHandler extends BaseThingHandler {
public AbstractThingHandler(Thing thing) {
protected AbstractThingHandler(Thing thing) {
super(thing);
}
}

View File

@ -376,7 +376,7 @@ public class ChannelCommandDescriptionProviderOSGiTest extends JavaOSGiTest {
}
private abstract static class AbstractThingHandler extends BaseThingHandler {
public AbstractThingHandler(Thing thing) {
protected AbstractThingHandler(Thing thing) {
super(thing);
}
}

View File

@ -501,7 +501,7 @@ public class ChannelStateDescriptionProviderOSGiTest extends JavaOSGiTest {
}
private abstract static class AbstractThingHandler extends BaseThingHandler {
public AbstractThingHandler(Thing thing) {
protected AbstractThingHandler(Thing thing) {
super(thing);
}
}