com.android.ide.common.rendering.api.ResourceValue Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of layoutlib-api Show documentation
Show all versions of layoutlib-api Show documentation
Library to use the rendering library for Android layouts: layoutlib
The newest version!
/*
* Copyright (C) 2008 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.rendering.api;
import com.android.annotations.Nullable;
import com.android.resources.ResourceType;
/**
* Represents an android resource with a name and a string value.
*/
public class ResourceValue extends ResourceReference {
private final ResourceType mType;
private final String mLibraryName;
protected String mValue;
public ResourceValue(ResourceType type, String name, boolean isFramework) {
this(type, name, isFramework, null);
}
public ResourceValue(ResourceType type, String name, boolean isFramework, String libraryName) {
super(name, isFramework);
mType = type;
mLibraryName = libraryName;
}
public ResourceValue(ResourceType type, String name, String value, boolean isFramework) {
this(type, name, value, isFramework, null);
}
public ResourceValue(ResourceType type, String name, String value, boolean isFramework, String libraryName) {
super(name, isFramework);
mType = type;
mValue = value;
mLibraryName = libraryName;
}
public ResourceType getResourceType() {
return mType;
}
/**
* Returns the name of the library where this resource was found or null if it is not from a library.
*/
public String getLibraryName() {
return mLibraryName;
}
/**
* Returns true if the resource is user defined.
*/
public boolean isUserDefined() {
return !isFramework() && mLibraryName == null;
}
/**
* Returns the value of the resource, as defined in the XML. This can be null
,
* for example for instances of {@link StyleResourceValue}.
*/
@Nullable
public String getValue() {
return mValue;
}
/**
* Similar to {@link #getValue()}, but returns the raw XML value. This is usually
* the same as getValue, but with a few exceptions. For example, for markup strings,
* you can have * {@code This is bold }.
* Here, {@link #getValue()} will return "{@code This is bold}" -- e.g. just
* the plain text flattened. However, this method will return "{@code This is bold}",
* which preserves the XML markup elements.
*/
public String getRawXmlValue() {
return getValue();
}
/**
* Sets the value of the resource.
* @param value the new value
*/
public void setValue(String value) {
mValue = value;
}
/**
* Sets the value from another resource.
* @param value the resource value
*/
public void replaceWith(ResourceValue value) {
mValue = value.mValue;
}
@Override
public String toString() {
return getClass().getSimpleName() + " [" + mType + "/" + getName() + " = " + mValue //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$
+ " (framework:" + isFramework() + ")]"; //$NON-NLS-1$ //$NON-NLS-2$
}
@Override
public int hashCode() {
final int prime = 31;
int result = super.hashCode();
result = prime * result + ((mType == null) ? 0 : mType.hashCode());
result = prime * result + ((mValue == null) ? 0 : mValue.hashCode());
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (!super.equals(obj))
return false;
if (getClass() != obj.getClass())
return false;
ResourceValue other = (ResourceValue) obj;
if (mType == null) {
//noinspection VariableNotUsedInsideIf
if (other.mType != null)
return false;
} else if (!mType.equals(other.mType))
return false;
if (mValue == null) {
//noinspection VariableNotUsedInsideIf
if (other.mValue != null)
return false;
} else if (!mValue.equals(other.mValue))
return false;
return true;
}
}