Skip to main content

An extension for JSON to support file including

Project description

json-include is an extended way for JSON to support file inclusion, it has two parts:

  1. A syntax definition called include syntax.

  2. A Python implementation to parse and build JSON file that contains include syntax.

Syntax

json-include supports an extended syntax called include syntax in JSON, formatted as:

{
    "...": "<json file name>"
}

The include syntax means that this object (the whole {"...": "<json file name>"}) in JSON is a reference to the JSON file named in <json file name> notation, and should be included into its place.

The included JSON should always be an object (dict) rather than an array (list), to prevent implicit meaning and make sure we can get a clear view of the structure without looking into the included JSON files.

In a normal JSON when we want to include another JSON on an attribute, it should be written as follows:

{
    "username": "alice",
    "profile": {
        "...": "<profile_model.json>"
    }
}

In this JSON a profile_model.json is included to present profile attribute, if the content of profile_model.json is like:

{
    "age": 18,
    "gender": "female"
}

then what we mean by the include syntax is that, when this JSON is being used as a normal JSON, it should be seen as:

{
    "username": "alice",
    "profile": {
        "age": 18,
        "gender": "female"
    }
}

To ture JSON with include syntax into a normal JSON, a build process is needed, that’s what the implementation does.

Python Implementation

Implementation could be of any language as long as it can understand the include syntax and output as expected, this repo contains a Python implementation for use.

Installation

pip install json-include

Usage

By installation a command called json-include will be registerd as an entry point, use it as follows:

usage: json-include [-h] DIR FILE

Command line tool to build JSON file by include syntax.

positional arguments:
  DIR         The directory path of source json files
  FILE        The name of the source json file

optional arguments:
  -h, --help  show this help message and exit

For example:

json-include test/source_json/ c.json

The parsed and built result of c.json will be printed.

Further usage of json_include package is documented in its source code, and test/ can also give you better understandings of how it works.

TODOs

  • [ ] Prevent circluar inclusion

  • [ ] Test circluar inclusion

  • [ ] Test invalid syntax

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

json-include-0.1.4.tar.gz (3.8 kB view details)

Uploaded Source

Built Distribution

json_include-0.1.4-py2-none-any.whl (5.9 kB view details)

Uploaded Python 2

File details

Details for the file json-include-0.1.4.tar.gz.

File metadata

File hashes

Hashes for json-include-0.1.4.tar.gz
Algorithm Hash digest
SHA256 e1c3879f8d27d4dd25003dd4fea392f640ad21be1f837ef8a243842e36588632
MD5 66d71d5bfbb8c5937d734bafb0ce2f88
BLAKE2b-256 8a29d92c9d1974023986b7369829acf734c953c9e8a284ec533450c58dcbf3aa

See more details on using hashes here.

File details

Details for the file json_include-0.1.4-py2-none-any.whl.

File metadata

File hashes

Hashes for json_include-0.1.4-py2-none-any.whl
Algorithm Hash digest
SHA256 8c0eb7aa1aabde2807a08ee2cccfe8c11d90e9fab44e1a12c83c920291468876
MD5 e57d92b3464969ffceda6ec857d9d624
BLAKE2b-256 c8b0a0108d3babb701cdf60a29d9c3114514c5ffe9a56820ee91b18d076c62eb

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page