/* * Copyright (C) 2016 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 com.android.launcher3.util; import android.content.ComponentName; import android.os.UserHandle; import com.android.launcher3.FolderInfo; import com.android.launcher3.ItemInfo; import com.android.launcher3.LauncherAppWidgetInfo; import com.android.launcher3.LauncherSettings.Favorites; import com.android.launcher3.WorkspaceItemInfo; import com.android.launcher3.shortcuts.ShortcutKey; import java.util.HashSet; /** * A utility class to check for {@link ItemInfo} */ public interface ItemInfoMatcher { boolean matches(ItemInfo info, ComponentName cn); /** * Filters {@param infos} to those satisfying the {@link #matches(ItemInfo, ComponentName)}. */ default HashSet filterItemInfos(Iterable infos) { HashSet filtered = new HashSet<>(); for (ItemInfo i : infos) { if (i instanceof WorkspaceItemInfo) { WorkspaceItemInfo info = (WorkspaceItemInfo) i; ComponentName cn = info.getTargetComponent(); if (cn != null && matches(info, cn)) { filtered.add(info); } } else if (i instanceof FolderInfo) { FolderInfo info = (FolderInfo) i; for (WorkspaceItemInfo s : info.contents) { ComponentName cn = s.getTargetComponent(); if (cn != null && matches(s, cn)) { filtered.add(s); } } } else if (i instanceof LauncherAppWidgetInfo) { LauncherAppWidgetInfo info = (LauncherAppWidgetInfo) i; ComponentName cn = info.providerName; if (cn != null && matches(info, cn)) { filtered.add(info); } } } return filtered; } /** * Returns a new matcher with returns true if either this or {@param matcher} returns true. */ default ItemInfoMatcher or(ItemInfoMatcher matcher) { return (info, cn) -> matches(info, cn) || matcher.matches(info, cn); } /** * Returns a new matcher with returns true if both this and {@param matcher} returns true. */ default ItemInfoMatcher and(ItemInfoMatcher matcher) { return (info, cn) -> matches(info, cn) && matcher.matches(info, cn); } /** * Returns a new matcher which returns the opposite boolean value of the provided * {@param matcher}. */ static ItemInfoMatcher not(ItemInfoMatcher matcher) { return (info, cn) -> !matcher.matches(info, cn); } static ItemInfoMatcher ofUser(UserHandle user) { return (info, cn) -> info.user.equals(user); } static ItemInfoMatcher ofComponents(HashSet components, UserHandle user) { return (info, cn) -> components.contains(cn) && info.user.equals(user); } static ItemInfoMatcher ofPackages(HashSet packageNames, UserHandle user) { return (info, cn) -> packageNames.contains(cn.getPackageName()) && info.user.equals(user); } static ItemInfoMatcher ofShortcutKeys(HashSet keys) { return (info, cn) -> info.itemType == Favorites.ITEM_TYPE_DEEP_SHORTCUT && keys.contains(ShortcutKey.fromItemInfo(info)); } static ItemInfoMatcher ofItemIds(IntSparseArrayMap ids, Boolean matchDefault) { return (info, cn) -> ids.get(info.id, matchDefault); } }