forked from github/cordova-android
reading preferences from phonegap.xml
adds PreferenceNode and PreferenceSet classes as wrappers for the W3C config.xml <preference> nodes populates a PreferenceSet @preferences member
This commit is contained in:
parent
d91beb5ad9
commit
752b1b0e30
5
.gitignore
vendored
5
.gitignore
vendored
@ -7,9 +7,10 @@ framework/proguard.cfg
|
|||||||
framework/phonegap.jar
|
framework/phonegap.jar
|
||||||
framework/phonegap-*.jar
|
framework/phonegap-*.jar
|
||||||
framework/bin
|
framework/bin
|
||||||
|
framework/test/com/phonegap/*.class
|
||||||
framework/assets/www/.DS_Store
|
framework/assets/www/.DS_Store
|
||||||
framework/assets/www/phonegap-*.js
|
framework/assets/www/phonegap-*.js
|
||||||
example
|
example
|
||||||
test
|
./test
|
||||||
tmp
|
tmp
|
||||||
*.tmp
|
*.tmp
|
||||||
|
@ -75,6 +75,9 @@ import com.phonegap.api.LOG;
|
|||||||
import com.phonegap.api.PhonegapActivity;
|
import com.phonegap.api.PhonegapActivity;
|
||||||
import com.phonegap.api.PluginManager;
|
import com.phonegap.api.PluginManager;
|
||||||
|
|
||||||
|
import com.phonegap.PreferenceNode;
|
||||||
|
import com.phonegap.PreferenceSet;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class is the main Android activity that represents the PhoneGap
|
* This class is the main Android activity that represents the PhoneGap
|
||||||
* application. It should be extended by the user to load the specific
|
* application. It should be extended by the user to load the specific
|
||||||
@ -220,6 +223,9 @@ public class DroidGap extends PhonegapActivity {
|
|||||||
// when another application (activity) is started.
|
// when another application (activity) is started.
|
||||||
protected boolean keepRunning = true;
|
protected boolean keepRunning = true;
|
||||||
|
|
||||||
|
// preferences read from phonegap.xml
|
||||||
|
protected PreferenceSet preferences;
|
||||||
|
|
||||||
private boolean classicRender;
|
private boolean classicRender;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -311,6 +317,8 @@ public class DroidGap extends PhonegapActivity {
|
|||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public void onCreate(Bundle savedInstanceState) {
|
public void onCreate(Bundle savedInstanceState) {
|
||||||
|
preferences = new PreferenceSet();
|
||||||
|
|
||||||
LOG.d(TAG, "DroidGap.onCreate()");
|
LOG.d(TAG, "DroidGap.onCreate()");
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
getWindow().requestFeature(Window.FEATURE_NO_TITLE);
|
getWindow().requestFeature(Window.FEATURE_NO_TITLE);
|
||||||
@ -1880,7 +1888,17 @@ public class DroidGap extends PhonegapActivity {
|
|||||||
{
|
{
|
||||||
this.classicRender = enabled.equals("true");
|
this.classicRender = enabled.equals("true");
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
else if (strNode.equals("preference")) {
|
||||||
|
String name = xml.getAttributeValue(null, "name");
|
||||||
|
String value = xml.getAttributeValue(null, "value");
|
||||||
|
String readonlyString = xml.getAttributeValue(null, "readonly");
|
||||||
|
|
||||||
|
boolean readonly = (readonlyString.equals("true"));
|
||||||
|
|
||||||
|
LOG.i("PhoneGapLog", "Found preference for %s", name);
|
||||||
|
|
||||||
|
preferences.add(new PreferenceNode(name, value, readonly));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
|
16
framework/src/com/phonegap/PreferenceNode.java
Normal file
16
framework/src/com/phonegap/PreferenceNode.java
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
package com.phonegap;
|
||||||
|
|
||||||
|
// represents the <preference> element from the W3C config.xml spec
|
||||||
|
// see http://www.w3.org/TR/widgets/#the-preference-element-and-its-attributes
|
||||||
|
public class PreferenceNode {
|
||||||
|
public String name;
|
||||||
|
public String value;
|
||||||
|
public boolean readonly;
|
||||||
|
|
||||||
|
// constructor
|
||||||
|
public PreferenceNode(String name, String value, boolean readonly) {
|
||||||
|
this.name = name;
|
||||||
|
this.value = value;
|
||||||
|
this.readonly = readonly;
|
||||||
|
}
|
||||||
|
}
|
33
framework/src/com/phonegap/PreferenceSet.java
Normal file
33
framework/src/com/phonegap/PreferenceSet.java
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
package com.phonegap;
|
||||||
|
|
||||||
|
import java.util.HashSet;
|
||||||
|
|
||||||
|
import com.phonegap.PreferenceNode;
|
||||||
|
|
||||||
|
public class PreferenceSet {
|
||||||
|
private HashSet<PreferenceNode> innerSet;
|
||||||
|
|
||||||
|
public PreferenceSet() {
|
||||||
|
this.innerSet = new HashSet<PreferenceNode>();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void add(PreferenceNode node) {
|
||||||
|
this.innerSet.add(node);
|
||||||
|
}
|
||||||
|
|
||||||
|
public int size() {
|
||||||
|
return this.innerSet.size();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void clear() {
|
||||||
|
this.innerSet.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
public String pref(String prefName) {
|
||||||
|
for (PreferenceNode n : innerSet)
|
||||||
|
if (prefName.equals(n.name))
|
||||||
|
return n.value;
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
35
framework/test/com/phonegap/PreferenceNodeTest.java
Normal file
35
framework/test/com/phonegap/PreferenceNodeTest.java
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
import org.junit.*;
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
|
||||||
|
import com.phonegap.PreferenceNode;
|
||||||
|
|
||||||
|
public class PreferenceNodeTest {
|
||||||
|
@Test
|
||||||
|
public void testConstructor() {
|
||||||
|
PreferenceNode foo = new com.phonegap.PreferenceNode("fullscreen", "false", false);
|
||||||
|
assertEquals("fullscreen", foo.name);
|
||||||
|
assertEquals("false", foo.value);
|
||||||
|
assertEquals(false, foo.readonly);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testNameAssignment() {
|
||||||
|
PreferenceNode foo = new com.phonegap.PreferenceNode("fullscreen", "false", false);
|
||||||
|
foo.name = "widescreen";
|
||||||
|
assertEquals("widescreen", foo.name);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testValueAssignment() {
|
||||||
|
PreferenceNode foo = new com.phonegap.PreferenceNode("fullscreen", "false", false);
|
||||||
|
foo.value = "maybe";
|
||||||
|
assertEquals("maybe", foo.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testReadonlyAssignment() {
|
||||||
|
PreferenceNode foo = new com.phonegap.PreferenceNode("fullscreen", "false", false);
|
||||||
|
foo.readonly = true;
|
||||||
|
assertEquals(true, foo.readonly);
|
||||||
|
}
|
||||||
|
}
|
41
framework/test/com/phonegap/PreferenceSetTest.java
Normal file
41
framework/test/com/phonegap/PreferenceSetTest.java
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
import org.junit.*;
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
|
||||||
|
import com.phonegap.PreferenceNode;
|
||||||
|
import com.phonegap.PreferenceSet;
|
||||||
|
|
||||||
|
public class PreferenceSetTest {
|
||||||
|
private PreferenceSet preferences;
|
||||||
|
private PreferenceNode screen;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() {
|
||||||
|
preferences = new PreferenceSet();
|
||||||
|
screen = new PreferenceNode("fullscreen", "true", false);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testAddition() {
|
||||||
|
preferences.add(screen);
|
||||||
|
assertEquals(1, preferences.size());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testClear() {
|
||||||
|
preferences.add(screen);
|
||||||
|
preferences.clear();
|
||||||
|
assertEquals(0, preferences.size());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testPreferenceRetrieval() {
|
||||||
|
preferences.add(screen);
|
||||||
|
assertEquals("true", preferences.pref("fullscreen"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testNoPreferenceRetrieval() {
|
||||||
|
// return null if the preference is not defined
|
||||||
|
assertEquals(null, preferences.pref("antigravity"));
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user