com.github.tommyettinger.tantrum.jdkgdxds.LongLongOrderedMapSerializer Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of tantrum-jdkgdxds Show documentation
Show all versions of tantrum-jdkgdxds Show documentation
Fury 5.x serializers for jdkgdxds types
/*
* Copyright (c) 2024 See AUTHORS file.
*
* 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.github.tommyettinger.tantrum.jdkgdxds;
import com.github.tommyettinger.ds.LongLongOrderedMap;
import org.apache.fury.Fury;
import org.apache.fury.memory.MemoryBuffer;
import org.apache.fury.serializer.Serializer;
import org.apache.fury.memory.Platform;
import com.github.tommyettinger.tantrum.digital.helpers.Support;
/**
* Fury {@link Serializer} for jdkgdxds {@link LongLongOrderedMap}s.
*/
public class LongLongOrderedMapSerializer extends Serializer {
public LongLongOrderedMapSerializer(Fury fury) {
super(fury, LongLongOrderedMap.class);
}
@Override
public void write(final MemoryBuffer output, final LongLongOrderedMap data) {
output.writePrimitiveArrayWithSize(data.keySet().toArray(), Platform.LONG_ARRAY_OFFSET, data.size() << 3);
output.writePrimitiveArrayWithSize(data.values().toArray(), Platform.LONG_ARRAY_OFFSET, data.size() << 3);
}
@Override
public LongLongOrderedMap read(MemoryBuffer input) {
return new LongLongOrderedMap(Support.readLongsAndSize(input), Support.readLongsAndSize(input));
}
}