more documentation
This commit is contained in:
parent
e63c508172
commit
bb13c931b3
8 changed files with 880 additions and 327 deletions
6
Doxyfile
6
Doxyfile
|
@ -83,7 +83,7 @@ GENERATE_DEPRECATEDLIST= YES
|
||||||
ENABLED_SECTIONS =
|
ENABLED_SECTIONS =
|
||||||
MAX_INITIALIZER_LINES = 30
|
MAX_INITIALIZER_LINES = 30
|
||||||
SHOW_USED_FILES = NO
|
SHOW_USED_FILES = NO
|
||||||
SHOW_FILES = YES
|
SHOW_FILES = NO
|
||||||
SHOW_NAMESPACES = NO
|
SHOW_NAMESPACES = NO
|
||||||
FILE_VERSION_FILTER =
|
FILE_VERSION_FILTER =
|
||||||
LAYOUT_FILE =
|
LAYOUT_FILE =
|
||||||
|
@ -153,11 +153,11 @@ HTML_COLORSTYLE_GAMMA = 80
|
||||||
HTML_TIMESTAMP = YES
|
HTML_TIMESTAMP = YES
|
||||||
HTML_DYNAMIC_SECTIONS = NO
|
HTML_DYNAMIC_SECTIONS = NO
|
||||||
HTML_INDEX_NUM_ENTRIES = 100
|
HTML_INDEX_NUM_ENTRIES = 100
|
||||||
GENERATE_DOCSET = NO
|
GENERATE_DOCSET = YES
|
||||||
DOCSET_FEEDNAME = "Doxygen generated docs"
|
DOCSET_FEEDNAME = "Doxygen generated docs"
|
||||||
DOCSET_BUNDLE_ID = me.nlohmann.json
|
DOCSET_BUNDLE_ID = me.nlohmann.json
|
||||||
DOCSET_PUBLISHER_ID = me.nlohmann
|
DOCSET_PUBLISHER_ID = me.nlohmann
|
||||||
DOCSET_PUBLISHER_NAME = Publisher
|
DOCSET_PUBLISHER_NAME = Niels Lohmann
|
||||||
GENERATE_HTMLHELP = NO
|
GENERATE_HTMLHELP = NO
|
||||||
CHM_FILE =
|
CHM_FILE =
|
||||||
HHC_LOCATION =
|
HHC_LOCATION =
|
||||||
|
|
18
Makefile
18
Makefile
|
@ -15,6 +15,24 @@ clean:
|
||||||
json_unit: test/unit.cpp src/json.hpp test/catch.hpp
|
json_unit: test/unit.cpp src/json.hpp test/catch.hpp
|
||||||
$(CXX) -std=c++11 $(CXXFLAGS) $(FLAGS) $(CPPFLAGS) -I src -I test $< $(LDFLAGS) -o $@
|
$(CXX) -std=c++11 $(CXXFLAGS) $(FLAGS) $(CPPFLAGS) -I src -I test $< $(LDFLAGS) -o $@
|
||||||
|
|
||||||
|
check: json_unit
|
||||||
|
./json_unit "*"
|
||||||
|
make check -C docs/examples
|
||||||
|
|
||||||
|
docset:
|
||||||
|
cp Doxyfile Doxyfile_docset
|
||||||
|
gsed -i 's/DISABLE_INDEX = NO/DISABLE_INDEX = YES/' Doxyfile_docset
|
||||||
|
gsed -i 's/SEARCHENGINE = YES/SEARCHENGINE = NO/' Doxyfile_docset
|
||||||
|
gsed -i 's/GENERATE_TREEVIEW = YES/GENERATE_TREEVIEW = NO/' Doxyfile_docset
|
||||||
|
gsed -i 's/SEPARATE_MEMBER_PAGES = NO/SEPARATE_MEMBER_PAGES = YES/' Doxyfile_docset
|
||||||
|
gsed -i 's/BINARY_TOC = YES/BINARY_TOC = NO/' Doxyfile_docset
|
||||||
|
rm -fr html *.docset
|
||||||
|
doxygen Doxyfile_docset
|
||||||
|
make -C html
|
||||||
|
mv html/*.docset .
|
||||||
|
gsed -i 's@<string>doxygen</string>@<string>json</string>@' me.nlohmann.json.docset/Contents/Info.plist
|
||||||
|
rm -fr Doxyfile_docset html
|
||||||
|
|
||||||
# create scanner with re2c
|
# create scanner with re2c
|
||||||
re2c: src/json.hpp.re2c
|
re2c: src/json.hpp.re2c
|
||||||
$(RE2C) -b -s -i --no-generation-date $< | $(SED) '1d' > src/json.hpp
|
$(RE2C) -b -s -i --no-generation-date $< | $(SED) '1d' > src/json.hpp
|
||||||
|
|
28
docs/examples/back.cpp
Normal file
28
docs/examples/back.cpp
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
#include <json.hpp>
|
||||||
|
|
||||||
|
using namespace nlohmann;
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
// create JSON values
|
||||||
|
json j_null;
|
||||||
|
json j_boolean = true;
|
||||||
|
json j_number_integer = 17;
|
||||||
|
json j_number_float = 23.42;
|
||||||
|
json j_object = {{"one", 1}, {"two", 2}};
|
||||||
|
json j_object_empty(json::value_t::object);
|
||||||
|
json j_array = {1, 2, 4, 8, 16};
|
||||||
|
json j_array_empty(json::value_t::array);
|
||||||
|
json j_string = "Hello, world";
|
||||||
|
|
||||||
|
// call back()
|
||||||
|
//std::cout << j_null.back() << '\n'; // would throw
|
||||||
|
std::cout << j_boolean.back() << '\n';
|
||||||
|
std::cout << j_number_integer.back() << '\n';
|
||||||
|
std::cout << j_number_float.back() << '\n';
|
||||||
|
std::cout << j_object.back() << '\n';
|
||||||
|
//std::cout << j_object_empty.back() << '\n'; // would throw
|
||||||
|
std::cout << j_array.back() << '\n';
|
||||||
|
//std::cout << j_array_empty.back() << '\n'; // would throw
|
||||||
|
std::cout << j_string.back() << '\n';
|
||||||
|
}
|
6
docs/examples/back.output
Normal file
6
docs/examples/back.output
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
true
|
||||||
|
17
|
||||||
|
23.42
|
||||||
|
2
|
||||||
|
16
|
||||||
|
"Hello, world"
|
28
docs/examples/front.cpp
Normal file
28
docs/examples/front.cpp
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
#include <json.hpp>
|
||||||
|
|
||||||
|
using namespace nlohmann;
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
// create JSON values
|
||||||
|
json j_null;
|
||||||
|
json j_boolean = true;
|
||||||
|
json j_number_integer = 17;
|
||||||
|
json j_number_float = 23.42;
|
||||||
|
json j_object = {{"one", 1}, {"two", 2}};
|
||||||
|
json j_object_empty(json::value_t::object);
|
||||||
|
json j_array = {1, 2, 4, 8, 16};
|
||||||
|
json j_array_empty(json::value_t::array);
|
||||||
|
json j_string = "Hello, world";
|
||||||
|
|
||||||
|
// call front()
|
||||||
|
//std::cout << j_null.front() << '\n'; // would throw
|
||||||
|
std::cout << j_boolean.front() << '\n';
|
||||||
|
std::cout << j_number_integer.front() << '\n';
|
||||||
|
std::cout << j_number_float.front() << '\n';
|
||||||
|
std::cout << j_object.front() << '\n';
|
||||||
|
//std::cout << j_object_empty.front() << '\n'; // would throw
|
||||||
|
std::cout << j_array.front() << '\n';
|
||||||
|
//std::cout << j_array_empty.front() << '\n'; // would throw
|
||||||
|
std::cout << j_string.front() << '\n';
|
||||||
|
}
|
6
docs/examples/front.output
Normal file
6
docs/examples/front.output
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
true
|
||||||
|
17
|
||||||
|
23.42
|
||||||
|
1
|
||||||
|
1
|
||||||
|
"Hello, world"
|
1068
src/json.hpp
1068
src/json.hpp
File diff suppressed because it is too large
Load diff
|
@ -1548,19 +1548,56 @@ class basic_json
|
||||||
return m_value.object->operator[](key);
|
return m_value.object->operator[](key);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// access the first element
|
/*!
|
||||||
|
@brief access the first element
|
||||||
|
|
||||||
|
Returns a reference to the first element in the container. For a JSON
|
||||||
|
container `c`, the expression `c.front()` is equivalent to `*c.begin()`.
|
||||||
|
|
||||||
|
@return In case of a compound value (array or object), a reference to the
|
||||||
|
first element is returned. In cast of number, string, or boolean values, a
|
||||||
|
reference to the value is returned.
|
||||||
|
|
||||||
|
@complexity Constant.
|
||||||
|
|
||||||
|
@note Calling `front` on an empty container is undefined.
|
||||||
|
|
||||||
|
@throw std::out_of_range when called on null value.
|
||||||
|
|
||||||
|
@liveexample{The following code shows an example for @ref front.,front}
|
||||||
|
*/
|
||||||
reference front()
|
reference front()
|
||||||
{
|
{
|
||||||
return *begin();
|
return *begin();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// access the first element
|
/*!
|
||||||
|
@copydoc basic_json::front()
|
||||||
|
*/
|
||||||
const_reference front() const
|
const_reference front() const
|
||||||
{
|
{
|
||||||
return *cbegin();
|
return *cbegin();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// access the last element
|
/*!
|
||||||
|
@brief access the last element
|
||||||
|
|
||||||
|
Returns a reference to the last element in the container. For a JSON
|
||||||
|
container `c`, the expression `c.back()` is equivalent to `{ auto tmp =
|
||||||
|
c.end(); --tmp; return *tmp; }`.
|
||||||
|
|
||||||
|
@return In case of a compound value (array or object), a reference to the
|
||||||
|
last element is returned. In cast of number, string, or boolean values, a
|
||||||
|
reference to the value is returned.
|
||||||
|
|
||||||
|
@complexity Constant.
|
||||||
|
|
||||||
|
@note Calling `back` on an empty container is undefined.
|
||||||
|
|
||||||
|
@throw std::out_of_range when called on null value.
|
||||||
|
|
||||||
|
@liveexample{The following code shows an example for @ref back.,back}
|
||||||
|
*/
|
||||||
reference back()
|
reference back()
|
||||||
{
|
{
|
||||||
auto tmp = end();
|
auto tmp = end();
|
||||||
|
@ -1568,7 +1605,9 @@ class basic_json
|
||||||
return *tmp;
|
return *tmp;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// access the last element
|
/*!
|
||||||
|
@copydoc basic_json::back()
|
||||||
|
*/
|
||||||
const_reference back() const
|
const_reference back() const
|
||||||
{
|
{
|
||||||
auto tmp = cend();
|
auto tmp = cend();
|
||||||
|
|
Loading…
Reference in a new issue