1
0
mirror of https://github.com/kgabis/parson.git synced 2025-01-14 06:12:54 +08:00
parson/README.md

146 lines
4.6 KiB
Markdown
Raw Normal View History

2012-10-16 19:56:54 +02:00
##About
Parson is a lighweight [json](http://json.org) library written in C.
2012-10-16 19:56:54 +02:00
##Features
* Full JSON support
* Lightweight (only 2 files)
2012-10-16 19:56:54 +02:00
* Simple API
* Addressing json values with dot notation (similiar to C structs or objects in most OO languages, e.g. "objectA.objectB.value")
* C89 compatible
* Test suites
##Installation
Run:
2012-10-16 19:56:54 +02:00
```
2012-10-18 21:37:03 +02:00
git clone https://github.com/kgabis/parson.git
2012-10-16 19:56:54 +02:00
```
and copy parson.h and parson.c to you source code tree.
2012-12-02 22:23:39 +01:00
Run ```make test``` to compile and run tests.
##Examples
###Parsing JSON
Here is a function, which prints basic commit info (date, sha and author) from a github repository.
2012-10-16 19:56:54 +02:00
```c
2012-10-22 19:25:32 +02:00
void print_commits_info(const char *username, const char *repo) {
2012-10-16 19:56:54 +02:00
JSON_Value *root_value;
JSON_Array *commits;
JSON_Object *commit;
size_t i;
2012-10-16 19:56:54 +02:00
char curl_command[512];
char cleanup_command[256];
char output_filename[] = "commits.json";
2012-10-16 19:56:54 +02:00
/* it ain't pretty, but it's not a libcurl tutorial */
sprintf(curl_command,
"curl -s \"https://api.github.com/repos/%s/%s/commits\" > %s",
username, repo, output_filename);
2012-10-16 19:56:54 +02:00
sprintf(cleanup_command, "rm -f %s", output_filename);
system(curl_command);
/* parsing json and validating output */
root_value = json_parse_file(output_filename);
if (json_value_get_type(root_value) != JSONArray) {
2012-10-16 19:56:54 +02:00
system(cleanup_command);
return;
}
2012-10-16 19:56:54 +02:00
/* getting array from root value and printing commit info */
commits = json_value_get_array(root_value);
printf("%-10.10s %-10.10s %s\n", "Date", "SHA", "Author");
for (i = 0; i < json_array_get_count(commits); i++) {
commit = json_array_get_object(commits, i);
printf("%.10s %.10s %s\n",
json_object_dotget_string(commit, "commit.author.date"),
json_object_get_string(commit, "sha"),
json_object_dotget_string(commit, "commit.author.name"));
}
/* cleanup code */
json_value_free(root_value);
system(cleanup_command);
}
2012-10-16 19:56:54 +02:00
```
Calling ```print_commits_info("torvalds", "linux");``` prints:
2012-10-16 19:56:54 +02:00
```
Date SHA Author
2012-10-15 dd8e8c4a2c David Rientjes
2012-10-15 3ce9e53e78 Michal Marek
2012-10-14 29bb4cc5e0 Randy Dunlap
2012-10-15 325adeb55e Ralf Baechle
2012-10-14 68687c842c Russell King
2012-10-14 ddffeb8c4d Linus Torvalds
...
```
###Persistence
In this example I'm using parson to save user information to a file and then load it and validate later.
```c
void persistence_example(void) {
JSON_Value *schema = json_parse_string("{\"name\":\"\"}");
JSON_Value *user_data = json_parse_file("user_data.json");
char buf[256];
const char *name = NULL;
if (!user_data || !json_validate(schema, user_data) == JSONSuccess) {
puts("Enter your name:");
scanf("%s", buf);
user_data = json_value_init_object();
json_object_set_string(json_object(user_data), "name", buf);
json_serialize_to_file(user_data, "user_data.json");
}
name = json_object_get_string(json_object(user_data), "name");
printf("Hello, %s.", name);
json_value_free(schema);
json_value_free(user_data);
return;
}
```
###Serialization
Creating JSON values is very simple thanks to the dot notation.
Object hierarchy is automatically created when addressing specific fields.
In the following example I create a simple JSON value containing basic information about a person.
```c
void serialization_example(void) {
JSON_Value *root_value = json_value_init_object();
JSON_Object *root_object = json_value_get_object(root_value);
char *serialized_string = NULL;
json_object_set_string(root_object, "name", "John Smith");
json_object_set_number(root_object, "age", 25);
json_object_dotset_string(root_object, "address.city", "Cupertino");
json_object_dotset_value(root_object, "contact.emails", json_parse_string("[\"email@example.com\",\"email2@example.com\"]"));
serialized_string = json_serialize_to_string(root_value);
puts(serialized_string);
json_free_serialized_string(serialized_string);
2014-10-08 14:45:39 +02:00
json_value_free(root_value);
}
```
Created value (after formatting outside parson):
```
{
"name":"John Smith",
"age":25,
"address":{
"city":"Cupertino"
},
"contact":{
"emails":[
"email@example.com",
"email2@example.com"
]
}
}
```
##Contributing
I will always merge *working* bug fixes. However, if you want to add something to the API,
I *won't* merge it without prior discussion.
Remember to follow parson's code style and write appropriate tests.
2012-10-16 19:56:54 +02:00
##License
[The MIT License (MIT)](http://opensource.org/licenses/mit-license.php)