From 0dc535b7ddc972eed9a615cf06f4c1e5466956f1 Mon Sep 17 00:00:00 2001 From: jjrv Date: Sat, 19 Dec 2015 23:17:28 +0200 Subject: [PATCH] Add documentation about XSD parser internals. --- README.md | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/README.md b/README.md index 83edcb5..2e63f49 100644 --- a/README.md +++ b/README.md @@ -9,6 +9,17 @@ Downloads schema files and keeps a local cache in the file system. Handles arbitrarily large files using streaming. +Parsing XSD schema files +------------------------ + +Schema handling is implemented in the `xsd` directory. Supported syntax elements are defined in its `types` subdirectory. Each element in the xsd namespace inherits from `types.Base` which has static and dynamic members that affect parser initialization. The `Base` class and its derived classes shouldn't have manually defined constructors, because the parser will instantiate objects to inspect the dynamic properties. Instead, an `init` function is called on constructed objects when creating them during actual parsing. + +The static members are mirrored as dynamic members of `BaseClass`. Any constructor of a class derived from `Base` can then be used as if it was a `BaseClass` instance. + +The static `mayContain` member function of syntax element types (classes derived from `types.base`) returns a list of other element types (defined as `BaseClass` instances) that it supports as direct children. The parser uses these to create a kind of state machine. + +Syntax elements may also have attributes. They should be initialized to `null` in the class definition (the TypeScript compiler will automatically generate a constructor to initialize them). The parser will construct an instance of each class it finds, and examine its automatically constructed dynamic members. During parsing, they will then be automatically initialized to attributes found in the schema being parsed. Unknown attributes will be ignored. + License =======