Skip to content

Commit

Permalink
Make null handling YAML 1.2 compliant.
Browse files Browse the repository at this point in the history
  • Loading branch information
TripleWhy authored and jbeder committed Apr 1, 2016
1 parent 34bd1a7 commit 52bcefa
Show file tree
Hide file tree
Showing 4 changed files with 10 additions and 6 deletions.
2 changes: 2 additions & 0 deletions include/yaml-cpp/null.h
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
#endif

#include "yaml-cpp/dll.h"
#include <string>

namespace YAML {
class Node;
Expand All @@ -17,6 +18,7 @@ inline bool operator==(const _Null&, const _Null&) { return true; }
inline bool operator!=(const _Null&, const _Null&) { return false; }

YAML_CPP_API bool IsNull(const Node& node); // old API only
YAML_CPP_API bool IsNullString(const std::string& str);

extern YAML_CPP_API _Null Null;
}
Expand Down
7 changes: 2 additions & 5 deletions src/emitterutils.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@
#include "stringsource.h"
#include "yaml-cpp/binary.h" // IWYU pragma: keep
#include "yaml-cpp/ostream_wrapper.h"
#include "yaml-cpp/null.h"

namespace YAML {
namespace Utils {
Expand Down Expand Up @@ -152,12 +153,8 @@ void WriteCodePoint(ostream_wrapper& out, int codePoint) {

bool IsValidPlainScalar(const std::string& str, FlowType::value flowType,
bool allowOnlyAscii) {
if (str.empty()) {
return false;
}

// check against null
if (str == "null") {
if (IsNullString(str)) {
return false;
}

Expand Down
4 changes: 4 additions & 0 deletions src/null.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2,4 +2,8 @@

namespace YAML {
_Null Null;

bool IsNullString(const std::string& str) {
return str.empty() || str == "~" || str == "null" || str == "Null" || str == "NULL";
}
}
3 changes: 2 additions & 1 deletion src/singledocparser.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
#include "yaml-cpp/eventhandler.h"
#include "yaml-cpp/exceptions.h" // IWYU pragma: keep
#include "yaml-cpp/mark.h"
#include "yaml-cpp/null.h"

namespace YAML {
SingleDocParser::SingleDocParser(Scanner& scanner, const Directives& directives)
Expand Down Expand Up @@ -75,7 +76,7 @@ void SingleDocParser::HandleNode(EventHandler& eventHandler) {

const Token& token = m_scanner.peek();

if (token.type == Token::PLAIN_SCALAR && token.value == "null") {
if (token.type == Token::PLAIN_SCALAR && IsNullString(token.value)) {
eventHandler.OnNull(mark, anchor);
m_scanner.pop();
return;
Expand Down

0 comments on commit 52bcefa

Please sign in to comment.