// Copyright 2016 the V8 project authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include "src/inspector/string-util.h" #include #include #include "src/base/platform/platform.h" #include "src/inspector/protocol/Protocol.h" #include "src/numbers/conversions.h" namespace v8_inspector { v8::Local toV8String(v8::Isolate* isolate, const String16& string) { if (string.isEmpty()) return v8::String::Empty(isolate); DCHECK_GT(v8::String::kMaxLength, string.length()); return v8::String::NewFromTwoByte( isolate, reinterpret_cast(string.characters16()), v8::NewStringType::kNormal, static_cast(string.length())) .ToLocalChecked(); } v8::Local toV8StringInternalized(v8::Isolate* isolate, const String16& string) { if (string.isEmpty()) return v8::String::Empty(isolate); DCHECK_GT(v8::String::kMaxLength, string.length()); return v8::String::NewFromTwoByte( isolate, reinterpret_cast(string.characters16()), v8::NewStringType::kInternalized, static_cast(string.length())) .ToLocalChecked(); } v8::Local toV8StringInternalized(v8::Isolate* isolate, const char* str) { return v8::String::NewFromUtf8(isolate, str, v8::NewStringType::kInternalized) .ToLocalChecked(); } v8::Local toV8String(v8::Isolate* isolate, const StringView& string) { if (!string.length()) return v8::String::Empty(isolate); DCHECK_GT(v8::String::kMaxLength, string.length()); if (string.is8Bit()) return v8::String::NewFromOneByte( isolate, reinterpret_cast(string.characters8()), v8::NewStringType::kNormal, static_cast(string.length())) .ToLocalChecked(); return v8::String::NewFromTwoByte( isolate, reinterpret_cast(string.characters16()), v8::NewStringType::kNormal, static_cast(string.length())) .ToLocalChecked(); } String16 toProtocolString(v8::Isolate* isolate, v8::Local value) { if (value.IsEmpty() || value->IsNullOrUndefined()) return String16(); std::unique_ptr buffer(new UChar[value->Length()]); value->Write(isolate, reinterpret_cast(buffer.get()), 0, value->Length()); return String16(buffer.get(), value->Length()); } String16 toProtocolStringWithTypeCheck(v8::Isolate* isolate, v8::Local value) { if (value.IsEmpty() || !value->IsString()) return String16(); return toProtocolString(isolate, value.As()); } String16 toString16(const StringView& string) { if (!string.length()) return String16(); if (string.is8Bit()) return String16(reinterpret_cast(string.characters8()), string.length()); return String16(string.characters16(), string.length()); } StringView toStringView(const String16& string) { if (string.isEmpty()) return StringView(); return StringView(string.characters16(), string.length()); } bool stringViewStartsWith(const StringView& string, const char* prefix) { if (!string.length()) return !(*prefix); if (string.is8Bit()) { for (size_t i = 0, j = 0; prefix[j] && i < string.length(); ++i, ++j) { if (string.characters8()[i] != prefix[j]) return false; } } else { for (size_t i = 0, j = 0; prefix[j] && i < string.length(); ++i, ++j) { if (string.characters16()[i] != prefix[j]) return false; } } return true; } namespace { // An empty string buffer doesn't own any string data; its ::string() returns a // default-constructed StringView instance. class EmptyStringBuffer : public StringBuffer { public: StringView string() const override { return StringView(); } }; // Contains LATIN1 text data or CBOR encoded binary data in a vector. class StringBuffer8 : public StringBuffer { public: explicit StringBuffer8(std::vector data) : data_(std::move(data)) {} StringView string() const override { return StringView(data_.data(), data_.size()); } private: std::vector data_; }; // Contains a 16 bit string (String16). class StringBuffer16 : public StringBuffer { public: explicit StringBuffer16(String16 data) : data_(std::move(data)) {} StringView string() const override { return StringView(data_.characters16(), data_.length()); } private: String16 data_; }; } // namespace // static std::unique_ptr StringBuffer::create(StringView string) { if (string.length() == 0) return std::make_unique(); if (string.is8Bit()) { return std::make_unique(std::vector( string.characters8(), string.characters8() + string.length())); } return std::make_unique( String16(string.characters16(), string.length())); } std::unique_ptr StringBufferFrom(String16 str) { if (str.isEmpty()) return std::make_unique(); return std::make_unique(std::move(str)); } std::unique_ptr StringBufferFrom(std::vector str) { if (str.empty()) return std::make_unique(); return std::make_unique(std::move(str)); } String16 stackTraceIdToString(uintptr_t id) { String16Builder builder; builder.appendNumber(static_cast(id)); return builder.toString(); } } // namespace v8_inspector namespace v8_crdtp { void SerializerTraits::Serialize( const v8_inspector::protocol::Binary& binary, std::vector* out) { cbor::EncodeBinary(span(binary.data(), binary.size()), out); } } // namespace v8_crdtp