diff --git a/.github/workflows/intl4x.yml b/.github/workflows/intl4x.yml index 15dc7b1a..ab7e5f8c 100644 --- a/.github/workflows/intl4x.yml +++ b/.github/workflows/intl4x.yml @@ -86,3 +86,31 @@ jobs: - run: dart --enable-experiment=native-assets pub get - run: dart --enable-experiment=native-assets test + + + build_fetch_local: + runs-on: ${{ matrix.os }} + + env: + ICU4X_BUILD_MODE: fetch + + strategy: + matrix: + os: [ubuntu-latest, windows-latest, macos-latest] + + defaults: + run: + working-directory: pkgs/intl4x + + steps: + - uses: actions/checkout@c85c95e3d7251135ab7dc9ce3241c5835cc595a9 + with: + submodules: true + + - uses: dart-lang/setup-dart@0a8a0fc875eb934c15d08629302413c671d3f672 + with: + sdk: dev + + - run: dart --enable-experiment=native-assets pub get + + - run: dart --enable-experiment=native-assets test diff --git a/pkgs/intl4x/lib/src/bindings/Bcp47ToIanaMapper.g.dart b/pkgs/intl4x/lib/src/bindings/Bcp47ToIanaMapper.g.dart deleted file mode 120000 index 5c63dc36..00000000 --- a/pkgs/intl4x/lib/src/bindings/Bcp47ToIanaMapper.g.dart +++ /dev/null @@ -1 +0,0 @@ -../../../../../submodules/icu4x/ffi/capi/bindings/dart/Bcp47ToIanaMapper.g.dart \ No newline at end of file diff --git a/pkgs/intl4x/lib/src/bindings/CalendarError.g.dart b/pkgs/intl4x/lib/src/bindings/CalendarError.g.dart new file mode 120000 index 00000000..ebc65fa3 --- /dev/null +++ b/pkgs/intl4x/lib/src/bindings/CalendarError.g.dart @@ -0,0 +1 @@ +../../../../../submodules/icu4x/ffi/capi/bindings/dart/CalendarError.g.dart \ No newline at end of file diff --git a/pkgs/intl4x/lib/src/bindings/CollatorResolvedOptions.g.dart b/pkgs/intl4x/lib/src/bindings/CollatorResolvedOptions.g.dart new file mode 120000 index 00000000..5cb11aa8 --- /dev/null +++ b/pkgs/intl4x/lib/src/bindings/CollatorResolvedOptions.g.dart @@ -0,0 +1 @@ +../../../../../submodules/icu4x/ffi/capi/bindings/dart/CollatorResolvedOptions.g.dart \ No newline at end of file diff --git a/pkgs/intl4x/lib/src/bindings/DataError.g.dart b/pkgs/intl4x/lib/src/bindings/DataError.g.dart new file mode 120000 index 00000000..49d6e44f --- /dev/null +++ b/pkgs/intl4x/lib/src/bindings/DataError.g.dart @@ -0,0 +1 @@ +../../../../../submodules/icu4x/ffi/capi/bindings/dart/DataError.g.dart \ No newline at end of file diff --git a/pkgs/intl4x/lib/src/bindings/FixedDecimalLimitError.g.dart b/pkgs/intl4x/lib/src/bindings/FixedDecimalLimitError.g.dart new file mode 120000 index 00000000..907ae320 --- /dev/null +++ b/pkgs/intl4x/lib/src/bindings/FixedDecimalLimitError.g.dart @@ -0,0 +1 @@ +../../../../../submodules/icu4x/ffi/capi/bindings/dart/FixedDecimalLimitError.g.dart \ No newline at end of file diff --git a/pkgs/intl4x/lib/src/bindings/FixedDecimalParseError.g.dart b/pkgs/intl4x/lib/src/bindings/FixedDecimalParseError.g.dart new file mode 120000 index 00000000..f33e521f --- /dev/null +++ b/pkgs/intl4x/lib/src/bindings/FixedDecimalParseError.g.dart @@ -0,0 +1 @@ +../../../../../submodules/icu4x/ffi/capi/bindings/dart/FixedDecimalParseError.g.dart \ No newline at end of file diff --git a/pkgs/intl4x/lib/src/bindings/FixedDecimalRoundingIncrement.g.dart b/pkgs/intl4x/lib/src/bindings/FixedDecimalRoundingIncrement.g.dart new file mode 120000 index 00000000..a5f1ee12 --- /dev/null +++ b/pkgs/intl4x/lib/src/bindings/FixedDecimalRoundingIncrement.g.dart @@ -0,0 +1 @@ +../../../../../submodules/icu4x/ffi/capi/bindings/dart/FixedDecimalRoundingIncrement.g.dart \ No newline at end of file diff --git a/pkgs/intl4x/lib/src/bindings/FixedDecimalRoundingMode.g.dart b/pkgs/intl4x/lib/src/bindings/FixedDecimalRoundingMode.g.dart new file mode 120000 index 00000000..4542407c --- /dev/null +++ b/pkgs/intl4x/lib/src/bindings/FixedDecimalRoundingMode.g.dart @@ -0,0 +1 @@ +../../../../../submodules/icu4x/ffi/capi/bindings/dart/FixedDecimalRoundingMode.g.dart \ No newline at end of file diff --git a/pkgs/intl4x/lib/src/bindings/IanaToBcp47Mapper.g.dart b/pkgs/intl4x/lib/src/bindings/IanaToBcp47Mapper.g.dart deleted file mode 120000 index f1d318f7..00000000 --- a/pkgs/intl4x/lib/src/bindings/IanaToBcp47Mapper.g.dart +++ /dev/null @@ -1 +0,0 @@ -../../../../../submodules/icu4x/ffi/capi/bindings/dart/IanaToBcp47Mapper.g.dart \ No newline at end of file diff --git a/pkgs/intl4x/lib/src/bindings/LocaleParseError.g.dart b/pkgs/intl4x/lib/src/bindings/LocaleParseError.g.dart new file mode 120000 index 00000000..e9f5ea74 --- /dev/null +++ b/pkgs/intl4x/lib/src/bindings/LocaleParseError.g.dart @@ -0,0 +1 @@ +../../../../../submodules/icu4x/ffi/capi/bindings/dart/LocaleParseError.g.dart \ No newline at end of file diff --git a/pkgs/intl4x/lib/src/bindings/MeasureUnit.g.dart b/pkgs/intl4x/lib/src/bindings/MeasureUnit.g.dart new file mode 120000 index 00000000..4052c474 --- /dev/null +++ b/pkgs/intl4x/lib/src/bindings/MeasureUnit.g.dart @@ -0,0 +1 @@ +../../../../../submodules/icu4x/ffi/capi/bindings/dart/MeasureUnit.g.dart \ No newline at end of file diff --git a/pkgs/intl4x/lib/src/bindings/MeasureUnitParser.g.dart b/pkgs/intl4x/lib/src/bindings/MeasureUnitParser.g.dart new file mode 120000 index 00000000..243cdba7 --- /dev/null +++ b/pkgs/intl4x/lib/src/bindings/MeasureUnitParser.g.dart @@ -0,0 +1 @@ +../../../../../submodules/icu4x/ffi/capi/bindings/dart/MeasureUnitParser.g.dart \ No newline at end of file diff --git a/pkgs/intl4x/lib/src/bindings/ResolvedCollatorOptions.g.dart b/pkgs/intl4x/lib/src/bindings/ResolvedCollatorOptions.g.dart deleted file mode 120000 index 214e3f44..00000000 --- a/pkgs/intl4x/lib/src/bindings/ResolvedCollatorOptions.g.dart +++ /dev/null @@ -1 +0,0 @@ -../../../../../submodules/icu4x/ffi/capi/bindings/dart/ResolvedCollatorOptions.g.dart \ No newline at end of file diff --git a/pkgs/intl4x/lib/src/bindings/RoundingIncrement.g.dart b/pkgs/intl4x/lib/src/bindings/RoundingIncrement.g.dart deleted file mode 120000 index eefaf89d..00000000 --- a/pkgs/intl4x/lib/src/bindings/RoundingIncrement.g.dart +++ /dev/null @@ -1 +0,0 @@ -../../../../../submodules/icu4x/ffi/capi/bindings/dart/RoundingIncrement.g.dart \ No newline at end of file diff --git a/pkgs/intl4x/lib/src/bindings/TimeZoneIdMapper.g.dart b/pkgs/intl4x/lib/src/bindings/TimeZoneIdMapper.g.dart new file mode 120000 index 00000000..56f3dc8d --- /dev/null +++ b/pkgs/intl4x/lib/src/bindings/TimeZoneIdMapper.g.dart @@ -0,0 +1 @@ +../../../../../submodules/icu4x/ffi/capi/bindings/dart/TimeZoneIdMapper.g.dart \ No newline at end of file diff --git a/pkgs/intl4x/lib/src/bindings/TimeZoneIdMapperWithFastCanonicalization.g.dart b/pkgs/intl4x/lib/src/bindings/TimeZoneIdMapperWithFastCanonicalization.g.dart new file mode 120000 index 00000000..aad32b4d --- /dev/null +++ b/pkgs/intl4x/lib/src/bindings/TimeZoneIdMapperWithFastCanonicalization.g.dart @@ -0,0 +1 @@ +../../../../../submodules/icu4x/ffi/capi/bindings/dart/TimeZoneIdMapperWithFastCanonicalization.g.dart \ No newline at end of file diff --git a/pkgs/intl4x/lib/src/bindings/TimeZoneInvalidIdError.g.dart b/pkgs/intl4x/lib/src/bindings/TimeZoneInvalidIdError.g.dart new file mode 120000 index 00000000..f94a8581 --- /dev/null +++ b/pkgs/intl4x/lib/src/bindings/TimeZoneInvalidIdError.g.dart @@ -0,0 +1 @@ +../../../../../submodules/icu4x/ffi/capi/bindings/dart/TimeZoneInvalidIdError.g.dart \ No newline at end of file diff --git a/pkgs/intl4x/lib/src/bindings/TimeZoneInvalidOffsetError.g.dart b/pkgs/intl4x/lib/src/bindings/TimeZoneInvalidOffsetError.g.dart new file mode 120000 index 00000000..a19615ff --- /dev/null +++ b/pkgs/intl4x/lib/src/bindings/TimeZoneInvalidOffsetError.g.dart @@ -0,0 +1 @@ +../../../../../submodules/icu4x/ffi/capi/bindings/dart/TimeZoneInvalidOffsetError.g.dart \ No newline at end of file diff --git a/pkgs/intl4x/lib/src/bindings/UnitsConverter.g.dart b/pkgs/intl4x/lib/src/bindings/UnitsConverter.g.dart new file mode 120000 index 00000000..01bce0b9 --- /dev/null +++ b/pkgs/intl4x/lib/src/bindings/UnitsConverter.g.dart @@ -0,0 +1 @@ +../../../../../submodules/icu4x/ffi/capi/bindings/dart/UnitsConverter.g.dart \ No newline at end of file diff --git a/pkgs/intl4x/lib/src/bindings/UnitsConverterFactory.g.dart b/pkgs/intl4x/lib/src/bindings/UnitsConverterFactory.g.dart new file mode 120000 index 00000000..82067f9a --- /dev/null +++ b/pkgs/intl4x/lib/src/bindings/UnitsConverterFactory.g.dart @@ -0,0 +1 @@ +../../../../../submodules/icu4x/ffi/capi/bindings/dart/UnitsConverterFactory.g.dart \ No newline at end of file diff --git a/pkgs/intl4x/lib/src/datetime_format/datetime_format_4x.dart b/pkgs/intl4x/lib/src/datetime_format/datetime_format_4x.dart index a42b7fce..f0ffd88b 100644 --- a/pkgs/intl4x/lib/src/datetime_format/datetime_format_4x.dart +++ b/pkgs/intl4x/lib/src/datetime_format/datetime_format_4x.dart @@ -100,7 +100,7 @@ class DateTimeFormat4X extends DateTimeFormatImpl { icu.Calendar.forKind(_data, calendarKind), ); if (_zonedDateTimeFormatter != null) { - final ianaToBcp47Mapper = icu.IanaToBcp47Mapper(_data); + final ianaToBcp47Mapper = icu.TimeZoneIdMapper(_data); final timeZone = icu.CustomTimeZone.empty() ..trySetIanaTimeZoneId(ianaToBcp47Mapper, options.timeZone!); return _zonedDateTimeFormatter.formatDatetimeWithCustomTimeZone( diff --git a/pkgs/intl4x/lib/src/locale/locale_4x.dart b/pkgs/intl4x/lib/src/locale/locale_4x.dart index f496b2a2..6df01c3c 100644 --- a/pkgs/intl4x/lib/src/locale/locale_4x.dart +++ b/pkgs/intl4x/lib/src/locale/locale_4x.dart @@ -9,8 +9,8 @@ import 'locale.dart'; extension Locale4X on Locale { icu.Locale to4X() { final icu4xLocale = icu.Locale.und()..language = language; - if (region != null) icu4xLocale.region = region!; - if (script != null) icu4xLocale.script = script!; + if (region != null) icu4xLocale.setRegion(region!); + if (script != null) icu4xLocale.setScript(script!); return icu4xLocale; } } diff --git a/pkgs/intl4x/lib/src/number_format/number_format_4x.dart b/pkgs/intl4x/lib/src/number_format/number_format_4x.dart index b9c4a1a0..a9dcea47 100644 --- a/pkgs/intl4x/lib/src/number_format/number_format_4x.dart +++ b/pkgs/intl4x/lib/src/number_format/number_format_4x.dart @@ -36,7 +36,7 @@ class NumberFormat4X extends NumberFormatImpl { final icu.FixedDecimal fixedDecimal; fixedDecimal = switch (number) { final int i => icu.FixedDecimal.fromInt(i), - final double d => icu.FixedDecimal.fromDoubleWithDoublePrecision(d), + final double d => icu.FixedDecimal.fromDoubleWithFloatingPrecision(d), final String s => icu.FixedDecimal.fromString(s), Object() => icu.FixedDecimal.fromString(number.toString()), }; @@ -103,11 +103,16 @@ class NumberFormat4X extends NumberFormatImpl { RoundingMode.floor => fixedDecimal.floor, RoundingMode.expand => fixedDecimal.expand, RoundingMode.trunc => fixedDecimal.trunc, - RoundingMode.halfCeil => fixedDecimal.halfCeil, - RoundingMode.halfFloor => fixedDecimal.halfFloor, - RoundingMode.halfExpand => fixedDecimal.halfExpand, - RoundingMode.halfTrunc => fixedDecimal.halfTrunc, - RoundingMode.halfEven => fixedDecimal.halfEven, + RoundingMode.halfCeil => (int position) => fixedDecimal.roundWithMode( + position, icu.FixedDecimalRoundingMode.halfCeil), + RoundingMode.halfFloor => (int position) => fixedDecimal.roundWithMode( + position, icu.FixedDecimalRoundingMode.halfFloor), + RoundingMode.halfExpand => (int position) => fixedDecimal.roundWithMode( + position, icu.FixedDecimalRoundingMode.halfExpand), + RoundingMode.halfTrunc => (int position) => fixedDecimal.roundWithMode( + position, icu.FixedDecimalRoundingMode.halfTrunc), + RoundingMode.halfEven => (int position) => fixedDecimal.roundWithMode( + position, icu.FixedDecimalRoundingMode.halfEven), }; roundingFunction(maxSignificantPosition); }