blob: 0ed7f20e87b10802ecf7a346a8fbf0b46b794f54 [file] [log] [blame]
/* Copyright (c) 2012-2015 Tresys Technology, LLC. All rights reserved.
*
* Developed by: Tresys Technology, LLC
* http://www.tresys.com
*
* Permission is hereby granted, free of charge, to any person obtaining a copy of
* this software and associated documentation files (the "Software"), to deal with
* the Software without restriction, including without limitation the rights to
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
* of the Software, and to permit persons to whom the Software is furnished to do
* so, subject to the following conditions:
*
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimers.
*
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimers in the
* documentation and/or other materials provided with the distribution.
*
* 3. Neither the names of Tresys Technology, nor the names of its contributors
* may be used to endorse or promote products derived from this Software
* without specific prior written permission.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* CONTRIBUTORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS WITH THE
* SOFTWARE.
*/
package edu.illinois.ncsa.daffodil.dsom
import edu.illinois.ncsa.daffodil.grammar._
import edu.illinois.ncsa.daffodil.processors._
import edu.illinois.ncsa.daffodil.schema.annotation.props.gen._
import edu.illinois.ncsa.daffodil.grammar.GrammarMixin
trait InitiatedTerminatedMixin
extends GrammarMixin
with AnnotatedMixin
with DelimitedRuntimeValuedPropertiesMixin { self: Term =>
private lazy val parentSaysInitiatedContent = {
val parentSays = self.immediatelyEnclosingModelGroup match {
case Some(s) if (s.initiatedContent == YesNo.Yes) => true
case _ => false
}
parentSays
}
final lazy val hasInitiator = {
val hasOne = initiatorExpr.isKnownNonEmpty
if (parentSaysInitiatedContent)
schemaDefinitionUnless(hasOne, "Enclosing group has initiatedContent='yes', but initiator is not defined.")
hasOne
}
final lazy val hasTerminator = {
terminatorExpr.isKnownNonEmpty
}
lazy val initiatorDiscriminator = prod("initiatorDiscriminator", parentSaysInitiatedContent) { InitiatedContent(this) }
lazy val initiatorRegion = prod("initiatorRegion", hasInitiator) { initiatorItself ~ initiatorDiscriminator }
lazy val initiatorItself = delimMTA ~ Initiator(this)
lazy val terminatorRegion = prod("terminatorRegion", hasTerminator) { delimMTA ~ Terminator(this) }
/**
* True if this term has initiator, terminator, or separator that are either statically
* present, or there is an expression. (Such expressions are not allowed to evaluate to "" - you
* can't turn off a delimiter by providing "" at runtime. Minimum length is 1 for these at runtime.
* <p>
* Override in Sequence to also check for separator.
*/
lazy val hasDelimiters = hasInitiator || hasTerminator
}