Commit 4c0ca533 authored by jbroman's avatar jbroman Committed by Commit bot

Add a missing cast to ValueDeserializer::ReadVarint.

Without this cast, the integer type isn't promoted before being shifted, and so
for types larger than sizeof(int) there is data loss. This will become an issue
once the host begins using this helper to send 64-bit integers.

BUG=chromium:148757

Review-Url: https://codereview.chromium.org/2326653002
Cr-Commit-Position: refs/heads/master@{#39296}
parent 252b84b0
...@@ -820,7 +820,7 @@ Maybe<T> ValueDeserializer::ReadVarint() { ...@@ -820,7 +820,7 @@ Maybe<T> ValueDeserializer::ReadVarint() {
if (position_ >= end_) return Nothing<T>(); if (position_ >= end_) return Nothing<T>();
uint8_t byte = *position_; uint8_t byte = *position_;
if (V8_LIKELY(shift < sizeof(T) * 8)) { if (V8_LIKELY(shift < sizeof(T) * 8)) {
value |= (byte & 0x7f) << shift; value |= static_cast<T>(byte & 0x7f) << shift;
shift += 7; shift += 7;
} }
has_another_byte = byte & 0x80; has_another_byte = byte & 0x80;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment