All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.prestosql.plugin.accumulo.serializers.MapLexicoder Maven / Gradle / Ivy

/*
 * 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 io.prestosql.plugin.accumulo.serializers;

import org.apache.accumulo.core.client.lexicoder.Lexicoder;

import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;

import static org.apache.accumulo.core.client.lexicoder.impl.ByteUtils.concat;
import static org.apache.accumulo.core.client.lexicoder.impl.ByteUtils.escape;
import static org.apache.accumulo.core.client.lexicoder.impl.ByteUtils.split;
import static org.apache.accumulo.core.client.lexicoder.impl.ByteUtils.unescape;

/**
 * Accumulo lexicoder for encoding a Java Map
 *
 * @param  Key data type
 * @param  Value data type
 */
public class MapLexicoder
        implements Lexicoder>
{
    private final Lexicoder keyLexicoder;
    private final Lexicoder valueLexicoder;

    public MapLexicoder(
            Lexicoder keyLexicoder,
            Lexicoder valueLexicoder)
    {
        this.keyLexicoder = keyLexicoder;
        this.valueLexicoder = valueLexicoder;
    }

    @Override
    public byte[] encode(Map v)
    {
        byte[][] elements = new byte[v.size() * 2][];
        int index = 0;
        for (Entry entry : v.entrySet()) {
            elements[index++] = escape(keyLexicoder.encode(entry.getKey()));
            elements[index++] = escape(valueLexicoder.encode(entry.getValue()));
        }

        return concat(elements);
    }

    @Override
    public Map decode(byte[] b)
    {
        byte[][] escapedElements = split(b);
        Map decodedMap = new HashMap<>();
        for (int i = 0; i < escapedElements.length; i += 2) {
            K key = keyLexicoder.decode(unescape(escapedElements[i]));
            V value = valueLexicoder.decode(unescape(escapedElements[i + 1]));
            decodedMap.put(key, value);
        }

        return decodedMap;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy