001/* 002 * Copyright (c) 2022-2024 See AUTHORS file. 003 * 004 * Licensed under the Apache License, Version 2.0 (the "License"); 005 * you may not use this file except in compliance with the License. 006 * You may obtain a copy of the License at 007 * 008 * http://www.apache.org/licenses/LICENSE-2.0 009 * 010 * Unless required by applicable law or agreed to in writing, software 011 * distributed under the License is distributed on an "AS IS" BASIS, 012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 013 * See the License for the specific language governing permissions and 014 * limitations under the License. 015 * 016 */ 017 018package com.github.tommyettinger.kryo.juniper; 019 020import com.esotericsoftware.kryo.Kryo; 021import com.esotericsoftware.kryo.Serializer; 022import com.esotericsoftware.kryo.io.Input; 023import com.esotericsoftware.kryo.io.Output; 024import com.github.tommyettinger.random.Bear32Random; 025 026/** 027 * Kryo {@link Serializer} for juniper {@link Bear32Random}s. 028 */ 029public class Bear32RandomSerializer extends Serializer<Bear32Random> { 030 031 public Bear32RandomSerializer() { 032 setImmutable(false); 033 setAcceptsNull(false); 034 } 035 036 @Override 037 public void write(final Kryo kryo, final Output output, final Bear32Random data) { 038 output.writeVarInt((int)data.getStateA(), false); 039 output.writeVarInt((int)data.getStateB(), false); 040 output.writeVarInt((int)data.getStateC(), false); 041 output.writeVarInt((int)data.getStateD(), false); 042 } 043 044 @Override 045 public Bear32Random read(final Kryo kryo, final Input input, final Class<? extends Bear32Random> dataClass) { 046 return new Bear32Random(input.readVarInt(false), input.readVarInt(false), 047 input.readVarInt(false), input.readVarInt(false)); 048 } 049 050 @Override 051 public Bear32Random copy(Kryo kryo, Bear32Random original) { 052 return original.copy(); 053 } 054}