Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- /*
- * Copyright (C) 2015 Jared Rummler <jared.rummler@gmail.com>
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
- package com.jrummyapps.android.os;
- /**
- * Gives access to the system properties store. The system properties tore contains a list of string
- * key-value pairs.
- *
- * @author Jared Rummler <jared.rummler@gmail.com>
- * @since Feb 8, 2015
- */
- public class SystemProperties {
- // ===========================================================
- // STATIC FIELDS
- // ===========================================================
- private static Class<?> CLASS;
- // ===========================================================
- // STATIC INITIALIZERS
- // ===========================================================
- static {
- try {
- CLASS = Class.forName("android.os.SystemProperties");
- } catch (ClassNotFoundException e) {
- }
- }
- // ===========================================================
- // STATIC METHODS
- // ===========================================================
- /** Get the value for the given key. */
- public static String get(String key) {
- try {
- return (String) CLASS.getMethod("get", String.class).invoke(null, key);
- } catch (Exception e) {
- return null;
- }
- }
- /**
- * Get the value for the given key.
- *
- * @return if the key isn't found, return def if it isn't null, or an empty string otherwise
- */
- public static String get(String key, String def) {
- try {
- return (String) CLASS.getMethod("get", String.class, String.class).invoke(null, key,
- def);
- } catch (Exception e) {
- return def;
- }
- }
- /**
- * Get the value for the given key, and return as an integer.
- *
- * @param key
- * the key to lookup
- * @param def
- * a default value to return
- * @return the key parsed as an integer, or def if the key isn't found or cannot be parsed
- */
- public static int getInt(String key, int def) {
- try {
- return (Integer) CLASS.getMethod("getInt", String.class, int.class).invoke(null, key,
- def);
- } catch (Exception e) {
- return def;
- }
- }
- /**
- * Get the value for the given key, and return as a long.
- *
- * @param key
- * the key to lookup
- * @param def
- * a default value to return
- * @return the key parsed as a long, or def if the key isn't found or cannot be parsed
- */
- public static long getLong(String key, long def) {
- try {
- return (Long) CLASS.getMethod("getLong", String.class, long.class).invoke(null, key,
- def);
- } catch (Exception e) {
- return def;
- }
- }
- /**
- * Get the value for the given key, returned as a boolean. Values 'n', 'no', '0', 'false' or
- * 'off' are considered false. Values 'y', 'yes', '1', 'true' or 'on' are considered true. (case
- * sensitive). If the key does not exist, or has any other value, then the default result is
- * returned.
- *
- * @param key
- * the key to lookup
- * @param def
- * a default value to return
- * @return the key parsed as a boolean, or def if the key isn't found or is not able to be
- * parsed as a boolean.
- */
- public static boolean getBoolean(String key, boolean def) {
- try {
- return (Boolean) CLASS.getMethod("getBoolean", String.class, boolean.class).invoke(
- null, key, def);
- } catch (Exception e) {
- return def;
- }
- }
- /** Set the value for the given key. */
- public static void set(String key, String val) {
- try {
- CLASS.getMethod("set", String.class, String.class).invoke(null, key, val);
- } catch (Exception ignored) {
- }
- }
- public static void addChangeCallback(Runnable callback) {
- try {
- CLASS.getMethod("addChangeCallback", Runnable.class).invoke(null, callback);
- } catch (Exception ignored) {
- }
- }
- public static void callChangeCallbacks() {
- try {
- CLASS.getMethod("callChangeCallbacks").invoke(null, (Object[]) null);
- } catch (Exception ignored) {
- }
- }
- private SystemProperties() {
- }
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement