All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.scijava.util.Prefs Maven / Gradle / Ivy

/*
 * #%L
 * SciJava Common shared library for SciJava software.
 * %%
 * Copyright (C) 2009 - 2017 Board of Regents of the University of
 * Wisconsin-Madison, Broad Institute of MIT and Harvard, Max Planck
 * Institute of Molecular Cell Biology and Genetics, University of
 * Konstanz, and KNIME GmbH.
 * %%
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 * 
 * 1. Redistributions of source code must retain the above copyright notice,
 *    this list of conditions and the following disclaimer.
 * 2. Redistributions in binary form must reproduce the above copyright notice,
 *    this list of conditions and the following disclaimer in the documentation
 *    and/or other materials provided with the distribution.
 * 
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGE.
 * #L%
 */

package org.scijava.util;

import java.util.List;
import java.util.Map;
import java.util.prefs.Preferences;

import org.scijava.prefs.DefaultPrefService;
import org.scijava.prefs.PrefService;

/**
 * Simple utility class that stores and retrieves user preferences.
 * 

* Some of this code was adapted from the PrefsUtil class by Robin Sharp of Javelin Software.. *

* * @author Curtis Rueden * @author Barry DeZonia * @author Grant Harris * @deprecated See {@link PrefService} */ @Deprecated public final class Prefs { private static PrefService prefService; private static PrefService prefServiceNoContext; private static double servicePriority = Double.MIN_VALUE; private Prefs() { // prevent instantiation of utility class } // -- Global preferences -- public static String get(final String name) { return service().get(name); } public static String get(final String name, final String defaultValue) { return service().get(name, defaultValue); } public static boolean getBoolean(final String name, final boolean defaultValue) { return service().getBoolean(name, defaultValue); } public static double getDouble(final String name, final double defaultValue) { return service().getDouble(name, defaultValue); } public static float getFloat(final String name, final float defaultValue) { return service().getFloat(name, defaultValue); } public static int getInt(final String name, final int defaultValue) { return service().getInt(name, defaultValue); } public static long getLong(final String name, final long defaultValue) { return service().getLong(name, defaultValue); } public static void put(final String name, final String value) { service().put(name, value); } public static void put(final String name, final boolean value) { service().put(name, value); } public static void put(final String name, final double value) { service().put(name, value); } public static void put(final String name, final float value) { service().put(name, value); } public static void put(final String name, final int value) { service().put(name, value); } public static void put(final String name, final long value) { service().put(name, value); } // -- Class-specific preferences -- public static String get(final Class c, final String name) { return service().get(c, name); } public static String get(final Class c, final String name, final String defaultValue) { return service().get(c, name, defaultValue); } public static boolean getBoolean(final Class c, final String name, final boolean defaultValue) { return service().getBoolean(c, name, defaultValue); } public static double getDouble(final Class c, final String name, final double defaultValue) { return service().getDouble(c, name, defaultValue); } public static float getFloat(final Class c, final String name, final float defaultValue) { return service().getFloat(c, name, defaultValue); } public static int getInt(final Class c, final String name, final int defaultValue) { return service().getInt(c, name, defaultValue); } public static long getLong(final Class c, final String name, final long defaultValue) { return service().getLong(c, name, defaultValue); } public static void put(final Class c, final String name, final String value) { service().put(c, name, value); } public static void put(final Class c, final String name, final boolean value) { service().put(c, name, value); } public static void put(final Class c, final String name, final double value) { service().put(c, name, value); } public static void put(final Class c, final String name, final float value) { service().put(c, name, value); } public static void put(final Class c, final String name, final int value) { service().put(c, name, value); } public static void put(final Class c, final String name, final long value) { service().put(c, name, value); } public static void clear(final Class c) { service().clear(c); } // -- Other/unsorted -- // TODO - Evaluate which of these methods are really needed, and which are // duplicate of similar functionality above. /** Clears everything. */ public static void clearAll() { service().clearAll(); } /** Clears the node. */ public static void clear(final String key) { service().clear(key); } public static void clear(final Preferences preferences, final String key) { service().clear(preferences.absolutePath(), key); } /** Removes the node. */ public static void remove(final Preferences preferences, final String key) { service().remove(preferences.absolutePath(), key); } /** Puts a map into the preferences. */ public static void putMap(final Map map, final String key) { service().putMap(map, key); } public static void putMap(final Preferences preferences, final Map map, final String key) { service().putMap(preferences.absolutePath(), map, key); } /** Puts a map into the preferences. */ public static void putMap(final Preferences preferences, final Map map) { service().putMap(preferences.absolutePath(), map); } /** Gets a Map from the preferences. */ public static Map getMap(final String key) { return service().getMap(key); } public static Map getMap(final Preferences preferences, final String key) { return service().getMap(preferences.absolutePath(), key); } /** Gets a Map from the preferences. */ public static Map getMap(final Preferences preferences) { return service().getMap(preferences.absolutePath()); } /** Puts a list into the preferences. */ public static void putList(final List list, final String key) { service().putList(list, key); } public static void putList(final Preferences preferences, final List list, final String key) { service().putList(preferences.absolutePath(), list, key); } /** Puts a list into the preferences. */ public static void putList(final Preferences preferences, final List list) { service().putList(preferences.absolutePath(), list); } /** Gets a List from the preferences. */ public static List getList(final String key) { return service().getList(key); } public static List getList(final Preferences preferences, final String key) { return service().getList(preferences.absolutePath(), key); } /** * Gets a List from the preferences. Returns an empty list if nothing in * prefs. */ public static List getList(final Preferences preferences) { return service().getList(preferences.absolutePath()); } // -- PrefService setter -- /** * Sets the {@link PrefService} */ public static void setDelegateService(final PrefService prefService, final double priority) { if (Double.compare(priority, Prefs.servicePriority) > 0) { Prefs.prefService = prefService; Prefs.servicePriority = priority; } } // -- Helper methods -- /** * Gets the delegate {@link PrefService} to use for preference operations. If * this service has not been explicitly set, then a {@link DefaultPrefService} * will be used. * * @return The current {@link PrefService} to use for delegation. */ private static PrefService service() { if (prefService != null) return prefService; if (prefServiceNoContext == null) prefServiceNoContext = new DefaultPrefService(); return prefServiceNoContext; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy