contack

Crates.iocontack
lib.rscontack
version0.9.2
sourcesrc
created_at2021-02-19 14:18:21.139592
updated_at2022-01-02 15:12:20.636485
descriptionA simple and easy contact library.
homepage
repositoryhttps://gitlab.com/john_t/contack
max_upload_size
id357583
size125,004
John Toohey (greenfierydragon)

documentation

README

Contack

License: MIT License

Contack is a contact library for rust. Rather than following the RFCs exactly, it gives up some compatibility for ease of use. For example, instead of being able to express any number of job roles, Contack gives you the option of only 1, which in turn is much easier to work with.

With the read_write feature you can have native support for serialisation and deserialisation, to VCard. This is achieved as follows:

use contack::Contact;
use contack::read_write::vcard::VCard;
use std::fs::File;
use std::io::prelude::*;
use std::error::Error;

fn main() -> Result<(), Box<dyn Error>> {
    // Load a VCard file
    let mut vcard = String::new();
    File::open("my_card.vcard")?.read_to_string(&mut vcard)?;
    
    // Serialise it
    let vcard: VCard = vcard.parse()?;
    
    // Convert it to a contact
    let mut contact: Contact = vcard.try_into()?;
    
    // Make some changes
    contact.role = Some(String::from("Being a handy example."));
    
    // Convert it to a VCard representation.
    let vcard: VCard = contact.into();
    
    // Print it to the stdout
    println!("{}", vcard.to_string());

    Ok(())
}

It also supports the following external libraries:

  • Diesel diesel_support. This supports both serialisation and deserialisation.
  • Sqlx sqlx_support. This supports both serialisation and deserialisation.
Commit count: 342

cargo fmt