LibTextCodec: Enable EXPLICIT_SYMBOL_EXPORT

This commit is contained in:
ayeteadoe 2025-06-28 12:57:28 -07:00 committed by Andrew Kaster
commit e497303e94
Notes: github-actions[bot] 2025-08-23 22:07:22 +00:00
4 changed files with 49 additions and 31 deletions

View file

@ -11,4 +11,4 @@ set(GENERATED_SOURCES
LookupTables.cpp LookupTables.cpp
) )
ladybird_lib(LibTextCodec textcodec) ladybird_lib(LibTextCodec textcodec EXPLICIT_SYMBOL_EXPORT)

View file

@ -12,10 +12,11 @@
#include <AK/Function.h> #include <AK/Function.h>
#include <AK/Optional.h> #include <AK/Optional.h>
#include <AK/String.h> #include <AK/String.h>
#include <LibTextCodec/Forward.h>
namespace TextCodec { namespace TextCodec {
class Decoder { class TEXTCODEC_API Decoder {
public: public:
virtual bool validate(StringView); virtual bool validate(StringView);
virtual ErrorOr<String> to_utf8(StringView); virtual ErrorOr<String> to_utf8(StringView);
@ -25,14 +26,14 @@ protected:
virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) = 0; virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) = 0;
}; };
class UTF8Decoder final : public Decoder { class TEXTCODEC_API UTF8Decoder final : public Decoder {
public: public:
virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) override; virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) override;
virtual bool validate(StringView) override; virtual bool validate(StringView) override;
virtual ErrorOr<String> to_utf8(StringView) override; virtual ErrorOr<String> to_utf8(StringView) override;
}; };
class UTF16BEDecoder final : public Decoder { class TEXTCODEC_API UTF16BEDecoder final : public Decoder {
public: public:
virtual bool validate(StringView) override; virtual bool validate(StringView) override;
virtual ErrorOr<String> to_utf8(StringView) override; virtual ErrorOr<String> to_utf8(StringView) override;
@ -41,7 +42,7 @@ private:
virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)>) override { VERIFY_NOT_REACHED(); } virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)>) override { VERIFY_NOT_REACHED(); }
}; };
class UTF16LEDecoder final : public Decoder { class TEXTCODEC_API UTF16LEDecoder final : public Decoder {
public: public:
virtual bool validate(StringView) override; virtual bool validate(StringView) override;
virtual ErrorOr<String> to_utf8(StringView) override; virtual ErrorOr<String> to_utf8(StringView) override;
@ -64,55 +65,55 @@ private:
Array<ArrayType, 128> m_translation_table; Array<ArrayType, 128> m_translation_table;
}; };
class Latin1Decoder final : public Decoder { class TEXTCODEC_API Latin1Decoder final : public Decoder {
public: public:
virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) override; virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) override;
virtual bool validate(StringView) override { return true; } virtual bool validate(StringView) override { return true; }
}; };
class PDFDocEncodingDecoder final : public Decoder { class TEXTCODEC_API PDFDocEncodingDecoder final : public Decoder {
public: public:
virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) override; virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) override;
virtual bool validate(StringView) override { return true; } virtual bool validate(StringView) override { return true; }
}; };
class XUserDefinedDecoder final : public Decoder { class TEXTCODEC_API XUserDefinedDecoder final : public Decoder {
public: public:
virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) override; virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) override;
virtual bool validate(StringView) override { return true; } virtual bool validate(StringView) override { return true; }
}; };
class GB18030Decoder final : public Decoder { class TEXTCODEC_API GB18030Decoder final : public Decoder {
public: public:
virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) override; virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) override;
}; };
class Big5Decoder final : public Decoder { class TEXTCODEC_API Big5Decoder final : public Decoder {
public: public:
virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) override; virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) override;
}; };
class EUCJPDecoder final : public Decoder { class TEXTCODEC_API EUCJPDecoder final : public Decoder {
public: public:
virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) override; virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) override;
}; };
class ISO2022JPDecoder final : public Decoder { class TEXTCODEC_API ISO2022JPDecoder final : public Decoder {
public: public:
virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) override; virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) override;
}; };
class ShiftJISDecoder final : public Decoder { class TEXTCODEC_API ShiftJISDecoder final : public Decoder {
public: public:
virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) override; virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) override;
}; };
class EUCKRDecoder final : public Decoder { class TEXTCODEC_API EUCKRDecoder final : public Decoder {
public: public:
virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) override; virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) override;
}; };
class ReplacementDecoder final : public Decoder { class TEXTCODEC_API ReplacementDecoder final : public Decoder {
public: public:
virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) override; virtual ErrorOr<void> process(StringView, Function<ErrorOr<void>(u32)> on_code_point) override;
virtual bool validate(StringView input) override { return input.is_empty(); } virtual bool validate(StringView input) override { return input.is_empty(); }
@ -120,18 +121,18 @@ public:
// This will return a decoder for the exact name specified, skipping get_standardized_encoding. // This will return a decoder for the exact name specified, skipping get_standardized_encoding.
// Use this when you want ISO-8859-1 instead of windows-1252. // Use this when you want ISO-8859-1 instead of windows-1252.
Optional<Decoder&> decoder_for_exact_name(StringView encoding); TEXTCODEC_API Optional<Decoder&> decoder_for_exact_name(StringView encoding);
Optional<Decoder&> decoder_for(StringView encoding); TEXTCODEC_API Optional<Decoder&> decoder_for(StringView encoding);
Optional<StringView> get_standardized_encoding(StringView encoding); TEXTCODEC_API Optional<StringView> get_standardized_encoding(StringView encoding);
// This returns the appropriate Unicode decoder for the sniffed BOM or nothing if there is no appropriate decoder. // This returns the appropriate Unicode decoder for the sniffed BOM or nothing if there is no appropriate decoder.
Optional<Decoder&> bom_sniff_to_decoder(StringView); TEXTCODEC_API Optional<Decoder&> bom_sniff_to_decoder(StringView);
// NOTE: This has an obnoxious name to discourage usage. Only use this if you absolutely must! For example, XHR in LibWeb uses this. // NOTE: This has an obnoxious name to discourage usage. Only use this if you absolutely must! For example, XHR in LibWeb uses this.
// This will use the given decoder unless there is a byte order mark in the input, in which we will instead use the appropriate Unicode decoder. // This will use the given decoder unless there is a byte order mark in the input, in which we will instead use the appropriate Unicode decoder.
ErrorOr<String> convert_input_to_utf8_using_given_decoder_unless_there_is_a_byte_order_mark(Decoder&, StringView); TEXTCODEC_API ErrorOr<String> convert_input_to_utf8_using_given_decoder_unless_there_is_a_byte_order_mark(Decoder&, StringView);
StringView get_output_encoding(StringView encoding); TEXTCODEC_API StringView get_output_encoding(StringView encoding);
} }

View file

@ -8,10 +8,11 @@
#include <AK/Forward.h> #include <AK/Forward.h>
#include <AK/Function.h> #include <AK/Function.h>
#include <LibTextCodec/Forward.h>
namespace TextCodec { namespace TextCodec {
class Encoder { class TEXTCODEC_API Encoder {
public: public:
virtual ErrorOr<void> process(Utf8View, Function<ErrorOr<void>(u8)> on_byte, Function<ErrorOr<void>(u32)> on_error) = 0; virtual ErrorOr<void> process(Utf8View, Function<ErrorOr<void>(u8)> on_byte, Function<ErrorOr<void>(u32)> on_error) = 0;
@ -19,17 +20,17 @@ protected:
virtual ~Encoder() = default; virtual ~Encoder() = default;
}; };
class UTF8Encoder final : public Encoder { class TEXTCODEC_API UTF8Encoder final : public Encoder {
public: public:
virtual ErrorOr<void> process(Utf8View, Function<ErrorOr<void>(u8)> on_byte, Function<ErrorOr<void>(u32)> on_error) override; virtual ErrorOr<void> process(Utf8View, Function<ErrorOr<void>(u8)> on_byte, Function<ErrorOr<void>(u32)> on_error) override;
}; };
class EUCJPEncoder final : public Encoder { class TEXTCODEC_API EUCJPEncoder final : public Encoder {
public: public:
virtual ErrorOr<void> process(Utf8View, Function<ErrorOr<void>(u8)> on_byte, Function<ErrorOr<void>(u32)> on_error) override; virtual ErrorOr<void> process(Utf8View, Function<ErrorOr<void>(u8)> on_byte, Function<ErrorOr<void>(u32)> on_error) override;
}; };
class ISO2022JPEncoder final : public Encoder { class TEXTCODEC_API ISO2022JPEncoder final : public Encoder {
public: public:
virtual ErrorOr<void> process(Utf8View, Function<ErrorOr<void>(u8)> on_byte, Function<ErrorOr<void>(u32)> on_error) override; virtual ErrorOr<void> process(Utf8View, Function<ErrorOr<void>(u8)> on_byte, Function<ErrorOr<void>(u32)> on_error) override;
@ -43,22 +44,22 @@ private:
ErrorOr<State> process_item(u32 item, State, Function<ErrorOr<void>(u8)>& on_byte, Function<ErrorOr<void>(u32)>& on_error); ErrorOr<State> process_item(u32 item, State, Function<ErrorOr<void>(u8)>& on_byte, Function<ErrorOr<void>(u32)>& on_error);
}; };
class ShiftJISEncoder final : public Encoder { class TEXTCODEC_API ShiftJISEncoder final : public Encoder {
public: public:
virtual ErrorOr<void> process(Utf8View, Function<ErrorOr<void>(u8)> on_byte, Function<ErrorOr<void>(u32)> on_error) override; virtual ErrorOr<void> process(Utf8View, Function<ErrorOr<void>(u8)> on_byte, Function<ErrorOr<void>(u32)> on_error) override;
}; };
class EUCKREncoder final : public Encoder { class TEXTCODEC_API EUCKREncoder final : public Encoder {
public: public:
virtual ErrorOr<void> process(Utf8View, Function<ErrorOr<void>(u8)> on_byte, Function<ErrorOr<void>(u32)> on_error) override; virtual ErrorOr<void> process(Utf8View, Function<ErrorOr<void>(u8)> on_byte, Function<ErrorOr<void>(u32)> on_error) override;
}; };
class Big5Encoder final : public Encoder { class TEXTCODEC_API Big5Encoder final : public Encoder {
public: public:
virtual ErrorOr<void> process(Utf8View, Function<ErrorOr<void>(u8)> on_byte, Function<ErrorOr<void>(u32)> on_error) override; virtual ErrorOr<void> process(Utf8View, Function<ErrorOr<void>(u8)> on_byte, Function<ErrorOr<void>(u32)> on_error) override;
}; };
class GB18030Encoder final : public Encoder { class TEXTCODEC_API GB18030Encoder final : public Encoder {
public: public:
enum class IsGBK { enum class IsGBK {
Yes, Yes,
@ -86,7 +87,7 @@ private:
Array<ArrayType, 128> m_translation_table; Array<ArrayType, 128> m_translation_table;
}; };
Optional<Encoder&> encoder_for_exact_name(StringView encoding); TEXTCODEC_API Optional<Encoder&> encoder_for_exact_name(StringView encoding);
Optional<Encoder&> encoder_for(StringView label); TEXTCODEC_API Optional<Encoder&> encoder_for(StringView label);
} }

View file

@ -0,0 +1,16 @@
/*
* Copyright (c) 2025, ayeteadoe <ayeteadoe@gmail.com>
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#pragma once
#include <LibTextCodec/Export.h>
namespace TextCodec {
class Decoder;
class Encoder;
}