| /* |
| * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. |
| */ |
| /* |
| * Licensed to the Apache Software Foundation (ASF) under one or more |
| * contributor license agreements. See the NOTICE file distributed with |
| * this work for additional information regarding copyright ownership. |
| * The ASF licenses this file to You 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. |
| */ |
| |
| package com.sun.org.apache.xerces.internal.impl.validation; |
| |
| import java.util.Iterator; |
| |
| /** |
| * <p>An extension of ValidationState which can be configured to turn |
| * off checking for ID/IDREF errors and unparsed entity errors.</p> |
| * |
| * @xerces.internal |
| * |
| * @author Peter McCracken, IBM |
| * @LastModified: Oct 2017 |
| */ |
| public final class ConfigurableValidationState extends ValidationState { |
| |
| /** |
| * Whether to check for ID/IDREF errors |
| */ |
| private boolean fIdIdrefChecking; |
| |
| /** |
| * Whether to check for unparsed entity errors |
| */ |
| private boolean fUnparsedEntityChecking; |
| |
| /** |
| * Creates a new ConfigurableValidationState. |
| * By default, error checking for both ID/IDREFs |
| * and unparsed entities are turned on. |
| */ |
| public ConfigurableValidationState() { |
| super(); |
| fIdIdrefChecking = true; |
| fUnparsedEntityChecking = true; |
| } |
| |
| /** |
| * Turns checking for ID/IDREF errors on and off. |
| * @param setting true to turn on error checking, |
| * false to turn off error checking |
| */ |
| public void setIdIdrefChecking(boolean setting) { |
| fIdIdrefChecking = setting; |
| } |
| |
| /** |
| * Turns checking for unparsed entity errors on and off. |
| * @param setting true to turn on error checking, |
| * false to turn off error checking |
| */ |
| public void setUnparsedEntityChecking(boolean setting) { |
| fUnparsedEntityChecking = setting; |
| } |
| |
| /** |
| * Checks if all IDREFs have a corresponding ID. |
| * @return null, if ID/IDREF checking is turned off |
| * otherwise, returns the value of the super implementation |
| */ |
| public Iterator<String> checkIDRefID() { |
| return (fIdIdrefChecking) ? super.checkIDRefID() : null; |
| } |
| |
| /** |
| * Checks if an ID has already been declared. |
| * @return false, if ID/IDREF checking is turned off |
| * otherwise, returns the value of the super implementation |
| */ |
| public boolean isIdDeclared(String name) { |
| return (fIdIdrefChecking) ? super.isIdDeclared(name) : false; |
| } |
| |
| /** |
| * Checks if an entity is declared. |
| * @return true, if unparsed entity checking is turned off |
| * otherwise, returns the value of the super implementation |
| */ |
| public boolean isEntityDeclared(String name) { |
| return (fUnparsedEntityChecking) ? super.isEntityDeclared(name) : true; |
| } |
| |
| /** |
| * Checks if an entity is unparsed. |
| * @return true, if unparsed entity checking is turned off |
| * otherwise, returns the value of the super implementation |
| */ |
| public boolean isEntityUnparsed(String name) { |
| return (fUnparsedEntityChecking) ? super.isEntityUnparsed(name) : true; |
| } |
| |
| /** |
| * Adds the ID, if ID/IDREF checking is enabled. |
| * @param name the ID to add |
| */ |
| public void addId(String name) { |
| if (fIdIdrefChecking) { |
| super.addId(name); |
| } |
| } |
| |
| /** |
| * Adds the IDREF, if ID/IDREF checking is enabled. |
| * @param name the IDREF to add |
| */ |
| public void addIdRef(String name) { |
| if (fIdIdrefChecking) { |
| super.addIdRef(name); |
| } |
| } |
| } |