org.apache.xerces.parsers
Class CachingParserPool.SynchronizedGrammarPool

java.lang.Object
  extended by org.apache.xerces.parsers.CachingParserPool.SynchronizedGrammarPool
All Implemented Interfaces:
XMLGrammarPool
Enclosing class:
CachingParserPool

public static final class CachingParserPool.SynchronizedGrammarPool
extends java.lang.Object
implements XMLGrammarPool

Synchronized grammar pool.

Author:
Andy Clark, IBM

Constructor Summary
CachingParserPool.SynchronizedGrammarPool(XMLGrammarPool grammarPool)
          Constructs a synchronized grammar pool.
 
Method Summary
 void cacheGrammars(java.lang.String grammarType, Grammar[] grammars)
          return the final set of grammars that the validator ended up with.
 void clear()
          clear the grammar pool
 void lockPool()
          lock the grammar pool
 Grammar retrieveGrammar(XMLGrammarDescription gDesc)
           This method requests that the application retrieve a grammar corresponding to the given GrammarIdentifier from its cache.
 Grammar[] retrieveInitialGrammarSet(java.lang.String grammarType)
           retrieve the initial known set of grammars.
 void unlockPool()
          unlock the grammar pool
 
Methods inherited from class java.lang.Object
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

CachingParserPool.SynchronizedGrammarPool

public CachingParserPool.SynchronizedGrammarPool(XMLGrammarPool grammarPool)
Constructs a synchronized grammar pool.

Method Detail

retrieveInitialGrammarSet

public Grammar[] retrieveInitialGrammarSet(java.lang.String grammarType)
Description copied from interface: XMLGrammarPool

retrieve the initial known set of grammars. this method is called by a validator before the validation starts. the application can provide an initial set of grammars available to the current validation attempt.

Specified by:
retrieveInitialGrammarSet in interface XMLGrammarPool
Parameters:
grammarType - the type of the grammar, from the org.apache.xerces.xni.grammars.Grammar interface.
Returns:
the set of grammars the validator may put in its "bucket"

retrieveGrammar

public Grammar retrieveGrammar(XMLGrammarDescription gDesc)
Description copied from interface: XMLGrammarPool

This method requests that the application retrieve a grammar corresponding to the given GrammarIdentifier from its cache. If it cannot do so it must return null; the parser will then call the EntityResolver. An application must not call its EntityResolver itself from this method; this may result in infinite recursions.

Specified by:
retrieveGrammar in interface XMLGrammarPool
Parameters:
gDesc - The description of the Grammar being requested.
Returns:
the Grammar corresponding to this description or null if no such Grammar is known.

cacheGrammars

public void cacheGrammars(java.lang.String grammarType,
                          Grammar[] grammars)
Description copied from interface: XMLGrammarPool

return the final set of grammars that the validator ended up with. This method is called after the validation finishes. The application may then choose to cache some of the returned grammars.

Specified by:
cacheGrammars in interface XMLGrammarPool
Parameters:
grammarType - the type of the grammars being returned;
grammars - an array containing the set of grammars being returned; order is not significant.

lockPool

public void lockPool()
lock the grammar pool

Specified by:
lockPool in interface XMLGrammarPool

clear

public void clear()
clear the grammar pool

Specified by:
clear in interface XMLGrammarPool

unlockPool

public void unlockPool()
unlock the grammar pool

Specified by:
unlockPool in interface XMLGrammarPool