3 releases (breaking)
0.3.0 | Dec 19, 2024 |
---|---|
0.2.0 | Dec 19, 2024 |
0.1.0 | Dec 19, 2024 |
#17 in #countries
317 downloads per month
Used in world-region
110KB
1.5K
SLoC
South America Crate
The south-america crate provides enums and conversions for South American countries and their subregions, analogous to the asia
and europe
crates. It includes:
- A
SouthAmericaRegion
enum representing South American countries, including subdivided regions for Brazil. - Conversion traits to convert between
SouthAmericaRegion
and standard ISO country codes. - Round-trip conversions from
SouthAmericaRegion
toCountry
(from a sharedcountry
crate) and back. - Serialization/Deserialization (Serde) support for
SouthAmericaRegion
and its subregions (likeBrazilRegion
). - Comprehensive test suites ensuring correctness and stability.
Features
- No unsafe code: Entirely safe Rust.
- No unwrap/expect: Error handling via
Result
and custom error types. - No thiserror: Manual error handling for full control.
Examples
Convert a SouthAmericaRegion
to a Country
:
use south_america::{SouthAmericaRegion, Country};
use std::convert::TryInto;
let region = SouthAmericaRegion::Brazil(south_america::BrazilRegion::Sul);
let country: Country = region.try_into().expect("Should map to Brazil");
assert_eq!(country.to_string(), "Brazil");
Convert a Country
back to SouthAmericaRegion
:
use south_america::{SouthAmericaRegion, Country};
use std::convert::TryInto;
let country = Country::Argentina;
let region: SouthAmericaRegion = country.try_into().expect("Should map to Argentina");
assert_eq!(region, SouthAmericaRegion::Argentina);
Serialize and deserialize SouthAmericaRegion
with JSON:
use south_america::{SouthAmericaRegion, BrazilRegion};
use serde_json;
let region = SouthAmericaRegion::Brazil(BrazilRegion::Nordeste);
let json = serde_json::to_string(®ion).expect("serialize");
assert!(json.contains("\"country\":\"Brazil\""));
assert!(json.contains("\"region\":\"Nordeste\""));
let deser: SouthAmericaRegion = serde_json::from_str(&json).expect("deserialize");
assert_eq!(deser, region);
Error Handling
If attempting impossible conversions (e.g., non-South American countries to SouthAmericaRegion
), an SouthAmericaRegionConversionError
is returned.
Contributing
Contributions, issues, and feature requests are welcome! Check the issues page.
- Fork it!
- Create your feature branch:
git checkout -b my-new-feature
- Commit changes:
git commit -am 'Add some feature'
- Push:
git push origin my-new-feature
- Submit a pull request
License
Licensed under the MIT license. See LICENSE for details.
Dependencies
~5.5–7.5MB
~134K SLoC