summaryrefslogtreecommitdiffstats
path: root/tcllib/modules/pt/pt_peg_from_json.tcl
blob: 0d99d21e70c6a2a39fae1d3450fad3accd42af94 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
# peg_from_json.tcl --
#
#	Conversion to PEG from JSON (Java Script Object Notation).
#
# Copyright (c) 2009 Andreas Kupries <andreas_kupries@sourceforge.net>
#
# See the file "license.terms" for information on usage and redistribution
# of this file, and for a DISCLAIMER OF ALL WARRANTIES.
# 
# RCS: @(#) $Id: pt_peg_from_json.tcl,v 1.1 2010/03/26 05:07:24 andreas_kupries Exp $

# This package takes text in JSON format (Java Script data transfer
# format) and produces the canonical serialization of a parsing
# expression grammar.

# ### ### ### ######### ######### #########
## Requisites

package require Tcl 8.5
package require pt::peg ; # Verification that the input is proper.
package require json

# ### ### ### ######### ######### #########
##

namespace eval ::pt::peg::from::json {
    namespace export convert
    namespace ensemble create
}

# ### ### ### ######### ######### #########
## API.

proc ::pt::peg::from::json::convert {text} {
    # Note: We cannot fail here on duplicate keys in the input, as we
    # do for Tcl-based canonical PEG serializations, because our
    # underlying JSON parser automatically merges them, by taking only
    # the last found definition. I.e. of two or more definitions for
    # some key X the last overwrites all previous occurences.

    return [pt::peg canonicalize [json::json2dict $text]]
}

# ### ### ### ######### ######### #########
## Ready

package provide pt::peg::from::json 1
return