Members:
- `element_selectors`: the indexes and/or fields needed to get from the top-level JSON value to the point where the difference is.
- `find_difference`: finds the first difference between two JSON ASTs. Returns `util::nullopt` if the two JSON ASTs are equal.
+
+## `json/location.h`
+
+### `json::Location`
+type representing a source-code location. Designed for speed, so it holds a pointer to the `Source` and the byte-index of the represented location.
+
+## `json/parser.h`
+
+### `json::Parse_error`
+Type representing a JSON parse error. Holds a `json::Location`, which holds a pointer to the `Source`, so the `Source` needs to be still valid when this is caught, unless you don't need the `location` field.
+Converts the `Location` to text on construction, so, if the `Source` object is destroyed before this `Location` is, it will still work.
+
+### `json::Parse_options`
+Options for parsing JSON.
+Members:
+- `allow_infinity_and_nan`: if the parser will parse +/-`Infinity` and `NaN`. The JSON specification doesn't allow `Infinity` or `NaN`.
+Ex: Allow parsing of `Infinity`, `-Infinity`, and `NaN`.
+- `allow_explicit_plus_sign_in_mantissa`: if the parser will parse a leading `+` on a number. The JSON specification doesn't allow a leading `+` on a number.
+Ex: Allow parsing `+123.45` in addition to `123.45`.
+- `allow_single_quote_strings`: if the parser will parse a string delimited by `'` instead of `"`. The JSON specification requires strings to be delimited by `"`.
+Ex: Allow parsing `'abc'` in addition to `"abc"`
+- `allow_number_to_start_with_dot`: if the parser will parse a leading `.` on a number. The JSON specification doesn't allow a leading `.` on a number, instead requiring a `0` before the `.`.
+Ex: Allow parsing `.25` in addition to `0.25`
+- `default_options`: create a `Parse_options` that holds the defaults.
+- `relaxed_options`: create a `Parse_options` that allows parsing all of the different options in `Parse_options`.
+
+### `json::parse`
+Parse the passed-in source into the JSON AST. Throws `json::Parse_error` on parse error.
+
+## `json/source.h`
+
+### `json::Source`
+type that holds the in-memory representation of a JSON source file.
+Members:
+- `file_name`: the name of the JSON source file.
+- `contents`: the contents of the JSON source file. Points to a buffer of size `contents_size`. Implemented as a `std::shared_ptr` so it's possible to point to a memory-mapped version of the source file for additional speed.
+- `contents_size`: the size of the memory buffer pointed to by `contents`.
+- `load_file`: loads the file indicated by the passed-in file name.
+- `load_stdin`: reads `stdin` until end-of-file, returning the source-code that was read.