all files / dirty-json/ dirty-json.js

100% Statements 12/12
100% Branches 2/2
100% Functions 1/1
100% Lines 12/12
4 statements, 1 branch Ignored     
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                                      67×                            
// Copyright 2015, 2014 Ryan Marcus
// This file is part of dirty-json.
// 
// dirty-json is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
// 
// dirty-json is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU Affero General Public License for more details.
// 
// You should have received a copy of the GNU Affero General Public License
// along with dirty-json.  If not, see <http://www.gnu.org/licenses/>.
 
"use strict";
 
let parser = require('./parser');
 
module.exports.parse = parse;
function parse(text, fallback) {
    return parser.parse(text).catch(e => {
        // our parser threw an error! see if the JSON was valid...
        /* istanbul ignore next */
        Iif (fallback === false) {
            console.log("throwing!!!");
            throw e;
        }
        
        try {
            let json = JSON.parse(text);
            // if we didn't throw, it was valid JSON!
            /* istanbul ignore next */
            console.warn("dirty-json got valid JSON that failed with the custom parser. We're returning the valid JSON, but please file a bug report here: https://github.com/RyanMarcus/dirty-json/issues  -- the JSON that caused the failure was: " + text);
 
            /* istanbul ignore next */
            return json;
        } catch (json_error) {
            throw e;
        }
    });
}