resolved conflicts for 693e11e5 to mnc-dr-dev-plus-aosp
Change-Id: I701841759a80f434a09b086492e817ca23a6a2e6
This commit is contained in:
@@ -4238,6 +4238,11 @@ public final class ActivityThread {
|
||||
|
||||
configDiff = mConfiguration.updateFrom(config);
|
||||
config = applyCompatConfiguration(mCurDefaultDisplayDpi);
|
||||
|
||||
final Theme systemTheme = getSystemContext().getTheme();
|
||||
if ((systemTheme.getChangingConfigurations() & configDiff) != 0) {
|
||||
systemTheme.rebase();
|
||||
}
|
||||
}
|
||||
|
||||
ArrayList<ComponentCallbacks2> callbacks = collectComponentCallbacks(false, config);
|
||||
|
||||
@@ -1426,10 +1426,12 @@ public class Resources {
|
||||
* if not already defined in the theme.
|
||||
*/
|
||||
public void applyStyle(int resId, boolean force) {
|
||||
AssetManager.applyThemeStyle(mTheme, resId, force);
|
||||
synchronized (mKey) {
|
||||
AssetManager.applyThemeStyle(mTheme, resId, force);
|
||||
|
||||
mThemeResId = resId;
|
||||
mKey.append(resId, force);
|
||||
mThemeResId = resId;
|
||||
mKey.append(resId, force);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -1442,10 +1444,14 @@ public class Resources {
|
||||
* @param other The existing Theme to copy from.
|
||||
*/
|
||||
public void setTo(Theme other) {
|
||||
AssetManager.copyTheme(mTheme, other.mTheme);
|
||||
synchronized (mKey) {
|
||||
synchronized (other.mKey) {
|
||||
AssetManager.copyTheme(mTheme, other.mTheme);
|
||||
|
||||
mThemeResId = other.mThemeResId;
|
||||
mKey.setTo(other.getKey());
|
||||
mThemeResId = other.mThemeResId;
|
||||
mKey.setTo(other.getKey());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -1468,11 +1474,13 @@ public class Resources {
|
||||
* @see #obtainStyledAttributes(AttributeSet, int[], int, int)
|
||||
*/
|
||||
public TypedArray obtainStyledAttributes(@StyleableRes int[] attrs) {
|
||||
final int len = attrs.length;
|
||||
final TypedArray array = TypedArray.obtain(Resources.this, len);
|
||||
array.mTheme = this;
|
||||
AssetManager.applyStyle(mTheme, 0, 0, 0, attrs, array.mData, array.mIndices);
|
||||
return array;
|
||||
synchronized (mKey) {
|
||||
final int len = attrs.length;
|
||||
final TypedArray array = TypedArray.obtain(Resources.this, len);
|
||||
array.mTheme = this;
|
||||
AssetManager.applyStyle(mTheme, 0, 0, 0, attrs, array.mData, array.mIndices);
|
||||
return array;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -1482,7 +1490,7 @@ public class Resources {
|
||||
* <p>Be sure to call {@link TypedArray#recycle() TypedArray.recycle()} when you are done
|
||||
* with the array.
|
||||
*
|
||||
* @param resid The desired style resource.
|
||||
* @param resId The desired style resource.
|
||||
* @param attrs The desired attributes in the style.
|
||||
*
|
||||
* @throws NotFoundException Throws NotFoundException if the given ID does not exist.
|
||||
@@ -1495,39 +1503,15 @@ public class Resources {
|
||||
* @see #obtainStyledAttributes(int[])
|
||||
* @see #obtainStyledAttributes(AttributeSet, int[], int, int)
|
||||
*/
|
||||
public TypedArray obtainStyledAttributes(@StyleRes int resid, @StyleableRes int[] attrs)
|
||||
public TypedArray obtainStyledAttributes(@StyleRes int resId, @StyleableRes int[] attrs)
|
||||
throws NotFoundException {
|
||||
final int len = attrs.length;
|
||||
final TypedArray array = TypedArray.obtain(Resources.this, len);
|
||||
array.mTheme = this;
|
||||
if (false) {
|
||||
int[] data = array.mData;
|
||||
|
||||
System.out.println("**********************************************************");
|
||||
System.out.println("**********************************************************");
|
||||
System.out.println("**********************************************************");
|
||||
System.out.println("Attributes:");
|
||||
String s = " Attrs:";
|
||||
int i;
|
||||
for (i=0; i<attrs.length; i++) {
|
||||
s = s + " 0x" + Integer.toHexString(attrs[i]);
|
||||
}
|
||||
System.out.println(s);
|
||||
s = " Found:";
|
||||
TypedValue value = new TypedValue();
|
||||
for (i=0; i<attrs.length; i++) {
|
||||
int d = i*AssetManager.STYLE_NUM_ENTRIES;
|
||||
value.type = data[d+AssetManager.STYLE_TYPE];
|
||||
value.data = data[d+AssetManager.STYLE_DATA];
|
||||
value.assetCookie = data[d+AssetManager.STYLE_ASSET_COOKIE];
|
||||
value.resourceId = data[d+AssetManager.STYLE_RESOURCE_ID];
|
||||
s = s + " 0x" + Integer.toHexString(attrs[i])
|
||||
+ "=" + value;
|
||||
}
|
||||
System.out.println(s);
|
||||
synchronized (mKey) {
|
||||
final int len = attrs.length;
|
||||
final TypedArray array = TypedArray.obtain(Resources.this, len);
|
||||
array.mTheme = this;
|
||||
AssetManager.applyStyle(mTheme, 0, resId, 0, attrs, array.mData, array.mIndices);
|
||||
return array;
|
||||
}
|
||||
AssetManager.applyStyle(mTheme, 0, resid, 0, attrs, array.mData, array.mIndices);
|
||||
return array;
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -1580,50 +1564,23 @@ public class Resources {
|
||||
*/
|
||||
public TypedArray obtainStyledAttributes(AttributeSet set,
|
||||
@StyleableRes int[] attrs, @AttrRes int defStyleAttr, @StyleRes int defStyleRes) {
|
||||
final int len = attrs.length;
|
||||
final TypedArray array = TypedArray.obtain(Resources.this, len);
|
||||
synchronized (mKey) {
|
||||
final int len = attrs.length;
|
||||
final TypedArray array = TypedArray.obtain(Resources.this, len);
|
||||
|
||||
// XXX note that for now we only work with compiled XML files.
|
||||
// To support generic XML files we will need to manually parse
|
||||
// out the attributes from the XML file (applying type information
|
||||
// contained in the resources and such).
|
||||
final XmlBlock.Parser parser = (XmlBlock.Parser)set;
|
||||
AssetManager.applyStyle(mTheme, defStyleAttr, defStyleRes,
|
||||
parser != null ? parser.mParseState : 0, attrs, array.mData, array.mIndices);
|
||||
// XXX note that for now we only work with compiled XML files.
|
||||
// To support generic XML files we will need to manually parse
|
||||
// out the attributes from the XML file (applying type information
|
||||
// contained in the resources and such).
|
||||
final XmlBlock.Parser parser = (XmlBlock.Parser) set;
|
||||
AssetManager.applyStyle(mTheme, defStyleAttr, defStyleRes,
|
||||
parser != null ? parser.mParseState : 0,
|
||||
attrs, array.mData, array.mIndices);
|
||||
array.mTheme = this;
|
||||
array.mXml = parser;
|
||||
|
||||
array.mTheme = this;
|
||||
array.mXml = parser;
|
||||
|
||||
if (false) {
|
||||
int[] data = array.mData;
|
||||
|
||||
System.out.println("Attributes:");
|
||||
String s = " Attrs:";
|
||||
int i;
|
||||
for (i=0; i<set.getAttributeCount(); i++) {
|
||||
s = s + " " + set.getAttributeName(i);
|
||||
int id = set.getAttributeNameResource(i);
|
||||
if (id != 0) {
|
||||
s = s + "(0x" + Integer.toHexString(id) + ")";
|
||||
}
|
||||
s = s + "=" + set.getAttributeValue(i);
|
||||
}
|
||||
System.out.println(s);
|
||||
s = " Found:";
|
||||
TypedValue value = new TypedValue();
|
||||
for (i=0; i<attrs.length; i++) {
|
||||
int d = i*AssetManager.STYLE_NUM_ENTRIES;
|
||||
value.type = data[d+AssetManager.STYLE_TYPE];
|
||||
value.data = data[d+AssetManager.STYLE_DATA];
|
||||
value.assetCookie = data[d+AssetManager.STYLE_ASSET_COOKIE];
|
||||
value.resourceId = data[d+AssetManager.STYLE_RESOURCE_ID];
|
||||
s = s + " 0x" + Integer.toHexString(attrs[i])
|
||||
+ "=" + value;
|
||||
}
|
||||
System.out.println(s);
|
||||
return array;
|
||||
}
|
||||
|
||||
return array;
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -1642,18 +1599,20 @@ public class Resources {
|
||||
*/
|
||||
@NonNull
|
||||
public TypedArray resolveAttributes(@NonNull int[] values, @NonNull int[] attrs) {
|
||||
final int len = attrs.length;
|
||||
if (values == null || len != values.length) {
|
||||
throw new IllegalArgumentException(
|
||||
"Base attribute values must the same length as attrs");
|
||||
synchronized (mKey) {
|
||||
final int len = attrs.length;
|
||||
if (values == null || len != values.length) {
|
||||
throw new IllegalArgumentException(
|
||||
"Base attribute values must the same length as attrs");
|
||||
}
|
||||
|
||||
final TypedArray array = TypedArray.obtain(Resources.this, len);
|
||||
AssetManager.resolveAttrs(mTheme, 0, 0, values, attrs, array.mData, array.mIndices);
|
||||
array.mTheme = this;
|
||||
array.mXml = null;
|
||||
|
||||
return array;
|
||||
}
|
||||
|
||||
final TypedArray array = TypedArray.obtain(Resources.this, len);
|
||||
AssetManager.resolveAttrs(mTheme, 0, 0, values, attrs, array.mData, array.mIndices);
|
||||
array.mTheme = this;
|
||||
array.mXml = null;
|
||||
|
||||
return array;
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -1674,14 +1633,9 @@ public class Resources {
|
||||
* <var>outValue</var> is valid, else false.
|
||||
*/
|
||||
public boolean resolveAttribute(int resid, TypedValue outValue, boolean resolveRefs) {
|
||||
boolean got = mAssets.getThemeValue(mTheme, resid, outValue, resolveRefs);
|
||||
if (false) {
|
||||
System.out.println(
|
||||
"resolveAttribute #" + Integer.toHexString(resid)
|
||||
+ " got=" + got + ", type=0x" + Integer.toHexString(outValue.type)
|
||||
+ ", data=0x" + Integer.toHexString(outValue.data));
|
||||
synchronized (mKey) {
|
||||
return mAssets.getThemeValue(mTheme, resid, outValue, resolveRefs);
|
||||
}
|
||||
return got;
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -1727,8 +1681,11 @@ public class Resources {
|
||||
* @see ActivityInfo
|
||||
*/
|
||||
public int getChangingConfigurations() {
|
||||
final int nativeChangingConfig = AssetManager.getThemeChangingConfigurations(mTheme);
|
||||
return ActivityInfo.activityInfoConfigNativeToJava(nativeChangingConfig);
|
||||
synchronized (mKey) {
|
||||
final int nativeChangingConfig =
|
||||
AssetManager.getThemeChangingConfigurations(mTheme);
|
||||
return ActivityInfo.activityInfoConfigNativeToJava(nativeChangingConfig);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -1739,7 +1696,9 @@ public class Resources {
|
||||
* @param prefix Text to prefix each line printed.
|
||||
*/
|
||||
public void dump(int priority, String tag, String prefix) {
|
||||
AssetManager.dumpTheme(mTheme, priority, tag, prefix);
|
||||
synchronized (mKey) {
|
||||
AssetManager.dumpTheme(mTheme, priority, tag, prefix);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -1789,19 +1748,21 @@ public class Resources {
|
||||
*/
|
||||
@ViewDebug.ExportedProperty(category = "theme", hasAdjacentMapping = true)
|
||||
public String[] getTheme() {
|
||||
final int N = mKey.mCount;
|
||||
final String[] themes = new String[N * 2];
|
||||
for (int i = 0, j = N - 1; i < themes.length; i += 2, --j) {
|
||||
final int resId = mKey.mResId[j];
|
||||
final boolean forced = mKey.mForce[j];
|
||||
try {
|
||||
themes[i] = getResourceName(resId);
|
||||
} catch (NotFoundException e) {
|
||||
themes[i] = Integer.toHexString(i);
|
||||
synchronized (mKey) {
|
||||
final int N = mKey.mCount;
|
||||
final String[] themes = new String[N * 2];
|
||||
for (int i = 0, j = N - 1; i < themes.length; i += 2, --j) {
|
||||
final int resId = mKey.mResId[j];
|
||||
final boolean forced = mKey.mForce[j];
|
||||
try {
|
||||
themes[i] = getResourceName(resId);
|
||||
} catch (NotFoundException e) {
|
||||
themes[i] = Integer.toHexString(i);
|
||||
}
|
||||
themes[i + 1] = forced ? "forced" : "not forced";
|
||||
}
|
||||
themes[i + 1] = forced ? "forced" : "not forced";
|
||||
return themes;
|
||||
}
|
||||
return themes;
|
||||
}
|
||||
|
||||
/** @hide */
|
||||
@@ -1822,13 +1783,15 @@ public class Resources {
|
||||
* @hide
|
||||
*/
|
||||
public void rebase() {
|
||||
AssetManager.clearTheme(mTheme);
|
||||
synchronized (mKey) {
|
||||
AssetManager.clearTheme(mTheme);
|
||||
|
||||
// Reapply the same styles in the same order.
|
||||
for (int i = 0; i < mKey.mCount; i++) {
|
||||
final int resId = mKey.mResId[i];
|
||||
final boolean force = mKey.mForce[i];
|
||||
AssetManager.applyThemeStyle(mTheme, resId, force);
|
||||
// Reapply the same styles in the same order.
|
||||
for (int i = 0; i < mKey.mCount; i++) {
|
||||
final int resId = mKey.mResId[i];
|
||||
final boolean force = mKey.mForce[i];
|
||||
AssetManager.applyThemeStyle(mTheme, resId, force);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1115,6 +1115,12 @@ public final class SystemServer {
|
||||
w.getDefaultDisplay().getMetrics(metrics);
|
||||
context.getResources().updateConfiguration(config, metrics);
|
||||
|
||||
// The system context's theme may be configuration-dependent.
|
||||
final Theme systemTheme = context.getTheme();
|
||||
if (systemTheme.getChangingConfigurations() != 0) {
|
||||
systemTheme.rebase();
|
||||
}
|
||||
|
||||
Trace.traceBegin(Trace.TRACE_TAG_SYSTEM_SERVER, "MakePowerManagerServiceReady");
|
||||
try {
|
||||
// TODO: use boot phase
|
||||
@@ -1329,4 +1335,4 @@ public final class SystemServer {
|
||||
Trace.traceBegin(Trace.TRACE_TAG_SYSTEM_SERVER, name);
|
||||
Slog.i(TAG, name);
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user