Skip to main content

TaxCodeGenerator

Struct TaxCodeGenerator 

Source
pub struct TaxCodeGenerator { /* private fields */ }
Expand description

Generates tax jurisdictions and tax codes from built-in rate tables.

The generator reads TaxConfig to determine which countries to produce jurisdictions for, whether to include sub-national jurisdictions (US states, Canadian provinces, etc.), and whether config-provided rate overrides should replace the built-in defaults.

§Examples

use datasynth_generators::tax::TaxCodeGenerator;

let mut gen = TaxCodeGenerator::new(42);
let (jurisdictions, codes) = gen.generate();
assert!(!jurisdictions.is_empty());
assert!(!codes.is_empty());

Implementations§

Source§

impl TaxCodeGenerator

Source

pub fn new(seed: u64) -> Self

Creates a new generator with default configuration.

Default config generates jurisdictions for US, DE, and GB.

Source

pub fn with_config(seed: u64, config: TaxConfig) -> Self

Creates a new generator with custom configuration.

Source

pub fn generate(&mut self) -> (Vec<TaxJurisdiction>, Vec<TaxCode>)

Generates tax jurisdictions and tax codes.

Returns a tuple of (Vec<TaxJurisdiction>, Vec<TaxCode>).

Source

pub fn generate_from_country_pack( &mut self, pack: &CountryPack, company_code: &str, fiscal_year: i32, ) -> (Vec<TaxJurisdiction>, Vec<TaxCode>)

Generates tax jurisdictions and tax codes from a [CountryPack].

This is an alternative to generate() that reads tax rates and sub-national jurisdictions from a country pack instead of using the hardcoded constants. If the pack carries no meaningful tax data (e.g. standard_rate == 0.0 and no sub-national entries), the method returns empty vectors so the caller can fall back to generate().

§Arguments
  • pack - The country pack whose tax data should drive generation.
  • company_code - Company code used to prefix generated IDs.
  • fiscal_year - Fiscal year; used to derive the effective date (January 1 of that year).

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more