tor-browser

The Tor Browser
git clone https://git.dasho.dev/tor-browser.git
Log | Files | Refs | README | LICENSE

VariantOffsetsCalculator.hpp (4328B)


      1 #ifndef icu4x_VariantOffsetsCalculator_HPP
      2 #define icu4x_VariantOffsetsCalculator_HPP
      3 
      4 #include "VariantOffsetsCalculator.d.hpp"
      5 
      6 #include <stdio.h>
      7 #include <stdint.h>
      8 #include <stddef.h>
      9 #include <stdbool.h>
     10 #include <memory>
     11 #include <functional>
     12 #include <optional>
     13 #include <cstdlib>
     14 #include "../diplomat_runtime.hpp"
     15 #include "DataError.hpp"
     16 #include "DataProvider.hpp"
     17 #include "IsoDate.hpp"
     18 #include "Time.hpp"
     19 #include "TimeZone.hpp"
     20 #include "VariantOffsets.hpp"
     21 
     22 
     23 namespace icu4x {
     24 namespace capi {
     25    extern "C" {
     26 
     27    icu4x::capi::VariantOffsetsCalculator* icu4x_VariantOffsetsCalculator_create_mv1(void);
     28 
     29    typedef struct icu4x_VariantOffsetsCalculator_create_with_provider_mv1_result {union {icu4x::capi::VariantOffsetsCalculator* ok; icu4x::capi::DataError err;}; bool is_ok;} icu4x_VariantOffsetsCalculator_create_with_provider_mv1_result;
     30    icu4x_VariantOffsetsCalculator_create_with_provider_mv1_result icu4x_VariantOffsetsCalculator_create_with_provider_mv1(const icu4x::capi::DataProvider* provider);
     31 
     32    typedef struct icu4x_VariantOffsetsCalculator_compute_offsets_from_time_zone_and_date_time_mv1_result {union {icu4x::capi::VariantOffsets ok; }; bool is_ok;} icu4x_VariantOffsetsCalculator_compute_offsets_from_time_zone_and_date_time_mv1_result;
     33    icu4x_VariantOffsetsCalculator_compute_offsets_from_time_zone_and_date_time_mv1_result icu4x_VariantOffsetsCalculator_compute_offsets_from_time_zone_and_date_time_mv1(const icu4x::capi::VariantOffsetsCalculator* self, const icu4x::capi::TimeZone* time_zone, const icu4x::capi::IsoDate* local_date, const icu4x::capi::Time* local_time);
     34 
     35    void icu4x_VariantOffsetsCalculator_destroy_mv1(VariantOffsetsCalculator* self);
     36 
     37    } // extern "C"
     38 } // namespace capi
     39 } // namespace
     40 
     41 inline std::unique_ptr<icu4x::VariantOffsetsCalculator> icu4x::VariantOffsetsCalculator::create() {
     42  auto result = icu4x::capi::icu4x_VariantOffsetsCalculator_create_mv1();
     43  return std::unique_ptr<icu4x::VariantOffsetsCalculator>(icu4x::VariantOffsetsCalculator::FromFFI(result));
     44 }
     45 
     46 inline diplomat::result<std::unique_ptr<icu4x::VariantOffsetsCalculator>, icu4x::DataError> icu4x::VariantOffsetsCalculator::create_with_provider(const icu4x::DataProvider& provider) {
     47  auto result = icu4x::capi::icu4x_VariantOffsetsCalculator_create_with_provider_mv1(provider.AsFFI());
     48  return result.is_ok ? diplomat::result<std::unique_ptr<icu4x::VariantOffsetsCalculator>, icu4x::DataError>(diplomat::Ok<std::unique_ptr<icu4x::VariantOffsetsCalculator>>(std::unique_ptr<icu4x::VariantOffsetsCalculator>(icu4x::VariantOffsetsCalculator::FromFFI(result.ok)))) : diplomat::result<std::unique_ptr<icu4x::VariantOffsetsCalculator>, icu4x::DataError>(diplomat::Err<icu4x::DataError>(icu4x::DataError::FromFFI(result.err)));
     49 }
     50 
     51 inline std::optional<icu4x::VariantOffsets> icu4x::VariantOffsetsCalculator::compute_offsets_from_time_zone_and_date_time(const icu4x::TimeZone& time_zone, const icu4x::IsoDate& local_date, const icu4x::Time& local_time) const {
     52  auto result = icu4x::capi::icu4x_VariantOffsetsCalculator_compute_offsets_from_time_zone_and_date_time_mv1(this->AsFFI(),
     53    time_zone.AsFFI(),
     54    local_date.AsFFI(),
     55    local_time.AsFFI());
     56  return result.is_ok ? std::optional<icu4x::VariantOffsets>(icu4x::VariantOffsets::FromFFI(result.ok)) : std::nullopt;
     57 }
     58 
     59 inline const icu4x::capi::VariantOffsetsCalculator* icu4x::VariantOffsetsCalculator::AsFFI() const {
     60  return reinterpret_cast<const icu4x::capi::VariantOffsetsCalculator*>(this);
     61 }
     62 
     63 inline icu4x::capi::VariantOffsetsCalculator* icu4x::VariantOffsetsCalculator::AsFFI() {
     64  return reinterpret_cast<icu4x::capi::VariantOffsetsCalculator*>(this);
     65 }
     66 
     67 inline const icu4x::VariantOffsetsCalculator* icu4x::VariantOffsetsCalculator::FromFFI(const icu4x::capi::VariantOffsetsCalculator* ptr) {
     68  return reinterpret_cast<const icu4x::VariantOffsetsCalculator*>(ptr);
     69 }
     70 
     71 inline icu4x::VariantOffsetsCalculator* icu4x::VariantOffsetsCalculator::FromFFI(icu4x::capi::VariantOffsetsCalculator* ptr) {
     72  return reinterpret_cast<icu4x::VariantOffsetsCalculator*>(ptr);
     73 }
     74 
     75 inline void icu4x::VariantOffsetsCalculator::operator delete(void* ptr) {
     76  icu4x::capi::icu4x_VariantOffsetsCalculator_destroy_mv1(reinterpret_cast<icu4x::capi::VariantOffsetsCalculator*>(ptr));
     77 }
     78 
     79 
     80 #endif // icu4x_VariantOffsetsCalculator_HPP