blob: 0ebd4ba1a796caba8bdba130b3ac7a87351d1d32 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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.
*/
#include "Version.hpp"
#include <limits>
#include <geode/DataInput.hpp>
#include <geode/DataOutput.hpp>
namespace apache {
namespace geode {
namespace client {
void Version::write(DataOutput& dataOutput, const Version& version,
bool compressed) {
const auto ordinal = version.getOrdinal();
if (compressed && (ordinal <= std::numeric_limits<int8_t>::max())) {
dataOutput.write(static_cast<int8_t>(ordinal));
} else {
dataOutput.write(kTokenOrdinal);
dataOutput.writeInt(ordinal);
}
}
Version Version::read(DataInput& dataInput) {
int16_t ordinal = dataInput.read();
if (kTokenOrdinal == ordinal) {
ordinal = dataInput.readInt16();
}
return Version(ordinal);
}
} // namespace client
} // namespace geode
} // namespace apache