Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 44467a0f authored by Diego Perez's avatar Diego Perez
Browse files

Remove custom service Class -> name mapping

Keeping the mapping manually is very error prone and the
SystemServiceRegistry already does it for us.

Bug: http://b.android.com/231975
Test: Added new test
Change-Id: I507c4a9d5f0821a5a237ee27f5e97c5cd9040223
parent 349a8aef
Loading
Loading
Loading
Loading
+29 −0
Original line number Diff line number Diff line
/*
 * Copyright (C) 2017 The Android Open Source Project
 *
 * 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 android.app;

/**
 * Class to allow accessing {@link SystemServiceRegistry#getSystemServiceName}
 */
public class SystemServiceRegistry_Accessor {
    /**
     * Gets the name of the system-level service that is represented by the specified class.
     */
    public static String getSystemServiceName(Class<?> serviceClass) {
        return SystemServiceRegistry.getSystemServiceName(serviceClass);
    }
}
+2 −25
Original line number Diff line number Diff line
@@ -41,6 +41,7 @@ import org.xmlpull.v1.XmlPullParserException;
import android.annotation.NonNull;
import android.annotation.Nullable;
import android.app.Notification;
import android.app.SystemServiceRegistry_Accessor;
import android.content.BroadcastReceiver;
import android.content.ComponentName;
import android.content.ContentResolver;
@@ -631,31 +632,7 @@ public class BridgeContext extends Context {

    @Override
    public String getSystemServiceName(Class<?> serviceClass) {
        if (serviceClass.equals(LayoutInflater.class)) {
            return LAYOUT_INFLATER_SERVICE;
        }

        if (serviceClass.equals(TextServicesManager.class)) {
            return TEXT_SERVICES_MANAGER_SERVICE;
        }

        if (serviceClass.equals(WindowManager.class)) {
            return WINDOW_SERVICE;
        }

        if (serviceClass.equals(PowerManager.class)) {
            return POWER_SERVICE;
        }

        if (serviceClass.equals(DisplayManager.class)) {
            return DISPLAY_SERVICE;
        }

        if (serviceClass.equals(AccessibilityManager.class)) {
            return ACCESSIBILITY_SERVICE;
        }

        throw new UnsupportedOperationException("Unsupported Service: " + serviceClass);
        return SystemServiceRegistry_Accessor.getSystemServiceName(serviceClass);
    }

    @Override
+39 −0
Original line number Diff line number Diff line
/*
 * Copyright (C) 2017 The Android Open Source Project
 *
 * 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 android.app;

import org.junit.Test;

import android.content.Context;
import android.hardware.input.InputManager;
import android.view.WindowManager;
import android.view.accessibility.AccessibilityManager;

import static org.junit.Assert.*;

public class SystemServiceRegistry_AccessorTest {
    @Test
    public void testRegistry() {
        // Just check a few services to make sure we don't break the accessor
        assertEquals(Context.ACCESSIBILITY_SERVICE,
                SystemServiceRegistry_Accessor.getSystemServiceName(AccessibilityManager.class));
        assertEquals(Context.INPUT_SERVICE,
                SystemServiceRegistry_Accessor.getSystemServiceName(InputManager.class));
        assertEquals(Context.WINDOW_SERVICE,
                SystemServiceRegistry_Accessor.getSystemServiceName(WindowManager.class));
    }
}
 No newline at end of file