README: add simple usage.

This commit is contained in:
Jonathan Bernard 2023-04-15 07:09:03 -05:00
parent 0f353e97ca
commit 2c625349bf

View File

@ -1,11 +1,51 @@
# VCard # VCard
`nim-vcard` is a purr-nim imolementation of the VCard format defined in RFCs `nim-vcard` is a pure nim implementation of the VCard format defined in RFCs
2425 and 2426. It allows you to parse and serialize VCards, as well as create 2425, 2426, and 6350. It allows you to parse and serialize VCards, as well as
VCards programmatically. It aims to be a complete implememtation, supporting create VCards programmatically. It aims to be a complete implememtation,
all of the features of the VCard3 standard. Because the standard provides many supporting all of the features of the VCard3 standard. Because the standard
features that may be rarely used, this library also provides a simolified API provides many features that may be rarely used, this library also provides a
for more typical use-cases. simplified API for more typical use-cases.
## Example Usage
```vcard
BEGIN:VCARD
VERSION:3.0
UID: 5db6f100-e2d6-4e8d-951f-d920586bc069
N:Foster;Jack;Allen;;
FN:Allen Foster
REV:20230408T122102Z
EMAIL;TYPE=home;TYPE=pref:allen@fosters.test
EMAIL;TYPE=work:jack.foster@company.test
TEL;TYPE=CELL:+1 (555) 123-4567
END:VCARD
```
```nim
import vcard
# Reading in an existing vcard
let vcards = parseVCard3File("jack.vcf")
assert vcards.len == 1
let vcAllen = vcards[0]
assert vcAllen.email.len == 2
assert vcAllen.email[0].value == "allen@fosters.test"
assert vcAllen.n.first == "Jack"
# Creating a new VCard
var vcSusan: VCard3
vcSusan.add(
newVC3_N(given = "Susan", family = "Foster"),
newVC3_Email(value = "susan@fosters.test", emailType = @["PREF", $etInternet),
newVC3_Tel(
value = "+1 (555) 444-3889",
telType = @[$ttHome, $ttCell, $ttVoice, $ttMsg])
)
writeFile("susan.vcf", $vcSusan)
```
## Future Goals ## Future Goals