Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit cf1aa551 authored by Narayan Kamath's avatar Narayan Kamath Committed by Gerrit Code Review
Browse files

Merge "XmlUtils#readThisMapXml should handle null keys."

parents 7e296254 f748257e
Loading
Loading
Loading
Loading
+7 −12
Original line number Diff line number Diff line
@@ -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]);
    }

    /**
@@ -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;
+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"));
    }
}