Skip to content

Latest commit

 

History

History
110 lines (81 loc) · 2.84 KB

README.md

File metadata and controls

110 lines (81 loc) · 2.84 KB

C++ Simple Object Notation (CSON)

CSON allows users to create objects with named type-safe attributes on the fly, using notation inspired from JSON:

auto x = cson(name = "Rafi", age = 55, work = "Singing");

std::cout << x.name << "," << x.age << "," << x.work << std::endl;

Here the type of each attribute is statically determined during the creation of object — which means x.name is std::string, x.age is int and so on:

x.age = "I'm a string"; //compilation error :  age is int
x.age++;                //okay
x.worK = "New job";     //compilation error :  object x has no member named `worK`

That's very intuitive.

More examples

#include <iostream>
#include <cson/cson.h++>

//creates few labels first
CSON_LABEL(name);
CSON_LABEL(age);
CSON_LABEL(work);
CSON_LABEL(func);
CSON_LABEL(child);
CSON_LABEL(items);

int main()
{
	//create a cson object with some attributes, even nested cson object
	auto x = cson(
		name = "Rafi",
		age = 55,
		items = {1,2,3,4,5},  //this turns into a std::vector<int>
		func = [](std::string const & name) { //can be a functor/function/lambda also
			std::cout << ("Hello " + name)  << std::endl;
		},
		child = cson(   //nested cson object
			name  = 100,                      //now name becomes int
			age   = "here age is string",     //age is std::string now
			items = {"Shaan", "Udit", "Sonu"},//this turns into std::vector<std::string>
			child = cson(                      //yet again
				func = "Hi",
				child = "Bye"
			)
		)
	);
	x.func("Lata");  //invoke function
	std::cout << x.child.name << std::endl; //access child attribute to print it
	std::cout << x << std::endl;  //print the entire object
}

It is also possibe to treat the attributes as keys, so we can write as:

x[func]("Lata");  //invoke function

std::cout << x[child][name] << std::endl; //access child attribute to print it

And we can even mix them:

std::cout << x.child[name] << std::endl; //access child attribute to print it
std::cout << x[child].name << std::endl; //access child attribute to print it

All mean exactly same thing!

We can also iterate over keys and values, but for that we have to use .for_each() method passing a generic lambda (requires C++14 or above). We cannot use normal for loop because that requires each value to be of the same type.

auto printable_values = cson(
  name = "Rafi",
  age = 55,
  dict = cson(
	  name = 1947,
	  age = "The type of age is deduced now which is std::string"
  ),
  work = "Singing"
);

printable_values.for_each([](std::string const & key, auto && value) {
    // note: in each iteration the type of 'value' could be different, which is why it's declared to be `auto`
    std::cout << key << " : " << value << std::endl;
});

Compilers

Use any compiler (gcc or clang) supporting -std=c++14.