| // Copyright 2023 The Chromium Authors |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef SERVICES_ACCESSIBILITY_FEATURES_TEXT_ENCODER_H_ |
| #define SERVICES_ACCESSIBILITY_FEATURES_TEXT_ENCODER_H_ |
| |
| #include "gin/handle.h" |
| #include "gin/object_template_builder.h" |
| #include "gin/wrappable.h" |
| #include "services/accessibility/features/registered_wrappable.h" |
| |
| namespace gin { |
| class Arguments; |
| } |
| |
| namespace ax { |
| |
| // Provides TextEncoder object to the Accessibility Service's V8 Javascript. |
| // This class is a parallel to blink::TextEncoder, which does the same for |
| // any blink renderer. |
| // Note that this only supports UTF-8 encoding. |
| class TextEncoder : public gin::Wrappable<TextEncoder>, |
| public RegisteredWrappable { |
| public: |
| static gin::WrapperInfo kWrapperInfo; |
| |
| static gin::Handle<TextEncoder> Create(v8::Local<v8::Context> context); |
| |
| ~TextEncoder() override = default; |
| TextEncoder(const TextEncoder&) = delete; |
| TextEncoder& operator=(const TextEncoder&) = delete; |
| |
| // gin::Wrappable: |
| gin::ObjectTemplateBuilder GetObjectTemplateBuilder( |
| v8::Isolate* isolate) override; |
| |
| // |
| // Methods exposed to Javascript. |
| // Note: gin::Wrappable's bound methods need to be public. |
| // |
| |
| // Encodes a Javascript string into a v8::Uint8Array. |
| // See third_party/blink/renderer/modules/encoding/text_encoder.idl. |
| void Encode(gin::Arguments* arguments); |
| |
| // |
| // End of methods exposed to Javascript. |
| // |
| |
| private: |
| explicit TextEncoder(v8::Local<v8::Context> context); |
| }; |
| |
| } // namespace ax |
| |
| #endif // SERVICES_ACCESSIBILITY_FEATURES_TEXT_ENCODER_H_ |