/* * Copyright (C) 2014 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.tools.klint.detector.api; import com.android.annotations.NonNull; import com.android.annotations.Nullable; import com.android.resources.ResourceFolderType; import com.android.tools.klint.client.api.LintDriver; import com.google.common.annotations.Beta; import java.io.File; /** * A {@link com.android.tools.lint.detector.api.Context} used when checking resource files * (both bitmaps and XML files; for XML files a subclass of this context is used: * {@link com.android.tools.lint.detector.api.XmlContext}.) * <p> * <b>NOTE: This is not a public or final API; if you rely on this be prepared * to adjust your code for the next tools release.</b> */ @Beta public class ResourceContext extends Context { private final ResourceFolderType mFolderType; /** * Construct a new {@link com.android.tools.lint.detector.api.ResourceContext} * * @param driver the driver running through the checks * @param project the project containing the file being checked * @param main the main project if this project is a library project, or * null if this is not a library project. The main project is * the root project of all library projects, not necessarily the * directly including project. * @param file the file being checked * @param folderType the {@link com.android.resources.ResourceFolderType} of this file, if any */ public ResourceContext( @NonNull LintDriver driver, @NonNull Project project, @Nullable Project main, @NonNull File file, @Nullable ResourceFolderType folderType) { super(driver, project, main, file); mFolderType = folderType; } /** * Returns the resource folder type of this XML file, if any. * * @return the resource folder type or null */ @Nullable public ResourceFolderType getResourceFolderType() { return mFolderType; } /** * Returns the folder version. For example, for the file values-v14/foo.xml, * it returns 14. * * @return the folder version, or -1 if no specific version was specified */ public int getFolderVersion() { return mDriver.getResourceFolderVersion(file); } }