| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 | "use strict";/** * Copyright (C) 2016-2019 Michael Kourlas * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * *   http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */Object.defineProperty(exports, "__esModule", { value: true });var error_1 = require("../error");var validate_1 = require("../validate");/** * Represents an element declaration in a document type definition. * * An element declaration is structured as follows, where `{text}` is the * text of the declaration: * * ```xml * <!ELEMENT {text}> * ``` */var XmlDtdElement = /** @class */ (function () {    function XmlDtdElement(parent, validation, options) {        this._validation = validation;        this._parent = parent;        this.charData = options.charData;    }    Object.defineProperty(XmlDtdElement.prototype, "charData", {        /**         * Gets the text of this element declaration.         */        get: function () {            return this._charData;        },        /**         * Sets the text of this element declaration.         */        set: function (charData) {            if (this._validation && !(0, validate_1.validateChar)(charData)) {                throw new Error((0, error_1.getContext)(this.up()) + ": element declaration"                    + (" \"" + charData + "\" should not contain characters")                    + " not allowed in XML");            }            this._charData = charData;        },        enumerable: false,        configurable: true    });    /**     * Returns an XML string representation of this element declaration.     */    XmlDtdElement.prototype.toString = function () {        return "<!ELEMENT " + this._charData + ">";    };    /**     * Returns the parent of this element declaration.     */    XmlDtdElement.prototype.up = function () {        return this._parent;    };    return XmlDtdElement;}());exports.default = XmlDtdElement;
 |