File: ujson.h

package info (click to toggle)
icu 76.1-4
  • links: PTS
  • area: main
  • in suites: forky, sid, trixie
  • size: 121,296 kB
  • sloc: cpp: 522,712; ansic: 113,387; sh: 4,983; makefile: 4,709; perl: 3,198; python: 2,847; xml: 2,652; sed: 36; lisp: 12
file content (38 lines) | stat: -rw-r--r-- 1,311 bytes parent folder | download | duplicates (13)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
// © 2024 and later: Unicode, Inc. and others.
// License & terms of use: http://www.unicode.org/copyright.html
#ifndef __UJSON_H__
#define __UJSON_H__

/*
  Without this code, the output if the JSON library code
  throws an exception would look like:
  terminate called after throwing an instance of 'nlohmann::json_abi_v3_11_3::detail::parse_error'
  what():  [json.exception.parse_error.101] parse error at line 1, column 1: attempting to parse an empty input; check that your input string or stream contains the expected JSON
Aborted (core dumped)

  (for example, if one of the JSON tests files contains an error or a file doesn't exist.)

  With this code, the output is:

  JSON exception thrown; modify tools/ctestfw//ujson.h to get diagnostics.
  Exiting immediately.

  The entire #if block can be commented out in order to temporarily enable exceptions
  and get a better parse error message (temporarily, while debugging).
 */

// Disable exceptions in JSON parser

#if _HAS_EXCEPTIONS == 0
#define JSON_TRY_USER if(true)
#define JSON_CATCH_USER(exception) if(false)
#define JSON_THROW_USER(exception) { \
    printf("JSON exception thrown; modify tools/toolutil/ujson.h to get diagnostics.\n\
Exiting immediately.\n"); \
    exit(1); \
}
#endif

#include "json-json.hpp"

#endif /* __UJSON_H__ */