Skip to content

Commit f27e5fe

Browse files
committed
Docs folder containing the contributions files
1 parent 2528e60 commit f27e5fe

File tree

5 files changed

+214
-0
lines changed

5 files changed

+214
-0
lines changed

docs/CONTRIBUTING.md

Lines changed: 22 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
# Contribution Guidelines
2+
3+
Feel free to work on any issue with a #hacktoberfest label.
4+
5+
If you discover an issue you would like to work on, you can add a new issue to the list. If it meets our criteria, a hacktoberfest label will be added.
6+
7+
# Who is allowed to submit pull requests for this project?
8+
9+
Anyone can submit pull requests for code, tests, or documentation.
10+
11+
# How do you decide which pull requests to accept?
12+
13+
* Does it call out a bug that needs to be fixed? If so, it goes to the top of the list.
14+
* Does it fix a major user inconvenience? These are given high priority as well.
15+
* Does it align with the specs? If not, it will probably not be accepted. It turns out there are gray areas in the specs. If this is in a gray area, it will likely be given the benefit of the doubt.
16+
* Does it break the existing behavior of the lib? If so, it will not be accepted, unless it fixes an egregious bug. This is happening less frequently now.
17+
18+
# For more guidance, see these links:
19+
20+
[README.md (includes build instructions)](https://github.com/stleary/JSON-java#readme)
21+
22+
[FAQ - all your questions answered](https://github.com/stleary/JSON-java/wiki/FAQ)

docs/FILES.md

Lines changed: 62 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,62 @@
1+
# Files
2+
3+
**JSONObject.java**: The `JSONObject` can parse text from a `String` or a `JSONTokener`
4+
to produce a map-like object. The object provides methods for manipulating its
5+
contents, and for producing a JSON compliant object serialization.
6+
7+
**JSONArray.java**: The `JSONArray` can parse text from a String or a `JSONTokener`
8+
to produce a vector-like object. The object provides methods for manipulating
9+
its contents, and for producing a JSON compliant array serialization.
10+
11+
**JSONTokener.java**: The `JSONTokener` breaks a text into a sequence of individual
12+
tokens. It can be constructed from a `String`, `Reader`, or `InputStream`. It also can
13+
parse text from a `String`, `Number`, `Boolean` or `null` like `"hello"`, `42`, `true`,
14+
`null` to produce a simple json object.
15+
16+
**JSONException.java**: The `JSONException` is the standard exception type thrown
17+
by this package.
18+
19+
**JSONPointer.java**: Implementation of
20+
[JSON Pointer (RFC 6901)](https://tools.ietf.org/html/rfc6901). Supports
21+
JSON Pointers both in the form of string representation and URI fragment
22+
representation.
23+
24+
**JSONPropertyIgnore.java**: Annotation class that can be used on Java Bean getter methods.
25+
When used on a bean method that would normally be serialized into a `JSONObject`, it
26+
overrides the getter-to-key-name logic and forces the property to be excluded from the
27+
resulting `JSONObject`.
28+
29+
**JSONPropertyName.java**: Annotation class that can be used on Java Bean getter methods.
30+
When used on a bean method that would normally be serialized into a `JSONObject`, it
31+
overrides the getter-to-key-name logic and uses the value of the annotation. The Bean
32+
processor will look through the class hierarchy. This means you can use the annotation on
33+
a base class or interface and the value of the annotation will be used even if the getter
34+
is overridden in a child class.
35+
36+
**JSONString.java**: The `JSONString` interface requires a `toJSONString` method,
37+
allowing an object to provide its own serialization.
38+
39+
**JSONStringer.java**: The `JSONStringer` provides a convenient facility for
40+
building JSON strings.
41+
42+
**JSONWriter.java**: The `JSONWriter` provides a convenient facility for building
43+
JSON text through a writer.
44+
45+
46+
**CDL.java**: `CDL` provides support for converting between JSON and comma
47+
delimited lists.
48+
49+
**Cookie.java**: `Cookie` provides support for converting between JSON and cookies.
50+
51+
**CookieList.java**: `CookieList` provides support for converting between JSON and
52+
cookie lists.
53+
54+
**HTTP.java**: `HTTP` provides support for converting between JSON and HTTP headers.
55+
56+
**HTTPTokener.java**: `HTTPTokener` extends `JSONTokener` for parsing HTTP headers.
57+
58+
**XML.java**: `XML` provides support for converting between JSON and XML.
59+
60+
**JSONML.java**: `JSONML` provides support for converting between JSONML and XML.
61+
62+
**XMLTokener.java**: `XMLTokener` extends `JSONTokener` for parsing XML text.

docs/NOTES.md

Lines changed: 87 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,87 @@
1+
# Notes
2+
3+
**Recent directory structure change**
4+
5+
_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._
6+
7+
**Implementation notes**
8+
9+
Numeric types in this package comply with
10+
[ECMA-404: The JSON Data Interchange Format](http://www.ecma-international.org/publications/files/ECMA-ST/ECMA-404.pdf) and
11+
[RFC 8259: The JavaScript Object Notation (JSON) Data Interchange Format](https://tools.ietf.org/html/rfc8259#section-6).
12+
This package fully supports `Integer`, `Long`, and `Double` Java types. Partial support
13+
for `BigInteger` and `BigDecimal` values in `JSONObject` and `JSONArray` objects is provided
14+
in the form of `get()`, `opt()`, and `put()` API methods.
15+
16+
Although 1.6 compatibility is currently supported, it is not a project goal and might be
17+
removed in some future release.
18+
19+
In compliance with RFC8259 page 10 section 9, the parser is more lax with what is valid
20+
JSON then the Generator. For Example, the tab character (U+0009) is allowed when reading
21+
JSON Text strings, but when output by the Generator, the tab is properly converted to \t in
22+
the string. Other instances may occur where reading invalid JSON text does not cause an
23+
error to be generated. Malformed JSON Texts such as missing end " (quote) on strings or
24+
invalid number formats (1.2e6.3) will cause errors as such documents can not be read
25+
reliably.
26+
27+
Some notable exceptions that the JSON Parser in this library accepts are:
28+
* Unquoted keys `{ key: "value" }`
29+
* Unquoted values `{ "key": value }`
30+
* Unescaped literals like "tab" in string values `{ "key": "value with an unescaped tab" }`
31+
* Numbers out of range for `Double` or `Long` are parsed as strings
32+
33+
Recent pull requests added a new method `putAll` on the JSONArray. The `putAll` method
34+
works similarly to other `put` methods in that it does not call `JSONObject.wrap` for items
35+
added. This can lead to inconsistent object representation in JSONArray structures.
36+
37+
For example, code like this will create a mixed JSONArray, some items wrapped, others
38+
not:
39+
40+
```java
41+
SomeBean[] myArr = new SomeBean[]{ new SomeBean(1), new SomeBean(2) };
42+
// these will be wrapped
43+
JSONArray jArr = new JSONArray(myArr);
44+
// these will not be wrapped
45+
jArr.putAll(new SomeBean[]{ new SomeBean(3), new SomeBean(4) });
46+
```
47+
48+
For structure consistency, it would be recommended that the above code is changed
49+
to look like 1 of 2 ways.
50+
51+
Option 1:
52+
```Java
53+
SomeBean[] myArr = new SomeBean[]{ new SomeBean(1), new SomeBean(2) };
54+
JSONArray jArr = new JSONArray();
55+
// these will not be wrapped
56+
jArr.putAll(myArr);
57+
// these will not be wrapped
58+
jArr.putAll(new SomeBean[]{ new SomeBean(3), new SomeBean(4) });
59+
// our jArr is now consistent.
60+
```
61+
62+
Option 2:
63+
```Java
64+
SomeBean[] myArr = new SomeBean[]{ new SomeBean(1), new SomeBean(2) };
65+
// these will be wrapped
66+
JSONArray jArr = new JSONArray(myArr);
67+
// these will be wrapped
68+
jArr.putAll(new JSONArray(new SomeBean[]{ new SomeBean(3), new SomeBean(4) }));
69+
// our jArr is now consistent.
70+
```
71+
72+
**Unit Test Conventions**
73+
74+
Test filenames should consist of the name of the module being tested, with the suffix "Test".
75+
For example, <b>Cookie.java</b> is tested by <b>CookieTest.java</b>.
76+
77+
<b>The fundamental issues with JSON-Java testing are:</b><br>
78+
* <b>JSONObjects</b> are unordered, making simple string comparison ineffective.
79+
* 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.
80+
* Access to the <b>JSONArray</b> and <b>JSONObject</b> internal containers for comparison is not currently available.
81+
82+
<b>General issues with unit testing are:</b><br>
83+
* Just writing tests to make coverage goals tends to result in poor tests.
84+
* 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.
85+
* 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.
86+
* 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.
87+
* 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.

docs/RELEASES.md

Lines changed: 38 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,38 @@
1+
# Release history:
2+
3+
JSON-java releases can be found by searching the Maven repository for groupId "org.json"
4+
and artifactId "json". For example:
5+
[https://search.maven.org/search?q=g:org.json%20AND%20a:json&core=gav](https://search.maven.org/search?q=g:org.json%20AND%20a:json&core=gav)
6+
7+
~~~
8+
20210307 Recent commits and potentially breaking fix to JSONPointer
9+
10+
20201115 Recent commits and first release after project structure change
11+
12+
20200518 Recent commits and snapshot before project structure change
13+
14+
20190722 Recent commits
15+
16+
20180813 POM change to include Automatic-Module-Name (#431)
17+
18+
20180130 Recent commits
19+
20+
20171018 Checkpoint for recent commits.
21+
22+
20170516 Roll up recent commits.
23+
24+
20160810 Revert code that was breaking opt*() methods.
25+
26+
20160807 This release contains a bug in the JSONObject.opt*() and JSONArray.opt*() methods,
27+
it is not recommended for use.
28+
Java 1.6 compatability fixed, JSONArray.toList() and JSONObject.toMap(),
29+
RFC4180 compatibility, JSONPointer, some exception fixes, optional XML type conversion.
30+
Contains the latest code as of 7 Aug 2016
31+
32+
20160212 Java 1.6 compatibility, OSGi bundle. Contains the latest code as of 12 Feb 2016.
33+
34+
20151123 JSONObject and JSONArray initialization with generics. Contains the latest code as of 23 Nov 2015.
35+
36+
20150729 Checkpoint for Maven central repository release. Contains the latest code
37+
as of 29 July 2015.
38+
~~~

docs/SECURITY.md

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
# Security Policy
2+
3+
## Reporting a Vulnerability
4+
5+
Please follow the instructions in the ["How are vulnerabilities and exploits handled?"](https://github.com/stleary/JSON-java/wiki/FAQ#how-are-vulnerabilities-and-exploits-handled) section in the FAQ.

0 commit comments

Comments
 (0)