"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 entity declaration in a document type definition. * * An entity declaration is structured as follows, where `{text}` is the * text of the declaration: * * ```xml * * ``` */ var XmlDtdEntity = /** @class */ (function () { function XmlDtdEntity(parent, validation, options) { this._validation = validation; this._parent = parent; this.charData = options.charData; } Object.defineProperty(XmlDtdEntity.prototype, "charData", { /** * Gets the text of this entity declaration. */ get: function () { return this._charData; }, /** * Sets the text of this entity declaration. */ set: function (charData) { if (this._validation && !validate_1.validateChar(charData)) { throw new Error(error_1.getContext(this.up()) + ": entity declaration" + (" \"" + charData + "\" should not contain characters") + " not allowed in XML"); } this._charData = charData; }, enumerable: true, configurable: true }); /** * Returns an XML string representation of this entity declaration. */ XmlDtdEntity.prototype.toString = function () { return ""; }; /** * Returns the parent of this entity declaration. */ XmlDtdEntity.prototype.up = function () { return this._parent; }; return XmlDtdEntity; }()); exports.default = XmlDtdEntity;