com.github.tommyettinger.tantrum.jdkgdxds.ObjectLongOrderedMapSerializer 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.ObjectLongOrderedMap;
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 ObjectLongOrderedMap}s.
*/
@SuppressWarnings("rawtypes")
public class ObjectLongOrderedMapSerializer extends Serializer {
public ObjectLongOrderedMapSerializer(Fury fury) {
super(fury, ObjectLongOrderedMap.class);
}
@Override
public void write(final MemoryBuffer output, final ObjectLongOrderedMap data) {
output.writePrimitiveArrayWithSize(data.values().toArray(), Platform.LONG_ARRAY_OFFSET, data.size() << 3);
for(Object v : data.keySet()){
fury.writeRef(output, v);
}
}
@Override
public ObjectLongOrderedMap> read(MemoryBuffer input) {
long[] vs = Support.readLongsAndSize(input);
final int len = vs.length;
Object[] ks = new Object[len];
for (int i = 0; i < len; i++) {
ks[i] = fury.readRef(input);
}
return new ObjectLongOrderedMap<>(ks, vs);
}
}