com.github.tommyettinger.tantrum.jdkgdxds.IntIntMapSerializer 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.IntIntMap;
import com.github.tommyettinger.tantrum.digital.helpers.Support;
import org.apache.fury.Fury;
import org.apache.fury.memory.MemoryBuffer;
import org.apache.fury.serializer.Serializer;
import org.apache.fury.memory.Platform;
/**
* Fury {@link Serializer} for jdkgdxds {@link IntIntMap}s.
*/
public class IntIntMapSerializer extends Serializer {
public IntIntMapSerializer(Fury fury) {
super(fury, IntIntMap.class);
}
@Override
public void write(final MemoryBuffer output, final IntIntMap data) {
output.writePrimitiveArrayWithSize(data.keySet().toArray(), Platform.INT_ARRAY_OFFSET, data.size() << 2);
output.writePrimitiveArrayWithSize(data.values().toArray(), Platform.INT_ARRAY_OFFSET, data.size() << 2);
}
@Override
public IntIntMap read(MemoryBuffer input) {
return new IntIntMap(Support.readIntsAndSize(input), Support.readIntsAndSize(input));
}
}