You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Copy file name to clipboardExpand all lines: README.md
+4-184Lines changed: 4 additions & 184 deletions
Display the source diff
Display the rich diff
Original file line number
Diff line number
Diff line change
@@ -32,7 +32,7 @@ The license includes this restriction: ["The software shall be used for good, no
32
32
33
33
# If you would like to contribute to this project
34
34
35
-
For more information on contributions, please see [CONTRIBUTING.md](https://github.com/stleary/JSON-java/blob/master/CONTRIBUTING.md)
35
+
For more information on contributions, please see [CONTRIBUTING.md](https://github.com/stleary/JSON-java/blob/master/docs/CONTRIBUTING.md)
36
36
37
37
Bug fixes, code improvements, and unit test coverage changes are welcome! Because this project is currently in the maintenance phase, the kinds of changes that can be accepted are limited. For more information, please read the [FAQ](https://github.com/stleary/JSON-java/wiki/FAQ).
38
38
@@ -98,192 +98,12 @@ gradlew clean build test
98
98
99
99
# Notes
100
100
101
-
**Recent directory structure change**
102
-
103
-
_Due to a recent commit - [#515 Merge tests and pom and code](https://github.com/stleary/JSON-java/pull/515) - the structure of the project has changed from a flat directory containing all of the Java files to a directory structure that includes unit tests and several tools used to build the project jar and run the unit tests. If you have difficulty using the new structure, please open an issue so we can work through it._
104
-
105
-
**Implementation notes**
106
-
107
-
Numeric types in this package comply with
108
-
[ECMA-404: The JSON Data Interchange Format](http://www.ecma-international.org/publications/files/ECMA-ST/ECMA-404.pdf) and
109
-
[RFC 8259: The JavaScript Object Notation (JSON) Data Interchange Format](https://tools.ietf.org/html/rfc8259#section-6).
110
-
This package fully supports `Integer`, `Long`, and `Double` Java types. Partial support
111
-
for `BigInteger` and `BigDecimal` values in `JSONObject` and `JSONArray` objects is provided
112
-
in the form of `get()`, `opt()`, and `put()` API methods.
113
-
114
-
Although 1.6 compatibility is currently supported, it is not a project goal and might be
115
-
removed in some future release.
116
-
117
-
In compliance with RFC8259 page 10 section 9, the parser is more lax with what is valid
118
-
JSON then the Generator. For Example, the tab character (U+0009) is allowed when reading
119
-
JSON Text strings, but when output by the Generator, the tab is properly converted to \t in
120
-
the string. Other instances may occur where reading invalid JSON text does not cause an
121
-
error to be generated. Malformed JSON Texts such as missing end " (quote) on strings or
122
-
invalid number formats (1.2e6.3) will cause errors as such documents can not be read
123
-
reliably.
124
-
125
-
Some notable exceptions that the JSON Parser in this library accepts are:
126
-
* Unquoted keys `{ key: "value" }`
127
-
* Unquoted values `{ "key": value }`
128
-
* Unescaped literals like "tab" in string values `{ "key": "value with an unescaped tab" }`
129
-
* Numbers out of range for `Double` or `Long` are parsed as strings
130
-
131
-
Recent pull requests added a new method `putAll` on the JSONArray. The `putAll` method
132
-
works similarly to other `put` methods in that it does not call `JSONObject.wrap` for items
133
-
added. This can lead to inconsistent object representation in JSONArray structures.
134
-
135
-
For example, code like this will create a mixed JSONArray, some items wrapped, others
Test filenames should consist of the name of the module being tested, with the suffix "Test".
173
-
For example, <b>Cookie.java</b> is tested by <b>CookieTest.java</b>.
174
-
175
-
<b>The fundamental issues with JSON-Java testing are:</b><br>
176
-
* <b>JSONObjects</b> are unordered, making simple string comparison ineffective.
177
-
* Comparisons via **equals()** is not currently supported. Neither <b>JSONArray</b> nor <b>JSONObject</b> override <b>hashCode()</b> or <b>equals()</b>, so comparison defaults to the <b>Object</b> equals(), which is not useful.
178
-
* Access to the <b>JSONArray</b> and <b>JSONObject</b> internal containers for comparison is not currently available.
179
-
180
-
<b>General issues with unit testing are:</b><br>
181
-
* Just writing tests to make coverage goals tends to result in poor tests.
182
-
* Unit tests are a form of documentation - how a given method works is demonstrated by the test. So for a code reviewer or future developer looking at code a good test helps explain how a function is supposed to work according to the original author. This can be difficult if you are not the original developer.
183
-
* It is difficult to evaluate unit tests in a vacuum. You also need to see the code being tested to understand if a test is good.
184
-
* Without unit tests, it is hard to feel confident about the quality of the code, especially when fixing bugs or refactoring. Good tests prevent regressions and keep the intent of the code correct.
185
-
* If you have unit test results along with pull requests, the reviewer has an easier time understanding your code and determining if it works as intended.
186
-
101
+
For more information, please see [NOTES.md](https://github.com/stleary/JSON-java/blob/master/docs/NOTES.md)
187
102
188
103
# Files
189
104
190
-
**JSONObject.java**: The `JSONObject` can parse text from a `String` or a `JSONTokener`
191
-
to produce a map-like object. The object provides methods for manipulating its
192
-
contents, and for producing a JSON compliant object serialization.
193
-
194
-
**JSONArray.java**: The `JSONArray` can parse text from a String or a `JSONTokener`
195
-
to produce a vector-like object. The object provides methods for manipulating
196
-
its contents, and for producing a JSON compliant array serialization.
197
-
198
-
**JSONTokener.java**: The `JSONTokener` breaks a text into a sequence of individual
199
-
tokens. It can be constructed from a `String`, `Reader`, or `InputStream`. It also can
200
-
parse text from a `String`, `Number`, `Boolean` or `null` like `"hello"`, `42`, `true`,
201
-
`null` to produce a simple json object.
202
-
203
-
**JSONException.java**: The `JSONException` is the standard exception type thrown
0 commit comments