"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 * * ``` */ 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 ""; }; /** * Returns the parent of this element declaration. */ XmlDtdElement.prototype.up = function () { return this._parent; }; return XmlDtdElement; }()); exports.default = XmlDtdElement;