-
Notifications
You must be signed in to change notification settings - Fork 8
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #201 from fktn-k/feature/195_basic_node_operators_…
…with_iostreams #195 Implement insertion/extraction operators for basic_node template class
- Loading branch information
Showing
23 changed files
with
281 additions
and
42 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
<small>Defined in header [`<fkYAML/node.hpp>`](https://github.com/fktn-k/fkYAML/blob/develop/include/fkYAML/node.hpp)</small> | ||
|
||
# <small>fkyaml::</small>operator>> | ||
|
||
```cpp | ||
inline std::istream& operator>>(std::istream& is, basic_node& n); | ||
``` | ||
|
||
Insertion operator for basic_node template class. | ||
Deserializes an input stream into a [`basic_node`](index.md). | ||
This API is a wrapper of [`basic_node::deserialize()`](deserialize.md) function for input streams to simplify the implementation in the user's code. | ||
|
||
## **Parameters** | ||
|
||
***`is`*** [in] | ||
: An input stream object. | ||
|
||
***`n`*** [in] | ||
: A basic_node object. | ||
|
||
## **Return Value** | ||
|
||
Reference to the input stream object `is`. | ||
|
||
???+ Example | ||
|
||
```yaml title="input.yaml" | ||
foo: true | ||
bar: 123 | ||
baz: 3.14 | ||
``` | ||
|
||
```cpp | ||
#include <fstream> | ||
#include <iostream> | ||
#include <fkYAML/node.hpp> | ||
|
||
int main() | ||
{ | ||
std::ifstream ifs("input.yaml"); | ||
fkyaml::node n; | ||
ifs >> n; | ||
|
||
// print the deserialization result. | ||
std::cout << n << std::endl; | ||
|
||
return 0; | ||
} | ||
``` | ||
|
||
```yaml | ||
foo: true | ||
bar: 123 | ||
baz: 3.14 | ||
``` | ||
|
||
### **See Also** | ||
|
||
* [basic_node](index.md) | ||
* [deserialize](deserialize.md) | ||
* [serialize](serialize.md) | ||
* [operator<<](insertion_operator.md) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,93 @@ | ||
<small>Defined in header [`<fkYAML/node.hpp>`](https://github.com/fktn-k/fkYAML/blob/develop/include/fkYAML/node.hpp)</small> | ||
|
||
# <small>fkyaml::</small>operator<< | ||
|
||
```cpp | ||
inline std::ostream& operator<<(std::ostream& os, const basic_node& n); | ||
``` | ||
|
||
Extraction operator for basic_node template class. | ||
Serializes YAML node values into an output stream. | ||
This API is a wrapper of [`basic_node::serialize()`](serialize.md) function to simplify the implementation in the user's code. | ||
For more detailed descriptions, please visit the reference page for the [`basic_node::serialize()`](serialize.md) function. | ||
|
||
## **Template Parameters** | ||
|
||
***SequenceType*** | ||
: Type for sequence node value containers. | ||
|
||
***MappingType*** | ||
: Type for mapping node value containers. | ||
|
||
***BooleanType*** | ||
: Type for boolean node values. | ||
|
||
***IntegerType*** | ||
: Type for integer node values. | ||
|
||
***FloatNumberType*** | ||
: Type for float number node values. | ||
|
||
***StringType*** | ||
: Type for string node values. | ||
|
||
***ConverterType*** | ||
: Type for converters between nodes and values of native data types. | ||
|
||
## **Parameters** | ||
|
||
***`os`*** [in] | ||
: An output stream object. | ||
|
||
***`n`*** [in] | ||
: A basic_node object. | ||
|
||
## **Return Value** | ||
|
||
Reference to the output stream object `os`. | ||
|
||
???+ Example | ||
|
||
```cpp | ||
#include <iostream> | ||
#include <fkYAML/node.hpp> | ||
|
||
int main() | ||
{ | ||
// create a basic_node object. | ||
fkyaml::node n = { | ||
{"foo", true}, | ||
{"bar", {1, 2, 3}}, | ||
{"baz", { | ||
{"qux", 3.14}, | ||
{"corge", nullptr} | ||
}} | ||
}; | ||
|
||
// serialize the basic_node object with insertion operator. | ||
// this is equivalent with: | ||
// std::cout << fkyaml::node::serialize(n) << std::endl; | ||
std::cout << n << std::endl; | ||
|
||
return 0; | ||
} | ||
``` | ||
|
||
output: | ||
```yaml | ||
foo: true | ||
bar: | ||
- 1 | ||
- 2 | ||
- 3 | ||
baz: | ||
qux: 3.14 | ||
corge: null | ||
``` | ||
|
||
### **See Also** | ||
|
||
* [basic_node](index.md) | ||
* [serialize](serialize.md) | ||
* [deserialize](deserialize.md) | ||
* [operator>>](extraction_operator.md) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.