diff options
5 files changed, 218 insertions, 99 deletions
diff --git a/eclipse/plugins/com.android.ide.eclipse.adt/src/com/android/ide/eclipse/adt/internal/editors/formatting/AndroidXmlFormattingStrategy.java b/eclipse/plugins/com.android.ide.eclipse.adt/src/com/android/ide/eclipse/adt/internal/editors/formatting/AndroidXmlFormattingStrategy.java index 4afa101..048e885 100644 --- a/eclipse/plugins/com.android.ide.eclipse.adt/src/com/android/ide/eclipse/adt/internal/editors/formatting/AndroidXmlFormattingStrategy.java +++ b/eclipse/plugins/com.android.ide.eclipse.adt/src/com/android/ide/eclipse/adt/internal/editors/formatting/AndroidXmlFormattingStrategy.java @@ -31,6 +31,7 @@ import com.android.ide.eclipse.adt.AdtUtils; import com.android.ide.eclipse.adt.internal.editors.layout.gle2.DomUtilities; import com.android.ide.eclipse.adt.internal.editors.resources.descriptors.ResourcesDescriptors; import com.android.ide.eclipse.adt.internal.preferences.AdtPrefs; +import com.android.resources.ResourceType; import com.android.sdklib.SdkConstants; import org.eclipse.jface.text.BadLocationException; @@ -500,7 +501,7 @@ public class AndroidXmlFormattingStrategy extends ContextBasedFormattingStrategy /** * Guess what style to use to edit the given document - layout, resource, manifest, ... ? */ - private static XmlFormatStyle guessStyle(IStructuredModel model, Document domDocument) { + static XmlFormatStyle guessStyle(IStructuredModel model, Document domDocument) { // The "layout" style is used for most XML resource file types: // layouts, color-lists and state-lists, animations, drawables, menus, etc XmlFormatStyle style = XmlFormatStyle.LAYOUT; @@ -516,7 +517,7 @@ public class AndroidXmlFormattingStrategy extends ContextBasedFormattingStrategy // Selectors are also used similar to resources if (rootElement != null && SELECTOR_TAG.equals(rootElement.getTagName())) { - style = XmlFormatStyle.RESOURCE; + return XmlFormatStyle.RESOURCE; } // The "manifest" style is used for manifest files @@ -527,13 +528,17 @@ public class AndroidXmlFormattingStrategy extends ContextBasedFormattingStrategy } else { int lastSlash = baseLocation.lastIndexOf('/'); if (lastSlash != -1) { - lastSlash = baseLocation.lastIndexOf('/', lastSlash - 1); - if (lastSlash != -1 && baseLocation.startsWith("/values", lastSlash)) { //$NON-NLS-1$ - style = XmlFormatStyle.RESOURCE; + int end = baseLocation.lastIndexOf('/', lastSlash - 1); // -1 is okay + String resourceFolder = baseLocation.substring(end + 1, lastSlash); + String[] segments = resourceFolder.split("-"); //$NON-NLS-1$ + ResourceType type = ResourceType.getEnum(segments[0]); + if (type != null) { + style = XmlFormatStyle.get(type); } } } } + return style; } diff --git a/eclipse/plugins/com.android.ide.eclipse.adt/src/com/android/ide/eclipse/adt/internal/editors/formatting/XmlFormatPreferences.java b/eclipse/plugins/com.android.ide.eclipse.adt/src/com/android/ide/eclipse/adt/internal/editors/formatting/XmlFormatPreferences.java index 0702776..04441fd 100644 --- a/eclipse/plugins/com.android.ide.eclipse.adt/src/com/android/ide/eclipse/adt/internal/editors/formatting/XmlFormatPreferences.java +++ b/eclipse/plugins/com.android.ide.eclipse.adt/src/com/android/ide/eclipse/adt/internal/editors/formatting/XmlFormatPreferences.java @@ -15,6 +15,7 @@ */ package com.android.ide.eclipse.adt.internal.editors.formatting; +import com.android.annotations.VisibleForTesting; import com.android.ide.eclipse.adt.internal.preferences.AdtPrefs; import com.android.ide.eclipse.adt.internal.preferences.AttributeSortOrder; @@ -56,7 +57,8 @@ public class XmlFormatPreferences { /** Tab width (number of spaces to display for a tab) */ private int mTabWidth = -1; // -1: uninitialized - private XmlFormatPreferences() { + @VisibleForTesting + protected XmlFormatPreferences() { } /** diff --git a/eclipse/plugins/com.android.ide.eclipse.adt/src/com/android/ide/eclipse/adt/internal/editors/formatting/XmlFormatStyle.java b/eclipse/plugins/com.android.ide.eclipse.adt/src/com/android/ide/eclipse/adt/internal/editors/formatting/XmlFormatStyle.java index 94bb763..fa65472 100644 --- a/eclipse/plugins/com.android.ide.eclipse.adt/src/com/android/ide/eclipse/adt/internal/editors/formatting/XmlFormatStyle.java +++ b/eclipse/plugins/com.android.ide.eclipse.adt/src/com/android/ide/eclipse/adt/internal/editors/formatting/XmlFormatStyle.java @@ -34,6 +34,9 @@ public enum XmlFormatStyle { /** Layout formatting style: blank lines between elements, attributes on separate lines */ LAYOUT, + /** Similar to layout formatting style, but no blank lines inside opening elements */ + FILE, + /** Resource style: one line per complete element including text child content */ RESOURCE, @@ -62,12 +65,22 @@ public enum XmlFormatStyle { case ID: case INTEGER: case STRING: + case PLURALS: case STYLE: case STYLEABLE: + case COLOR: return RESOURCE; - default: + case LAYOUT: return LAYOUT; + + case DRAWABLE: + case MENU: + case ANIM: + case ANIMATOR: + case INTERPOLATOR: + default: + return FILE; } } @@ -79,10 +92,19 @@ public enum XmlFormatStyle { * @return the suitable format style to use */ public static XmlFormatStyle getForFolderType(ResourceFolderType folderType) { - if (folderType == ResourceFolderType.VALUES) { - return RESOURCE; - } else { - return LAYOUT; + switch (folderType) { + case LAYOUT: + return LAYOUT; + case COLOR: + case VALUES: + return RESOURCE; + case ANIM: + case ANIMATOR: + case DRAWABLE: + case INTERPOLATOR: + case MENU: + default: + return FILE; } } @@ -97,8 +119,12 @@ public enum XmlFormatStyle { return MANIFEST; } - String parentName = path.segment(path.segmentCount() - 1); - ResourceFolderType folderType = ResourceFolderType.getFolderType(parentName); - return getForFolderType(folderType); + if (path.segmentCount() > 2) { + String parentName = path.segment(path.segmentCount() - 2); + ResourceFolderType folderType = ResourceFolderType.getFolderType(parentName); + return getForFolderType(folderType); + } + + return FILE; } }
\ No newline at end of file diff --git a/eclipse/plugins/com.android.ide.eclipse.adt/src/com/android/ide/eclipse/adt/internal/editors/formatting/XmlPrettyPrinter.java b/eclipse/plugins/com.android.ide.eclipse.adt/src/com/android/ide/eclipse/adt/internal/editors/formatting/XmlPrettyPrinter.java index 21fb9a2..b2d7955 100644 --- a/eclipse/plugins/com.android.ide.eclipse.adt/src/com/android/ide/eclipse/adt/internal/editors/formatting/XmlPrettyPrinter.java +++ b/eclipse/plugins/com.android.ide.eclipse.adt/src/com/android/ide/eclipse/adt/internal/editors/formatting/XmlPrettyPrinter.java @@ -649,7 +649,8 @@ public class XmlPrettyPrinter { // element if (mPrefs.spaceBeforeClose && (mStyle != XmlFormatStyle.RESOURCE || isClosed) // in <selector> files etc still treat the <item> entries as in resource files - && !ITEM_TAG.equals(element.getTagName())) { + && !ITEM_TAG.equals(element.getTagName()) + && (isClosed || element.getAttributes().getLength() > 0)) { mOut.append(' '); } @@ -708,7 +709,8 @@ public class XmlPrettyPrinter { return true; } - if (mStyle == XmlFormatStyle.MANIFEST || mStyle == XmlFormatStyle.RESOURCE) { + if (mStyle == XmlFormatStyle.MANIFEST || mStyle == XmlFormatStyle.RESOURCE + || mStyle == XmlFormatStyle.FILE) { Node curr = element.getPreviousSibling(); // <style> elements are traditionally separated unless it follows a comment diff --git a/eclipse/plugins/com.android.ide.eclipse.tests/src/com/android/ide/eclipse/adt/internal/editors/formatting/XmlPrettyPrinterTest.java b/eclipse/plugins/com.android.ide.eclipse.tests/src/com/android/ide/eclipse/adt/internal/editors/formatting/XmlPrettyPrinterTest.java index e1186aa..90286c4 100644 --- a/eclipse/plugins/com.android.ide.eclipse.tests/src/com/android/ide/eclipse/adt/internal/editors/formatting/XmlPrettyPrinterTest.java +++ b/eclipse/plugins/com.android.ide.eclipse.tests/src/com/android/ide/eclipse/adt/internal/editors/formatting/XmlPrettyPrinterTest.java @@ -19,13 +19,17 @@ import com.android.ide.eclipse.adt.internal.editors.layout.gle2.DomUtilities; import com.android.ide.eclipse.adt.internal.preferences.AdtPrefs; import org.eclipse.jface.preference.PreferenceStore; +import org.eclipse.wst.sse.core.internal.provisional.IStructuredModel; +import org.eclipse.wst.xml.core.internal.provisional.document.IDOMModel; import org.w3c.dom.Document; import org.w3c.dom.Node; import org.w3c.dom.NodeList; import junit.framework.TestCase; -@SuppressWarnings("javadoc") +@SuppressWarnings({ + "javadoc", "restriction" +}) public class XmlPrettyPrinterTest extends TestCase { @Override protected void setUp() throws Exception { @@ -39,12 +43,23 @@ public class XmlPrettyPrinterTest extends TestCase { assertTrue(formatPrefs.oneAttributeOnFirstLine); } - private void checkFormat(XmlFormatPreferences prefs, XmlFormatStyle style, - String xml, String expected, String delimiter, - String startNodeName, boolean openTagOnly, String endNodeName) throws Exception { - - Document document = DomUtilities.parseStructuredDocument(xml); - assertNotNull(document); + private void checkFormat(XmlFormatPreferences prefs, String baseLocation, + String xml, + String expected, String delimiter, String startNodeName, + boolean openTagOnly, String endNodeName) throws Exception { + + IStructuredModel model = DomUtilities.createStructuredModel(xml); + assertNotNull(model); + model.setBaseLocation(baseLocation); + Document document = null; + if (model instanceof IDOMModel) { + IDOMModel domModel = (IDOMModel) model; + document = domModel.getDocument(); + } else { + fail("Can't get DOM model"); + return; + } + XmlFormatStyle style = AndroidXmlFormattingStrategy.guessStyle(model, document); XmlPrettyPrinter printer = new XmlPrettyPrinter(prefs, style, delimiter); @@ -95,31 +110,29 @@ public class XmlPrettyPrinterTest extends TestCase { return caretContextIndex + caretDelta; } - private void checkFormat(XmlFormatPreferences prefs, XmlFormatStyle style, - String xml, String expected, String delimiter) throws Exception { - checkFormat(prefs, style, xml, expected, delimiter, null, false, null); + private void checkFormat(XmlFormatPreferences prefs, String baseLocation, String xml, + String expected, String delimiter) throws Exception { + checkFormat(prefs, baseLocation, xml, expected, delimiter, null, false, null); } - private void checkFormat(XmlFormatPreferences prefs, XmlFormatStyle style, - String xml, String expected) throws Exception { - checkFormat(prefs, style, xml, expected, "\n"); //$NON-NLS-1$ + private void checkFormat(XmlFormatPreferences prefs, String baseLocation, String xml, + String expected) throws Exception { + checkFormat(prefs, baseLocation, xml, expected, "\n"); //$NON-NLS-1$ } - private void checkFormat(XmlFormatStyle style, String xml, String expected) + private void checkFormat(String baseLocation, String xml, String expected) throws Exception { XmlFormatPreferences prefs = XmlFormatPreferences.create(); - checkFormat(prefs, style, xml, expected); - } - - private void checkFormat(String xml, String expected) throws Exception { - checkFormat(XmlFormatStyle.LAYOUT, xml, expected); + checkFormat(prefs, baseLocation, xml, expected); } public void testLayout1() throws Exception { checkFormat( + "res/layout-port/layout1.xml", "<LinearLayout><Button></Button></LinearLayout>", - "<LinearLayout >\n" + + + "<LinearLayout>\n" + "\n" + - " <Button >\n" + + " <Button>\n" + " </Button>\n" + "\n" + "</LinearLayout>"); @@ -127,8 +140,10 @@ public class XmlPrettyPrinterTest extends TestCase { public void testLayout2() throws Exception { checkFormat( + "res/layout-port/layout2.xml", "<LinearLayout><Button foo=\"bar\"></Button></LinearLayout>", - "<LinearLayout >\n" + + + "<LinearLayout>\n" + "\n" + " <Button foo=\"bar\" >\n" + " </Button>\n" + @@ -140,9 +155,10 @@ public class XmlPrettyPrinterTest extends TestCase { XmlFormatPreferences prefs = XmlFormatPreferences.create(); prefs.oneAttributeOnFirstLine = true; checkFormat( - prefs, XmlFormatStyle.LAYOUT, + prefs, "res/layout-land/layout3.xml", "<LinearLayout><Button foo=\"bar\"></Button></LinearLayout>", - "<LinearLayout >\n" + + + "<LinearLayout>\n" + "\n" + " <Button foo=\"bar\" >\n" + " </Button>\n" + @@ -150,26 +166,25 @@ public class XmlPrettyPrinterTest extends TestCase { "</LinearLayout>"); } - /* - // TODO: This test will only work with the Eclipse DOM because our parser doesn't - // handle the ElementImpl case which records empty elements public void testClosedElements() throws Exception { checkFormat( - XmlPrettyPrinter.Style.RESOURCE, + "res/values/strings.xml", "<resources>\n" + "<item name=\"title_container\" type=\"id\" />\n" + "<item name=\"title_logo\" type=\"id\"/>\n" + "</resources>\n", + "<resources>\n" + - " <item name=\"title_container\" type=\"id\" />\n" + - " <item name=\"title_logo\" type=\"id\" />\n" + + "\n" + + " <item name=\"title_container\" type=\"id\"/>\n" + + " <item name=\"title_logo\" type=\"id\"/>\n" + + "\n" + "</resources>"); } - */ public void testResources() throws Exception { checkFormat( - XmlFormatStyle.RESOURCE, + "res/values-us/strings.xml", "<resources><item name=\"foo\">Text value here </item></resources>", "<resources>\n\n" + " <item name=\"foo\">Text value here </item>\n" + @@ -179,7 +194,7 @@ public class XmlPrettyPrinterTest extends TestCase { public void testNodeTypes() throws Exception { // Ensures that a document with all kinds of node types is serialized correctly checkFormat( - XmlFormatStyle.LAYOUT, + "res/layout-xlarge/layout.xml", "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n" + "<!--\n" + "/**\n" + @@ -207,7 +222,6 @@ public class XmlPrettyPrinterTest extends TestCase { "Type <key>less-than</key> (<)\n" + "--> \n" + "</LinearLayout>", - "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n" + "<!--\n" + "/**\n" + @@ -241,9 +255,10 @@ public class XmlPrettyPrinterTest extends TestCase { public void testWindowsDelimiters() throws Exception { checkFormat( - XmlFormatPreferences.create(), XmlFormatStyle.LAYOUT, + XmlFormatPreferences.create(), "res/layout-xlarge/layout.xml", "<LinearLayout><Button foo=\"bar\"></Button></LinearLayout>", - "<LinearLayout >\r\n" + + + "<LinearLayout>\r\n" + "\r\n" + " <Button foo=\"bar\" >\r\n" + " </Button>\r\n" + @@ -256,19 +271,20 @@ public class XmlPrettyPrinterTest extends TestCase { XmlFormatPreferences prefs = XmlFormatPreferences.create(); prefs.removeEmptyLines = true; checkFormat( - prefs, XmlFormatStyle.LAYOUT, + prefs, "res/layout-xlarge/layout.xml", "<foo><bar><baz1></baz1><baz2></baz2></bar><bar2></bar2><bar3><baz12></baz12></bar3></foo>", - "<foo >\n" + - " <bar >\n" + - " <baz1 >\n" + + + "<foo>\n" + + " <bar>\n" + + " <baz1>\n" + " </baz1>\n" + - " <baz2 >\n" + + " <baz2>\n" + " </baz2>\n" + " </bar>\n" + - " <bar2 >\n" + + " <bar2>\n" + " </bar2>\n" + - " <bar3 >\n" + - " <baz12 >\n" + + " <bar3>\n" + + " <baz12>\n" + " </baz12>\n" + " </bar3>\n" + "</foo>"); @@ -276,49 +292,54 @@ public class XmlPrettyPrinterTest extends TestCase { public void testRange() throws Exception { checkFormat( - XmlFormatPreferences.create(), XmlFormatStyle.LAYOUT, + XmlFormatPreferences.create(), "res/layout-xlarge/layout.xml", "<LinearLayout><Button foo=\"bar\"></Button><CheckBox/></LinearLayout>", "\n" + " <Button foo=\"bar\" >\n" + " </Button>\n" + "\n" + " <CheckBox />\n", - "\n", "Button", false, "CheckBox"); + "\n", + "Button", false, "CheckBox"); } public void testOpenTagOnly() throws Exception { checkFormat( - XmlFormatPreferences.create(), XmlFormatStyle.LAYOUT, + XmlFormatPreferences.create(), "res/layout-xlarge/layout.xml", "<LinearLayout><Button foo=\"bar\"></Button><CheckBox/></LinearLayout>", "\n" + " <Button foo=\"bar\" >\n" + " </Button>\n", + "\n", - "\n", "Button", true, "Button"); + "Button", true, "Button"); } public void testRange2() throws Exception { XmlFormatPreferences prefs = XmlFormatPreferences.create(); prefs.removeEmptyLines = true; checkFormat( - prefs, XmlFormatStyle.LAYOUT, + prefs, "res/layout-xlarge/layout.xml", "<foo><bar><baz1></baz1><baz2></baz2></bar><bar2></bar2><bar3><baz12></baz12></bar3></foo>", - " <baz1 >\n" + + + " <baz1>\n" + " </baz1>\n" + - " <baz2 >\n" + + " <baz2>\n" + " </baz2>\n" + " </bar>\n" + - " <bar2 >\n" + + " <bar2>\n" + " </bar2>\n" + - " <bar3 >\n" + - " <baz12 >\n" + + " <bar3>\n" + + " <baz12>\n" + " </baz12>\n", - "\n", "baz1", false, "baz12"); + + "\n", + "baz1", false, "baz12"); } public void testEOLcomments() throws Exception { checkFormat( - XmlFormatStyle.RESOURCE, + "res/drawable-mdpi/states.xml", "<selector xmlns:android=\"http://schemas.android.com/apk/res/android\">\n" + " <item android:state_pressed=\"true\"\n" + " android:color=\"#ffff0000\"/> <!-- pressed -->\n" + @@ -326,7 +347,6 @@ public class XmlPrettyPrinterTest extends TestCase { " android:color=\"#ff0000ff\"/> <!-- focused -->\n" + " <item android:color=\"#ff000000\"/> <!-- default -->\n" + "</selector>", - "<selector xmlns:android=\"http://schemas.android.com/apk/res/android\">\n" + "\n" + " <item android:state_pressed=\"true\" android:color=\"#ffff0000\"/> <!-- pressed -->\n" + @@ -338,12 +358,11 @@ public class XmlPrettyPrinterTest extends TestCase { public void testFormatColorList() throws Exception { checkFormat( - XmlFormatStyle.RESOURCE, + "res/drawable-hdpi/states.xml", "<selector xmlns:android=\"http://schemas.android.com/apk/res/android\">\n" + "<item android:state_activated=\"true\" android:color=\"#FFFFFF\"/>\n" + "<item android:color=\"#777777\" /> <!-- not selected -->\n" + "</selector>", - "<selector xmlns:android=\"http://schemas.android.com/apk/res/android\">\n" + "\n" + " <item android:state_activated=\"true\" android:color=\"#FFFFFF\"/>\n" + @@ -354,7 +373,7 @@ public class XmlPrettyPrinterTest extends TestCase { public void testPreserveNewlineAfterComment() throws Exception { checkFormat( - XmlFormatStyle.RESOURCE, + "res/values/dimen.xml", "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n" + "<resources><dimen name=\"colorstrip_height\">6dip</dimen>\n" + " <!-- comment1 --><dimen name=\"title_height\">45dip</dimen>\n" + @@ -369,7 +388,6 @@ public class XmlPrettyPrinterTest extends TestCase { "\n" + " <dimen name=\"text_size_medium\">18sp</dimen><dimen name=\"text_size_large\">22sp</dimen>\n" + "</resources>", - "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n" + "<resources>\n" + "\n" + @@ -391,7 +409,7 @@ public class XmlPrettyPrinterTest extends TestCase { public void testPlurals() throws Exception { checkFormat( - XmlFormatStyle.RESOURCE, + "res/values-us/strings.xml", "<resources xmlns:xliff=\"urn:oasis:names:tc:xliff:document:1.2\">\n" + "<string name=\"toast_sync_error\">Sync error: <xliff:g id=\"error\">%1$s</xliff:g></string>\n" + "<string name=\"session_subtitle\"><xliff:g id=\"time\">%1$s</xliff:g> in <xliff:g id=\"room\">%2$s</xliff:g></string>\n" + @@ -401,7 +419,6 @@ public class XmlPrettyPrinterTest extends TestCase { "<item quantity=\"other\"><xliff:g id=\"number_of_days\">%1$s</xliff:g> days, <xliff:g id=\"remaining_time\">%2$s</xliff:g></item>\n" + "</plurals>\n" + "</resources>", - "<resources xmlns:xliff=\"urn:oasis:names:tc:xliff:document:1.2\">\n" + "\n" + " <string name=\"toast_sync_error\">Sync error: <xliff:g id=\"error\">%1$s</xliff:g></string>\n" + @@ -418,7 +435,7 @@ public class XmlPrettyPrinterTest extends TestCase { public void testMultiAttributeResource() throws Exception { checkFormat( - XmlFormatStyle.RESOURCE, + "res/values-us/strings.xml", "<resources><string name=\"debug_enable_debug_logging_label\" translatable=\"false\">Enable extra debug logging?</string></resources>", "<resources>\n" + "\n" + @@ -429,14 +446,13 @@ public class XmlPrettyPrinterTest extends TestCase { public void testMultilineCommentAlignment() throws Exception { checkFormat( - XmlFormatStyle.RESOURCE, + "res/values-us/strings.xml", "<resources>" + " <!-- Deprecated strings - Move the identifiers to this section, mark as DO NOT TRANSLATE,\n" + " and remove the actual text. These will be removed in a bulk operation. -->\n" + " <!-- Do Not Translate. Unused string. -->\n" + " <string name=\"meeting_invitation\"></string>\n" + "</resources>", - "<resources>\n" + "\n" + " <!--\n" + @@ -451,7 +467,7 @@ public class XmlPrettyPrinterTest extends TestCase { public void testLineCommentSpacing() throws Exception { checkFormat( - XmlFormatStyle.RESOURCE, + "res/values-us/strings.xml", "<resources>\n" + "\n" + " <dimen name=\"colorstrip_height\">6dip</dimen>\n" + @@ -467,7 +483,6 @@ public class XmlPrettyPrinterTest extends TestCase { " <dimen name=\"text_size_large\">22sp</dimen>\n" + "\n" + "</resources>", - "<resources>\n" + "\n" + " <dimen name=\"colorstrip_height\">6dip</dimen>\n" + @@ -487,7 +502,7 @@ public class XmlPrettyPrinterTest extends TestCase { public void testCommentHandling() throws Exception { checkFormat( - XmlFormatPreferences.create(), XmlFormatStyle.LAYOUT, + XmlFormatPreferences.create(), "res/layout/layout1.xml", "<foo >\n" + "\n" + " <!-- abc\n" + @@ -504,7 +519,7 @@ public class XmlPrettyPrinterTest extends TestCase { "\n" + "</foo>", - "<foo >\n" + + "<foo>\n" + "\n" + " <!--\n" + " abc\n" + @@ -531,14 +546,14 @@ public class XmlPrettyPrinterTest extends TestCase { public void testCommentHandling2() throws Exception { checkFormat( - XmlFormatPreferences.create(), XmlFormatStyle.LAYOUT, + XmlFormatPreferences.create(), "res/layout-xlarge/layout.xml", "<foo >\n" + " <!-- multi -->\n" + "\n" + " <bar />\n" + "</foo>", - "<foo >\n" + + "<foo>\n" + "\n" + " <!-- multi -->\n" + "\n" + @@ -549,7 +564,7 @@ public class XmlPrettyPrinterTest extends TestCase { public void testMenus1() throws Exception { checkFormat( - XmlFormatPreferences.create(), XmlFormatStyle.LAYOUT, + XmlFormatPreferences.create(), "res/menu/menu1.xml", // http://code.google.com/p/android/issues/detail?id=21383 "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n" + "<menu xmlns:android=\"http://schemas.android.com/apk/res/android\" >\n" + @@ -584,15 +599,12 @@ public class XmlPrettyPrinterTest extends TestCase { " android:icon=\"@android:drawable/ic_menu_more\"\n" + " android:showAsAction=\"ifRoom|withText\"\n" + " android:title=\"@string/menu_debug\">\n" + - "\n" + - " <menu >\n" + - "\n" + + " <menu>\n" + " <item\n" + " android:id=\"@+id/menu_debug_clearCache_memory\"\n" + " android:icon=\"@android:drawable/ic_menu_delete\"\n" + " android:showAsAction=\"ifRoom|withText\"\n" + " android:title=\"@string/menu_debug_clearCache_memory\"/>\n" + - "\n" + " <item\n" + " android:id=\"@+id/menu_debug_clearCache_file\"\n" + " android:icon=\"@android:drawable/ic_menu_delete\"\n" + @@ -608,7 +620,7 @@ public class XmlPrettyPrinterTest extends TestCase { XmlFormatPreferences prefs = XmlFormatPreferences.create(); prefs.removeEmptyLines = true; checkFormat( - prefs, XmlFormatStyle.LAYOUT, + prefs, "res/drawable-hdpi/layerlist.xml", // http://code.google.com/p/android/issues/detail?id=21346 "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n" + "<layer-list xmlns:android=\"http://schemas.android.com/apk/res/android\">\n" + @@ -631,7 +643,6 @@ public class XmlPrettyPrinterTest extends TestCase { " </shape>\n" + " </item>\n" + "</layer-list>", - "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n" + "<layer-list xmlns:android=\"http://schemas.android.com/apk/res/android\" >\n" + " <item>\n" + @@ -657,7 +668,7 @@ public class XmlPrettyPrinterTest extends TestCase { public void testMenus3() throws Exception { checkFormat( - XmlFormatPreferences.create(), XmlFormatStyle.LAYOUT, + XmlFormatPreferences.create(), "res/menu/menu1.xml", // http://code.google.com/p/android/issues/detail?id=21227 "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n" + "<menu xmlns:android=\"http://schemas.android.com/apk/res/android\" >\n" + @@ -681,9 +692,7 @@ public class XmlPrettyPrinterTest extends TestCase { " <item\n" + " android:icon=\"@android:drawable/ic_menu_more\"\n" + " android:title=\"@string/account_list_menu_more\">\n" + - "\n" + - " <menu >\n" + - "\n" + + " <menu>\n" + " <item\n" + " android:id=\"@+id/account_list_menu_backup_restore\"\n" + " android:icon=\"@android:drawable/ic_menu_save\"\n" + @@ -692,5 +701,80 @@ public class XmlPrettyPrinterTest extends TestCase { " </item>\n" + "\n" + "</menu>"); + + } + + public void testColors1() throws Exception { + checkFormat( + XmlFormatPreferences.create(), "res/values/colors.xml", + "<resources>\n" + + " <color name=\"enrollment_error\">#99e21f14</color>\n" + + "\n" + + " <color name=\"service_starting_up\">#99000000</color>\n" + + "</resources>", + + "<resources>\n" + + "\n" + + " <color name=\"enrollment_error\">#99e21f14</color>\n" + + " <color name=\"service_starting_up\">#99000000</color>\n" + + "\n" + + "</resources>"); + } + + public void testEclipseFormatStyle1() throws Exception { + XmlFormatPreferences prefs = new XmlFormatPreferences() { + @Override + public String getOneIndentUnit() { + return "\t"; + } + + @Override + public int getTabWidth() { + return 8; + } + }; + checkFormat( + prefs, "res/values/colors.xml", + "<resources>\n" + + " <color name=\"enrollment_error\">#99e21f14</color>\n" + + "\n" + + " <color name=\"service_starting_up\">#99000000</color>\n" + + "</resources>", + + "<resources>\n" + + "\n" + + "\t<color name=\"enrollment_error\">#99e21f14</color>\n" + + "\t<color name=\"service_starting_up\">#99000000</color>\n" + + "\n" + + "</resources>"); + } + + public void testEclipseFormatStyle2() throws Exception { + XmlFormatPreferences prefs = new XmlFormatPreferences() { + @Override + public String getOneIndentUnit() { + return " "; + } + + @Override + public int getTabWidth() { + return 2; + } + }; + prefs.useEclipseIndent = true; + checkFormat( + prefs, "res/values/colors.xml", + "<resources>\n" + + " <color name=\"enrollment_error\">#99e21f14</color>\n" + + "\n" + + " <color name=\"service_starting_up\">#99000000</color>\n" + + "</resources>", + + "<resources>\n" + + "\n" + + " <color name=\"enrollment_error\">#99e21f14</color>\n" + + " <color name=\"service_starting_up\">#99000000</color>\n" + + "\n" + + "</resources>"); } } |