com.android.ide.common.res2.ResourceFile Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of sdk-common Show documentation
Show all versions of sdk-common Show documentation
sdk-common library used by other Android tools libraries.
/*
* Copyright (C) 2012 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.ide.common.res2;
import com.android.SdkConstants;
import com.android.annotations.NonNull;
import com.google.common.base.Objects;
import org.w3c.dom.Document;
import org.w3c.dom.Node;
import java.io.File;
import java.util.List;
/**
* Represents a file in a resource folders.
*
* It contains a link to the {@link File}, the qualifier string (which is the name of the folder
* after the first '-' character), a list of {@link ResourceItem}s and a type.
*
* The type of the file is based on whether the file is located in a values folder
* ({@link FileType#XML_VALUES}) or in another folder ({@link FileType#SINGLE_FILE} or
* {@link FileType#GENERATED_FILES}).
*/
public class ResourceFile extends DataFile {
static final String ATTR_QUALIFIER = "qualifiers";
private String mQualifiers;
/**
* Creates a resource file with a single resource item.
*
* The source file is set on the item with {@link ResourceItem#setSource(DataFile)}
*
* The type of the ResourceFile will be {@link FileType#SINGLE_FILE}.
*
* @param file the File
* @param item the resource item
* @param qualifiers the qualifiers.
*/
public ResourceFile(@NonNull File file, @NonNull ResourceItem item,
@NonNull String qualifiers) {
super(file, FileType.SINGLE_FILE);
mQualifiers = qualifiers;
init(item);
}
/**
* Creates a resource file with a list of resource items.
*
* The source file is set on the items with {@link ResourceItem#setSource(DataFile)}
*
* The type of the ResourceFile will be {@link FileType#XML_VALUES}.
*
* @param file the File
* @param items the resource items
* @param qualifiers the qualifiers.
*/
public ResourceFile(@NonNull File file, @NonNull List items,
@NonNull String qualifiers) {
this(file, items, qualifiers, FileType.XML_VALUES);
}
private ResourceFile(@NonNull File file, @NonNull List items,
@NonNull String qualifiers, @NonNull FileType fileType) {
super(file, fileType);
mQualifiers = qualifiers;
init(items);
}
public static ResourceFile generatedFiles(
@NonNull File file,
@NonNull List items,
@NonNull String qualifiers) {
// TODO: Replace other constructors with named methods.
return new ResourceFile(file, items, qualifiers, FileType.GENERATED_FILES);
}
@NonNull
public String getQualifiers() {
return mQualifiers;
}
// Used in Studio
public void setQualifiers(@NonNull String qualifiers) {
mQualifiers = qualifiers;
}
@Override
void addExtraAttributes(Document document, Node node, String namespaceUri) {
NodeUtils.addAttribute(document, node, namespaceUri, ATTR_QUALIFIER,
getQualifiers());
if (getType() == FileType.GENERATED_FILES) {
NodeUtils.addAttribute(document, node, namespaceUri, SdkConstants.ATTR_PREPROCESSING, "true");
}
}
@Override
public String toString() {
return Objects.toStringHelper(getClass())
.add("mFile", mFile)
.add("mQualifiers", mQualifiers)
.toString();
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy