Loading core/java/com/android/internal/util/XmlUtils.java +7 −12 Original line number Diff line number Diff line Loading @@ -482,12 +482,13 @@ public class XmlUtils { * @see #readThisMapXml * #see #writeMapXml */ public static final HashMap readMapXml(InputStream in) @SuppressWarnings("unchecked") public static final HashMap<String, ?> readMapXml(InputStream in) throws XmlPullParserException, java.io.IOException { XmlPullParser parser = Xml.newPullParser(); parser.setInput(in, null); return (HashMap)readValueXml(parser, new String[1]); return (HashMap<String, ?>) readValueXml(parser, new String[1]); } /** Loading Loading @@ -548,22 +549,16 @@ public class XmlUtils { * * @see #readMapXml */ public static final HashMap readThisMapXml(XmlPullParser parser, String endTag, String[] name) throws XmlPullParserException, java.io.IOException public static final HashMap<String, ?> readThisMapXml(XmlPullParser parser, String endTag, String[] name) throws XmlPullParserException, java.io.IOException { HashMap map = new HashMap(); HashMap<String, Object> map = new HashMap<String, Object>(); int eventType = parser.getEventType(); do { if (eventType == parser.START_TAG) { Object val = readThisValueXml(parser, name); if (name[0] != null) { //System.out.println("Adding to map: " + name + " -> " + val); map.put(name[0], val); } else { throw new XmlPullParserException( "Map value without name attribute: " + parser.getName()); } } else if (eventType == parser.END_TAG) { if (parser.getName().equals(endTag)) { return map; Loading core/tests/coretests/src/com/android/internal/util/XmlUtilsTest.java 0 → 100644 +41 −0 Original line number Diff line number Diff line /** * Copyright (C) 2013 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.internal.util; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.InputStream; import java.util.HashMap; import java.util.Map; import junit.framework.TestCase; public class XmlUtilsTest extends TestCase { // https://code.google.com/p/android/issues/detail?id=63717 public void testMapWithNullKeys() throws Exception { ByteArrayOutputStream baos = new ByteArrayOutputStream(1024); Map<String, Object> map = new HashMap<String, Object>(); map.put(null, "nullValue"); map.put("foo", "fooValue"); XmlUtils.writeMapXml(map, baos); InputStream mapInput = new ByteArrayInputStream(baos.toByteArray()); HashMap<String, ?> deserialized = XmlUtils.readMapXml(mapInput); assertEquals("nullValue", deserialized.get(null)); assertEquals("fooValue", deserialized.get("foo")); } } Loading
core/java/com/android/internal/util/XmlUtils.java +7 −12 Original line number Diff line number Diff line Loading @@ -482,12 +482,13 @@ public class XmlUtils { * @see #readThisMapXml * #see #writeMapXml */ public static final HashMap readMapXml(InputStream in) @SuppressWarnings("unchecked") public static final HashMap<String, ?> readMapXml(InputStream in) throws XmlPullParserException, java.io.IOException { XmlPullParser parser = Xml.newPullParser(); parser.setInput(in, null); return (HashMap)readValueXml(parser, new String[1]); return (HashMap<String, ?>) readValueXml(parser, new String[1]); } /** Loading Loading @@ -548,22 +549,16 @@ public class XmlUtils { * * @see #readMapXml */ public static final HashMap readThisMapXml(XmlPullParser parser, String endTag, String[] name) throws XmlPullParserException, java.io.IOException public static final HashMap<String, ?> readThisMapXml(XmlPullParser parser, String endTag, String[] name) throws XmlPullParserException, java.io.IOException { HashMap map = new HashMap(); HashMap<String, Object> map = new HashMap<String, Object>(); int eventType = parser.getEventType(); do { if (eventType == parser.START_TAG) { Object val = readThisValueXml(parser, name); if (name[0] != null) { //System.out.println("Adding to map: " + name + " -> " + val); map.put(name[0], val); } else { throw new XmlPullParserException( "Map value without name attribute: " + parser.getName()); } } else if (eventType == parser.END_TAG) { if (parser.getName().equals(endTag)) { return map; Loading
core/tests/coretests/src/com/android/internal/util/XmlUtilsTest.java 0 → 100644 +41 −0 Original line number Diff line number Diff line /** * Copyright (C) 2013 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.internal.util; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.InputStream; import java.util.HashMap; import java.util.Map; import junit.framework.TestCase; public class XmlUtilsTest extends TestCase { // https://code.google.com/p/android/issues/detail?id=63717 public void testMapWithNullKeys() throws Exception { ByteArrayOutputStream baos = new ByteArrayOutputStream(1024); Map<String, Object> map = new HashMap<String, Object>(); map.put(null, "nullValue"); map.put("foo", "fooValue"); XmlUtils.writeMapXml(map, baos); InputStream mapInput = new ByteArrayInputStream(baos.toByteArray()); HashMap<String, ?> deserialized = XmlUtils.readMapXml(mapInput); assertEquals("nullValue", deserialized.get(null)); assertEquals("fooValue", deserialized.get("foo")); } }