Skip to content

Commit

Permalink
Use once_cell::Lazy instead of lazy_static, clippy cleanup
Browse files Browse the repository at this point in the history
  • Loading branch information
ds-cbo authored and rubdos committed Jul 7, 2024
1 parent 32aafb5 commit ef03f93
Show file tree
Hide file tree
Showing 13 changed files with 361 additions and 346 deletions.
2 changes: 1 addition & 1 deletion src/carrier.rs
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ impl AsRef<str> for Carrier {
}

impl fmt::Display for Carrier {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
write!(f, "{}", self.0)
}
}
653 changes: 329 additions & 324 deletions src/consts.rs

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions src/country.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,9 @@
// See the License for the specific language governing permissions and
// limitations under the License.

// Needed because of re-export of Id::*
#![allow(unused_qualifications)]

//! Country related types.
use serde_derive::{Deserialize, Serialize};
Expand Down
2 changes: 1 addition & 1 deletion src/extension.rs
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ impl AsRef<str> for Extension {
}

impl fmt::Display for Extension {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
write!(f, "{}", self.0)
}
}
8 changes: 4 additions & 4 deletions src/formatter.rs
Original file line number Diff line number Diff line change
Expand Up @@ -98,7 +98,7 @@ pub fn format_with<'d, 'n>(
}

impl<'n, 'd, 'f> fmt::Display for Formatter<'n, 'd, 'f> {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
let db = self.database.unwrap_or(&DATABASE);

// If the country code is invalid, return an error.
Expand Down Expand Up @@ -247,9 +247,9 @@ fn replace(
.get(1)
.unwrap()
.as_str();
let format = transform.replace(*consts::NP, meta.national_prefix().unwrap_or(""));
let format = format.replace(*consts::FG, &format!("${}", first));
let format = format.replace(*consts::CC, carrier.unwrap_or(""));
let format = transform.replace(consts::NP, meta.national_prefix().unwrap_or(""));
let format = format.replace(consts::FG, &format!("${}", first));
let format = format.replace(consts::CC, carrier.unwrap_or(""));

consts::FIRST_GROUP.replace(formatter.format(), &*format)
} else {
Expand Down
19 changes: 13 additions & 6 deletions src/metadata/database.rs
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,9 @@ use std::io::{BufReader, Cursor};
use std::path::Path;
use std::sync::{Arc, Mutex};

use once_cell::sync::Lazy;

use bincode;
use bincode::Options;
use fnv::FnvHashMap;
use regex_cache::{CachedRegex, CachedRegexBuilder, RegexCache};
Expand All @@ -29,12 +32,16 @@ use crate::Metadata;

const DATABASE: &[u8] = include_bytes!(concat!(env!("OUT_DIR"), "/database.bin"));

lazy_static::lazy_static! {
/// The Google provided metadata database, used as default.
pub static ref DEFAULT: Database =
Database::from(bincode::options()
.with_varint_encoding().deserialize(DATABASE).unwrap()).unwrap();
}
/// The Google provided metadata database, used as default.
pub static DEFAULT: Lazy<Database> = Lazy::new(|| {
Database::from(
bincode::options()
.with_varint_encoding()
.deserialize(DATABASE)
.unwrap(),
)
.unwrap()
});

/// Representation of a database of metadata for phone number.
#[derive(Clone, Debug)]
Expand Down
2 changes: 1 addition & 1 deletion src/national_number.rs
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@ impl From<NationalNumber> for u64 {
}

impl fmt::Display for NationalNumber {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
for _ in 0..self.zeros() {
write!(f, "0")?;
}
Expand Down
2 changes: 1 addition & 1 deletion src/parser/helper.rs
Original file line number Diff line number Diff line change
Expand Up @@ -369,7 +369,7 @@ pub fn normalize<'a>(mut number: Number<'a>, mappings: &FnvHashMap<char, char>)
number
}

pub fn trim(value: Cow<str>, start: usize) -> Cow<str> {
pub fn trim(value: Cow<'_, str>, start: usize) -> Cow<'_, str> {
match value {
Cow::Borrowed(value) => Cow::Borrowed(&value[start..]),

Expand Down
2 changes: 1 addition & 1 deletion src/parser/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ pub fn parse_with<S: AsRef<str>>(
country: Option<country::Id>,
string: S,
) -> Result<PhoneNumber, error::Parse> {
fn phone_number(i: &str) -> IResult<&str, helper::Number> {
fn phone_number(i: &str) -> IResult<&str, helper::Number<'_>> {
parse! { i => alt((rfc3966::phone_number, natural::phone_number)) }
}

Expand Down
2 changes: 1 addition & 1 deletion src/parser/natural.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ use nom::IResult;
use crate::consts;
use crate::parser::helper::*;

pub fn phone_number(i: &str) -> IResult<&str, Number> {
pub fn phone_number(i: &str) -> IResult<&str, Number<'_>> {
let (_, i) = extract(i)?;
let extension = consts::EXTN_PATTERN.captures(i);

Expand Down
4 changes: 2 additions & 2 deletions src/parser/rfc3966.rs
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ use nom::{

use crate::parser::helper::*;

pub fn phone_number(i: &str) -> IResult<&str, Number> {
pub fn phone_number(i: &str) -> IResult<&str, Number<'_>> {
parse! { i =>
opt(tag_no_case("Tel:"));
let prefix = opt(prefix);
Expand Down Expand Up @@ -168,6 +168,6 @@ mod test {
#[test]
fn advisory_1() {
// Just make sure this does not panic.
let _ = rfc3966::phone_number(".;phone-context=");
rfc3966::phone_number(".;phone-context=").unwrap();
}
}
6 changes: 3 additions & 3 deletions src/phone_number.rs
Original file line number Diff line number Diff line change
Expand Up @@ -148,14 +148,14 @@ impl FromStr for PhoneNumber {
}

impl fmt::Display for PhoneNumber {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
write!(f, "{}", self.format())
}
}

impl PhoneNumber {
/// Get information about the country for the phone number.
pub fn country(&self) -> Country {
pub fn country(&self) -> Country<'_> {
Country(self)
}

Expand Down Expand Up @@ -251,7 +251,7 @@ impl<'a> Deref for Country<'a> {

#[cfg(test)]
mod test {
use crate::country::{self, *};
use crate::country::{self, Id::*};
use crate::metadata::DATABASE;
use crate::Type;
use crate::{parser, Mode, PhoneNumber};
Expand Down
2 changes: 1 addition & 1 deletion src/validator.rs
Original file line number Diff line number Diff line change
Expand Up @@ -106,7 +106,7 @@ pub fn is_valid_with(database: &Database, number: &PhoneNumber) -> bool {
.unwrap_or(false)
}

pub fn length(meta: &Metadata, number: &ParseNumber, kind: Type) -> Validation {
pub fn length(meta: &Metadata, number: &ParseNumber<'_>, kind: Type) -> Validation {
let desc = if let Some(desc) = meta.descriptors().get(kind) {
desc
} else {
Expand Down

0 comments on commit ef03f93

Please sign in to comment.