dc6715320d
2010-06-03 Andrew John Hughes <ahughes@redhat.com> * examples/gnu/classpath/examples/CORBA/NamingService/Demo.java, * examples/gnu/classpath/examples/CORBA/SimpleCommunication/Demo.java, * examples/gnu/classpath/examples/CORBA/SimpleCommunication/communication/StructureToPass.java, * examples/gnu/classpath/examples/CORBA/SimpleCommunication/communication/StructureToReturn.java, * examples/gnu/classpath/examples/CORBA/SimpleCommunication/communication/TreeNode.java, * examples/gnu/classpath/examples/CORBA/SimpleCommunication/communication/WeThrowThisException.java, * examples/gnu/classpath/examples/CORBA/SimpleCommunication/communication/WeThrowThisExceptionHelper.java, * examples/gnu/classpath/examples/CORBA/SimpleCommunication/communication/_DemoTesterImplBase.java, * examples/gnu/classpath/examples/CORBA/SimpleCommunication/communication/_DemoTesterStub.java, * examples/gnu/classpath/examples/CORBA/swing/x5/CanvasWorld.java, * examples/gnu/classpath/examples/CORBA/swing/x5/ChatConstants.java, * examples/gnu/classpath/examples/CORBA/swing/x5/ClientFrame.java, * examples/gnu/classpath/examples/CORBA/swing/x5/Demo.java, * examples/gnu/classpath/examples/CORBA/swing/x5/GameManager.java, * examples/gnu/classpath/examples/CORBA/swing/x5/GameManagerImpl.java, * examples/gnu/classpath/examples/CORBA/swing/x5/IorReader.java, * examples/gnu/classpath/examples/CORBA/swing/x5/OrbStarter.java, * examples/gnu/classpath/examples/CORBA/swing/x5/Player.java, * examples/gnu/classpath/examples/CORBA/swing/x5/PlayerImpl.java, * examples/gnu/classpath/examples/CORBA/swing/x5/PlayingDesk.java, * examples/gnu/classpath/examples/CORBA/swing/x5/State.java, * examples/gnu/classpath/examples/CORBA/swing/x5/X5Server.java, * examples/gnu/classpath/examples/CORBA/swing/x5/_GameManagerImpl_Tie.java, * examples/gnu/classpath/examples/CORBA/swing/x5/_GameManager_Stub.java, * examples/gnu/classpath/examples/CORBA/swing/x5/_PlayerImpl_Tie.java, * examples/gnu/classpath/examples/CORBA/swing/x5/_Player_Stub.java, * examples/gnu/classpath/examples/awt/AicasGraphicsBenchmark.java, * examples/gnu/classpath/examples/awt/Demo.java, * examples/gnu/classpath/examples/awt/HintingDemo.java, * examples/gnu/classpath/examples/datatransfer/Demo.java, * examples/gnu/classpath/examples/html/Demo.java, * examples/gnu/classpath/examples/java2d/J2dBenchmark.java, * examples/gnu/classpath/examples/java2d/J2dBenchmarkGUI.java, * examples/gnu/classpath/examples/java2d/JNIOverhead.java, * examples/gnu/classpath/examples/jawt/DemoJAWT.java, * examples/gnu/classpath/examples/management/TestClassLoading.java, * examples/gnu/classpath/examples/management/TestCompilation.java, * examples/gnu/classpath/examples/management/TestGarbageCollector.java, * examples/gnu/classpath/examples/management/TestMemory.java, * examples/gnu/classpath/examples/management/TestMemoryManager.java, * examples/gnu/classpath/examples/management/TestMemoryPool.java, * examples/gnu/classpath/examples/management/TestThread.java, * examples/gnu/classpath/examples/midi/Demo.java, * examples/gnu/classpath/examples/print/Demo.java, * examples/gnu/classpath/examples/sound/AudioPlayerSample.java, * examples/gnu/classpath/examples/swing/BrowserEditorKit.java, * examples/gnu/classpath/examples/swing/ButtonDemo.java, * examples/gnu/classpath/examples/swing/ComboBoxDemo.java, * examples/gnu/classpath/examples/swing/Demo.java, * examples/gnu/classpath/examples/swing/DemoFactory.java, * examples/gnu/classpath/examples/swing/DocumentFilterDemo.java, * examples/gnu/classpath/examples/swing/FileChooserDemo.java, * examples/gnu/classpath/examples/swing/HtmlDemo.java, * examples/gnu/classpath/examples/swing/ListDemo.java, * examples/gnu/classpath/examples/swing/MetalThemeEditor.java, * examples/gnu/classpath/examples/swing/NavigationFilterDemo.java, * examples/gnu/classpath/examples/swing/ScrollBarDemo.java, * examples/gnu/classpath/examples/swing/SliderDemo.java, * examples/gnu/classpath/examples/swing/SpinnerDemo.java, * examples/gnu/classpath/examples/swing/TabbedPaneDemo.java, * examples/gnu/classpath/examples/swing/TableDemo.java, * examples/gnu/classpath/examples/swing/TextAreaDemo.java, * examples/gnu/classpath/examples/swing/TextFieldDemo.java, * examples/gnu/classpath/examples/swing/TreeDemo.java, * external/jsr166/java/util/ArrayDeque.java, * external/jsr166/java/util/concurrent/ArrayBlockingQueue.java, * external/jsr166/java/util/concurrent/ConcurrentHashMap.java, * external/jsr166/java/util/concurrent/ConcurrentSkipListMap.java, * external/jsr166/java/util/concurrent/ConcurrentSkipListSet.java, * external/jsr166/java/util/concurrent/CopyOnWriteArraySet.java, * external/jsr166/java/util/concurrent/CyclicBarrier.java, * external/jsr166/java/util/concurrent/DelayQueue.java, * external/jsr166/java/util/concurrent/Executors.java, * external/jsr166/java/util/concurrent/FutureTask.java, * external/jsr166/java/util/concurrent/LinkedBlockingDeque.java, * external/jsr166/java/util/concurrent/LinkedBlockingQueue.java, * external/jsr166/java/util/concurrent/PriorityBlockingQueue.java, * external/jsr166/java/util/concurrent/ScheduledExecutorService.java, * external/jsr166/java/util/concurrent/ScheduledThreadPoolExecutor.java, * external/jsr166/java/util/concurrent/Semaphore.java, * external/jsr166/java/util/concurrent/SynchronousQueue.java, * external/jsr166/java/util/concurrent/ThreadPoolExecutor.java, * external/jsr166/java/util/concurrent/atomic/AtomicInteger.java, * external/jsr166/java/util/concurrent/atomic/AtomicIntegerFieldUpdater.java, * external/jsr166/java/util/concurrent/atomic/AtomicLong.java, * external/jsr166/java/util/concurrent/atomic/AtomicLongFieldUpdater.java, * external/jsr166/java/util/concurrent/atomic/AtomicReferenceFieldUpdater.java, * external/jsr166/java/util/concurrent/locks/AbstractQueuedLongSynchronizer.java, * external/jsr166/java/util/concurrent/locks/AbstractQueuedSynchronizer.java, * external/jsr166/java/util/concurrent/locks/ReentrantReadWriteLock.java, * external/relaxngDatatype/org/relaxng/datatype/Datatype.java, * external/relaxngDatatype/org/relaxng/datatype/DatatypeBuilder.java, * external/relaxngDatatype/org/relaxng/datatype/DatatypeException.java, * external/relaxngDatatype/org/relaxng/datatype/DatatypeLibrary.java, * external/relaxngDatatype/org/relaxng/datatype/DatatypeLibraryFactory.java, * external/relaxngDatatype/org/relaxng/datatype/DatatypeStreamingValidator.java, * external/relaxngDatatype/org/relaxng/datatype/ValidationContext.java, * external/relaxngDatatype/org/relaxng/datatype/helpers/DatatypeLibraryLoader.java, * external/relaxngDatatype/org/relaxng/datatype/helpers/ParameterlessDatatypeBuilder.java, * external/relaxngDatatype/org/relaxng/datatype/helpers/StreamingValidatorImpl.java, * external/sax/org/xml/sax/AttributeList.java, * external/sax/org/xml/sax/Attributes.java, * external/sax/org/xml/sax/ContentHandler.java, * external/sax/org/xml/sax/DTDHandler.java, * external/sax/org/xml/sax/DocumentHandler.java, * external/sax/org/xml/sax/EntityResolver.java, * external/sax/org/xml/sax/ErrorHandler.java, * external/sax/org/xml/sax/HandlerBase.java, * external/sax/org/xml/sax/InputSource.java, * external/sax/org/xml/sax/Locator.java, * external/sax/org/xml/sax/Parser.java, * external/sax/org/xml/sax/SAXException.java, * external/sax/org/xml/sax/SAXNotRecognizedException.java, * external/sax/org/xml/sax/SAXNotSupportedException.java, * external/sax/org/xml/sax/SAXParseException.java, * external/sax/org/xml/sax/XMLReader.java, * external/sax/org/xml/sax/ext/Attributes2.java, * external/sax/org/xml/sax/ext/Attributes2Impl.java, * external/sax/org/xml/sax/ext/DeclHandler.java, * external/sax/org/xml/sax/ext/DefaultHandler2.java, * external/sax/org/xml/sax/ext/EntityResolver2.java, * external/sax/org/xml/sax/ext/LexicalHandler.java, * external/sax/org/xml/sax/ext/Locator2.java, * external/sax/org/xml/sax/ext/Locator2Impl.java, * external/sax/org/xml/sax/helpers/AttributeListImpl.java, * external/sax/org/xml/sax/helpers/AttributesImpl.java, * external/sax/org/xml/sax/helpers/DefaultHandler.java, * external/sax/org/xml/sax/helpers/LocatorImpl.java, * external/sax/org/xml/sax/helpers/NamespaceSupport.java, * external/sax/org/xml/sax/helpers/NewInstance.java, * external/sax/org/xml/sax/helpers/ParserAdapter.java, * external/sax/org/xml/sax/helpers/ParserFactory.java, * external/sax/org/xml/sax/helpers/XMLFilterImpl.java, * external/sax/org/xml/sax/helpers/XMLReaderAdapter.java, * external/sax/org/xml/sax/helpers/XMLReaderFactory.java, * external/w3c_dom/org/w3c/dom/Attr.java, * external/w3c_dom/org/w3c/dom/CDATASection.java, * external/w3c_dom/org/w3c/dom/CharacterData.java, * external/w3c_dom/org/w3c/dom/Comment.java, * external/w3c_dom/org/w3c/dom/DOMConfiguration.java, * external/w3c_dom/org/w3c/dom/DOMError.java, * external/w3c_dom/org/w3c/dom/DOMErrorHandler.java, * external/w3c_dom/org/w3c/dom/DOMException.java, * external/w3c_dom/org/w3c/dom/DOMImplementation.java, * external/w3c_dom/org/w3c/dom/DOMImplementationList.java, * external/w3c_dom/org/w3c/dom/DOMImplementationSource.java, * external/w3c_dom/org/w3c/dom/DOMLocator.java, * external/w3c_dom/org/w3c/dom/DOMStringList.java, * external/w3c_dom/org/w3c/dom/Document.java, * external/w3c_dom/org/w3c/dom/DocumentFragment.java, * external/w3c_dom/org/w3c/dom/DocumentType.java, * external/w3c_dom/org/w3c/dom/Element.java, * external/w3c_dom/org/w3c/dom/Entity.java, * external/w3c_dom/org/w3c/dom/EntityReference.java, * external/w3c_dom/org/w3c/dom/NameList.java, * external/w3c_dom/org/w3c/dom/NamedNodeMap.java, * external/w3c_dom/org/w3c/dom/Node.java, * external/w3c_dom/org/w3c/dom/NodeList.java, * external/w3c_dom/org/w3c/dom/Notation.java, * external/w3c_dom/org/w3c/dom/ProcessingInstruction.java, * external/w3c_dom/org/w3c/dom/Text.java, * external/w3c_dom/org/w3c/dom/TypeInfo.java, * external/w3c_dom/org/w3c/dom/UserDataHandler.java, * external/w3c_dom/org/w3c/dom/bootstrap/DOMImplementationRegistry.java, * external/w3c_dom/org/w3c/dom/css/CSS2Properties.java, * external/w3c_dom/org/w3c/dom/css/CSSCharsetRule.java, * external/w3c_dom/org/w3c/dom/css/CSSFontFaceRule.java, * external/w3c_dom/org/w3c/dom/css/CSSImportRule.java, * external/w3c_dom/org/w3c/dom/css/CSSMediaRule.java, * external/w3c_dom/org/w3c/dom/css/CSSPageRule.java, * external/w3c_dom/org/w3c/dom/css/CSSPrimitiveValue.java, * external/w3c_dom/org/w3c/dom/css/CSSRule.java, * external/w3c_dom/org/w3c/dom/css/CSSRuleList.java, * external/w3c_dom/org/w3c/dom/css/CSSStyleDeclaration.java, * external/w3c_dom/org/w3c/dom/css/CSSStyleRule.java, * external/w3c_dom/org/w3c/dom/css/CSSStyleSheet.java, * external/w3c_dom/org/w3c/dom/css/CSSUnknownRule.java, * external/w3c_dom/org/w3c/dom/css/CSSValue.java, * external/w3c_dom/org/w3c/dom/css/CSSValueList.java, * external/w3c_dom/org/w3c/dom/css/Counter.java, * external/w3c_dom/org/w3c/dom/css/DOMImplementationCSS.java, * external/w3c_dom/org/w3c/dom/css/DocumentCSS.java, * external/w3c_dom/org/w3c/dom/css/ElementCSSInlineStyle.java, * external/w3c_dom/org/w3c/dom/css/RGBColor.java, * external/w3c_dom/org/w3c/dom/css/Rect.java, * external/w3c_dom/org/w3c/dom/css/ViewCSS.java, * external/w3c_dom/org/w3c/dom/events/DocumentEvent.java, * external/w3c_dom/org/w3c/dom/events/Event.java, * external/w3c_dom/org/w3c/dom/events/EventException.java, * external/w3c_dom/org/w3c/dom/events/EventListener.java, * external/w3c_dom/org/w3c/dom/events/EventTarget.java, * external/w3c_dom/org/w3c/dom/events/MouseEvent.java, * external/w3c_dom/org/w3c/dom/events/MutationEvent.java, * external/w3c_dom/org/w3c/dom/events/UIEvent.java, * external/w3c_dom/org/w3c/dom/html2/HTMLAnchorElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLAppletElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLAreaElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLBRElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLBaseElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLBaseFontElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLBodyElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLButtonElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLCollection.java, * external/w3c_dom/org/w3c/dom/html2/HTMLDListElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLDirectoryElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLDivElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLDocument.java, * external/w3c_dom/org/w3c/dom/html2/HTMLElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLFieldSetElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLFontElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLFormElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLFrameElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLFrameSetElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLHRElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLHeadElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLHeadingElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLHtmlElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLIFrameElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLImageElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLInputElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLIsIndexElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLLIElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLLabelElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLLegendElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLLinkElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLMapElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLMenuElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLMetaElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLModElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLOListElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLObjectElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLOptGroupElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLOptionElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLOptionsCollection.java, * external/w3c_dom/org/w3c/dom/html2/HTMLParagraphElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLParamElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLPreElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLQuoteElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLScriptElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLSelectElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLStyleElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLTableCaptionElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLTableCellElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLTableColElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLTableElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLTableRowElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLTableSectionElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLTextAreaElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLTitleElement.java, * external/w3c_dom/org/w3c/dom/html2/HTMLUListElement.java, * external/w3c_dom/org/w3c/dom/ls/DOMImplementationLS.java, * external/w3c_dom/org/w3c/dom/ls/LSException.java, * external/w3c_dom/org/w3c/dom/ls/LSInput.java, * external/w3c_dom/org/w3c/dom/ls/LSLoadEvent.java, * external/w3c_dom/org/w3c/dom/ls/LSOutput.java, * external/w3c_dom/org/w3c/dom/ls/LSParser.java, * external/w3c_dom/org/w3c/dom/ls/LSParserFilter.java, * external/w3c_dom/org/w3c/dom/ls/LSProgressEvent.java, * external/w3c_dom/org/w3c/dom/ls/LSResourceResolver.java, * external/w3c_dom/org/w3c/dom/ls/LSSerializer.java, * external/w3c_dom/org/w3c/dom/ls/LSSerializerFilter.java, * external/w3c_dom/org/w3c/dom/ranges/DocumentRange.java, * external/w3c_dom/org/w3c/dom/ranges/Range.java, * external/w3c_dom/org/w3c/dom/ranges/RangeException.java, * external/w3c_dom/org/w3c/dom/stylesheets/DocumentStyle.java, * external/w3c_dom/org/w3c/dom/stylesheets/LinkStyle.java, * external/w3c_dom/org/w3c/dom/stylesheets/MediaList.java, * external/w3c_dom/org/w3c/dom/stylesheets/StyleSheet.java, * external/w3c_dom/org/w3c/dom/stylesheets/StyleSheetList.java, * external/w3c_dom/org/w3c/dom/traversal/DocumentTraversal.java, * external/w3c_dom/org/w3c/dom/traversal/NodeFilter.java, * external/w3c_dom/org/w3c/dom/traversal/NodeIterator.java, * external/w3c_dom/org/w3c/dom/traversal/TreeWalker.java, * external/w3c_dom/org/w3c/dom/views/AbstractView.java, * external/w3c_dom/org/w3c/dom/views/DocumentView.java, * external/w3c_dom/org/w3c/dom/xpath/XPathEvaluator.java, * external/w3c_dom/org/w3c/dom/xpath/XPathException.java, * external/w3c_dom/org/w3c/dom/xpath/XPathExpression.java, * external/w3c_dom/org/w3c/dom/xpath/XPathNSResolver.java, * external/w3c_dom/org/w3c/dom/xpath/XPathNamespace.java, * external/w3c_dom/org/w3c/dom/xpath/XPathResult.java, * gnu/CORBA/BigDecimalHelper.java, * gnu/CORBA/CDR/AbstractCdrInput.java, * gnu/CORBA/CDR/AbstractCdrOutput.java, * gnu/CORBA/CDR/AbstractDataInput.java, * gnu/CORBA/CDR/AbstractDataOutput.java, * gnu/CORBA/CDR/AligningInput.java, * gnu/CORBA/CDR/AligningOutput.java, * gnu/CORBA/CDR/ArrayValueHelper.java, * gnu/CORBA/CDR/BigEndianInputStream.java, * gnu/CORBA/CDR/BigEndianOutputStream.java, * gnu/CORBA/CDR/BufferedCdrOutput.java, * gnu/CORBA/CDR/BufferredCdrInput.java, * gnu/CORBA/CDR/HeadlessInput.java, * gnu/CORBA/CDR/IDLTypeHelper.java, * gnu/CORBA/CDR/LittleEndianOutputStream.java, * gnu/CORBA/CDR/UnknownExceptionCtxHandler.java, * gnu/CORBA/CDR/VMVio.java, * gnu/CORBA/CDR/Vio.java, * gnu/CORBA/CDR/gnuRuntime.java, * gnu/CORBA/CDR/gnuValueStream.java, * gnu/CORBA/CdrEncapsCodecImpl.java, * gnu/CORBA/CollocatedOrbs.java, * gnu/CORBA/Connected_objects.java, * gnu/CORBA/DefaultSocketFactory.java, * gnu/CORBA/DuplicateNameHolder.java, * gnu/CORBA/DynAn/AbstractAny.java, * gnu/CORBA/DynAn/DivideableAny.java, * gnu/CORBA/DynAn/NameValuePairHolder.java, * gnu/CORBA/DynAn/RecordAny.java, * gnu/CORBA/DynAn/ValueChangeListener.java, * gnu/CORBA/DynAn/gnuDynAny.java, * gnu/CORBA/DynAn/gnuDynAnyFactory.java, * gnu/CORBA/DynAn/gnuDynArray.java, * gnu/CORBA/DynAn/gnuDynEnum.java, * gnu/CORBA/DynAn/gnuDynFixed.java, * gnu/CORBA/DynAn/gnuDynSequence.java, * gnu/CORBA/DynAn/gnuDynUnion.java, * gnu/CORBA/DynAn/gnuDynValue.java, * gnu/CORBA/DynAn/gnuDynValueBox.java, * gnu/CORBA/DynAnySeqHolder.java, * gnu/CORBA/EmptyExceptionHolder.java, * gnu/CORBA/ForwardRequestHelper.java, * gnu/CORBA/GIOP/CharSets_OSF.java, * gnu/CORBA/GIOP/CloseMessage.java, * gnu/CORBA/GIOP/ErrorMessage.java, * gnu/CORBA/GIOP/MessageHeader.java, * gnu/CORBA/GIOP/ServiceContext.java, * gnu/CORBA/GIOP/v1_2/RequestHeader.java, * gnu/CORBA/GeneralHolder.java, * gnu/CORBA/IOR.java, * gnu/CORBA/Interceptor/ClientRequestInterceptors.java, * gnu/CORBA/Interceptor/ForwardRequestHolder.java, * gnu/CORBA/Interceptor/IORInterceptors.java, * gnu/CORBA/Interceptor/Registrator.java, * gnu/CORBA/Interceptor/ServerRequestInterceptors.java, * gnu/CORBA/Interceptor/gnuClientRequestInfo.java, * gnu/CORBA/Interceptor/gnuIcCurrent.java, * gnu/CORBA/Interceptor/gnuIorInfo.java, * gnu/CORBA/Interceptor/gnuServerRequestInfo.java, * gnu/CORBA/IorDelegate.java, * gnu/CORBA/IorObject.java, * gnu/CORBA/Minor.java, * gnu/CORBA/NameDynAnyPairHolder.java, * gnu/CORBA/NameDynAnyPairSeqHolder.java, * gnu/CORBA/NameValuePairHolder.java, * gnu/CORBA/NameValuePairSeqHolder.java, * gnu/CORBA/NamingService/NameParser.java, * gnu/CORBA/NamingService/NamingMap.java, * gnu/CORBA/NamingService/NamingServiceTransient.java, * gnu/CORBA/NamingService/TransientContext.java, * gnu/CORBA/ObjectCreator.java, * gnu/CORBA/OrbFocused.java, * gnu/CORBA/OrbFunctional.java, * gnu/CORBA/OrbRestricted.java, * gnu/CORBA/Poa/AOM.java, * gnu/CORBA/Poa/AccessiblePolicy.java, * gnu/CORBA/Poa/DynamicImpHandler.java, * gnu/CORBA/Poa/ForwardRequestHolder.java, * gnu/CORBA/Poa/ForwardedServant.java, * gnu/CORBA/Poa/InvalidPolicyHolder.java, * gnu/CORBA/Poa/LocalDelegate.java, * gnu/CORBA/Poa/LocalRequest.java, * gnu/CORBA/Poa/LocalServerRequest.java, * gnu/CORBA/Poa/ORB_1_4.java, * gnu/CORBA/Poa/ServantDelegateImpl.java, * gnu/CORBA/Poa/StandardPolicies.java, * gnu/CORBA/Poa/gnuAdapterActivator.java, * gnu/CORBA/Poa/gnuForwardRequest.java, * gnu/CORBA/Poa/gnuIdAssignmentPolicy.java, * gnu/CORBA/Poa/gnuIdUniquenessPolicy.java, * gnu/CORBA/Poa/gnuImplicitActivationPolicy.java, * gnu/CORBA/Poa/gnuLifespanPolicy.java, * gnu/CORBA/Poa/gnuPOA.java, * gnu/CORBA/Poa/gnuPOAManager.java, * gnu/CORBA/Poa/gnuPoaCurrent.java, * gnu/CORBA/Poa/gnuRequestProcessingPolicy.java, * gnu/CORBA/Poa/gnuServantObject.java, * gnu/CORBA/Poa/gnuServantRetentionPolicy.java, * gnu/CORBA/Poa/gnuThreadPolicy.java, * gnu/CORBA/ServiceRequestAdapter.java, * gnu/CORBA/SetOverrideTypeHolder.java, * gnu/CORBA/SimpleDelegate.java, * gnu/CORBA/SocketRepository.java, * gnu/CORBA/StreamHolder.java, * gnu/CORBA/TypeCodeHelper.java, * gnu/CORBA/TypeKindNamer.java, * gnu/CORBA/Version.java, * gnu/CORBA/_PolicyImplBase.java, * gnu/CORBA/gnuAny.java, * gnu/CORBA/gnuCodecFactory.java, * gnu/CORBA/gnuEnvironment.java, * gnu/CORBA/gnuRequest.java, * gnu/CORBA/gnuValueHolder.java, * gnu/CORBA/interfaces/SocketFactory.java, * gnu/CORBA/typecodes/AliasTypeCode.java, * gnu/CORBA/typecodes/ArrayTypeCode.java, * gnu/CORBA/typecodes/FixedTypeCode.java, * gnu/CORBA/typecodes/GeneralTypeCode.java, * gnu/CORBA/typecodes/PrimitiveTypeCode.java, * gnu/CORBA/typecodes/RecordTypeCode.java, * gnu/CORBA/typecodes/RecursiveTypeCode.java, * gnu/CORBA/typecodes/StringTypeCode.java, * gnu/classpath/Pair.java, * gnu/classpath/Pointer.java, * gnu/classpath/Pointer32.java, * gnu/classpath/Pointer64.java, * gnu/classpath/ServiceFactory.java, * gnu/classpath/ServiceProviderLoadingAction.java, * gnu/classpath/SystemProperties.java, * gnu/classpath/debug/Component.java, * gnu/classpath/debug/PreciseFilter.java, * gnu/classpath/debug/SystemLogger.java, * gnu/classpath/debug/TeeInputStream.java, * gnu/classpath/debug/TeeReader.java, * gnu/classpath/jdwp/Jdwp.java, * gnu/classpath/jdwp/JdwpConstants.java, * gnu/classpath/jdwp/event/BreakpointEvent.java, * gnu/classpath/jdwp/event/ClassPrepareEvent.java, * gnu/classpath/jdwp/event/ClassUnloadEvent.java, * gnu/classpath/jdwp/event/Event.java, * gnu/classpath/jdwp/event/EventManager.java, * gnu/classpath/jdwp/event/EventRequest.java, * gnu/classpath/jdwp/event/ExceptionEvent.java, * gnu/classpath/jdwp/event/MethodEntryEvent.java, * gnu/classpath/jdwp/event/MethodExitEvent.java, * gnu/classpath/jdwp/event/SingleStepEvent.java, * gnu/classpath/jdwp/event/ThreadEndEvent.java, * gnu/classpath/jdwp/event/VmDeathEvent.java, * gnu/classpath/jdwp/event/VmInitEvent.java, * gnu/classpath/jdwp/event/filters/ClassExcludeFilter.java, * gnu/classpath/jdwp/event/filters/ClassMatchFilter.java, * gnu/classpath/jdwp/event/filters/ClassOnlyFilter.java, * gnu/classpath/jdwp/event/filters/ExceptionOnlyFilter.java, * gnu/classpath/jdwp/event/filters/FieldOnlyFilter.java, * gnu/classpath/jdwp/event/filters/InstanceOnlyFilter.java, * gnu/classpath/jdwp/event/filters/StepFilter.java, * gnu/classpath/jdwp/event/filters/ThreadOnlyFilter.java, * gnu/classpath/jdwp/exception/InvalidClassException.java, * gnu/classpath/jdwp/exception/InvalidClassLoaderException.java, * gnu/classpath/jdwp/exception/InvalidEventTypeException.java, * gnu/classpath/jdwp/exception/InvalidFieldException.java, * gnu/classpath/jdwp/exception/InvalidFrameException.java, * gnu/classpath/jdwp/exception/InvalidLocationException.java, * gnu/classpath/jdwp/exception/InvalidMethodException.java, * gnu/classpath/jdwp/exception/InvalidObjectException.java, * gnu/classpath/jdwp/exception/InvalidSlotException.java, * gnu/classpath/jdwp/exception/InvalidStringException.java, * gnu/classpath/jdwp/exception/InvalidThreadException.java, * gnu/classpath/jdwp/exception/InvalidThreadGroupException.java, * gnu/classpath/jdwp/exception/NativeMethodException.java, * gnu/classpath/jdwp/exception/NotImplementedException.java, * gnu/classpath/jdwp/id/JdwpId.java, * gnu/classpath/jdwp/id/NullObjectId.java, * gnu/classpath/jdwp/processor/ArrayReferenceCommandSet.java, * gnu/classpath/jdwp/processor/ArrayTypeCommandSet.java, * gnu/classpath/jdwp/processor/ClassLoaderReferenceCommandSet.java, * gnu/classpath/jdwp/processor/ClassObjectReferenceCommandSet.java, * gnu/classpath/jdwp/processor/ClassTypeCommandSet.java, * gnu/classpath/jdwp/processor/CommandSet.java, * gnu/classpath/jdwp/processor/EventRequestCommandSet.java, * gnu/classpath/jdwp/processor/FieldCommandSet.java, * gnu/classpath/jdwp/processor/InterfaceTypeCommandSet.java, * gnu/classpath/jdwp/processor/MethodCommandSet.java, * gnu/classpath/jdwp/processor/ObjectReferenceCommandSet.java, * gnu/classpath/jdwp/processor/PacketProcessor.java, * gnu/classpath/jdwp/processor/ReferenceTypeCommandSet.java, * gnu/classpath/jdwp/processor/StackFrameCommandSet.java, * gnu/classpath/jdwp/processor/StringReferenceCommandSet.java, * gnu/classpath/jdwp/processor/ThreadGroupReferenceCommandSet.java, * gnu/classpath/jdwp/processor/ThreadReferenceCommandSet.java, * gnu/classpath/jdwp/processor/VirtualMachineCommandSet.java, * gnu/classpath/jdwp/transport/JdwpCommandPacket.java, * gnu/classpath/jdwp/transport/JdwpConnection.java, * gnu/classpath/jdwp/transport/JdwpPacket.java, * gnu/classpath/jdwp/transport/JdwpReplyPacket.java, * gnu/classpath/jdwp/transport/SocketTransport.java, * gnu/classpath/jdwp/transport/TransportFactory.java, * gnu/classpath/jdwp/util/JdwpString.java, * gnu/classpath/jdwp/util/LineTable.java, * gnu/classpath/jdwp/util/Location.java, * gnu/classpath/jdwp/util/MethodResult.java, * gnu/classpath/jdwp/util/MonitorInfo.java, * gnu/classpath/jdwp/util/Signature.java, * gnu/classpath/jdwp/util/VariableTable.java, * gnu/classpath/jdwp/value/ArrayValue.java, * gnu/classpath/jdwp/value/BooleanValue.java, * gnu/classpath/jdwp/value/ByteValue.java, * gnu/classpath/jdwp/value/CharValue.java, * gnu/classpath/jdwp/value/DoubleValue.java, * gnu/classpath/jdwp/value/FloatValue.java, * gnu/classpath/jdwp/value/IntValue.java, * gnu/classpath/jdwp/value/LongValue.java, * gnu/classpath/jdwp/value/ObjectValue.java, * gnu/classpath/jdwp/value/ShortValue.java, * gnu/classpath/jdwp/value/StringValue.java, * gnu/classpath/jdwp/value/Value.java, * gnu/classpath/jdwp/value/ValueFactory.java, * gnu/classpath/jdwp/value/VoidValue.java, * gnu/classpath/toolkit/DefaultDaemonThreadFactory.java, * gnu/java/awt/AWTUtilities.java, * gnu/java/awt/BitMaskExtent.java, * gnu/java/awt/BitwiseXORComposite.java, * gnu/java/awt/Buffers.java, * gnu/java/awt/ClasspathGraphicsEnvironment.java, * gnu/java/awt/ClasspathToolkit.java, * gnu/java/awt/ComponentDataBlitOp.java, * gnu/java/awt/EmbeddedWindow.java, * gnu/java/awt/GradientPaintContext.java, * gnu/java/awt/color/CieXyzConverter.java, * gnu/java/awt/color/ClutProfileConverter.java, * gnu/java/awt/color/ColorLookUpTable.java, * gnu/java/awt/color/GrayProfileConverter.java, * gnu/java/awt/color/GrayScaleConverter.java, * gnu/java/awt/color/LinearRGBConverter.java, * gnu/java/awt/color/ProfileHeader.java, * gnu/java/awt/color/RgbProfileConverter.java, * gnu/java/awt/color/SrgbConverter.java, * gnu/java/awt/color/ToneReproductionCurve.java, * gnu/java/awt/dnd/GtkMouseDragGestureRecognizer.java, * gnu/java/awt/dnd/peer/gtk/GtkDragSourceContextPeer.java, * gnu/java/awt/dnd/peer/gtk/GtkDropTargetContextPeer.java, * gnu/java/awt/dnd/peer/gtk/GtkDropTargetPeer.java, * gnu/java/awt/font/FontDelegate.java, * gnu/java/awt/font/FontFactory.java, * gnu/java/awt/font/GNUGlyphVector.java, * gnu/java/awt/font/OpenTypeFontPeer.java, * gnu/java/awt/font/autofit/GlyphHints.java, * gnu/java/awt/font/autofit/Latin.java, * gnu/java/awt/font/autofit/Utils.java, * gnu/java/awt/font/opentype/CharGlyphMap.java, * gnu/java/awt/font/opentype/GlyphNamer.java, * gnu/java/awt/font/opentype/MacResourceFork.java, * gnu/java/awt/font/opentype/NameDecoder.java, * gnu/java/awt/font/opentype/OpenTypeFont.java, * gnu/java/awt/font/opentype/OpenTypeFontFactory.java, * gnu/java/awt/font/opentype/truetype/GlyphLoader.java, * gnu/java/awt/font/opentype/truetype/GlyphLocator.java, * gnu/java/awt/font/opentype/truetype/GlyphMeasurer.java, * gnu/java/awt/font/opentype/truetype/Point.java, * gnu/java/awt/font/opentype/truetype/TrueTypeScaler.java, * gnu/java/awt/font/opentype/truetype/VirtualMachine.java, * gnu/java/awt/font/opentype/truetype/Zone.java, * gnu/java/awt/font/opentype/truetype/ZonePathIterator.java, * gnu/java/awt/image/AsyncImage.java, * gnu/java/awt/image/ImageConverter.java, * gnu/java/awt/image/ImageDecoder.java, * gnu/java/awt/image/XBMDecoder.java, * gnu/java/awt/java2d/AbstractGraphics2D.java, * gnu/java/awt/java2d/AlphaCompositeContext.java, * gnu/java/awt/java2d/CubicSegment.java, * gnu/java/awt/java2d/LineSegment.java, * gnu/java/awt/java2d/PixelCoverage.java, * gnu/java/awt/java2d/QuadSegment.java, * gnu/java/awt/java2d/RasterGraphics.java, * gnu/java/awt/java2d/ScanlineConverter.java, * gnu/java/awt/java2d/ScanlineCoverage.java, * gnu/java/awt/java2d/Segment.java, * gnu/java/awt/java2d/TexturePaintContext.java, * gnu/java/awt/peer/ClasspathDesktopPeer.java, * gnu/java/awt/peer/ClasspathFontPeer.java, * gnu/java/awt/peer/GLightweightPeer.java, * gnu/java/awt/peer/GnomeDesktopPeer.java, * gnu/java/awt/peer/KDEDesktopPeer.java, * gnu/java/awt/peer/gtk/AsyncImage.java, * gnu/java/awt/peer/gtk/BufferedImageGraphics.java, * gnu/java/awt/peer/gtk/CairoGraphics2D.java, * gnu/java/awt/peer/gtk/CairoSurface.java, * gnu/java/awt/peer/gtk/CairoSurfaceGraphics.java, * gnu/java/awt/peer/gtk/ComponentGraphics.java, * gnu/java/awt/peer/gtk/ComponentGraphicsCopy.java, * gnu/java/awt/peer/gtk/FreetypeGlyphVector.java, * gnu/java/awt/peer/gtk/GdkFontPeer.java, * gnu/java/awt/peer/gtk/GdkGraphicsConfiguration.java, * gnu/java/awt/peer/gtk/GdkGraphicsEnvironment.java, * gnu/java/awt/peer/gtk/GdkPixbufDecoder.java, * gnu/java/awt/peer/gtk/GdkRobotPeer.java, * gnu/java/awt/peer/gtk/GdkScreenGraphicsDevice.java, * gnu/java/awt/peer/gtk/GtkButtonPeer.java, * gnu/java/awt/peer/gtk/GtkCheckboxPeer.java, * gnu/java/awt/peer/gtk/GtkChoicePeer.java, * gnu/java/awt/peer/gtk/GtkClipboard.java, * gnu/java/awt/peer/gtk/GtkComponentPeer.java, * gnu/java/awt/peer/gtk/GtkContainerPeer.java, * gnu/java/awt/peer/gtk/GtkCursor.java, * gnu/java/awt/peer/gtk/GtkDialogPeer.java, * gnu/java/awt/peer/gtk/GtkFileDialogPeer.java, * gnu/java/awt/peer/gtk/GtkFramePeer.java, * gnu/java/awt/peer/gtk/GtkGenericPeer.java, * gnu/java/awt/peer/gtk/GtkImage.java, * gnu/java/awt/peer/gtk/GtkImageConsumer.java, * gnu/java/awt/peer/gtk/GtkLabelPeer.java, * gnu/java/awt/peer/gtk/GtkListPeer.java, * gnu/java/awt/peer/gtk/GtkMenuComponentPeer.java, * gnu/java/awt/peer/gtk/GtkMenuPeer.java, * gnu/java/awt/peer/gtk/GtkMouseInfoPeer.java, * gnu/java/awt/peer/gtk/GtkPanelPeer.java, * gnu/java/awt/peer/gtk/GtkPopupMenuPeer.java, * gnu/java/awt/peer/gtk/GtkScrollbarPeer.java, * gnu/java/awt/peer/gtk/GtkSelection.java, * gnu/java/awt/peer/gtk/GtkToolkit.java, * gnu/java/awt/peer/gtk/GtkVolatileImage.java, * gnu/java/awt/peer/gtk/GtkWindowPeer.java, * gnu/java/awt/peer/gtk/VolatileImageGraphics.java, * gnu/java/awt/peer/headless/HeadlessGraphicsEnvironment.java, * gnu/java/awt/peer/qt/MainQtThread.java, * gnu/java/awt/peer/qt/QMatrix.java, * gnu/java/awt/peer/qt/QPainterPath.java, * gnu/java/awt/peer/qt/QPen.java, * gnu/java/awt/peer/qt/QtAudioClip.java, * gnu/java/awt/peer/qt/QtButtonPeer.java, * gnu/java/awt/peer/qt/QtCheckboxPeer.java, * gnu/java/awt/peer/qt/QtChoicePeer.java, * gnu/java/awt/peer/qt/QtComponentGraphics.java, * gnu/java/awt/peer/qt/QtComponentPeer.java, * gnu/java/awt/peer/qt/QtContainerPeer.java, * gnu/java/awt/peer/qt/QtDialogPeer.java, * gnu/java/awt/peer/qt/QtEmbeddedWindowPeer.java, * gnu/java/awt/peer/qt/QtFileDialogPeer.java, * gnu/java/awt/peer/qt/QtFontMetrics.java, * gnu/java/awt/peer/qt/QtFontPeer.java, * gnu/java/awt/peer/qt/QtFramePeer.java, * gnu/java/awt/peer/qt/QtGraphics.java, * gnu/java/awt/peer/qt/QtGraphicsEnvironment.java, * gnu/java/awt/peer/qt/QtImage.java, * gnu/java/awt/peer/qt/QtImageConsumer.java, * gnu/java/awt/peer/qt/QtImageDirectGraphics.java, * gnu/java/awt/peer/qt/QtImageGraphics.java, * gnu/java/awt/peer/qt/QtLabelPeer.java, * gnu/java/awt/peer/qt/QtListPeer.java, * gnu/java/awt/peer/qt/QtMenuBarPeer.java, * gnu/java/awt/peer/qt/QtMenuComponentPeer.java, * gnu/java/awt/peer/qt/QtMenuItemPeer.java, * gnu/java/awt/peer/qt/QtMenuPeer.java, * gnu/java/awt/peer/qt/QtPanelPeer.java, * gnu/java/awt/peer/qt/QtPopupMenuPeer.java, * gnu/java/awt/peer/qt/QtRepaintThread.java, * gnu/java/awt/peer/qt/QtScreenDevice.java, * gnu/java/awt/peer/qt/QtScreenDeviceConfiguration.java, * gnu/java/awt/peer/qt/QtScrollPanePeer.java, * gnu/java/awt/peer/qt/QtScrollbarPeer.java, * gnu/java/awt/peer/qt/QtTextAreaPeer.java, * gnu/java/awt/peer/qt/QtTextFieldPeer.java, * gnu/java/awt/peer/qt/QtToolkit.java, * gnu/java/awt/peer/qt/QtVolatileImage.java, * gnu/java/awt/peer/qt/QtWindowPeer.java, * gnu/java/awt/peer/swing/SwingButtonPeer.java, * gnu/java/awt/peer/swing/SwingCheckboxPeer.java, * gnu/java/awt/peer/swing/SwingComponent.java, * gnu/java/awt/peer/swing/SwingComponentPeer.java, * gnu/java/awt/peer/swing/SwingContainerPeer.java, * gnu/java/awt/peer/swing/SwingLabelPeer.java, * gnu/java/awt/peer/swing/SwingListPeer.java, * gnu/java/awt/peer/swing/SwingMenuItemPeer.java, * gnu/java/awt/peer/swing/SwingMenuPeer.java, * gnu/java/awt/peer/swing/SwingTextAreaPeer.java, * gnu/java/awt/peer/swing/SwingTextFieldPeer.java, * gnu/java/awt/peer/x/GLGraphics.java, * gnu/java/awt/peer/x/KeyboardMapping.java, * gnu/java/awt/peer/x/XEventPump.java, * gnu/java/awt/peer/x/XFontPeer.java, * gnu/java/awt/peer/x/XFramePeer.java, * gnu/java/awt/peer/x/XGraphics2D.java, * gnu/java/awt/peer/x/XGraphicsConfiguration.java, * gnu/java/awt/peer/x/XGraphicsDevice.java, * gnu/java/awt/peer/x/XGraphicsEnvironment.java, * gnu/java/awt/peer/x/XImage.java, * gnu/java/awt/peer/x/XToolkit.java, * gnu/java/awt/peer/x/XWindowPeer.java, * gnu/java/awt/print/JavaPrinterGraphics.java, * gnu/java/awt/print/JavaPrinterJob.java, * gnu/java/awt/print/PostScriptGraphics2D.java, * gnu/java/awt/print/SpooledDocument.java, * gnu/java/beans/BeanInfoEmbryo.java, * gnu/java/beans/DefaultExceptionListener.java, * gnu/java/beans/ExplicitBeanInfo.java, * gnu/java/beans/IntrospectionIncubator.java, * gnu/java/beans/decoder/AbstractContext.java, * gnu/java/beans/decoder/AbstractCreatableObjectContext.java, * gnu/java/beans/decoder/AbstractElementHandler.java, * gnu/java/beans/decoder/AbstractObjectContext.java, * gnu/java/beans/decoder/ArrayContext.java, * gnu/java/beans/decoder/ArrayHandler.java, * gnu/java/beans/decoder/AssemblyException.java, * gnu/java/beans/decoder/BooleanHandler.java, * gnu/java/beans/decoder/ByteHandler.java, * gnu/java/beans/decoder/CharHandler.java, * gnu/java/beans/decoder/ClassHandler.java, * gnu/java/beans/decoder/ConstructorContext.java, * gnu/java/beans/decoder/Context.java, * gnu/java/beans/decoder/DecoderContext.java, * gnu/java/beans/decoder/DoubleHandler.java, * gnu/java/beans/decoder/DummyContext.java, * gnu/java/beans/decoder/DummyHandler.java, * gnu/java/beans/decoder/ElementHandler.java, * gnu/java/beans/decoder/FloatHandler.java, * gnu/java/beans/decoder/GrowableArrayContext.java, * gnu/java/beans/decoder/IndexContext.java, * gnu/java/beans/decoder/IntHandler.java, * gnu/java/beans/decoder/JavaHandler.java, * gnu/java/beans/decoder/LongHandler.java, * gnu/java/beans/decoder/MethodContext.java, * gnu/java/beans/decoder/MethodFinder.java, * gnu/java/beans/decoder/NullHandler.java, * gnu/java/beans/decoder/ObjectContext.java, * gnu/java/beans/decoder/ObjectHandler.java, * gnu/java/beans/decoder/PersistenceParser.java, * gnu/java/beans/decoder/PropertyContext.java, * gnu/java/beans/decoder/ShortHandler.java, * gnu/java/beans/decoder/SimpleHandler.java, * gnu/java/beans/decoder/StaticMethodContext.java, * gnu/java/beans/decoder/StringHandler.java, * gnu/java/beans/decoder/VoidHandler.java, * gnu/java/beans/editors/ColorEditor.java, * gnu/java/beans/editors/FontEditor.java, * gnu/java/beans/editors/NativeBooleanEditor.java, * gnu/java/beans/editors/NativeByteEditor.java, * gnu/java/beans/editors/NativeDoubleEditor.java, * gnu/java/beans/editors/NativeFloatEditor.java, * gnu/java/beans/editors/NativeIntEditor.java, * gnu/java/beans/editors/NativeLongEditor.java, * gnu/java/beans/editors/NativeShortEditor.java, * gnu/java/beans/editors/StringEditor.java, * gnu/java/beans/encoder/ArrayPersistenceDelegate.java, * gnu/java/beans/encoder/ClassPersistenceDelegate.java, * gnu/java/beans/encoder/CollectionPersistenceDelegate.java, * gnu/java/beans/encoder/Context.java, * gnu/java/beans/encoder/GenericScannerState.java, * gnu/java/beans/encoder/IgnoringScannerState.java, * gnu/java/beans/encoder/MapPersistenceDelegate.java, * gnu/java/beans/encoder/ObjectId.java, * gnu/java/beans/encoder/PrimitivePersistenceDelegate.java, * gnu/java/beans/encoder/ReportingScannerState.java, * gnu/java/beans/encoder/Root.java, * gnu/java/beans/encoder/ScanEngine.java, * gnu/java/beans/encoder/ScannerState.java, * gnu/java/beans/encoder/StAXWriter.java, * gnu/java/beans/encoder/Writer.java, * gnu/java/beans/encoder/elements/ArrayInstantiation.java, * gnu/java/beans/encoder/elements/Array_Get.java, * gnu/java/beans/encoder/elements/ClassResolution.java, * gnu/java/beans/encoder/elements/Element.java, * gnu/java/beans/encoder/elements/List_Get.java, * gnu/java/beans/encoder/elements/List_Set.java, * gnu/java/beans/encoder/elements/MethodInvocation.java, * gnu/java/beans/encoder/elements/NullObject.java, * gnu/java/beans/encoder/elements/ObjectInstantiation.java, * gnu/java/beans/encoder/elements/ObjectReference.java, * gnu/java/beans/encoder/elements/PrimitiveInstantiation.java, * gnu/java/beans/encoder/elements/StaticFieldAccess.java, * gnu/java/beans/encoder/elements/StaticMethodInvocation.java, * gnu/java/beans/encoder/elements/StringReference.java, * gnu/java/io/ASN1ParsingException.java, * gnu/java/io/Base64InputStream.java, * gnu/java/io/ClassLoaderObjectInputStream.java, * gnu/java/io/NullOutputStream.java, * gnu/java/io/ObjectIdentityMap2Int.java, * gnu/java/io/ObjectIdentityWrapper.java, * gnu/java/io/PlatformHelper.java, * gnu/java/lang/CPStringBuilder.java, * gnu/java/lang/CharData.java, * gnu/java/lang/InstrumentationImpl.java, * gnu/java/lang/MainThread.java, * gnu/java/lang/management/BeanImpl.java, * gnu/java/lang/management/ClassLoadingMXBeanImpl.java, * gnu/java/lang/management/CompilationMXBeanImpl.java, * gnu/java/lang/management/GarbageCollectorMXBeanImpl.java, * gnu/java/lang/management/MemoryMXBeanImpl.java, * gnu/java/lang/management/MemoryManagerMXBeanImpl.java, * gnu/java/lang/management/MemoryPoolMXBeanImpl.java, * gnu/java/lang/management/OperatingSystemMXBeanImpl.java, * gnu/java/lang/management/RuntimeMXBeanImpl.java, * gnu/java/lang/management/ThreadMXBeanImpl.java, * gnu/java/lang/reflect/TypeSignature.java, * gnu/java/locale/LocaleHelper.java, * gnu/java/math/Fixed.java, * gnu/java/math/GMP.java, * gnu/java/math/MPN.java, * gnu/java/net/CRLFInputStream.java, * gnu/java/net/CRLFOutputStream.java, * gnu/java/net/DefaultContentHandlerFactory.java, * gnu/java/net/DefaultProxySelector.java, * gnu/java/net/EmptyX509TrustManager.java, * gnu/java/net/GetLocalHostAction.java, * gnu/java/net/HeaderFieldHelper.java, * gnu/java/net/IndexListParser.java, * gnu/java/net/LineInputStream.java, * gnu/java/net/PlainDatagramSocketImpl.java, * gnu/java/net/PlainSocketImpl.java, * gnu/java/net/loader/FileResource.java, * gnu/java/net/loader/FileURLLoader.java, * gnu/java/net/loader/JarURLLoader.java, * gnu/java/net/loader/JarURLResource.java, * gnu/java/net/loader/RemoteResource.java, * gnu/java/net/loader/RemoteURLLoader.java, * gnu/java/net/loader/Resource.java, * gnu/java/net/loader/URLLoader.java, * gnu/java/net/protocol/file/Connection.java, * gnu/java/net/protocol/file/Handler.java, * gnu/java/net/protocol/ftp/ActiveModeDTP.java, * gnu/java/net/protocol/ftp/BlockInputStream.java, * gnu/java/net/protocol/ftp/BlockOutputStream.java, * gnu/java/net/protocol/ftp/CompressedInputStream.java, * gnu/java/net/protocol/ftp/CompressedOutputStream.java, * gnu/java/net/protocol/ftp/DTP.java, * gnu/java/net/protocol/ftp/DTPInputStream.java, * gnu/java/net/protocol/ftp/DTPOutputStream.java, * gnu/java/net/protocol/ftp/FTPConnection.java, * gnu/java/net/protocol/ftp/FTPException.java, * gnu/java/net/protocol/ftp/FTPResponse.java, * gnu/java/net/protocol/ftp/FTPURLConnection.java, * gnu/java/net/protocol/ftp/Handler.java, * gnu/java/net/protocol/ftp/PassiveModeDTP.java, * gnu/java/net/protocol/ftp/StreamInputStream.java, * gnu/java/net/protocol/ftp/StreamOutputStream.java, * gnu/java/net/protocol/http/Authenticator.java, * gnu/java/net/protocol/http/ByteArrayRequestBodyWriter.java, * gnu/java/net/protocol/http/ChunkedInputStream.java, * gnu/java/net/protocol/http/Cookie.java, * gnu/java/net/protocol/http/CookieManager.java, * gnu/java/net/protocol/http/Credentials.java, * gnu/java/net/protocol/http/HTTPConnection.java, * gnu/java/net/protocol/http/HTTPDateFormat.java, * gnu/java/net/protocol/http/HTTPURLConnection.java, * gnu/java/net/protocol/http/Handler.java, * gnu/java/net/protocol/http/Headers.java, * gnu/java/net/protocol/http/Request.java, * gnu/java/net/protocol/http/RequestBodyWriter.java, * gnu/java/net/protocol/http/Response.java, * gnu/java/net/protocol/http/ResponseHeaderHandler.java, * gnu/java/net/protocol/http/SimpleCookieManager.java, * gnu/java/net/protocol/https/Handler.java, * gnu/java/net/protocol/jar/Connection.java, * gnu/java/net/protocol/jar/Handler.java, * gnu/java/nio/ChannelInputStream.java, * gnu/java/nio/ChannelOutputStream.java, * gnu/java/nio/ChannelReader.java, * gnu/java/nio/ChannelWriter.java, * gnu/java/nio/DatagramChannelImpl.java, * gnu/java/nio/DatagramChannelSelectionKey.java, * gnu/java/nio/EpollSelectionKeyImpl.java, * gnu/java/nio/EpollSelectorImpl.java, * gnu/java/nio/FileChannelImpl.java, * gnu/java/nio/FileLockImpl.java, * gnu/java/nio/InputStreamChannel.java, * gnu/java/nio/KqueueSelectionKeyImpl.java, * gnu/java/nio/KqueueSelectorImpl.java, * gnu/java/nio/NIODatagramSocket.java, * gnu/java/nio/NIOServerSocket.java, * gnu/java/nio/NIOSocket.java, * gnu/java/nio/NIOSocketImpl.java, * gnu/java/nio/OutputStreamChannel.java, * gnu/java/nio/PipeImpl.java, * gnu/java/nio/SelectionKeyImpl.java, * gnu/java/nio/SelectorImpl.java, * gnu/java/nio/SelectorProviderImpl.java, * gnu/java/nio/ServerSocketChannelImpl.java, * gnu/java/nio/ServerSocketChannelSelectionKey.java, * gnu/java/nio/SocketChannelImpl.java, * gnu/java/nio/SocketChannelSelectionKey.java, * gnu/java/nio/SocketChannelSelectionKeyImpl.java, * gnu/java/nio/VMChannelOwner.java, * gnu/java/nio/charset/ByteCharset.java, * gnu/java/nio/charset/ByteDecodeLoopHelper.java, * gnu/java/nio/charset/ByteEncodeLoopHelper.java, * gnu/java/nio/charset/Cp424.java, * gnu/java/nio/charset/Cp437.java, * gnu/java/nio/charset/Cp737.java, * gnu/java/nio/charset/Cp775.java, * gnu/java/nio/charset/Cp850.java, * gnu/java/nio/charset/Cp852.java, * gnu/java/nio/charset/Cp855.java, * gnu/java/nio/charset/Cp857.java, * gnu/java/nio/charset/Cp860.java, * gnu/java/nio/charset/Cp861.java, * gnu/java/nio/charset/Cp862.java, * gnu/java/nio/charset/Cp863.java, * gnu/java/nio/charset/Cp864.java, * gnu/java/nio/charset/Cp865.java, * gnu/java/nio/charset/Cp866.java, * gnu/java/nio/charset/Cp869.java, * gnu/java/nio/charset/Cp874.java, * gnu/java/nio/charset/EncodingHelper.java, * gnu/java/nio/charset/ISO_8859_1.java, * gnu/java/nio/charset/ISO_8859_13.java, * gnu/java/nio/charset/ISO_8859_15.java, * gnu/java/nio/charset/ISO_8859_2.java, * gnu/java/nio/charset/ISO_8859_3.java, * gnu/java/nio/charset/ISO_8859_4.java, * gnu/java/nio/charset/ISO_8859_5.java, * gnu/java/nio/charset/ISO_8859_6.java, * gnu/java/nio/charset/ISO_8859_7.java, * gnu/java/nio/charset/ISO_8859_8.java, * gnu/java/nio/charset/ISO_8859_9.java, * gnu/java/nio/charset/KOI_8.java, * gnu/java/nio/charset/MS874.java, * gnu/java/nio/charset/MacCentralEurope.java, * gnu/java/nio/charset/MacCroatian.java, * gnu/java/nio/charset/MacCyrillic.java, * gnu/java/nio/charset/MacDingbat.java, * gnu/java/nio/charset/MacGreek.java, * gnu/java/nio/charset/MacIceland.java, * gnu/java/nio/charset/MacRoman.java, * gnu/java/nio/charset/MacRomania.java, * gnu/java/nio/charset/MacSymbol.java, * gnu/java/nio/charset/MacThai.java, * gnu/java/nio/charset/MacTurkish.java, * gnu/java/nio/charset/Provider.java, * gnu/java/nio/charset/US_ASCII.java, * gnu/java/nio/charset/UTF_16.java, * gnu/java/nio/charset/UTF_16BE.java, * gnu/java/nio/charset/UTF_16Decoder.java, * gnu/java/nio/charset/UTF_16Encoder.java, * gnu/java/nio/charset/UTF_16LE.java, * gnu/java/nio/charset/UTF_8.java, * gnu/java/nio/charset/UnicodeLittle.java, * gnu/java/nio/charset/Windows1250.java, * gnu/java/nio/charset/Windows1251.java, * gnu/java/nio/charset/Windows1252.java, * gnu/java/nio/charset/Windows1253.java, * gnu/java/nio/charset/Windows1254.java, * gnu/java/nio/charset/Windows1255.java, * gnu/java/nio/charset/Windows1256.java, * gnu/java/nio/charset/Windows1257.java, * gnu/java/nio/charset/Windows1258.java, * gnu/java/nio/charset/iconv/IconvCharset.java, * gnu/java/nio/charset/iconv/IconvDecoder.java, * gnu/java/nio/charset/iconv/IconvEncoder.java, * gnu/java/nio/charset/iconv/IconvProvider.java, * gnu/java/rmi/RMIMarshalledObjectInputStream.java, * gnu/java/rmi/RMIMarshalledObjectOutputStream.java, * gnu/java/rmi/activation/ActivationSystemTransient.java, * gnu/java/rmi/activation/BidiTable.java, * gnu/java/rmi/activation/DefaultActivationGroup.java, * gnu/java/rmi/activation/DefaultActivationSystem.java, * gnu/java/rmi/dgc/DGCImpl.java, * gnu/java/rmi/dgc/DGCImpl_Skel.java, * gnu/java/rmi/dgc/DGCImpl_Stub.java, * gnu/java/rmi/dgc/LeaseRenewingTask.java, * gnu/java/rmi/registry/RegistryImpl.java, * gnu/java/rmi/registry/RegistryImpl_Skel.java, * gnu/java/rmi/registry/RegistryImpl_Stub.java, * gnu/java/rmi/server/ActivatableRef.java, * gnu/java/rmi/server/ActivatableServerRef.java, * gnu/java/rmi/server/CombinedClassLoader.java, * gnu/java/rmi/server/ConnectionRunnerPool.java, * gnu/java/rmi/server/ProtocolConstants.java, * gnu/java/rmi/server/RMIClassLoaderImpl.java, * gnu/java/rmi/server/RMIDefaultSocketFactory.java, * gnu/java/rmi/server/RMIHashes.java, * gnu/java/rmi/server/RMIIncomingThread.java, * gnu/java/rmi/server/RMIObjectInputStream.java, * gnu/java/rmi/server/RMIObjectOutputStream.java, * gnu/java/rmi/server/UnicastConnection.java, * gnu/java/rmi/server/UnicastConnectionManager.java, * gnu/java/rmi/server/UnicastRef.java, * gnu/java/rmi/server/UnicastRemoteCall.java, * gnu/java/rmi/server/UnicastRemoteStub.java, * gnu/java/rmi/server/UnicastServer.java, * gnu/java/rmi/server/UnicastServerRef.java, * gnu/java/security/Engine.java, * gnu/java/security/OID.java, * gnu/java/security/PolicyFile.java, * gnu/java/security/Properties.java, * gnu/java/security/Registry.java, * gnu/java/security/Requires.java, * gnu/java/security/action/GetPropertyAction.java, * gnu/java/security/action/SetAccessibleAction.java, * gnu/java/security/der/DERValue.java, * gnu/java/security/hash/BaseHash.java, * gnu/java/security/hash/HashFactory.java, * gnu/java/security/hash/Haval.java, * gnu/java/security/hash/IMessageDigest.java, * gnu/java/security/hash/MD2.java, * gnu/java/security/hash/MD4.java, * gnu/java/security/hash/MD5.java, * gnu/java/security/hash/RipeMD128.java, * gnu/java/security/hash/RipeMD160.java, * gnu/java/security/hash/Sha160.java, * gnu/java/security/hash/Sha256.java, * gnu/java/security/hash/Sha384.java, * gnu/java/security/hash/Sha512.java, * gnu/java/security/hash/Tiger.java, * gnu/java/security/hash/Whirlpool.java, * gnu/java/security/jce/hash/HavalSpi.java, * gnu/java/security/jce/hash/MD2Spi.java, * gnu/java/security/jce/hash/MD4Spi.java, * gnu/java/security/jce/hash/MD5Spi.java, * gnu/java/security/jce/hash/MessageDigestAdapter.java, * gnu/java/security/jce/hash/RipeMD128Spi.java, * gnu/java/security/jce/hash/RipeMD160Spi.java, * gnu/java/security/jce/hash/Sha160Spi.java, * gnu/java/security/jce/hash/Sha256Spi.java, * gnu/java/security/jce/hash/Sha384Spi.java, * gnu/java/security/jce/hash/Sha512Spi.java, * gnu/java/security/jce/hash/TigerSpi.java, * gnu/java/security/jce/hash/WhirlpoolSpi.java, * gnu/java/security/jce/prng/HavalRandomSpi.java, * gnu/java/security/jce/prng/MD2RandomSpi.java, * gnu/java/security/jce/prng/MD4RandomSpi.java, * gnu/java/security/jce/prng/MD5RandomSpi.java, * gnu/java/security/jce/prng/RipeMD128RandomSpi.java, * gnu/java/security/jce/prng/RipeMD160RandomSpi.java, * gnu/java/security/jce/prng/SecureRandomAdapter.java, * gnu/java/security/jce/prng/Sha160RandomSpi.java, * gnu/java/security/jce/prng/Sha256RandomSpi.java, * gnu/java/security/jce/prng/Sha384RandomSpi.java, * gnu/java/security/jce/prng/Sha512RandomSpi.java, * gnu/java/security/jce/prng/TigerRandomSpi.java, * gnu/java/security/jce/prng/WhirlpoolRandomSpi.java, * gnu/java/security/jce/sig/DSSKeyFactory.java, * gnu/java/security/jce/sig/DSSKeyPairGeneratorSpi.java, * gnu/java/security/jce/sig/DSSParameters.java, * gnu/java/security/jce/sig/DSSRawSignatureSpi.java, * gnu/java/security/jce/sig/KeyPairGeneratorAdapter.java, * gnu/java/security/jce/sig/RSAPSSRawSignatureSpi.java, * gnu/java/security/jce/sig/SignatureAdapter.java, * gnu/java/security/key/IKeyPairCodec.java, * gnu/java/security/key/IKeyPairGenerator.java, * gnu/java/security/key/KeyPairCodecFactory.java, * gnu/java/security/key/KeyPairGeneratorFactory.java, * gnu/java/security/key/dss/DSSKey.java, * gnu/java/security/key/dss/DSSKeyPairGenerator.java, * gnu/java/security/key/dss/DSSKeyPairPKCS8Codec.java, * gnu/java/security/key/dss/DSSKeyPairRawCodec.java, * gnu/java/security/key/dss/DSSKeyPairX509Codec.java, * gnu/java/security/key/dss/DSSPrivateKey.java, * gnu/java/security/key/dss/DSSPublicKey.java, * gnu/java/security/key/dss/FIPS186.java, * gnu/java/security/key/rsa/GnuRSAKey.java, * gnu/java/security/key/rsa/GnuRSAPrivateKey.java, * gnu/java/security/key/rsa/GnuRSAPublicKey.java, * gnu/java/security/key/rsa/RSAKeyPairGenerator.java, * gnu/java/security/key/rsa/RSAKeyPairPKCS8Codec.java, * gnu/java/security/key/rsa/RSAKeyPairRawCodec.java, * gnu/java/security/key/rsa/RSAKeyPairX509Codec.java, * gnu/java/security/pkcs/PKCS7Data.java, * gnu/java/security/pkcs/PKCS7SignedData.java, * gnu/java/security/pkcs/SignerInfo.java, * gnu/java/security/prng/BasePRNG.java, * gnu/java/security/prng/EntropySource.java, * gnu/java/security/prng/IRandom.java, * gnu/java/security/prng/LimitReachedException.java, * gnu/java/security/prng/MDGenerator.java, * gnu/java/security/prng/PRNGFactory.java, * gnu/java/security/prng/RandomEventListener.java, * gnu/java/security/provider/DefaultPolicy.java, * gnu/java/security/provider/PKIXCertPathValidatorImpl.java, * gnu/java/security/sig/BaseSignature.java, * gnu/java/security/sig/ISignature.java, * gnu/java/security/sig/ISignatureCodec.java, * gnu/java/security/sig/SignatureCodecFactory.java, * gnu/java/security/sig/SignatureFactory.java, * gnu/java/security/sig/dss/DSSSignature.java, * gnu/java/security/sig/dss/DSSSignatureRawCodec.java, * gnu/java/security/sig/dss/DSSSignatureX509Codec.java, * gnu/java/security/sig/rsa/EME_PKCS1_V1_5.java, * gnu/java/security/sig/rsa/EMSA_PKCS1_V1_5.java, * gnu/java/security/sig/rsa/EMSA_PSS.java, * gnu/java/security/sig/rsa/RSA.java, * gnu/java/security/sig/rsa/RSAPKCS1V1_5Signature.java, * gnu/java/security/sig/rsa/RSAPKCS1V1_5SignatureRawCodec.java, * gnu/java/security/sig/rsa/RSAPKCS1V1_5SignatureX509Codec.java, * gnu/java/security/sig/rsa/RSAPSSSignature.java, * gnu/java/security/sig/rsa/RSAPSSSignatureRawCodec.java, * gnu/java/security/sig/rsa/RSASignatureFactory.java, * gnu/java/security/util/ByteArray.java, * gnu/java/security/util/ByteBufferOutputStream.java, * gnu/java/security/util/ExpirableObject.java, * gnu/java/security/util/FormatUtil.java, * gnu/java/security/util/IntegerUtil.java, * gnu/java/security/util/PRNG.java, * gnu/java/security/util/Prime.java, * gnu/java/security/util/Sequence.java, * gnu/java/security/util/SimpleList.java, * gnu/java/security/util/Util.java, * gnu/java/security/x509/X509CRLSelectorImpl.java, * gnu/java/security/x509/X509CertSelectorImpl.java, * gnu/java/security/x509/ext/CertificatePolicies.java, * gnu/java/security/x509/ext/GeneralName.java, * gnu/java/security/x509/ext/GeneralSubtree.java, * gnu/java/security/x509/ext/NameConstraints.java, * gnu/java/text/AttributedFormatBuffer.java, * gnu/java/text/BaseBreakIterator.java, * gnu/java/text/CharacterBreakIterator.java, * gnu/java/text/FormatBuffer.java, * gnu/java/text/FormatCharacterIterator.java, * gnu/java/text/LineBreakIterator.java, * gnu/java/text/SentenceBreakIterator.java, * gnu/java/text/StringFormatBuffer.java, * gnu/java/text/WordBreakIterator.java, * gnu/java/util/Base64.java, * gnu/java/util/DoubleEnumeration.java, * gnu/java/util/EmptyEnumeration.java, * gnu/java/util/WeakIdentityHashMap.java, * gnu/java/util/ZoneInfo.java, * gnu/java/util/jar/JarUtils.java, * gnu/java/util/prefs/FileBasedFactory.java, * gnu/java/util/prefs/FileBasedPreferences.java, * gnu/java/util/prefs/GConfBasedFactory.java, * gnu/java/util/prefs/GConfBasedPreferences.java, * gnu/java/util/prefs/MemoryBasedFactory.java, * gnu/java/util/prefs/MemoryBasedPreferences.java, * gnu/java/util/prefs/NodeReader.java, * gnu/java/util/prefs/NodeWriter.java, * gnu/java/util/prefs/gconf/GConfNativePeer.java, * gnu/java/util/regex/BacktrackStack.java, * gnu/java/util/regex/CharIndexed.java, * gnu/java/util/regex/CharIndexedInputStream.java, * gnu/java/util/regex/RE.java, * gnu/java/util/regex/REFilterInputStream.java, * gnu/java/util/regex/REMatch.java, * gnu/java/util/regex/REMatchEnumeration.java, * gnu/java/util/regex/RESyntax.java, * gnu/java/util/regex/REToken.java, * gnu/java/util/regex/RETokenAny.java, * gnu/java/util/regex/RETokenBackRef.java, * gnu/java/util/regex/RETokenChar.java, * gnu/java/util/regex/RETokenEnd.java, * gnu/java/util/regex/RETokenEndOfPreviousMatch.java, * gnu/java/util/regex/RETokenIndependent.java, * gnu/java/util/regex/RETokenLookAhead.java, * gnu/java/util/regex/RETokenLookBehind.java, * gnu/java/util/regex/RETokenNamedProperty.java, * gnu/java/util/regex/RETokenOneOf.java, * gnu/java/util/regex/RETokenPOSIX.java, * gnu/java/util/regex/RETokenRange.java, * gnu/java/util/regex/RETokenRepeated.java, * gnu/java/util/regex/RETokenStart.java, * gnu/java/util/regex/RETokenWordBoundary.java, * gnu/java/util/regex/UncheckedRE.java, * gnu/javax/activation/viewers/ImageViewer.java, * gnu/javax/activation/viewers/TextEditor.java, * gnu/javax/activation/viewers/TextViewer.java, * gnu/javax/crypto/assembly/Assembly.java, * gnu/javax/crypto/assembly/Cascade.java, * gnu/javax/crypto/assembly/CascadeStage.java, * gnu/javax/crypto/assembly/CascadeTransformer.java, * gnu/javax/crypto/assembly/DeflateTransformer.java, * gnu/javax/crypto/assembly/Direction.java, * gnu/javax/crypto/assembly/LoopbackTransformer.java, * gnu/javax/crypto/assembly/ModeStage.java, * gnu/javax/crypto/assembly/Operation.java, * gnu/javax/crypto/assembly/PaddingTransformer.java, * gnu/javax/crypto/assembly/Stage.java, * gnu/javax/crypto/assembly/Transformer.java, * gnu/javax/crypto/assembly/TransformerException.java, * gnu/javax/crypto/cipher/Anubis.java, * gnu/javax/crypto/cipher/BaseCipher.java, * gnu/javax/crypto/cipher/Blowfish.java, * gnu/javax/crypto/cipher/Cast5.java, * gnu/javax/crypto/cipher/CipherFactory.java, * gnu/javax/crypto/cipher/DES.java, * gnu/javax/crypto/cipher/IBlockCipher.java, * gnu/javax/crypto/cipher/IBlockCipherSpi.java, * gnu/javax/crypto/cipher/Khazad.java, * gnu/javax/crypto/cipher/NullCipher.java, * gnu/javax/crypto/cipher/Rijndael.java, * gnu/javax/crypto/cipher/Serpent.java, * gnu/javax/crypto/cipher/Square.java, * gnu/javax/crypto/cipher/TripleDES.java, * gnu/javax/crypto/cipher/Twofish.java, * gnu/javax/crypto/cipher/WeakKeyException.java, * gnu/javax/crypto/jce/DiffieHellmanImpl.java, * gnu/javax/crypto/jce/GnuCrypto.java, * gnu/javax/crypto/jce/GnuSasl.java, * gnu/javax/crypto/jce/PBKDF2SecretKeyFactory.java, * gnu/javax/crypto/jce/cipher/AESKeyWrapSpi.java, * gnu/javax/crypto/jce/cipher/AESSpi.java, * gnu/javax/crypto/jce/cipher/ARCFourSpi.java, * gnu/javax/crypto/jce/cipher/AnubisSpi.java, * gnu/javax/crypto/jce/cipher/BlowfishSpi.java, * gnu/javax/crypto/jce/cipher/Cast5Spi.java, * gnu/javax/crypto/jce/cipher/CipherAdapter.java, * gnu/javax/crypto/jce/cipher/DESSpi.java, * gnu/javax/crypto/jce/cipher/KeyWrappingAlgorithmAdapter.java, * gnu/javax/crypto/jce/cipher/KhazadSpi.java, * gnu/javax/crypto/jce/cipher/NullCipherSpi.java, * gnu/javax/crypto/jce/cipher/PBES2.java, * gnu/javax/crypto/jce/cipher/RijndaelSpi.java, * gnu/javax/crypto/jce/cipher/SerpentSpi.java, * gnu/javax/crypto/jce/cipher/SquareSpi.java, * gnu/javax/crypto/jce/cipher/TripleDESSpi.java, * gnu/javax/crypto/jce/cipher/TwofishSpi.java, * gnu/javax/crypto/jce/key/AnubisSecretKeyFactoryImpl.java, * gnu/javax/crypto/jce/key/BlowfishSecretKeyFactoryImpl.java, * gnu/javax/crypto/jce/key/Cast5SecretKeyFactoryImpl.java, * gnu/javax/crypto/jce/key/SecretKeyGeneratorImpl.java, * gnu/javax/crypto/jce/keyring/GnuKeyring.java, * gnu/javax/crypto/jce/mac/HMacHavalSpi.java, * gnu/javax/crypto/jce/mac/HMacMD2Spi.java, * gnu/javax/crypto/jce/mac/HMacMD4Spi.java, * gnu/javax/crypto/jce/mac/HMacMD5Spi.java, * gnu/javax/crypto/jce/mac/HMacRipeMD128Spi.java, * gnu/javax/crypto/jce/mac/HMacRipeMD160Spi.java, * gnu/javax/crypto/jce/mac/HMacSHA160Spi.java, * gnu/javax/crypto/jce/mac/HMacSHA256Spi.java, * gnu/javax/crypto/jce/mac/HMacSHA384Spi.java, * gnu/javax/crypto/jce/mac/HMacSHA512Spi.java, * gnu/javax/crypto/jce/mac/HMacTigerSpi.java, * gnu/javax/crypto/jce/mac/HMacWhirlpoolSpi.java, * gnu/javax/crypto/jce/mac/MacAdapter.java, * gnu/javax/crypto/jce/mac/TMMH16Spi.java, * gnu/javax/crypto/jce/mac/UHash32Spi.java, * gnu/javax/crypto/jce/mac/UMac32Spi.java, * gnu/javax/crypto/jce/params/BlockCipherParameters.java, * gnu/javax/crypto/jce/params/DEREncodingException.java, * gnu/javax/crypto/jce/params/DERReader.java, * gnu/javax/crypto/jce/params/DERWriter.java, * gnu/javax/crypto/jce/prng/ARCFourRandomSpi.java, * gnu/javax/crypto/jce/prng/CSPRNGSpi.java, * gnu/javax/crypto/jce/prng/FortunaImpl.java, * gnu/javax/crypto/jce/prng/ICMRandomSpi.java, * gnu/javax/crypto/jce/prng/UMacRandomSpi.java, * gnu/javax/crypto/jce/sig/DHParameters.java, * gnu/javax/crypto/jce/spec/BlockCipherParameterSpec.java, * gnu/javax/crypto/jce/spec/TMMHParameterSpec.java, * gnu/javax/crypto/jce/spec/UMac32ParameterSpec.java, * gnu/javax/crypto/key/BaseKeyAgreementParty.java, * gnu/javax/crypto/key/GnuPBEKey.java, * gnu/javax/crypto/key/GnuSecretKey.java, * gnu/javax/crypto/key/IKeyAgreementParty.java, * gnu/javax/crypto/key/IncomingMessage.java, * gnu/javax/crypto/key/KeyAgreementException.java, * gnu/javax/crypto/key/KeyAgreementFactory.java, * gnu/javax/crypto/key/OutgoingMessage.java, * gnu/javax/crypto/key/dh/DHKeyPairPKCS8Codec.java, * gnu/javax/crypto/key/dh/DHKeyPairRawCodec.java, * gnu/javax/crypto/key/dh/DHKeyPairX509Codec.java, * gnu/javax/crypto/key/dh/DiffieHellmanKeyAgreement.java, * gnu/javax/crypto/key/dh/DiffieHellmanReceiver.java, * gnu/javax/crypto/key/dh/DiffieHellmanSender.java, * gnu/javax/crypto/key/dh/ElGamalKeyAgreement.java, * gnu/javax/crypto/key/dh/ElGamalReceiver.java, * gnu/javax/crypto/key/dh/ElGamalSender.java, * gnu/javax/crypto/key/dh/GnuDHKey.java, * gnu/javax/crypto/key/dh/GnuDHKeyPairGenerator.java, * gnu/javax/crypto/key/dh/GnuDHPrivateKey.java, * gnu/javax/crypto/key/dh/GnuDHPublicKey.java, * gnu/javax/crypto/key/dh/RFC2631.java, * gnu/javax/crypto/key/srp6/SRP6Host.java, * gnu/javax/crypto/key/srp6/SRP6KeyAgreement.java, * gnu/javax/crypto/key/srp6/SRP6SaslClient.java, * gnu/javax/crypto/key/srp6/SRP6SaslServer.java, * gnu/javax/crypto/key/srp6/SRP6TLSClient.java, * gnu/javax/crypto/key/srp6/SRP6TLSServer.java, * gnu/javax/crypto/key/srp6/SRP6User.java, * gnu/javax/crypto/key/srp6/SRPAlgorithm.java, * gnu/javax/crypto/key/srp6/SRPKey.java, * gnu/javax/crypto/key/srp6/SRPKeyPairGenerator.java, * gnu/javax/crypto/key/srp6/SRPKeyPairRawCodec.java, * gnu/javax/crypto/key/srp6/SRPPrivateKey.java, * gnu/javax/crypto/key/srp6/SRPPublicKey.java, * gnu/javax/crypto/keyring/AuthenticatedEntry.java, * gnu/javax/crypto/keyring/BaseKeyring.java, * gnu/javax/crypto/keyring/BinaryDataEntry.java, * gnu/javax/crypto/keyring/CertPathEntry.java, * gnu/javax/crypto/keyring/CertificateEntry.java, * gnu/javax/crypto/keyring/CompressedEntry.java, * gnu/javax/crypto/keyring/EncryptedEntry.java, * gnu/javax/crypto/keyring/Entry.java, * gnu/javax/crypto/keyring/EnvelopeEntry.java, * gnu/javax/crypto/keyring/GnuPrivateKeyring.java, * gnu/javax/crypto/keyring/GnuPublicKeyring.java, * gnu/javax/crypto/keyring/IKeyring.java, * gnu/javax/crypto/keyring/IPrivateKeyring.java, * gnu/javax/crypto/keyring/IPublicKeyring.java, * gnu/javax/crypto/keyring/MalformedKeyringException.java, * gnu/javax/crypto/keyring/MaskableEnvelopeEntry.java, * gnu/javax/crypto/keyring/MeteredInputStream.java, * gnu/javax/crypto/keyring/PasswordAuthenticatedEntry.java, * gnu/javax/crypto/keyring/PasswordEncryptedEntry.java, * gnu/javax/crypto/keyring/PasswordProtectedEntry.java, * gnu/javax/crypto/keyring/PrimitiveEntry.java, * gnu/javax/crypto/keyring/PrivateKeyEntry.java, * gnu/javax/crypto/keyring/Properties.java, * gnu/javax/crypto/keyring/PublicKeyEntry.java, * gnu/javax/crypto/kwa/BaseKeyWrappingAlgorithm.java, * gnu/javax/crypto/kwa/IKeyWrappingAlgorithm.java, * gnu/javax/crypto/kwa/KeyWrappingAlgorithmFactory.java, * gnu/javax/crypto/kwa/TripleDESKeyWrap.java, * gnu/javax/crypto/mac/BaseMac.java, * gnu/javax/crypto/mac/HMac.java, * gnu/javax/crypto/mac/HMacFactory.java, * gnu/javax/crypto/mac/IMac.java, * gnu/javax/crypto/mac/MacFactory.java, * gnu/javax/crypto/mac/MacInputStream.java, * gnu/javax/crypto/mac/MacOutputStream.java, * gnu/javax/crypto/mac/OMAC.java, * gnu/javax/crypto/mac/TMMH16.java, * gnu/javax/crypto/mac/UHash32.java, * gnu/javax/crypto/mac/UMac32.java, * gnu/javax/crypto/mode/BaseMode.java, * gnu/javax/crypto/mode/CBC.java, * gnu/javax/crypto/mode/CFB.java, * gnu/javax/crypto/mode/CTR.java, * gnu/javax/crypto/mode/EAX.java, * gnu/javax/crypto/mode/ECB.java, * gnu/javax/crypto/mode/IAuthenticatedMode.java, * gnu/javax/crypto/mode/ICM.java, * gnu/javax/crypto/mode/IMode.java, * gnu/javax/crypto/mode/ModeFactory.java, * gnu/javax/crypto/mode/OFB.java, * gnu/javax/crypto/pad/BasePad.java, * gnu/javax/crypto/pad/IPad.java, * gnu/javax/crypto/pad/PKCS1_V1_5.java, * gnu/javax/crypto/pad/PKCS7.java, * gnu/javax/crypto/pad/PadFactory.java, * gnu/javax/crypto/pad/TBC.java, * gnu/javax/crypto/pad/WrongPaddingException.java, * gnu/javax/crypto/prng/ARCFour.java, * gnu/javax/crypto/prng/CSPRNG.java, * gnu/javax/crypto/prng/ICMGenerator.java, * gnu/javax/crypto/prng/IPBE.java, * gnu/javax/crypto/prng/PBKDF2.java, * gnu/javax/crypto/prng/PRNGFactory.java, * gnu/javax/crypto/prng/UMacGenerator.java, * gnu/javax/crypto/sasl/AuthInfo.java, * gnu/javax/crypto/sasl/AuthInfoProviderFactory.java, * gnu/javax/crypto/sasl/ClientFactory.java, * gnu/javax/crypto/sasl/ClientMechanism.java, * gnu/javax/crypto/sasl/ConfidentialityException.java, * gnu/javax/crypto/sasl/IAuthInfoProvider.java, * gnu/javax/crypto/sasl/IAuthInfoProviderFactory.java, * gnu/javax/crypto/sasl/IllegalMechanismStateException.java, * gnu/javax/crypto/sasl/InputBuffer.java, * gnu/javax/crypto/sasl/IntegrityException.java, * gnu/javax/crypto/sasl/NoSuchMechanismException.java, * gnu/javax/crypto/sasl/NoSuchUserException.java, * gnu/javax/crypto/sasl/OutputBuffer.java, * gnu/javax/crypto/sasl/SaslEncodingException.java, * gnu/javax/crypto/sasl/SaslInputStream.java, * gnu/javax/crypto/sasl/SaslOutputStream.java, * gnu/javax/crypto/sasl/SaslUtil.java, * gnu/javax/crypto/sasl/ServerFactory.java, * gnu/javax/crypto/sasl/ServerMechanism.java, * gnu/javax/crypto/sasl/UserAlreadyExistsException.java, * gnu/javax/crypto/sasl/anonymous/AnonymousClient.java, * gnu/javax/crypto/sasl/anonymous/AnonymousServer.java, * gnu/javax/crypto/sasl/anonymous/AnonymousUtil.java, * gnu/javax/crypto/sasl/crammd5/CramMD5AuthInfoProvider.java, * gnu/javax/crypto/sasl/crammd5/CramMD5Client.java, * gnu/javax/crypto/sasl/crammd5/CramMD5Registry.java, * gnu/javax/crypto/sasl/crammd5/CramMD5Server.java, * gnu/javax/crypto/sasl/crammd5/CramMD5Util.java, * gnu/javax/crypto/sasl/crammd5/PasswordFile.java, * gnu/javax/crypto/sasl/plain/PasswordFile.java, * gnu/javax/crypto/sasl/plain/PlainAuthInfoProvider.java, * gnu/javax/crypto/sasl/plain/PlainClient.java, * gnu/javax/crypto/sasl/plain/PlainRegistry.java, * gnu/javax/crypto/sasl/plain/PlainServer.java, * gnu/javax/crypto/sasl/srp/CALG.java, * gnu/javax/crypto/sasl/srp/ClientStore.java, * gnu/javax/crypto/sasl/srp/IALG.java, * gnu/javax/crypto/sasl/srp/KDF.java, * gnu/javax/crypto/sasl/srp/PasswordFile.java, * gnu/javax/crypto/sasl/srp/SRP.java, * gnu/javax/crypto/sasl/srp/SRPAuthInfoProvider.java, * gnu/javax/crypto/sasl/srp/SRPClient.java, * gnu/javax/crypto/sasl/srp/SRPRegistry.java, * gnu/javax/crypto/sasl/srp/SRPServer.java, * gnu/javax/crypto/sasl/srp/SecurityContext.java, * gnu/javax/crypto/sasl/srp/ServerStore.java, * gnu/javax/crypto/sasl/srp/StoreEntry.java, * gnu/javax/imageio/IIOInputStream.java, * gnu/javax/imageio/bmp/BMPDecoder.java, * gnu/javax/imageio/bmp/BMPEncoder.java, * gnu/javax/imageio/bmp/BMPException.java, * gnu/javax/imageio/bmp/BMPFileHeader.java, * gnu/javax/imageio/bmp/BMPImageReader.java, * gnu/javax/imageio/bmp/BMPImageReaderSpi.java, * gnu/javax/imageio/bmp/BMPImageWriter.java, * gnu/javax/imageio/bmp/BMPImageWriterSpi.java, * gnu/javax/imageio/bmp/BMPInfoHeader.java, * gnu/javax/imageio/bmp/DecodeBF16.java, * gnu/javax/imageio/bmp/DecodeBF32.java, * gnu/javax/imageio/bmp/DecodeRGB1.java, * gnu/javax/imageio/bmp/DecodeRGB24.java, * gnu/javax/imageio/bmp/DecodeRGB4.java, * gnu/javax/imageio/bmp/DecodeRGB8.java, * gnu/javax/imageio/bmp/DecodeRLE4.java, * gnu/javax/imageio/bmp/DecodeRLE8.java, * gnu/javax/imageio/bmp/EncodeRGB1.java, * gnu/javax/imageio/bmp/EncodeRGB16.java, * gnu/javax/imageio/bmp/EncodeRGB24.java, * gnu/javax/imageio/bmp/EncodeRGB32.java, * gnu/javax/imageio/bmp/EncodeRGB4.java, * gnu/javax/imageio/bmp/EncodeRGB8.java, * gnu/javax/imageio/bmp/EncodeRLE4.java, * gnu/javax/imageio/bmp/EncodeRLE8.java, * gnu/javax/imageio/gif/GIFFile.java, * gnu/javax/imageio/gif/GIFImageReader.java, * gnu/javax/imageio/gif/GIFImageReaderSpi.java, * gnu/javax/imageio/jpeg/DCT.java, * gnu/javax/imageio/jpeg/JPEGComponent.java, * gnu/javax/imageio/jpeg/JPEGDecoder.java, * gnu/javax/imageio/jpeg/JPEGImageInputStream.java, * gnu/javax/imageio/jpeg/JPEGImageReader.java, * gnu/javax/imageio/jpeg/JPEGImageReaderSpi.java, * gnu/javax/imageio/jpeg/JPEGMarker.java, * gnu/javax/imageio/jpeg/ZigZag.java, * gnu/javax/imageio/png/PNGChunk.java, * gnu/javax/imageio/png/PNGData.java, * gnu/javax/imageio/png/PNGDecoder.java, * gnu/javax/imageio/png/PNGEncoder.java, * gnu/javax/imageio/png/PNGException.java, * gnu/javax/imageio/png/PNGFile.java, * gnu/javax/imageio/png/PNGFilter.java, * gnu/javax/imageio/png/PNGGamma.java, * gnu/javax/imageio/png/PNGHeader.java, * gnu/javax/imageio/png/PNGICCProfile.java, * gnu/javax/imageio/png/PNGImageReader.java, * gnu/javax/imageio/png/PNGPalette.java, * gnu/javax/imageio/png/PNGPhys.java, * gnu/javax/imageio/png/PNGTime.java, * gnu/javax/management/ListenerData.java, * gnu/javax/management/Server.java, * gnu/javax/management/Translator.java, * gnu/javax/naming/giop/ContextContinuation.java, * gnu/javax/naming/giop/CorbalocParser.java, * gnu/javax/naming/giop/GiopNamingEnumeration.java, * gnu/javax/naming/giop/GiopNamingServiceFactory.java, * gnu/javax/naming/giop/GiopNamingServiceURLContext.java, * gnu/javax/naming/giop/ListBindingsEnumeration.java, * gnu/javax/naming/giop/ListEnumeration.java, * gnu/javax/naming/ictxImpl/trans/GnuName.java, * gnu/javax/naming/jndi/url/corbaname/corbanameURLContextFactory.java, * gnu/javax/naming/jndi/url/rmi/ContextContinuation.java, * gnu/javax/naming/jndi/url/rmi/ListBindingsEnumeration.java, * gnu/javax/naming/jndi/url/rmi/ListEnumeration.java, * gnu/javax/naming/jndi/url/rmi/RmiContinuation.java, * gnu/javax/naming/jndi/url/rmi/RmiNamingEnumeration.java, * gnu/javax/naming/jndi/url/rmi/rmiURLContext.java, * gnu/javax/naming/jndi/url/rmi/rmiURLContextFactory.java, * gnu/javax/net/ssl/AbstractSessionContext.java, * gnu/javax/net/ssl/PreSharedKeyManager.java, * gnu/javax/net/ssl/PreSharedKeyManagerParameters.java, * gnu/javax/net/ssl/SSLCipherSuite.java, * gnu/javax/net/ssl/SSLRecordHandler.java, * gnu/javax/net/ssl/Session.java, * gnu/javax/net/ssl/SessionStoreException.java, * gnu/javax/net/ssl/provider/AbstractHandshake.java, * gnu/javax/net/ssl/provider/Alert.java, * gnu/javax/net/ssl/provider/AlertException.java, * gnu/javax/net/ssl/provider/Builder.java, * gnu/javax/net/ssl/provider/Certificate.java, * gnu/javax/net/ssl/provider/CertificateBuilder.java, * gnu/javax/net/ssl/provider/CertificateRequest.java, * gnu/javax/net/ssl/provider/CertificateRequestBuilder.java, * gnu/javax/net/ssl/provider/CertificateStatusRequest.java, * gnu/javax/net/ssl/provider/CertificateStatusType.java, * gnu/javax/net/ssl/provider/CertificateURL.java, * gnu/javax/net/ssl/provider/CertificateVerify.java, * gnu/javax/net/ssl/provider/CipherSuite.java, * gnu/javax/net/ssl/provider/CipherSuiteList.java, * gnu/javax/net/ssl/provider/ClientCertificateTypeList.java, * gnu/javax/net/ssl/provider/ClientDHE_PSKParameters.java, * gnu/javax/net/ssl/provider/ClientDiffieHellmanPublic.java, * gnu/javax/net/ssl/provider/ClientHandshake.java, * gnu/javax/net/ssl/provider/ClientHello.java, * gnu/javax/net/ssl/provider/ClientHelloBuilder.java, * gnu/javax/net/ssl/provider/ClientHelloV2.java, * gnu/javax/net/ssl/provider/ClientKeyExchangeBuilder.java, * gnu/javax/net/ssl/provider/ClientPSKParameters.java, * gnu/javax/net/ssl/provider/ClientRSA_PSKParameters.java, * gnu/javax/net/ssl/provider/CompressionMethod.java, * gnu/javax/net/ssl/provider/CompressionMethodList.java, * gnu/javax/net/ssl/provider/Constructed.java, * gnu/javax/net/ssl/provider/Debug.java, * gnu/javax/net/ssl/provider/DelegatedTask.java, * gnu/javax/net/ssl/provider/EmptyExchangeKeys.java, * gnu/javax/net/ssl/provider/EncryptedPreMasterSecret.java, * gnu/javax/net/ssl/provider/ExchangeKeys.java, * gnu/javax/net/ssl/provider/Extension.java, * gnu/javax/net/ssl/provider/ExtensionList.java, * gnu/javax/net/ssl/provider/Handshake.java, * gnu/javax/net/ssl/provider/InputSecurityParameters.java, * gnu/javax/net/ssl/provider/Jessie.java, * gnu/javax/net/ssl/provider/MaxFragmentLength.java, * gnu/javax/net/ssl/provider/OutputSecurityParameters.java, * gnu/javax/net/ssl/provider/PreSharedKeyManagerFactoryImpl.java, * gnu/javax/net/ssl/provider/Random.java, * gnu/javax/net/ssl/provider/SSLContextImpl.java, * gnu/javax/net/ssl/provider/SSLEngineImpl.java, * gnu/javax/net/ssl/provider/SSLRSASignatureImpl.java, * gnu/javax/net/ssl/provider/SSLServerSocketFactoryImpl.java, * gnu/javax/net/ssl/provider/SSLServerSocketImpl.java, * gnu/javax/net/ssl/provider/SSLSocketFactoryImpl.java, * gnu/javax/net/ssl/provider/SSLSocketImpl.java, * gnu/javax/net/ssl/provider/SSLv3HMacMD5Impl.java, * gnu/javax/net/ssl/provider/SSLv3HMacSHAImpl.java, * gnu/javax/net/ssl/provider/ServerDHE_PSKParameters.java, * gnu/javax/net/ssl/provider/ServerDHParams.java, * gnu/javax/net/ssl/provider/ServerHandshake.java, * gnu/javax/net/ssl/provider/ServerHello.java, * gnu/javax/net/ssl/provider/ServerHelloBuilder.java, * gnu/javax/net/ssl/provider/ServerHelloDone.java, * gnu/javax/net/ssl/provider/ServerKeyExchangeBuilder.java, * gnu/javax/net/ssl/provider/ServerNameList.java, * gnu/javax/net/ssl/provider/ServerPSKParameters.java, * gnu/javax/net/ssl/provider/ServerRSA_PSKParameters.java, * gnu/javax/net/ssl/provider/SessionImpl.java, * gnu/javax/net/ssl/provider/Signature.java, * gnu/javax/net/ssl/provider/SignatureAlgorithm.java, * gnu/javax/net/ssl/provider/SimpleSessionContext.java, * gnu/javax/net/ssl/provider/TruncatedHMAC.java, * gnu/javax/net/ssl/provider/TrustedAuthorities.java, * gnu/javax/net/ssl/provider/UnresolvedExtensionValue.java, * gnu/javax/net/ssl/provider/Util.java, * gnu/javax/net/ssl/provider/X500PrincipalList.java, * gnu/javax/net/ssl/provider/X509KeyManagerFactory.java, * gnu/javax/net/ssl/provider/X509TrustManagerFactory.java, * gnu/javax/print/ipp/IppRequest.java, * gnu/javax/rmi/CORBA/CorbaInput.java, * gnu/javax/rmi/CORBA/CorbaOutput.java, * gnu/javax/rmi/CORBA/DefaultWriteObjectTester.java, * gnu/javax/rmi/CORBA/DelegateFactory.java, * gnu/javax/rmi/CORBA/GetDelegateInstanceException.java, * gnu/javax/rmi/CORBA/PortableRemoteObjectDelegateImpl.java, * gnu/javax/rmi/CORBA/RmiUtilities.java, * gnu/javax/rmi/CORBA/StubDelegateImpl.java, * gnu/javax/rmi/CORBA/TieTargetRecord.java, * gnu/javax/rmi/CORBA/UtilDelegateImpl.java, * gnu/javax/rmi/CORBA/ValueHandlerDelegateImpl.java, * gnu/javax/security/auth/callback/AWTCallbackHandler.java, * gnu/javax/security/auth/callback/AbstractCallbackHandler.java, * gnu/javax/security/auth/callback/CertificateCallback.java, * gnu/javax/security/auth/callback/ConsoleCallbackHandler.java, * gnu/javax/security/auth/callback/DefaultCallbackHandler.java, * gnu/javax/security/auth/callback/SwingCallbackHandler.java, * gnu/javax/security/auth/login/ConfigFileParser.java, * gnu/javax/security/auth/login/ConfigFileTokenizer.java, * gnu/javax/security/auth/login/GnuConfiguration.java, * gnu/javax/sound/AudioSecurityManager.java, * gnu/javax/sound/midi/alsa/AlsaInputPortDevice.java, * gnu/javax/sound/midi/alsa/AlsaMidiDeviceProvider.java, * gnu/javax/sound/midi/alsa/AlsaMidiSequencerDevice.java, * gnu/javax/sound/midi/alsa/AlsaOutputPortDevice.java, * gnu/javax/sound/midi/alsa/AlsaPortDevice.java, * gnu/javax/sound/midi/dssi/DSSIMidiDeviceProvider.java, * gnu/javax/sound/midi/dssi/DSSISynthesizer.java, * gnu/javax/sound/midi/file/ExtendedMidiFileFormat.java, * gnu/javax/sound/midi/file/MidiDataInputStream.java, * gnu/javax/sound/midi/file/MidiDataOutputStream.java, * gnu/javax/sound/midi/file/MidiFileReader.java, * gnu/javax/sound/midi/file/MidiFileWriter.java, * gnu/javax/sound/sampled/AU/AUReader.java, * gnu/javax/sound/sampled/WAV/WAVReader.java, * gnu/javax/sound/sampled/gstreamer/GStreamerMixer.java, * gnu/javax/sound/sampled/gstreamer/GStreamerMixerProvider.java, * gnu/javax/sound/sampled/gstreamer/io/GstAudioFileReader.java, * gnu/javax/sound/sampled/gstreamer/io/GstAudioFileReaderNativePeer.java, * gnu/javax/sound/sampled/gstreamer/io/GstInputStream.java, * gnu/javax/sound/sampled/gstreamer/lines/GstDataLine.java, * gnu/javax/sound/sampled/gstreamer/lines/GstNativeDataLine.java, * gnu/javax/sound/sampled/gstreamer/lines/GstPipeline.java, * gnu/javax/sound/sampled/gstreamer/lines/GstSourceDataLine.java, * gnu/javax/swing/plaf/gnu/GNULookAndFeel.java, * gnu/javax/swing/text/html/CharacterAttributeTranslator.java, * gnu/javax/swing/text/html/CombinedAttributes.java, * gnu/javax/swing/text/html/ImageViewIconFactory.java, * gnu/javax/swing/text/html/css/BorderStyle.java, * gnu/javax/swing/text/html/css/CSSParser.java, * gnu/javax/swing/text/html/css/CSSScanner.java, * gnu/javax/swing/text/html/css/Selector.java, * gnu/javax/swing/text/html/parser/GnuParserDelegator.java, * gnu/javax/swing/text/html/parser/HTML_401F.java, * gnu/javax/swing/text/html/parser/SmallHtmlAttributeSet.java, * gnu/javax/swing/text/html/parser/htmlAttributeSet.java, * gnu/javax/swing/text/html/parser/htmlValidator.java, * gnu/javax/swing/text/html/parser/models/list.java, * gnu/javax/swing/text/html/parser/support/Parser.java, * gnu/javax/swing/text/html/parser/support/low/ReaderTokenizer.java, * gnu/javax/swing/text/html/parser/support/textPreProcessor.java, * gnu/javax/swing/tree/GnuPath.java, * gnu/test/Fail.java, * gnu/test/Pass.java, * gnu/test/Test.java, * gnu/test/Unsupported.java, * gnu/xml/aelfred2/JAXPFactory.java, * gnu/xml/aelfred2/SAXDriver.java, * gnu/xml/aelfred2/XmlParser.java, * gnu/xml/aelfred2/XmlReader.java, * gnu/xml/dom/Consumer.java, * gnu/xml/dom/DTDAttributeTypeInfo.java, * gnu/xml/dom/DTDElementTypeInfo.java, * gnu/xml/dom/DomAttr.java, * gnu/xml/dom/DomCDATASection.java, * gnu/xml/dom/DomCharacterData.java, * gnu/xml/dom/DomComment.java, * gnu/xml/dom/DomDOMException.java, * gnu/xml/dom/DomDoctype.java, * gnu/xml/dom/DomDocument.java, * gnu/xml/dom/DomDocumentBuilder.java, * gnu/xml/dom/DomDocumentBuilderFactory.java, * gnu/xml/dom/DomDocumentConfiguration.java, * gnu/xml/dom/DomDocumentFragment.java, * gnu/xml/dom/DomElement.java, * gnu/xml/dom/DomEntity.java, * gnu/xml/dom/DomEntityReference.java, * gnu/xml/dom/DomEvent.java, * gnu/xml/dom/DomExtern.java, * gnu/xml/dom/DomImpl.java, * gnu/xml/dom/DomIterator.java, * gnu/xml/dom/DomNSResolverContext.java, * gnu/xml/dom/DomNamedNodeMap.java, * gnu/xml/dom/DomNode.java, * gnu/xml/dom/DomNodeIterator.java, * gnu/xml/dom/DomNotation.java, * gnu/xml/dom/DomNsNode.java, * gnu/xml/dom/DomProcessingInstruction.java, * gnu/xml/dom/DomText.java, * gnu/xml/dom/DomXPathExpression.java, * gnu/xml/dom/DomXPathNSResolver.java, * gnu/xml/dom/DomXPathResult.java, * gnu/xml/dom/ImplementationList.java, * gnu/xml/dom/ImplementationSource.java, * gnu/xml/dom/JAXPFactory.java, * gnu/xml/dom/html2/DomHTMLAnchorElement.java, * gnu/xml/dom/html2/DomHTMLAppletElement.java, * gnu/xml/dom/html2/DomHTMLAreaElement.java, * gnu/xml/dom/html2/DomHTMLBRElement.java, * gnu/xml/dom/html2/DomHTMLBaseElement.java, * gnu/xml/dom/html2/DomHTMLBaseFontElement.java, * gnu/xml/dom/html2/DomHTMLBodyElement.java, * gnu/xml/dom/html2/DomHTMLButtonElement.java, * gnu/xml/dom/html2/DomHTMLCollection.java, * gnu/xml/dom/html2/DomHTMLDListElement.java, * gnu/xml/dom/html2/DomHTMLDirectoryElement.java, * gnu/xml/dom/html2/DomHTMLDivElement.java, * gnu/xml/dom/html2/DomHTMLDocument.java, * gnu/xml/dom/html2/DomHTMLElement.java, * gnu/xml/dom/html2/DomHTMLEmbedElement.java, * gnu/xml/dom/html2/DomHTMLFieldSetElement.java, * gnu/xml/dom/html2/DomHTMLFontElement.java, * gnu/xml/dom/html2/DomHTMLFormElement.java, * gnu/xml/dom/html2/DomHTMLFrameElement.java, * gnu/xml/dom/html2/DomHTMLFrameSetElement.java, * gnu/xml/dom/html2/DomHTMLHRElement.java, * gnu/xml/dom/html2/DomHTMLHeadElement.java, * gnu/xml/dom/html2/DomHTMLHeadingElement.java, * gnu/xml/dom/html2/DomHTMLHtmlElement.java, * gnu/xml/dom/html2/DomHTMLIFrameElement.java, * gnu/xml/dom/html2/DomHTMLImageElement.java, * gnu/xml/dom/html2/DomHTMLImpl.java, * gnu/xml/dom/html2/DomHTMLInputElement.java, * gnu/xml/dom/html2/DomHTMLIsIndexElement.java, * gnu/xml/dom/html2/DomHTMLLIElement.java, * gnu/xml/dom/html2/DomHTMLLabelElement.java, * gnu/xml/dom/html2/DomHTMLLegendElement.java, * gnu/xml/dom/html2/DomHTMLLinkElement.java, * gnu/xml/dom/html2/DomHTMLMapElement.java, * gnu/xml/dom/html2/DomHTMLMenuElement.java, * gnu/xml/dom/html2/DomHTMLMetaElement.java, * gnu/xml/dom/html2/DomHTMLModElement.java, * gnu/xml/dom/html2/DomHTMLOListElement.java, * gnu/xml/dom/html2/DomHTMLObjectElement.java, * gnu/xml/dom/html2/DomHTMLOptGroupElement.java, * gnu/xml/dom/html2/DomHTMLOptionElement.java, * gnu/xml/dom/html2/DomHTMLParagraphElement.java, * gnu/xml/dom/html2/DomHTMLParamElement.java, * gnu/xml/dom/html2/DomHTMLParser.java, * gnu/xml/dom/html2/DomHTMLPreElement.java, * gnu/xml/dom/html2/DomHTMLQuoteElement.java, * gnu/xml/dom/html2/DomHTMLScriptElement.java, * gnu/xml/dom/html2/DomHTMLSelectElement.java, * gnu/xml/dom/html2/DomHTMLStyleElement.java, * gnu/xml/dom/html2/DomHTMLTableCaptionElement.java, * gnu/xml/dom/html2/DomHTMLTableCellElement.java, * gnu/xml/dom/html2/DomHTMLTableColElement.java, * gnu/xml/dom/html2/DomHTMLTableElement.java, * gnu/xml/dom/html2/DomHTMLTableRowElement.java, * gnu/xml/dom/html2/DomHTMLTableSectionElement.java, * gnu/xml/dom/html2/DomHTMLTextAreaElement.java, * gnu/xml/dom/html2/DomHTMLTitleElement.java, * gnu/xml/dom/html2/DomHTMLUListElement.java, * gnu/xml/dom/ls/DomLSException.java, * gnu/xml/dom/ls/DomLSInput.java, * gnu/xml/dom/ls/DomLSOutput.java, * gnu/xml/dom/ls/DomLSParser.java, * gnu/xml/dom/ls/DomLSSerializer.java, * gnu/xml/dom/ls/FilteredSAXEventSink.java, * gnu/xml/dom/ls/ReaderInputStream.java, * gnu/xml/dom/ls/SAXEventSink.java, * gnu/xml/dom/ls/WriterOutputStream.java, * gnu/xml/libxmlj/dom/GnomeAttr.java, * gnu/xml/libxmlj/dom/GnomeCDATASection.java, * gnu/xml/libxmlj/dom/GnomeCharacterData.java, * gnu/xml/libxmlj/dom/GnomeComment.java, * gnu/xml/libxmlj/dom/GnomeDOMException.java, * gnu/xml/libxmlj/dom/GnomeDOMStringList.java, * gnu/xml/libxmlj/dom/GnomeDocument.java, * gnu/xml/libxmlj/dom/GnomeDocumentBuilder.java, * gnu/xml/libxmlj/dom/GnomeDocumentBuilderFactory.java, * gnu/xml/libxmlj/dom/GnomeDocumentFragment.java, * gnu/xml/libxmlj/dom/GnomeDocumentType.java, * gnu/xml/libxmlj/dom/GnomeElement.java, * gnu/xml/libxmlj/dom/GnomeEntity.java, * gnu/xml/libxmlj/dom/GnomeEntityReference.java, * gnu/xml/libxmlj/dom/GnomeNamedNodeMap.java, * gnu/xml/libxmlj/dom/GnomeNode.java, * gnu/xml/libxmlj/dom/GnomeNodeList.java, * gnu/xml/libxmlj/dom/GnomeNotation.java, * gnu/xml/libxmlj/dom/GnomeProcessingInstruction.java, * gnu/xml/libxmlj/dom/GnomeText.java, * gnu/xml/libxmlj/dom/GnomeTypeInfo.java, * gnu/xml/libxmlj/dom/GnomeXPathExpression.java, * gnu/xml/libxmlj/dom/GnomeXPathNSResolver.java, * gnu/xml/libxmlj/dom/GnomeXPathNodeList.java, * gnu/xml/libxmlj/dom/GnomeXPathResult.java, * gnu/xml/libxmlj/sax/GnomeLocator.java, * gnu/xml/libxmlj/sax/GnomeSAXParser.java, * gnu/xml/libxmlj/sax/GnomeSAXParserFactory.java, * gnu/xml/libxmlj/sax/GnomeXMLReader.java, * gnu/xml/libxmlj/sax/Namespaces.java, * gnu/xml/libxmlj/sax/StringArrayAttributes.java, * gnu/xml/libxmlj/sax/XMLName.java, * gnu/xml/libxmlj/transform/ErrorListenerErrorHandler.java, * gnu/xml/libxmlj/transform/GnomeTransformer.java, * gnu/xml/libxmlj/transform/GnomeTransformerFactory.java, * gnu/xml/libxmlj/transform/URIResolverEntityResolver.java, * gnu/xml/libxmlj/util/EmptyNodeList.java, * gnu/xml/libxmlj/util/NamedInputStream.java, * gnu/xml/libxmlj/util/StandaloneDocumentType.java, * gnu/xml/libxmlj/util/StandaloneLocator.java, * gnu/xml/libxmlj/util/XMLJ.java, * gnu/xml/pipeline/CallFilter.java, * gnu/xml/pipeline/DomConsumer.java, * gnu/xml/pipeline/EventConsumer.java, * gnu/xml/pipeline/EventFilter.java, * gnu/xml/pipeline/LinkFilter.java, * gnu/xml/pipeline/NSFilter.java, * gnu/xml/pipeline/PipelineFactory.java, * gnu/xml/pipeline/TeeConsumer.java, * gnu/xml/pipeline/TextConsumer.java, * gnu/xml/pipeline/ValidationConsumer.java, * gnu/xml/pipeline/WellFormednessFilter.java, * gnu/xml/pipeline/XIncludeFilter.java, * gnu/xml/pipeline/XsltFilter.java, * gnu/xml/stream/AttributeImpl.java, * gnu/xml/stream/BufferedReader.java, * gnu/xml/stream/CRLFReader.java, * gnu/xml/stream/CharactersImpl.java, * gnu/xml/stream/CommentImpl.java, * gnu/xml/stream/DTDImpl.java, * gnu/xml/stream/EndDocumentImpl.java, * gnu/xml/stream/EndElementImpl.java, * gnu/xml/stream/EntityDeclarationImpl.java, * gnu/xml/stream/EntityReferenceImpl.java, * gnu/xml/stream/FilteredEventReader.java, * gnu/xml/stream/FilteredStreamReader.java, * gnu/xml/stream/NamespaceImpl.java, * gnu/xml/stream/NotationDeclarationImpl.java, * gnu/xml/stream/ProcessingInstructionImpl.java, * gnu/xml/stream/SAXParser.java, * gnu/xml/stream/SAXParserFactory.java, * gnu/xml/stream/StartDocumentImpl.java, * gnu/xml/stream/StartElementImpl.java, * gnu/xml/stream/UnicodeReader.java, * gnu/xml/stream/XIncludeFilter.java, * gnu/xml/stream/XMLEventAllocatorImpl.java, * gnu/xml/stream/XMLEventFactoryImpl.java, * gnu/xml/stream/XMLEventImpl.java, * gnu/xml/stream/XMLEventReaderImpl.java, * gnu/xml/stream/XMLEventWriterImpl.java, * gnu/xml/stream/XMLInputFactoryImpl.java, * gnu/xml/stream/XMLOutputFactoryImpl.java, * gnu/xml/stream/XMLParser.java, * gnu/xml/stream/XMLStreamWriterImpl.java, * gnu/xml/transform/AbstractNumberNode.java, * gnu/xml/transform/ApplyImportsNode.java, * gnu/xml/transform/ApplyTemplatesNode.java, * gnu/xml/transform/AttributeNode.java, * gnu/xml/transform/AttributeSet.java, * gnu/xml/transform/Bindings.java, * gnu/xml/transform/CallTemplateNode.java, * gnu/xml/transform/ChooseNode.java, * gnu/xml/transform/CommentNode.java, * gnu/xml/transform/CopyNode.java, * gnu/xml/transform/CopyOfNode.java, * gnu/xml/transform/CurrentFunction.java, * gnu/xml/transform/DOMSourceLocator.java, * gnu/xml/transform/DocumentFunction.java, * gnu/xml/transform/ElementAvailableFunction.java, * gnu/xml/transform/ElementNode.java, * gnu/xml/transform/ErrorListenerErrorHandler.java, * gnu/xml/transform/ForEachNode.java, * gnu/xml/transform/FormatNumberFunction.java, * gnu/xml/transform/FunctionAvailableFunction.java, * gnu/xml/transform/GenerateIdFunction.java, * gnu/xml/transform/IfNode.java, * gnu/xml/transform/Key.java, * gnu/xml/transform/KeyFunction.java, * gnu/xml/transform/LiteralNode.java, * gnu/xml/transform/MessageNode.java, * gnu/xml/transform/NamespaceProxy.java, * gnu/xml/transform/NodeNumberNode.java, * gnu/xml/transform/NumberNode.java, * gnu/xml/transform/OtherwiseNode.java, * gnu/xml/transform/ParameterNode.java, * gnu/xml/transform/ProcessingInstructionNode.java, * gnu/xml/transform/SAXSerializer.java, * gnu/xml/transform/SAXTemplatesHandler.java, * gnu/xml/transform/SAXTransformerHandler.java, * gnu/xml/transform/SortKey.java, * gnu/xml/transform/StreamSerializer.java, * gnu/xml/transform/StrippingInstruction.java, * gnu/xml/transform/Stylesheet.java, * gnu/xml/transform/SystemPropertyFunction.java, * gnu/xml/transform/Template.java, * gnu/xml/transform/TemplateNode.java, * gnu/xml/transform/TemplatesImpl.java, * gnu/xml/transform/TextNode.java, * gnu/xml/transform/TransformerFactoryImpl.java, * gnu/xml/transform/TransformerImpl.java, * gnu/xml/transform/TransformerOutputProperties.java, * gnu/xml/transform/URIResolverEntityResolver.java, * gnu/xml/transform/UnparsedEntityUriFunction.java, * gnu/xml/transform/ValueOfNode.java, * gnu/xml/transform/WhenNode.java, * gnu/xml/transform/WithParam.java, * gnu/xml/transform/XSLComparator.java, * gnu/xml/transform/XSLURIResolver.java, * gnu/xml/util/DoParse.java, * gnu/xml/util/DomParser.java, * gnu/xml/util/Resolver.java, * gnu/xml/util/SAXNullTransformerFactory.java, * gnu/xml/util/XCat.java, * gnu/xml/util/XHTMLWriter.java, * gnu/xml/util/XMLWriter.java, * gnu/xml/validation/datatype/Annotation.java, * gnu/xml/validation/datatype/AnySimpleType.java, * gnu/xml/validation/datatype/AnyType.java, * gnu/xml/validation/datatype/AnyURIType.java, * gnu/xml/validation/datatype/AtomicSimpleType.java, * gnu/xml/validation/datatype/Base64BinaryType.java, * gnu/xml/validation/datatype/BooleanType.java, * gnu/xml/validation/datatype/ByteType.java, * gnu/xml/validation/datatype/DateTimeType.java, * gnu/xml/validation/datatype/DateType.java, * gnu/xml/validation/datatype/DecimalType.java, * gnu/xml/validation/datatype/DoubleType.java, * gnu/xml/validation/datatype/DurationType.java, * gnu/xml/validation/datatype/EntitiesType.java, * gnu/xml/validation/datatype/EntityType.java, * gnu/xml/validation/datatype/EnumerationFacet.java, * gnu/xml/validation/datatype/Facet.java, * gnu/xml/validation/datatype/FloatType.java, * gnu/xml/validation/datatype/FractionDigitsFacet.java, * gnu/xml/validation/datatype/GDayType.java, * gnu/xml/validation/datatype/GMonthDayType.java, * gnu/xml/validation/datatype/GMonthType.java, * gnu/xml/validation/datatype/GYearMonthType.java, * gnu/xml/validation/datatype/GYearType.java, * gnu/xml/validation/datatype/HexBinaryType.java, * gnu/xml/validation/datatype/IDRefType.java, * gnu/xml/validation/datatype/IDRefsType.java, * gnu/xml/validation/datatype/IDType.java, * gnu/xml/validation/datatype/IntType.java, * gnu/xml/validation/datatype/IntegerType.java, * gnu/xml/validation/datatype/LanguageType.java, * gnu/xml/validation/datatype/LengthFacet.java, * gnu/xml/validation/datatype/ListSimpleType.java, * gnu/xml/validation/datatype/LongType.java, * gnu/xml/validation/datatype/MaxExclusiveFacet.java, * gnu/xml/validation/datatype/MaxInclusiveFacet.java, * gnu/xml/validation/datatype/MaxLengthFacet.java, * gnu/xml/validation/datatype/MinExclusiveFacet.java, * gnu/xml/validation/datatype/MinInclusiveFacet.java, * gnu/xml/validation/datatype/MinLengthFacet.java, * gnu/xml/validation/datatype/NCNameType.java, * gnu/xml/validation/datatype/NMTokenType.java, * gnu/xml/validation/datatype/NMTokensType.java, * gnu/xml/validation/datatype/NameType.java, * gnu/xml/validation/datatype/NegativeIntegerType.java, * gnu/xml/validation/datatype/NonNegativeIntegerType.java, * gnu/xml/validation/datatype/NonPositiveIntegerType.java, * gnu/xml/validation/datatype/NormalizedStringType.java, * gnu/xml/validation/datatype/NotationType.java, * gnu/xml/validation/datatype/PatternFacet.java, * gnu/xml/validation/datatype/PositiveIntegerType.java, * gnu/xml/validation/datatype/QNameType.java, * gnu/xml/validation/datatype/ShortType.java, * gnu/xml/validation/datatype/SimpleType.java, * gnu/xml/validation/datatype/StringType.java, * gnu/xml/validation/datatype/TimeType.java, * gnu/xml/validation/datatype/TokenType.java, * gnu/xml/validation/datatype/TotalDigitsFacet.java, * gnu/xml/validation/datatype/Type.java, * gnu/xml/validation/datatype/TypeBuilder.java, * gnu/xml/validation/datatype/TypeLibrary.java, * gnu/xml/validation/datatype/TypeLibraryFactory.java, * gnu/xml/validation/datatype/UnionSimpleType.java, * gnu/xml/validation/datatype/UnsignedByteType.java, * gnu/xml/validation/datatype/UnsignedIntType.java, * gnu/xml/validation/datatype/UnsignedLongType.java, * gnu/xml/validation/datatype/UnsignedShortType.java, * gnu/xml/validation/datatype/WhiteSpaceFacet.java, * gnu/xml/validation/relaxng/AnyNameNameClass.java, * gnu/xml/validation/relaxng/AttributePattern.java, * gnu/xml/validation/relaxng/ChoiceNameClass.java, * gnu/xml/validation/relaxng/ChoicePattern.java, * gnu/xml/validation/relaxng/DataPattern.java, * gnu/xml/validation/relaxng/Define.java, * gnu/xml/validation/relaxng/ElementPattern.java, * gnu/xml/validation/relaxng/EmptyPattern.java, * gnu/xml/validation/relaxng/FullSyntaxBuilder.java, * gnu/xml/validation/relaxng/Grammar.java, * gnu/xml/validation/relaxng/GrammarException.java, * gnu/xml/validation/relaxng/GrammarValidator.java, * gnu/xml/validation/relaxng/GroupPattern.java, * gnu/xml/validation/relaxng/InterleavePattern.java, * gnu/xml/validation/relaxng/ListPattern.java, * gnu/xml/validation/relaxng/NSNameNameClass.java, * gnu/xml/validation/relaxng/NameClass.java, * gnu/xml/validation/relaxng/NameNameClass.java, * gnu/xml/validation/relaxng/NotAllowedPattern.java, * gnu/xml/validation/relaxng/OneOrMorePattern.java, * gnu/xml/validation/relaxng/Param.java, * gnu/xml/validation/relaxng/Pattern.java, * gnu/xml/validation/relaxng/RELAXNGSchemaFactory.java, * gnu/xml/validation/relaxng/RefPattern.java, * gnu/xml/validation/relaxng/TextPattern.java, * gnu/xml/validation/relaxng/ValuePattern.java, * gnu/xml/validation/xmlschema/AnyAttribute.java, * gnu/xml/validation/xmlschema/AttributeDeclaration.java, * gnu/xml/validation/xmlschema/AttributeUse.java, * gnu/xml/validation/xmlschema/ComplexType.java, * gnu/xml/validation/xmlschema/ElementDeclaration.java, * gnu/xml/validation/xmlschema/Particle.java, * gnu/xml/validation/xmlschema/ValidationException.java, * gnu/xml/validation/xmlschema/XMLSchema.java, * gnu/xml/validation/xmlschema/XMLSchemaAttributeTypeInfo.java, * gnu/xml/validation/xmlschema/XMLSchemaBuilder.java, * gnu/xml/validation/xmlschema/XMLSchemaElementTypeInfo.java, * gnu/xml/validation/xmlschema/XMLSchemaSchemaFactory.java, * gnu/xml/validation/xmlschema/XMLSchemaTypeInfo.java, * gnu/xml/validation/xmlschema/XMLSchemaTypeInfoProvider.java, * gnu/xml/validation/xmlschema/XMLSchemaValidator.java, * gnu/xml/validation/xmlschema/XMLSchemaValidatorHandler.java, * gnu/xml/xpath/AndExpr.java, * gnu/xml/xpath/ArithmeticExpr.java, * gnu/xml/xpath/BooleanFunction.java, * gnu/xml/xpath/CeilingFunction.java, * gnu/xml/xpath/ConcatFunction.java, * gnu/xml/xpath/Constant.java, * gnu/xml/xpath/ContainsFunction.java, * gnu/xml/xpath/CountFunction.java, * gnu/xml/xpath/DocumentOrderComparator.java, * gnu/xml/xpath/EqualityExpr.java, * gnu/xml/xpath/Expr.java, * gnu/xml/xpath/FalseFunction.java, * gnu/xml/xpath/FloorFunction.java, * gnu/xml/xpath/Function.java, * gnu/xml/xpath/FunctionCall.java, * gnu/xml/xpath/IdFunction.java, * gnu/xml/xpath/LangFunction.java, * gnu/xml/xpath/LastFunction.java, * gnu/xml/xpath/LocalNameFunction.java, * gnu/xml/xpath/NameFunction.java, * gnu/xml/xpath/NameTest.java, * gnu/xml/xpath/NamespaceTest.java, * gnu/xml/xpath/NamespaceUriFunction.java, * gnu/xml/xpath/NegativeExpr.java, * gnu/xml/xpath/NodeTypeTest.java, * gnu/xml/xpath/NormalizeSpaceFunction.java, * gnu/xml/xpath/NotFunction.java, * gnu/xml/xpath/NumberFunction.java, * gnu/xml/xpath/OrExpr.java, * gnu/xml/xpath/ParenthesizedExpr.java, * gnu/xml/xpath/Path.java, * gnu/xml/xpath/Pattern.java, * gnu/xml/xpath/PositionFunction.java, * gnu/xml/xpath/Predicate.java, * gnu/xml/xpath/RelationalExpr.java, * gnu/xml/xpath/Root.java, * gnu/xml/xpath/RoundFunction.java, * gnu/xml/xpath/Selector.java, * gnu/xml/xpath/StartsWithFunction.java, * gnu/xml/xpath/Steps.java, * gnu/xml/xpath/StringFunction.java, * gnu/xml/xpath/StringLengthFunction.java, * gnu/xml/xpath/SubstringAfterFunction.java, * gnu/xml/xpath/SubstringBeforeFunction.java, * gnu/xml/xpath/SubstringFunction.java, * gnu/xml/xpath/SumFunction.java, * gnu/xml/xpath/Test.java, * gnu/xml/xpath/TranslateFunction.java, * gnu/xml/xpath/TrueFunction.java, * gnu/xml/xpath/UnionExpr.java, * gnu/xml/xpath/VariableReference.java, * gnu/xml/xpath/XPathFactoryImpl.java, * gnu/xml/xpath/XPathImpl.java, * gnu/xml/xpath/XPathParser.java, * gnu/xml/xpath/XPathTokenizer.java, * java/applet/Applet.java, * java/awt/AWTEvent.java, * java/awt/AWTEventMulticaster.java, * java/awt/AWTKeyStroke.java, * java/awt/AlphaComposite.java, * java/awt/BasicStroke.java, * java/awt/BorderLayout.java, * java/awt/BufferCapabilities.java, * java/awt/Button.java, * java/awt/Canvas.java, * java/awt/CardLayout.java, * java/awt/Checkbox.java, * java/awt/CheckboxGroup.java, * java/awt/CheckboxMenuItem.java, * java/awt/Choice.java, * java/awt/Color.java, * java/awt/ColorPaintContext.java, * java/awt/Component.java, * java/awt/Container.java, * java/awt/ContainerOrderFocusTraversalPolicy.java, * java/awt/Cursor.java, * java/awt/DefaultFocusTraversalPolicy.java, * java/awt/DefaultKeyboardFocusManager.java, * java/awt/Desktop.java, * java/awt/Dialog.java, * java/awt/DisplayMode.java, * java/awt/Event.java, * java/awt/EventDispatchThread.java, * java/awt/EventQueue.java, * java/awt/FileDialog.java, * java/awt/FlowLayout.java, * java/awt/FocusTraversalPolicy.java, * java/awt/Font.java, * java/awt/FontMetrics.java, * java/awt/Frame.java, * java/awt/GradientPaint.java, * java/awt/Graphics.java, * java/awt/Graphics2D.java, * java/awt/GraphicsConfiguration.java, * java/awt/GraphicsDevice.java, * java/awt/GridBagConstraints.java, * java/awt/GridBagLayout.java, * java/awt/GridLayout.java, * java/awt/Image.java, * java/awt/Insets.java, * java/awt/JobAttributes.java, * java/awt/KeyboardFocusManager.java, * java/awt/Label.java, * java/awt/LightweightDispatcher.java, * java/awt/List.java, * java/awt/MediaTracker.java, * java/awt/Menu.java, * java/awt/MenuBar.java, * java/awt/MenuComponent.java, * java/awt/MenuItem.java, * java/awt/MenuShortcut.java, * java/awt/MouseInfo.java, * java/awt/PageAttributes.java, * java/awt/Point.java, * java/awt/PointerInfo.java, * java/awt/Polygon.java, * java/awt/PopupMenu.java, * java/awt/Rectangle.java, * java/awt/RenderingHints.java, * java/awt/Robot.java, * java/awt/ScrollPane.java, * java/awt/ScrollPaneAdjustable.java, * java/awt/Scrollbar.java, * java/awt/Shape.java, * java/awt/SystemColor.java, * java/awt/TextArea.java, * java/awt/TextComponent.java, * java/awt/TextField.java, * java/awt/TexturePaint.java, * java/awt/Toolkit.java, * java/awt/Window.java, * java/awt/color/ICC_ColorSpace.java, * java/awt/color/ICC_Profile.java, * java/awt/color/ICC_ProfileGray.java, * java/awt/color/ICC_ProfileRGB.java, * java/awt/datatransfer/Clipboard.java, * java/awt/datatransfer/ClipboardOwner.java, * java/awt/datatransfer/DataFlavor.java, * java/awt/datatransfer/FlavorEvent.java, * java/awt/datatransfer/FlavorListener.java, * java/awt/datatransfer/MimeType.java, * java/awt/datatransfer/StringSelection.java, * java/awt/datatransfer/SystemFlavorMap.java, * java/awt/datatransfer/Transferable.java, * java/awt/datatransfer/UnsupportedFlavorException.java, * java/awt/dnd/Autoscroll.java, * java/awt/dnd/DnDEventMulticaster.java, * java/awt/dnd/DragGestureEvent.java, * java/awt/dnd/DragGestureRecognizer.java, * java/awt/dnd/DragSource.java, * java/awt/dnd/DragSourceContext.java, * java/awt/dnd/DragSourceDropEvent.java, * java/awt/dnd/DragSourceEvent.java, * java/awt/dnd/DropTarget.java, * java/awt/dnd/DropTargetContext.java, * java/awt/dnd/DropTargetDragEvent.java, * java/awt/dnd/DropTargetDropEvent.java, * java/awt/dnd/DropTargetEvent.java, * java/awt/dnd/MouseDragGestureRecognizer.java, * java/awt/dnd/peer/DropTargetContextPeer.java, * java/awt/event/AWTEventListener.java, * java/awt/event/ActionEvent.java, * java/awt/event/ComponentAdapter.java, * java/awt/event/ComponentEvent.java, * java/awt/event/InputEvent.java, * java/awt/event/InputMethodEvent.java, * java/awt/event/InvocationEvent.java, * java/awt/event/KeyEvent.java, * java/awt/event/MouseEvent.java, * java/awt/event/MouseListener.java, * java/awt/event/MouseWheelEvent.java, * java/awt/event/WindowEvent.java, * java/awt/font/FontRenderContext.java, * java/awt/font/GlyphJustificationInfo.java, * java/awt/font/GlyphMetrics.java, * java/awt/font/GlyphVector.java, * java/awt/font/GraphicAttribute.java, * java/awt/font/ImageGraphicAttribute.java, * java/awt/font/LineBreakMeasurer.java, * java/awt/font/LineMetrics.java, * java/awt/font/MultipleMaster.java, * java/awt/font/OpenType.java, * java/awt/font/ShapeGraphicAttribute.java, * java/awt/font/TextAttribute.java, * java/awt/font/TextHitInfo.java, * java/awt/font/TextLayout.java, * java/awt/font/TextMeasurer.java, * java/awt/font/TransformAttribute.java, * java/awt/geom/AffineTransform.java, * java/awt/geom/Arc2D.java, * java/awt/geom/Area.java, * java/awt/geom/CubicCurve2D.java, * java/awt/geom/Ellipse2D.java, * java/awt/geom/FlatteningPathIterator.java, * java/awt/geom/GeneralPath.java, * java/awt/geom/Line2D.java, * java/awt/geom/QuadCurve2D.java, * java/awt/geom/RectangularShape.java, * java/awt/geom/RoundRectangle2D.java, * java/awt/im/InputContext.java, * java/awt/im/spi/InputMethodDescriptor.java, * java/awt/image/AffineTransformOp.java, * java/awt/image/AreaAveragingScaleFilter.java, * java/awt/image/BandCombineOp.java, * java/awt/image/BandedSampleModel.java, * java/awt/image/BufferedImage.java, * java/awt/image/BufferedImageFilter.java, * java/awt/image/BufferedImageOp.java, * java/awt/image/ByteLookupTable.java, * java/awt/image/ColorConvertOp.java, * java/awt/image/ColorModel.java, * java/awt/image/ComponentColorModel.java, * java/awt/image/ComponentSampleModel.java, * java/awt/image/ConvolveOp.java, * java/awt/image/CropImageFilter.java, * java/awt/image/DataBuffer.java, * java/awt/image/DataBufferByte.java, * java/awt/image/DataBufferDouble.java, * java/awt/image/DataBufferFloat.java, * java/awt/image/DataBufferInt.java, * java/awt/image/DataBufferShort.java, * java/awt/image/DataBufferUShort.java, * java/awt/image/DirectColorModel.java, * java/awt/image/FilteredImageSource.java, * java/awt/image/ImageConsumer.java, * java/awt/image/ImageFilter.java, * java/awt/image/ImageObserver.java, * java/awt/image/ImageProducer.java, * java/awt/image/IndexColorModel.java, * java/awt/image/Kernel.java, * java/awt/image/LookupOp.java, * java/awt/image/LookupTable.java, * java/awt/image/MemoryImageSource.java, * java/awt/image/MultiPixelPackedSampleModel.java, * java/awt/image/PackedColorModel.java, * java/awt/image/PixelGrabber.java, * java/awt/image/PixelInterleavedSampleModel.java, * java/awt/image/RGBImageFilter.java, * java/awt/image/Raster.java, * java/awt/image/RasterOp.java, * java/awt/image/RenderedImage.java, * java/awt/image/ReplicateScaleFilter.java, * java/awt/image/RescaleOp.java, * java/awt/image/SampleModel.java, * java/awt/image/ShortLookupTable.java, * java/awt/image/SinglePixelPackedSampleModel.java, * java/awt/image/TileObserver.java, * java/awt/image/WritableRaster.java, * java/awt/image/WritableRenderedImage.java, * java/awt/image/renderable/ContextualRenderedImageFactory.java, * java/awt/image/renderable/ParameterBlock.java, * java/awt/image/renderable/RenderContext.java, * java/awt/image/renderable/RenderableImage.java, * java/awt/image/renderable/RenderableImageOp.java, * java/awt/image/renderable/RenderableImageProducer.java, * java/awt/image/renderable/RenderedImageFactory.java, * java/awt/peer/ButtonPeer.java, * java/awt/peer/CanvasPeer.java, * java/awt/peer/CheckboxMenuItemPeer.java, * java/awt/peer/CheckboxPeer.java, * java/awt/peer/ChoicePeer.java, * java/awt/peer/ComponentPeer.java, * java/awt/peer/ContainerPeer.java, * java/awt/peer/DesktopPeer.java, * java/awt/peer/DialogPeer.java, * java/awt/peer/FileDialogPeer.java, * java/awt/peer/FontPeer.java, * java/awt/peer/FramePeer.java, * java/awt/peer/LabelPeer.java, * java/awt/peer/LightweightPeer.java, * java/awt/peer/ListPeer.java, * java/awt/peer/MenuBarPeer.java, * java/awt/peer/MenuComponentPeer.java, * java/awt/peer/MenuItemPeer.java, * java/awt/peer/MenuPeer.java, * java/awt/peer/MouseInfoPeer.java, * java/awt/peer/PanelPeer.java, * java/awt/peer/PopupMenuPeer.java, * java/awt/peer/RobotPeer.java, * java/awt/peer/ScrollPanePeer.java, * java/awt/peer/ScrollbarPeer.java, * java/awt/peer/TextComponentPeer.java, * java/awt/peer/TextFieldPeer.java, * java/awt/peer/WindowPeer.java, * java/awt/print/Book.java, * java/awt/print/PageFormat.java, * java/awt/print/Pageable.java, * java/awt/print/Paper.java, * java/awt/print/PrinterGraphics.java, * java/awt/print/PrinterIOException.java, * java/awt/print/PrinterJob.java, * java/beans/AppletInitializer.java, * java/beans/BeanDescriptor.java, * java/beans/BeanInfo.java, * java/beans/Beans.java, * java/beans/Customizer.java, * java/beans/DefaultPersistenceDelegate.java, * java/beans/DesignMode.java, * java/beans/Encoder.java, * java/beans/EventHandler.java, * java/beans/EventSetDescriptor.java, * java/beans/Expression.java, * java/beans/FeatureDescriptor.java, * java/beans/IndexedPropertyChangeEvent.java, * java/beans/IndexedPropertyDescriptor.java, * java/beans/Introspector.java, * java/beans/MethodDescriptor.java, * java/beans/ParameterDescriptor.java, * java/beans/PersistenceDelegate.java, * java/beans/PropertyChangeSupport.java, * java/beans/PropertyDescriptor.java, * java/beans/PropertyEditor.java, * java/beans/PropertyEditorManager.java, * java/beans/SimpleBeanInfo.java, * java/beans/Statement.java, * java/beans/VetoableChangeSupport.java, * java/beans/Visibility.java, * java/beans/XMLDecoder.java, * java/beans/XMLEncoder.java, * java/beans/beancontext/BeanContext.java, * java/beans/beancontext/BeanContextChild.java, * java/beans/beancontext/BeanContextChildComponentProxy.java, * java/beans/beancontext/BeanContextChildSupport.java, * java/beans/beancontext/BeanContextContainerProxy.java, * java/beans/beancontext/BeanContextEvent.java, * java/beans/beancontext/BeanContextMembershipEvent.java, * java/beans/beancontext/BeanContextMembershipListener.java, * java/beans/beancontext/BeanContextProxy.java, * java/beans/beancontext/BeanContextServiceAvailableEvent.java, * java/beans/beancontext/BeanContextServiceProvider.java, * java/beans/beancontext/BeanContextServiceProviderBeanInfo.java, * java/beans/beancontext/BeanContextServiceRevokedEvent.java, * java/beans/beancontext/BeanContextServiceRevokedListener.java, * java/beans/beancontext/BeanContextServices.java, * java/beans/beancontext/BeanContextServicesListener.java, * java/beans/beancontext/BeanContextServicesSupport.java, * java/beans/beancontext/BeanContextSupport.java, * java/io/BufferedInputStream.java, * java/io/BufferedOutputStream.java, * java/io/BufferedReader.java, * java/io/BufferedWriter.java, * java/io/ByteArrayInputStream.java, * java/io/ByteArrayOutputStream.java, * java/io/CharArrayReader.java, * java/io/CharArrayWriter.java, * java/io/DataInput.java, * java/io/DataInputStream.java, * java/io/DataOutput.java, * java/io/DataOutputStream.java, * java/io/DeleteFileHelper.java, * java/io/EOFException.java, * java/io/Externalizable.java, * java/io/File.java, * java/io/FileDescriptor.java, * java/io/FileFilter.java, * java/io/FileInputStream.java, * java/io/FileOutputStream.java, * java/io/FilePermission.java, * java/io/FileReader.java, * java/io/FileWriter.java, * java/io/FilenameFilter.java, * java/io/FilterInputStream.java, * java/io/FilterOutputStream.java, * java/io/FilterReader.java, * java/io/FilterWriter.java, * java/io/InputStream.java, * java/io/InputStreamReader.java, * java/io/InvalidClassException.java, * java/io/LineNumberInputStream.java, * java/io/LineNumberReader.java, * java/io/ObjectInput.java, * java/io/ObjectInputStream.java, * java/io/ObjectInputValidation.java, * java/io/ObjectOutput.java, * java/io/ObjectOutputStream.java, * java/io/ObjectStreamClass.java, * java/io/ObjectStreamConstants.java, * java/io/ObjectStreamField.java, * java/io/OutputStream.java, * java/io/OutputStreamWriter.java, * java/io/PipedInputStream.java, * java/io/PipedOutputStream.java, * java/io/PipedReader.java, * java/io/PipedWriter.java, * java/io/PrintStream.java, * java/io/PrintWriter.java, * java/io/PushbackInputStream.java, * java/io/PushbackReader.java, * java/io/RandomAccessFile.java, * java/io/Reader.java, * java/io/SequenceInputStream.java, * java/io/Serializable.java, * java/io/SerializablePermission.java, * java/io/StreamTokenizer.java, * java/io/StringBufferInputStream.java, * java/io/StringReader.java, * java/io/StringWriter.java, * java/io/UnsupportedEncodingException.java, * java/io/Writer.java, * java/lang/AbstractStringBuffer.java, * java/lang/Boolean.java, * java/lang/Character.java, * java/lang/Class.java, * java/lang/ClassLoader.java, * java/lang/Comparable.java, * java/lang/Double.java, * java/lang/Enum.java, * java/lang/EnumConstantNotPresentException.java, * java/lang/Float.java, * java/lang/IllegalArgumentException.java, * java/lang/IllegalStateException.java, * java/lang/IndexOutOfBoundsException.java, * java/lang/Integer.java, * java/lang/Long.java, * java/lang/Math.java, * java/lang/NoClassDefFoundError.java, * java/lang/Object.java, * java/lang/Package.java, * java/lang/ProcessBuilder.java, * java/lang/Runtime.java, * java/lang/SecurityException.java, * java/lang/SecurityManager.java, * java/lang/StackTraceElement.java, * java/lang/StrictMath.java, * java/lang/String.java, * java/lang/StringBuffer.java, * java/lang/StringBuilder.java, * java/lang/System.java, * java/lang/Thread.java, * java/lang/ThreadLocal.java, * java/lang/Throwable.java, * java/lang/TypeNotPresentException.java, * java/lang/UnsupportedOperationException.java, * java/lang/annotation/Annotation.java, * java/lang/annotation/AnnotationTypeMismatchException.java, * java/lang/annotation/IncompleteAnnotationException.java, * java/lang/instrument/ClassFileTransformer.java, * java/lang/instrument/Instrumentation.java, * java/lang/management/ClassLoadingMXBean.java, * java/lang/management/CompilationMXBean.java, * java/lang/management/GarbageCollectorMXBean.java, * java/lang/management/ManagementFactory.java, * java/lang/management/ManagementPermission.java, * java/lang/management/MemoryMXBean.java, * java/lang/management/MemoryManagerMXBean.java, * java/lang/management/MemoryNotificationInfo.java, * java/lang/management/MemoryPoolMXBean.java, * java/lang/management/MemoryType.java, * java/lang/management/MemoryUsage.java, * java/lang/management/MonitorInfo.java, * java/lang/management/OperatingSystemMXBean.java, * java/lang/management/RuntimeMXBean.java, * java/lang/management/ThreadInfo.java, * java/lang/management/ThreadMXBean.java, * java/lang/ref/PhantomReference.java, * java/lang/ref/Reference.java, * java/lang/ref/ReferenceQueue.java, * java/lang/ref/SoftReference.java, * java/lang/ref/WeakReference.java, * java/lang/reflect/AccessibleObject.java, * java/lang/reflect/AnnotatedElement.java, * java/lang/reflect/Array.java, * java/lang/reflect/Constructor.java, * java/lang/reflect/Field.java, * java/lang/reflect/GenericArrayType.java, * java/lang/reflect/GenericDeclaration.java, * java/lang/reflect/InvocationHandler.java, * java/lang/reflect/MalformedParameterizedTypeException.java, * java/lang/reflect/Method.java, * java/lang/reflect/Modifier.java, * java/lang/reflect/Proxy.java, * java/lang/reflect/Type.java, * java/lang/reflect/TypeVariable.java, * java/lang/reflect/WildcardType.java, * java/math/BigDecimal.java, * java/math/BigInteger.java, * java/math/MathContext.java, * java/math/RoundingMode.java, * java/net/ContentHandler.java, * java/net/DatagramSocket.java, * java/net/DatagramSocketImpl.java, * java/net/HttpURLConnection.java, * java/net/Inet4Address.java, * java/net/Inet6Address.java, * java/net/InetAddress.java, * java/net/InetSocketAddress.java, * java/net/MimeTypeMapper.java, * java/net/MulticastSocket.java, * java/net/NetworkInterface.java, * java/net/Proxy.java, * java/net/ProxySelector.java, * java/net/ResolverCache.java, * java/net/ServerSocket.java, * java/net/Socket.java, * java/net/SocketPermission.java, * java/net/URI.java, * java/net/URL.java, * java/net/URLClassLoader.java, * java/net/URLConnection.java, * java/net/URLDecoder.java, * java/net/URLEncoder.java, * java/net/URLStreamHandler.java, * java/nio/Buffer.java, * java/nio/BufferOverflowException.java, * java/nio/BufferUnderflowException.java, * java/nio/ByteBuffer.java, * java/nio/ByteBufferHelper.java, * java/nio/ByteBufferImpl.java, * java/nio/ByteOrder.java, * java/nio/CharBuffer.java, * java/nio/CharBufferImpl.java, * java/nio/CharSequenceBuffer.java, * java/nio/CharViewBufferImpl.java, * java/nio/DirectByteBufferImpl.java, * java/nio/DoubleBuffer.java, * java/nio/DoubleBufferImpl.java, * java/nio/DoubleViewBufferImpl.java, * java/nio/FloatBuffer.java, * java/nio/FloatBufferImpl.java, * java/nio/FloatViewBufferImpl.java, * java/nio/IntBuffer.java, * java/nio/IntBufferImpl.java, * java/nio/IntViewBufferImpl.java, * java/nio/InvalidMarkException.java, * java/nio/LongBuffer.java, * java/nio/LongBufferImpl.java, * java/nio/LongViewBufferImpl.java, * java/nio/MappedByteBuffer.java, * java/nio/MappedByteBufferImpl.java, * java/nio/ReadOnlyBufferException.java, * java/nio/ShortBuffer.java, * java/nio/ShortBufferImpl.java, * java/nio/ShortViewBufferImpl.java, * java/nio/channels/FileChannel.java, * java/nio/channels/SocketChannel.java, * java/nio/channels/spi/AbstractInterruptibleChannel.java, * java/nio/channels/spi/AbstractSelectableChannel.java, * java/nio/channels/spi/AbstractSelectionKey.java, * java/nio/channels/spi/AbstractSelector.java, * java/nio/channels/spi/SelectorProvider.java, * java/nio/charset/CharacterCodingException.java, * java/nio/charset/Charset.java, * java/nio/charset/CharsetDecoder.java, * java/nio/charset/CharsetEncoder.java, * java/nio/charset/CoderMalfunctionError.java, * java/nio/charset/CoderResult.java, * java/nio/charset/CodingErrorAction.java, * java/nio/charset/IllegalCharsetNameException.java, * java/nio/charset/MalformedInputException.java, * java/nio/charset/UnmappableCharacterException.java, * java/nio/charset/UnsupportedCharsetException.java, * java/rmi/AccessException.java, * java/rmi/AlreadyBoundException.java, * java/rmi/MarshalledObject.java, * java/rmi/Naming.java, * java/rmi/NoSuchObjectException.java, * java/rmi/NotBoundException.java, * java/rmi/RMISecurityException.java, * java/rmi/RMISecurityManager.java, * java/rmi/Remote.java, * java/rmi/RemoteException.java, * java/rmi/StubNotFoundException.java, * java/rmi/UnknownHostException.java, * java/rmi/activation/Activatable.java, * java/rmi/activation/ActivationDesc.java, * java/rmi/activation/ActivationGroup.java, * java/rmi/activation/ActivationGroupDesc.java, * java/rmi/activation/ActivationGroupID.java, * java/rmi/activation/ActivationID.java, * java/rmi/activation/ActivationInstantiator.java, * java/rmi/activation/ActivationMonitor.java, * java/rmi/activation/ActivationSystem.java, * java/rmi/activation/Activator.java, * java/rmi/activation/UnknownGroupException.java, * java/rmi/dgc/DGC.java, * java/rmi/dgc/Lease.java, * java/rmi/dgc/VMID.java, * java/rmi/registry/LocateRegistry.java, * java/rmi/registry/Registry.java, * java/rmi/registry/RegistryHandler.java, * java/rmi/server/LoaderHandler.java, * java/rmi/server/LogStream.java, * java/rmi/server/ObjID.java, * java/rmi/server/Operation.java, * java/rmi/server/RMIClassLoader.java, * java/rmi/server/RMIClientSocketFactory.java, * java/rmi/server/RMIFailureHandler.java, * java/rmi/server/RMIServerSocketFactory.java, * java/rmi/server/RMISocketFactory.java, * java/rmi/server/RemoteCall.java, * java/rmi/server/RemoteObject.java, * java/rmi/server/RemoteObjectInvocationHandler.java, * java/rmi/server/RemoteRef.java, * java/rmi/server/RemoteServer.java, * java/rmi/server/RemoteStub.java, * java/rmi/server/ServerRef.java, * java/rmi/server/Skeleton.java, * java/rmi/server/UID.java, * java/rmi/server/UnicastRemoteObject.java, * java/rmi/server/Unreferenced.java, * java/security/AccessControlContext.java, * java/security/AccessController.java, * java/security/AlgorithmParameterGenerator.java, * java/security/AlgorithmParameterGeneratorSpi.java, * java/security/AlgorithmParameters.java, * java/security/AlgorithmParametersSpi.java, * java/security/CodeSource.java, * java/security/DigestInputStream.java, * java/security/DigestOutputStream.java, * java/security/GeneralSecurityException.java, * java/security/Identity.java, * java/security/IdentityScope.java, * java/security/KeyFactory.java, * java/security/KeyFactorySpi.java, * java/security/KeyPairGenerator.java, * java/security/KeyPairGeneratorSpi.java, * java/security/KeyStore.java, * java/security/KeyStoreSpi.java, * java/security/MessageDigest.java, * java/security/MessageDigestSpi.java, * java/security/Permission.java, * java/security/Permissions.java, * java/security/Policy.java, * java/security/ProtectionDomain.java, * java/security/Provider.java, * java/security/ProviderException.java, * java/security/SecureClassLoader.java, * java/security/SecureRandom.java, * java/security/SecureRandomSpi.java, * java/security/Security.java, * java/security/Signature.java, * java/security/SignatureSpi.java, * java/security/SignedObject.java, * java/security/Signer.java, * java/security/acl/Acl.java, * java/security/acl/AclEntry.java, * java/security/acl/Group.java, * java/security/acl/Owner.java, * java/security/cert/CRL.java, * java/security/cert/CRLSelector.java, * java/security/cert/CertPathBuilder.java, * java/security/cert/CertPathBuilderResult.java, * java/security/cert/CertPathValidator.java, * java/security/cert/CertPathValidatorResult.java, * java/security/cert/CertPathValidatorSpi.java, * java/security/cert/CertSelector.java, * java/security/cert/CertStore.java, * java/security/cert/CertStoreParameters.java, * java/security/cert/CertStoreSpi.java, * java/security/cert/Certificate.java, * java/security/cert/CertificateFactory.java, * java/security/cert/CertificateFactorySpi.java, * java/security/cert/CollectionCertStoreParameters.java, * java/security/cert/LDAPCertStoreParameters.java, * java/security/cert/PKIXBuilderParameters.java, * java/security/cert/PKIXCertPathBuilderResult.java, * java/security/cert/PKIXCertPathChecker.java, * java/security/cert/PKIXCertPathValidatorResult.java, * java/security/cert/PKIXParameters.java, * java/security/cert/PolicyNode.java, * java/security/cert/PolicyQualifierInfo.java, * java/security/cert/X509CRL.java, * java/security/cert/X509CRLEntry.java, * java/security/cert/X509CertSelector.java, * java/security/cert/X509Certificate.java, * java/security/cert/X509Extension.java, * java/security/spec/AlgorithmParameterSpec.java, * java/security/spec/DSAParameterSpec.java, * java/security/spec/DSAPrivateKeySpec.java, * java/security/spec/DSAPublicKeySpec.java, * java/security/spec/EncodedKeySpec.java, * java/security/spec/InvalidParameterSpecException.java, * java/security/spec/KeySpec.java, * java/security/spec/PKCS8EncodedKeySpec.java, * java/security/spec/PSSParameterSpec.java, * java/security/spec/RSAKeyGenParameterSpec.java, * java/security/spec/RSAMultiPrimePrivateCrtKeySpec.java, * java/security/spec/RSAOtherPrimeInfo.java, * java/security/spec/RSAPrivateCrtKeySpec.java, * java/security/spec/RSAPrivateKeySpec.java, * java/security/spec/RSAPublicKeySpec.java, * java/security/spec/X509EncodedKeySpec.java, * java/sql/Array.java, * java/sql/BatchUpdateException.java, * java/sql/Blob.java, * java/sql/CallableStatement.java, * java/sql/Clob.java, * java/sql/Connection.java, * java/sql/DataTruncation.java, * java/sql/DatabaseMetaData.java, * java/sql/Date.java, * java/sql/Driver.java, * java/sql/DriverManager.java, * java/sql/DriverPropertyInfo.java, * java/sql/ParameterMetaData.java, * java/sql/PreparedStatement.java, * java/sql/Ref.java, * java/sql/ResultSet.java, * java/sql/ResultSetMetaData.java, * java/sql/SQLData.java, * java/sql/SQLException.java, * java/sql/SQLInput.java, * java/sql/SQLOutput.java, * java/sql/SQLPermission.java, * java/sql/SQLWarning.java, * java/sql/Savepoint.java, * java/sql/Statement.java, * java/sql/Struct.java, * java/sql/Time.java, * java/sql/Timestamp.java, * java/sql/Types.java, * java/text/Annotation.java, * java/text/AttributedCharacterIterator.java, * java/text/AttributedString.java, * java/text/AttributedStringIterator.java, * java/text/Bidi.java, * java/text/BreakIterator.java, * java/text/CharacterIterator.java, * java/text/ChoiceFormat.java, * java/text/CollationElementIterator.java, * java/text/CollationKey.java, * java/text/Collator.java, * java/text/DateFormat.java, * java/text/DateFormatSymbols.java, * java/text/DecimalFormat.java, * java/text/DecimalFormatSymbols.java, * java/text/FieldPosition.java, * java/text/Format.java, * java/text/MessageFormat.java, * java/text/NumberFormat.java, * java/text/ParsePosition.java, * java/text/RuleBasedCollator.java, * java/text/SimpleDateFormat.java, * java/text/StringCharacterIterator.java, * java/text/spi/DateFormatProvider.java, * java/text/spi/NumberFormatProvider.java, * java/util/AbstractCollection.java, * java/util/AbstractList.java, * java/util/AbstractMap.java, * java/util/AbstractSet.java, * java/util/ArrayList.java, * java/util/Arrays.java, * java/util/BitSet.java, * java/util/Calendar.java, * java/util/Collections.java, * java/util/Currency.java, * java/util/Date.java, * java/util/Dictionary.java, * java/util/DuplicateFormatFlagsException.java, * java/util/EnumMap.java, * java/util/EnumSet.java, * java/util/FormatFlagsConversionMismatchException.java, * java/util/Formattable.java, * java/util/FormattableFlags.java, * java/util/Formatter.java, * java/util/FormatterClosedException.java, * java/util/GregorianCalendar.java, * java/util/HashMap.java, * java/util/Hashtable.java, * java/util/IdentityHashMap.java, * java/util/IllegalFormatCodePointException.java, * java/util/IllegalFormatConversionException.java, * java/util/IllegalFormatException.java, * java/util/IllegalFormatFlagsException.java, * java/util/IllegalFormatPrecisionException.java, * java/util/IllegalFormatWidthException.java, * java/util/InputMismatchException.java, * java/util/LinkedHashMap.java, * java/util/LinkedHashSet.java, * java/util/LinkedList.java, * java/util/List.java, * java/util/Locale.java, * java/util/Map.java, * java/util/MissingFormatArgumentException.java, * java/util/MissingFormatWidthException.java, * java/util/PriorityQueue.java, * java/util/Properties.java, * java/util/PropertyPermission.java, * java/util/PropertyPermissionCollection.java, * java/util/Random.java, * java/util/ResourceBundle.java, * java/util/ServiceConfigurationError.java, * java/util/ServiceLoader.java, * java/util/SimpleTimeZone.java, * java/util/StringTokenizer.java, * java/util/TimeZone.java, * java/util/Timer.java, * java/util/TreeMap.java, * java/util/TreeSet.java, * java/util/UUID.java, * java/util/UnknownFormatConversionException.java, * java/util/UnknownFormatFlagsException.java, * java/util/Vector.java, * java/util/WeakHashMap.java, * java/util/concurrent/CopyOnWriteArrayList.java, * java/util/jar/Attributes.java, * java/util/jar/JarEntry.java, * java/util/jar/JarFile.java, * java/util/jar/JarInputStream.java, * java/util/jar/JarOutputStream.java, * java/util/jar/Manifest.java, * java/util/logging/ConsoleHandler.java, * java/util/logging/ErrorManager.java, * java/util/logging/FileHandler.java, * java/util/logging/Formatter.java, * java/util/logging/Handler.java, * java/util/logging/Level.java, * java/util/logging/LogManager.java, * java/util/logging/LogRecord.java, * java/util/logging/Logger.java, * java/util/logging/LoggingMXBean.java, * java/util/logging/LoggingPermission.java, * java/util/logging/MemoryHandler.java, * java/util/logging/SocketHandler.java, * java/util/logging/StreamHandler.java, * java/util/logging/XMLFormatter.java, * java/util/prefs/AbstractPreferences.java, * java/util/prefs/NodeChangeEvent.java, * java/util/prefs/NodeChangeListener.java, * java/util/prefs/PreferenceChangeEvent.java, * java/util/prefs/PreferenceChangeListener.java, * java/util/prefs/Preferences.java, * java/util/prefs/PreferencesFactory.java, * java/util/regex/MatchResult.java, * java/util/regex/Pattern.java, * java/util/regex/PatternSyntaxException.java, * java/util/spi/LocaleNameProvider.java, * java/util/spi/TimeZoneNameProvider.java, * java/util/zip/Adler32.java, * java/util/zip/CRC32.java, * java/util/zip/CheckedInputStream.java, * java/util/zip/CheckedOutputStream.java, * java/util/zip/Deflater.java, * java/util/zip/DeflaterEngine.java, * java/util/zip/DeflaterHuffman.java, * java/util/zip/DeflaterOutputStream.java, * java/util/zip/DeflaterPending.java, * java/util/zip/GZIPInputStream.java, * java/util/zip/GZIPOutputStream.java, * java/util/zip/Inflater.java, * java/util/zip/InflaterDynHeader.java, * java/util/zip/InflaterHuffmanTree.java, * java/util/zip/InflaterInputStream.java, * java/util/zip/OutputWindow.java, * java/util/zip/PendingBuffer.java, * java/util/zip/StreamManipulator.java, * java/util/zip/ZipConstants.java, * java/util/zip/ZipEntry.java, * java/util/zip/ZipFile.java, * java/util/zip/ZipInputStream.java, * java/util/zip/ZipOutputStream.java, * javax/accessibility/AccessibleExtendedText.java, * javax/accessibility/AccessibleRelation.java, * javax/accessibility/AccessibleRole.java, * javax/accessibility/AccessibleState.java, * javax/activation/ActivationDataFlavor.java, * javax/activation/CommandInfo.java, * javax/activation/CommandMap.java, * javax/activation/CommandObject.java, * javax/activation/DataContentHandler.java, * javax/activation/DataContentHandlerFactory.java, * javax/activation/DataHandler.java, * javax/activation/DataHandlerDataSource.java, * javax/activation/DataSource.java, * javax/activation/DataSourceDataContentHandler.java, * javax/activation/FileDataSource.java, * javax/activation/FileTypeMap.java, * javax/activation/MailcapCommandMap.java, * javax/activation/MimeType.java, * javax/activation/MimeTypeParameterList.java, * javax/activation/MimeTypeParseException.java, * javax/activation/MimetypesFileTypeMap.java, * javax/activation/ObjectDataContentHandler.java, * javax/activation/URLDataSource.java, * javax/activation/UnsupportedDataTypeException.java, * javax/crypto/Cipher.java, * javax/crypto/CipherOutputStream.java, * javax/crypto/ExemptionMechanism.java, * javax/crypto/KeyAgreement.java, * javax/crypto/KeyGenerator.java, * javax/crypto/Mac.java, * javax/crypto/MacSpi.java, * javax/crypto/SecretKeyFactory.java, * javax/crypto/spec/PBEKeySpec.java, * javax/imageio/IIOImage.java, * javax/imageio/IIOParam.java, * javax/imageio/IIOParamController.java, * javax/imageio/ImageIO.java, * javax/imageio/ImageReadParam.java, * javax/imageio/ImageReader.java, * javax/imageio/ImageTranscoder.java, * javax/imageio/ImageTypeSpecifier.java, * javax/imageio/ImageWriteParam.java, * javax/imageio/ImageWriter.java, * javax/imageio/event/IIOReadProgressListener.java, * javax/imageio/event/IIOReadUpdateListener.java, * javax/imageio/event/IIOWriteProgressListener.java, * javax/imageio/metadata/IIOInvalidTreeException.java, * javax/imageio/metadata/IIOMetadata.java, * javax/imageio/metadata/IIOMetadataFormatImpl.java, * javax/imageio/metadata/IIOMetadataNode.java, * javax/imageio/plugins/bmp/BMPImageWriteParam.java, * javax/imageio/plugins/jpeg/JPEGHuffmanTable.java, * javax/imageio/spi/IIORegistry.java, * javax/imageio/spi/ImageReaderSpi.java, * javax/imageio/spi/ImageWriterSpi.java, * javax/imageio/spi/RegisterableService.java, * javax/imageio/spi/ServiceRegistry.java, * javax/imageio/stream/FileCacheImageInputStream.java, * javax/imageio/stream/FileCacheImageOutputStream.java, * javax/imageio/stream/FileImageInputStream.java, * javax/imageio/stream/FileImageOutputStream.java, * javax/imageio/stream/ImageInputStream.java, * javax/imageio/stream/ImageInputStreamImpl.java, * javax/imageio/stream/ImageOutputStreamImpl.java, * javax/imageio/stream/MemoryCacheImageInputStream.java, * javax/imageio/stream/MemoryCacheImageOutputStream.java, * javax/management/Attribute.java, * javax/management/AttributeChangeNotification.java, * javax/management/AttributeChangeNotificationFilter.java, * javax/management/AttributeList.java, * javax/management/AttributeNotFoundException.java, * javax/management/AttributeValueExp.java, * javax/management/BadAttributeValueExpException.java, * javax/management/BadBinaryOpValueExpException.java, * javax/management/BadStringOperationException.java, * javax/management/DefaultLoaderRepository.java, * javax/management/Descriptor.java, * javax/management/DynamicMBean.java, * javax/management/InstanceAlreadyExistsException.java, * javax/management/InstanceNotFoundException.java, * javax/management/IntrospectionException.java, * javax/management/InvalidApplicationException.java, * javax/management/InvalidAttributeValueException.java, * javax/management/JMException.java, * javax/management/JMRuntimeException.java, * javax/management/JMX.java, * javax/management/ListenerNotFoundException.java, * javax/management/MBeanAttributeInfo.java, * javax/management/MBeanConstructorInfo.java, * javax/management/MBeanException.java, * javax/management/MBeanFeatureInfo.java, * javax/management/MBeanInfo.java, * javax/management/MBeanNotificationInfo.java, * javax/management/MBeanOperationInfo.java, * javax/management/MBeanParameterInfo.java, * javax/management/MBeanPermission.java, * javax/management/MBeanRegistrationException.java, * javax/management/MBeanServer.java, * javax/management/MBeanServerBuilder.java, * javax/management/MBeanServerConnection.java, * javax/management/MBeanServerDelegate.java, * javax/management/MBeanServerFactory.java, * javax/management/MBeanServerInvocationHandler.java, * javax/management/MBeanServerNotification.java, * javax/management/MBeanServerPermission.java, * javax/management/MBeanTrustPermission.java, * javax/management/MalformedObjectNameException.java, * javax/management/NotCompliantMBeanException.java, * javax/management/Notification.java, * javax/management/NotificationBroadcaster.java, * javax/management/NotificationBroadcasterSupport.java, * javax/management/NotificationEmitter.java, * javax/management/NotificationFilter.java, * javax/management/NotificationFilterSupport.java, * javax/management/NotificationListener.java, * javax/management/ObjectInstance.java, * javax/management/ObjectName.java, * javax/management/OperationsException.java, * javax/management/PersistentMBean.java, * javax/management/Query.java, * javax/management/QueryEval.java, * javax/management/QueryExp.java, * javax/management/ReflectionException.java, * javax/management/RuntimeErrorException.java, * javax/management/RuntimeMBeanException.java, * javax/management/RuntimeOperationsException.java, * javax/management/ServiceNotFoundException.java, * javax/management/StandardMBean.java, * javax/management/StringValueExp.java, * javax/management/ValueExp.java, * javax/management/loading/ClassLoaderRepository.java, * javax/management/openmbean/ArrayType.java, * javax/management/openmbean/CompositeData.java, * javax/management/openmbean/CompositeDataInvocationHandler.java, * javax/management/openmbean/CompositeDataSupport.java, * javax/management/openmbean/CompositeType.java, * javax/management/openmbean/InvalidKeyException.java, * javax/management/openmbean/InvalidOpenTypeException.java, * javax/management/openmbean/KeyAlreadyExistsException.java, * javax/management/openmbean/OpenDataException.java, * javax/management/openmbean/OpenMBeanAttributeInfo.java, * javax/management/openmbean/OpenMBeanAttributeInfoSupport.java, * javax/management/openmbean/OpenMBeanConstructorInfo.java, * javax/management/openmbean/OpenMBeanConstructorInfoSupport.java, * javax/management/openmbean/OpenMBeanInfo.java, * javax/management/openmbean/OpenMBeanInfoSupport.java, * javax/management/openmbean/OpenMBeanOperationInfo.java, * javax/management/openmbean/OpenMBeanOperationInfoSupport.java, * javax/management/openmbean/OpenMBeanParameterInfo.java, * javax/management/openmbean/OpenMBeanParameterInfoSupport.java, * javax/management/openmbean/OpenType.java, * javax/management/openmbean/SimpleType.java, * javax/management/openmbean/TabularData.java, * javax/management/openmbean/TabularDataSupport.java, * javax/management/openmbean/TabularType.java, * javax/management/remote/NotificationResult.java, * javax/management/remote/TargetedNotification.java, * javax/management/remote/rmi/RMIConnection.java, * javax/naming/AuthenticationException.java, * javax/naming/AuthenticationNotSupportedException.java, * javax/naming/BinaryRefAddr.java, * javax/naming/Binding.java, * javax/naming/CannotProceedException.java, * javax/naming/CommunicationException.java, * javax/naming/CompositeName.java, * javax/naming/CompoundName.java, * javax/naming/ConfigurationException.java, * javax/naming/Context.java, * javax/naming/ContextNotEmptyException.java, * javax/naming/InitialContext.java, * javax/naming/InsufficientResourcesException.java, * javax/naming/InterruptedNamingException.java, * javax/naming/InvalidNameException.java, * javax/naming/LimitExceededException.java, * javax/naming/LinkException.java, * javax/naming/LinkLoopException.java, * javax/naming/MalformedLinkException.java, * javax/naming/Name.java, * javax/naming/NameAlreadyBoundException.java, * javax/naming/NameClassPair.java, * javax/naming/NameNotFoundException.java, * javax/naming/NameParser.java, * javax/naming/NamingEnumeration.java, * javax/naming/NamingException.java, * javax/naming/NamingSecurityException.java, * javax/naming/NoInitialContextException.java, * javax/naming/NoPermissionException.java, * javax/naming/NotContextException.java, * javax/naming/PartialResultException.java, * javax/naming/RefAddr.java, * javax/naming/Reference.java, * javax/naming/Referenceable.java, * javax/naming/ReferralException.java, * javax/naming/ServiceUnavailableException.java, * javax/naming/SizeLimitExceededException.java, * javax/naming/StringRefAddr.java, * javax/naming/TimeLimitExceededException.java, * javax/naming/directory/AttributeInUseException.java, * javax/naming/directory/Attributes.java, * javax/naming/directory/BasicAttribute.java, * javax/naming/directory/BasicAttributes.java, * javax/naming/directory/InitialDirContext.java, * javax/naming/directory/ModificationItem.java, * javax/naming/directory/SearchControls.java, * javax/naming/directory/SearchResult.java, * javax/naming/event/EventContext.java, * javax/naming/event/NamespaceChangeListener.java, * javax/naming/event/NamingEvent.java, * javax/naming/event/NamingExceptionEvent.java, * javax/naming/event/NamingListener.java, * javax/naming/event/ObjectChangeListener.java, * javax/naming/ldap/Control.java, * javax/naming/ldap/ControlFactory.java, * javax/naming/ldap/ExtendedRequest.java, * javax/naming/ldap/ExtendedResponse.java, * javax/naming/ldap/HasControls.java, * javax/naming/ldap/InitialLdapContext.java, * javax/naming/ldap/LdapContext.java, * javax/naming/ldap/LdapReferralException.java, * javax/naming/ldap/StartTlsRequest.java, * javax/naming/ldap/UnsolicitedNotification.java, * javax/naming/ldap/UnsolicitedNotificationEvent.java, * javax/naming/ldap/UnsolicitedNotificationListener.java, * javax/naming/spi/DirObjectFactory.java, * javax/naming/spi/DirStateFactory.java, * javax/naming/spi/DirectoryManager.java, * javax/naming/spi/InitialContextFactory.java, * javax/naming/spi/InitialContextFactoryBuilder.java, * javax/naming/spi/NamingManager.java, * javax/naming/spi/ObjectFactory.java, * javax/naming/spi/ObjectFactoryBuilder.java, * javax/naming/spi/ResolveResult.java, * javax/naming/spi/Resolver.java, * javax/naming/spi/StateFactory.java, * javax/net/ssl/CertPathTrustManagerParameters.java, * javax/net/ssl/KeyManagerFactory.java, * javax/net/ssl/KeyStoreBuilderParameters.java, * javax/net/ssl/SSLContext.java, * javax/net/ssl/SSLEngine.java, * javax/net/ssl/SSLEngineResult.java, * javax/net/ssl/SSLException.java, * javax/net/ssl/TrustManagerFactory.java, * javax/net/ssl/X509ExtendedKeyManager.java, * javax/print/AttributeException.java, * javax/print/CancelablePrintJob.java, * javax/print/Doc.java, * javax/print/DocFlavor.java, * javax/print/DocPrintJob.java, * javax/print/FlavorException.java, * javax/print/MultiDoc.java, * javax/print/MultiDocPrintJob.java, * javax/print/MultiDocPrintService.java, * javax/print/PrintException.java, * javax/print/PrintService.java, * javax/print/PrintServiceLookup.java, * javax/print/ServiceUI.java, * javax/print/ServiceUIFactory.java, * javax/print/SimpleDoc.java, * javax/print/StreamPrintService.java, * javax/print/StreamPrintServiceFactory.java, * javax/print/URIException.java, * javax/print/attribute/Attribute.java, * javax/print/attribute/AttributeSet.java, * javax/print/attribute/AttributeSetUtilities.java, * javax/print/attribute/DateTimeSyntax.java, * javax/print/attribute/DocAttribute.java, * javax/print/attribute/DocAttributeSet.java, * javax/print/attribute/EnumSyntax.java, * javax/print/attribute/HashAttributeSet.java, * javax/print/attribute/HashDocAttributeSet.java, * javax/print/attribute/HashPrintJobAttributeSet.java, * javax/print/attribute/HashPrintRequestAttributeSet.java, * javax/print/attribute/HashPrintServiceAttributeSet.java, * javax/print/attribute/IntegerSyntax.java, * javax/print/attribute/PrintJobAttribute.java, * javax/print/attribute/PrintJobAttributeSet.java, * javax/print/attribute/PrintRequestAttribute.java, * javax/print/attribute/PrintRequestAttributeSet.java, * javax/print/attribute/PrintServiceAttribute.java, * javax/print/attribute/PrintServiceAttributeSet.java, * javax/print/attribute/ResolutionSyntax.java, * javax/print/attribute/SetOfIntegerSyntax.java, * javax/print/attribute/Size2DSyntax.java, * javax/print/attribute/SupportedValuesAttribute.java, * javax/print/attribute/TextSyntax.java, * javax/print/attribute/URISyntax.java, * javax/print/attribute/UnmodifiableSetException.java, * javax/print/attribute/standard/Chromaticity.java, * javax/print/attribute/standard/ColorSupported.java, * javax/print/attribute/standard/Compression.java, * javax/print/attribute/standard/Copies.java, * javax/print/attribute/standard/CopiesSupported.java, * javax/print/attribute/standard/DateTimeAtCompleted.java, * javax/print/attribute/standard/DateTimeAtCreation.java, * javax/print/attribute/standard/DateTimeAtProcessing.java, * javax/print/attribute/standard/Destination.java, * javax/print/attribute/standard/DocumentName.java, * javax/print/attribute/standard/Fidelity.java, * javax/print/attribute/standard/Finishings.java, * javax/print/attribute/standard/JobHoldUntil.java, * javax/print/attribute/standard/JobImpressions.java, * javax/print/attribute/standard/JobImpressionsCompleted.java, * javax/print/attribute/standard/JobImpressionsSupported.java, * javax/print/attribute/standard/JobKOctets.java, * javax/print/attribute/standard/JobKOctetsProcessed.java, * javax/print/attribute/standard/JobKOctetsSupported.java, * javax/print/attribute/standard/JobMediaSheets.java, * javax/print/attribute/standard/JobMediaSheetsCompleted.java, * javax/print/attribute/standard/JobMediaSheetsSupported.java, * javax/print/attribute/standard/JobMessageFromOperator.java, * javax/print/attribute/standard/JobName.java, * javax/print/attribute/standard/JobOriginatingUserName.java, * javax/print/attribute/standard/JobPriority.java, * javax/print/attribute/standard/JobPrioritySupported.java, * javax/print/attribute/standard/JobSheets.java, * javax/print/attribute/standard/JobState.java, * javax/print/attribute/standard/JobStateReason.java, * javax/print/attribute/standard/JobStateReasons.java, * javax/print/attribute/standard/Media.java, * javax/print/attribute/standard/MediaName.java, * javax/print/attribute/standard/MediaPrintableArea.java, * javax/print/attribute/standard/MediaSize.java, * javax/print/attribute/standard/MediaSizeName.java, * javax/print/attribute/standard/MediaTray.java, * javax/print/attribute/standard/MultipleDocumentHandling.java, * javax/print/attribute/standard/NumberOfDocuments.java, * javax/print/attribute/standard/NumberOfInterveningJobs.java, * javax/print/attribute/standard/NumberUp.java, * javax/print/attribute/standard/NumberUpSupported.java, * javax/print/attribute/standard/OrientationRequested.java, * javax/print/attribute/standard/OutputDeviceAssigned.java, * javax/print/attribute/standard/PDLOverrideSupported.java, * javax/print/attribute/standard/PageRanges.java, * javax/print/attribute/standard/PagesPerMinute.java, * javax/print/attribute/standard/PagesPerMinuteColor.java, * javax/print/attribute/standard/PresentationDirection.java, * javax/print/attribute/standard/PrintQuality.java, * javax/print/attribute/standard/PrinterInfo.java, * javax/print/attribute/standard/PrinterIsAcceptingJobs.java, * javax/print/attribute/standard/PrinterLocation.java, * javax/print/attribute/standard/PrinterMakeAndModel.java, * javax/print/attribute/standard/PrinterMessageFromOperator.java, * javax/print/attribute/standard/PrinterMoreInfo.java, * javax/print/attribute/standard/PrinterMoreInfoManufacturer.java, * javax/print/attribute/standard/PrinterName.java, * javax/print/attribute/standard/PrinterResolution.java, * javax/print/attribute/standard/PrinterState.java, * javax/print/attribute/standard/PrinterStateReason.java, * javax/print/attribute/standard/PrinterStateReasons.java, * javax/print/attribute/standard/PrinterURI.java, * javax/print/attribute/standard/QueuedJobCount.java, * javax/print/attribute/standard/ReferenceUriSchemesSupported.java, * javax/print/attribute/standard/RequestingUserName.java, * javax/print/attribute/standard/Severity.java, * javax/print/attribute/standard/SheetCollate.java, * javax/print/attribute/standard/Sides.java, * javax/print/event/PrintEvent.java, * javax/print/event/PrintJobAdapter.java, * javax/print/event/PrintJobAttributeEvent.java, * javax/print/event/PrintJobAttributeListener.java, * javax/print/event/PrintJobEvent.java, * javax/print/event/PrintJobListener.java, * javax/print/event/PrintServiceAttributeEvent.java, * javax/print/event/PrintServiceAttributeListener.java, * javax/rmi/CORBA/ClassDesc.java, * javax/rmi/CORBA/PortableRemoteObjectDelegate.java, * javax/rmi/CORBA/Stub.java, * javax/rmi/CORBA/StubDelegate.java, * javax/rmi/CORBA/Tie.java, * javax/rmi/CORBA/Util.java, * javax/rmi/CORBA/UtilDelegate.java, * javax/rmi/CORBA/ValueHandler.java, * javax/rmi/CORBA/ValueHandlerMultiFormat.java, * javax/rmi/PortableRemoteObject.java, * javax/rmi/ssl/SslRMIClientSocketFactory.java, * javax/rmi/ssl/SslRMIServerSocketFactory.java, * javax/security/auth/Subject.java, * javax/security/auth/callback/ChoiceCallback.java, * javax/security/auth/callback/ConfirmationCallback.java, * javax/security/auth/callback/NameCallback.java, * javax/security/auth/callback/PasswordCallback.java, * javax/security/auth/callback/TextInputCallback.java, * javax/security/auth/callback/TextOutputCallback.java, * javax/security/auth/kerberos/DelegationPermission.java, * javax/security/auth/kerberos/KerberosKey.java, * javax/security/auth/kerberos/KerberosPrincipal.java, * javax/security/auth/kerberos/ServicePermission.java, * javax/security/auth/login/AccountNotFoundException.java, * javax/security/auth/login/AppConfigurationEntry.java, * javax/security/auth/login/LoginContext.java, * javax/security/sasl/Sasl.java, * javax/sound/midi/ControllerEventListener.java, * javax/sound/midi/Instrument.java, * javax/sound/midi/InvalidMidiDataException.java, * javax/sound/midi/MetaEventListener.java, * javax/sound/midi/MetaMessage.java, * javax/sound/midi/MidiChannel.java, * javax/sound/midi/MidiDevice.java, * javax/sound/midi/MidiEvent.java, * javax/sound/midi/MidiFileFormat.java, * javax/sound/midi/MidiMessage.java, * javax/sound/midi/MidiSystem.java, * javax/sound/midi/MidiUnavailableException.java, * javax/sound/midi/Patch.java, * javax/sound/midi/Receiver.java, * javax/sound/midi/Sequence.java, * javax/sound/midi/Sequencer.java, * javax/sound/midi/ShortMessage.java, * javax/sound/midi/Soundbank.java, * javax/sound/midi/SoundbankResource.java, * javax/sound/midi/Synthesizer.java, * javax/sound/midi/SysexMessage.java, * javax/sound/midi/Track.java, * javax/sound/midi/Transmitter.java, * javax/sound/midi/VoiceStatus.java, * javax/sound/midi/spi/MidiDeviceProvider.java, * javax/sound/midi/spi/MidiFileReader.java, * javax/sound/midi/spi/MidiFileWriter.java, * javax/sound/midi/spi/SoundbankReader.java, * javax/sound/sampled/AudioFileFormat.java, * javax/sound/sampled/AudioFormat.java, * javax/sound/sampled/AudioInputStream.java, * javax/sound/sampled/AudioPermission.java, * javax/sound/sampled/AudioSystem.java, * javax/sound/sampled/BooleanControl.java, * javax/sound/sampled/Clip.java, * javax/sound/sampled/CompoundControl.java, * javax/sound/sampled/DataLine.java, * javax/sound/sampled/EnumControl.java, * javax/sound/sampled/FloatControl.java, * javax/sound/sampled/Line.java, * javax/sound/sampled/LineEvent.java, * javax/sound/sampled/LineUnavailableException.java, * javax/sound/sampled/Mixer.java, * javax/sound/sampled/Port.java, * javax/sound/sampled/ReverbType.java, * javax/sound/sampled/UnsupportedAudioFileException.java, * javax/sound/sampled/spi/AudioFileReader.java, * javax/sound/sampled/spi/AudioFileWriter.java, * javax/sound/sampled/spi/FormatConversionProvider.java, * javax/sql/ConnectionEvent.java, * javax/sql/ConnectionEventListener.java, * javax/sql/ConnectionPoolDataSource.java, * javax/sql/DataSource.java, * javax/sql/PooledConnection.java, * javax/sql/RowSet.java, * javax/sql/RowSetEvent.java, * javax/sql/RowSetInternal.java, * javax/sql/RowSetListener.java, * javax/sql/RowSetMetaData.java, * javax/sql/RowSetReader.java, * javax/sql/RowSetWriter.java, * javax/sql/XAConnection.java, * javax/sql/XADataSource.java, * javax/swing/AbstractAction.java, * javax/swing/AbstractButton.java, * javax/swing/AbstractCellEditor.java, * javax/swing/AbstractListModel.java, * javax/swing/AbstractSpinnerModel.java, * javax/swing/Action.java, * javax/swing/BorderFactory.java, * javax/swing/BoundedRangeModel.java, * javax/swing/Box.java, * javax/swing/BoxLayout.java, * javax/swing/ButtonGroup.java, * javax/swing/ButtonModel.java, * javax/swing/CellEditor.java, * javax/swing/CellRendererPane.java, * javax/swing/ComboBoxModel.java, * javax/swing/ComponentInputMap.java, * javax/swing/DebugGraphics.java, * javax/swing/DefaultBoundedRangeModel.java, * javax/swing/DefaultButtonModel.java, * javax/swing/DefaultCellEditor.java, * javax/swing/DefaultComboBoxModel.java, * javax/swing/DefaultDesktopManager.java, * javax/swing/DefaultFocusManager.java, * javax/swing/DefaultListModel.java, * javax/swing/DefaultListSelectionModel.java, * javax/swing/DefaultSingleSelectionModel.java, * javax/swing/FocusManager.java, * javax/swing/GrayFilter.java, * javax/swing/Icon.java, * javax/swing/ImageIcon.java, * javax/swing/InputMap.java, * javax/swing/InternalFrameFocusTraversalPolicy.java, * javax/swing/JApplet.java, * javax/swing/JButton.java, * javax/swing/JCheckBox.java, * javax/swing/JCheckBoxMenuItem.java, * javax/swing/JComboBox.java, * javax/swing/JComponent.java, * javax/swing/JDesktopPane.java, * javax/swing/JDialog.java, * javax/swing/JEditorPane.java, * javax/swing/JFileChooser.java, * javax/swing/JFormattedTextField.java, * javax/swing/JFrame.java, * javax/swing/JInternalFrame.java, * javax/swing/JLabel.java, * javax/swing/JLayeredPane.java, * javax/swing/JList.java, * javax/swing/JMenu.java, * javax/swing/JMenuBar.java, * javax/swing/JMenuItem.java, * javax/swing/JOptionPane.java, * javax/swing/JPanel.java, * javax/swing/JPasswordField.java, * javax/swing/JPopupMenu.java, * javax/swing/JProgressBar.java, * javax/swing/JRadioButton.java, * javax/swing/JRadioButtonMenuItem.java, * javax/swing/JRootPane.java, * javax/swing/JScrollBar.java, * javax/swing/JScrollPane.java, * javax/swing/JSeparator.java, * javax/swing/JSlider.java, * javax/swing/JSpinner.java, * javax/swing/JSplitPane.java, * javax/swing/JTabbedPane.java, * javax/swing/JTable.java, * javax/swing/JTextArea.java, * javax/swing/JTextField.java, * javax/swing/JTextPane.java, * javax/swing/JToggleButton.java, * javax/swing/JToolBar.java, * javax/swing/JToolTip.java, * javax/swing/JTree.java, * javax/swing/JViewport.java, * javax/swing/JWindow.java, * javax/swing/KeyStroke.java, * javax/swing/KeyboardManager.java, * javax/swing/LayoutFocusTraversalPolicy.java, * javax/swing/ListCellRenderer.java, * javax/swing/ListSelectionModel.java, * javax/swing/LookAndFeel.java, * javax/swing/MenuSelectionManager.java, * javax/swing/OverlayLayout.java, * javax/swing/Popup.java, * javax/swing/PopupFactory.java, * javax/swing/ProgressMonitor.java, * javax/swing/ProgressMonitorInputStream.java, * javax/swing/Renderer.java, * javax/swing/RepaintManager.java, * javax/swing/ScrollPaneLayout.java, * javax/swing/Scrollable.java, * javax/swing/SingleSelectionModel.java, * javax/swing/SizeRequirements.java, * javax/swing/SizeSequence.java, * javax/swing/SortingFocusTraversalPolicy.java, * javax/swing/SpinnerDateModel.java, * javax/swing/SpinnerListModel.java, * javax/swing/SpinnerModel.java, * javax/swing/SpinnerNumberModel.java, * javax/swing/Spring.java, * javax/swing/SpringLayout.java, * javax/swing/SwingConstants.java, * javax/swing/SwingUtilities.java, * javax/swing/Timer.java, * javax/swing/ToolTipManager.java, * javax/swing/TransferHandler.java, * javax/swing/UIDefaults.java, * javax/swing/UIManager.java, * javax/swing/UnsupportedLookAndFeelException.java, * javax/swing/ViewportLayout.java, * javax/swing/WindowConstants.java, * javax/swing/border/AbstractBorder.java, * javax/swing/border/BevelBorder.java, * javax/swing/border/Border.java, * javax/swing/border/CompoundBorder.java, * javax/swing/border/EmptyBorder.java, * javax/swing/border/EtchedBorder.java, * javax/swing/border/LineBorder.java, * javax/swing/border/MatteBorder.java, * javax/swing/border/SoftBevelBorder.java, * javax/swing/border/TitledBorder.java, * javax/swing/colorchooser/AbstractColorChooserPanel.java, * javax/swing/colorchooser/ColorChooserComponentFactory.java, * javax/swing/colorchooser/ColorSelectionModel.java, * javax/swing/colorchooser/DefaultColorSelectionModel.java, * javax/swing/colorchooser/DefaultHSBChooserPanel.java, * javax/swing/colorchooser/DefaultRGBChooserPanel.java, * javax/swing/colorchooser/DefaultSwatchChooserPanel.java, * javax/swing/event/AncestorEvent.java, * javax/swing/event/AncestorListener.java, * javax/swing/event/CaretEvent.java, * javax/swing/event/CaretListener.java, * javax/swing/event/CellEditorListener.java, * javax/swing/event/ChangeEvent.java, * javax/swing/event/ChangeListener.java, * javax/swing/event/DocumentEvent.java, * javax/swing/event/DocumentListener.java, * javax/swing/event/EventListenerList.java, * javax/swing/event/HyperlinkEvent.java, * javax/swing/event/HyperlinkListener.java, * javax/swing/event/InternalFrameAdapter.java, * javax/swing/event/InternalFrameEvent.java, * javax/swing/event/InternalFrameListener.java, * javax/swing/event/ListDataEvent.java, * javax/swing/event/ListDataListener.java, * javax/swing/event/ListSelectionEvent.java, * javax/swing/event/ListSelectionListener.java, * javax/swing/event/MenuDragMouseEvent.java, * javax/swing/event/MenuDragMouseListener.java, * javax/swing/event/MenuEvent.java, * javax/swing/event/MenuKeyEvent.java, * javax/swing/event/MenuKeyListener.java, * javax/swing/event/MenuListener.java, * javax/swing/event/MouseInputListener.java, * javax/swing/event/PopupMenuEvent.java, * javax/swing/event/PopupMenuListener.java, * javax/swing/event/SwingPropertyChangeSupport.java, * javax/swing/event/TableColumnModelEvent.java, * javax/swing/event/TableColumnModelListener.java, * javax/swing/event/TableModelEvent.java, * javax/swing/event/TableModelListener.java, * javax/swing/event/TreeExpansionEvent.java, * javax/swing/event/TreeExpansionListener.java, * javax/swing/event/TreeModelEvent.java, * javax/swing/event/TreeModelListener.java, * javax/swing/event/TreeSelectionEvent.java, * javax/swing/event/TreeSelectionListener.java, * javax/swing/event/TreeWillExpandListener.java, * javax/swing/event/UndoableEditEvent.java, * javax/swing/filechooser/FileFilter.java, * javax/swing/filechooser/FileSystemView.java, * javax/swing/filechooser/FileView.java, * javax/swing/filechooser/UnixFileSystemView.java, * javax/swing/plaf/BorderUIResource.java, * javax/swing/plaf/ColorChooserUI.java, * javax/swing/plaf/ColorUIResource.java, * javax/swing/plaf/ComboBoxUI.java, * javax/swing/plaf/ComponentInputMapUIResource.java, * javax/swing/plaf/ComponentUI.java, * javax/swing/plaf/FileChooserUI.java, * javax/swing/plaf/IconUIResource.java, * javax/swing/plaf/SplitPaneUI.java, * javax/swing/plaf/TabbedPaneUI.java, * javax/swing/plaf/TextUI.java, * javax/swing/plaf/UIResource.java, * javax/swing/plaf/basic/BasicArrowButton.java, * javax/swing/plaf/basic/BasicBorders.java, * javax/swing/plaf/basic/BasicButtonListener.java, * javax/swing/plaf/basic/BasicButtonUI.java, * javax/swing/plaf/basic/BasicCheckBoxMenuItemUI.java, * javax/swing/plaf/basic/BasicCheckBoxUI.java, * javax/swing/plaf/basic/BasicColorChooserUI.java, * javax/swing/plaf/basic/BasicComboBoxEditor.java, * javax/swing/plaf/basic/BasicComboBoxRenderer.java, * javax/swing/plaf/basic/BasicComboBoxUI.java, * javax/swing/plaf/basic/BasicComboPopup.java, * javax/swing/plaf/basic/BasicDesktopIconUI.java, * javax/swing/plaf/basic/BasicDesktopPaneUI.java, * javax/swing/plaf/basic/BasicDirectoryModel.java, * javax/swing/plaf/basic/BasicEditorPaneUI.java, * javax/swing/plaf/basic/BasicFileChooserUI.java, * javax/swing/plaf/basic/BasicFormattedTextFieldUI.java, * javax/swing/plaf/basic/BasicGraphicsUtils.java, * javax/swing/plaf/basic/BasicHTML.java, * javax/swing/plaf/basic/BasicIconFactory.java, * javax/swing/plaf/basic/BasicInternalFrameTitlePane.java, * javax/swing/plaf/basic/BasicInternalFrameUI.java, * javax/swing/plaf/basic/BasicLabelUI.java, * javax/swing/plaf/basic/BasicListUI.java, * javax/swing/plaf/basic/BasicLookAndFeel.java, * javax/swing/plaf/basic/BasicMenuBarUI.java, * javax/swing/plaf/basic/BasicMenuItemUI.java, * javax/swing/plaf/basic/BasicMenuUI.java, * javax/swing/plaf/basic/BasicOptionPaneUI.java, * javax/swing/plaf/basic/BasicPanelUI.java, * javax/swing/plaf/basic/BasicPasswordFieldUI.java, * javax/swing/plaf/basic/BasicPopupMenuUI.java, * javax/swing/plaf/basic/BasicProgressBarUI.java, * javax/swing/plaf/basic/BasicRadioButtonUI.java, * javax/swing/plaf/basic/BasicRootPaneUI.java, * javax/swing/plaf/basic/BasicScrollBarUI.java, * javax/swing/plaf/basic/BasicScrollPaneUI.java, * javax/swing/plaf/basic/BasicSeparatorUI.java, * javax/swing/plaf/basic/BasicSliderUI.java, * javax/swing/plaf/basic/BasicSpinnerUI.java, * javax/swing/plaf/basic/BasicSplitPaneDivider.java, * javax/swing/plaf/basic/BasicSplitPaneUI.java, * javax/swing/plaf/basic/BasicTabbedPaneUI.java, * javax/swing/plaf/basic/BasicTableHeaderUI.java, * javax/swing/plaf/basic/BasicTableUI.java, * javax/swing/plaf/basic/BasicTextAreaUI.java, * javax/swing/plaf/basic/BasicTextFieldUI.java, * javax/swing/plaf/basic/BasicTextPaneUI.java, * javax/swing/plaf/basic/BasicTextUI.java, * javax/swing/plaf/basic/BasicToggleButtonUI.java, * javax/swing/plaf/basic/BasicToolBarUI.java, * javax/swing/plaf/basic/BasicToolTipUI.java, * javax/swing/plaf/basic/BasicTreeUI.java, * javax/swing/plaf/basic/BasicViewportUI.java, * javax/swing/plaf/metal/DefaultMetalTheme.java, * javax/swing/plaf/metal/MetalBorders.java, * javax/swing/plaf/metal/MetalButtonListener.java, * javax/swing/plaf/metal/MetalButtonUI.java, * javax/swing/plaf/metal/MetalCheckBoxIcon.java, * javax/swing/plaf/metal/MetalCheckBoxUI.java, * javax/swing/plaf/metal/MetalComboBoxButton.java, * javax/swing/plaf/metal/MetalComboBoxEditor.java, * javax/swing/plaf/metal/MetalComboBoxIcon.java, * javax/swing/plaf/metal/MetalComboBoxUI.java, * javax/swing/plaf/metal/MetalFileChooserUI.java, * javax/swing/plaf/metal/MetalIconFactory.java, * javax/swing/plaf/metal/MetalInternalFrameTitlePane.java, * javax/swing/plaf/metal/MetalInternalFrameUI.java, * javax/swing/plaf/metal/MetalLabelUI.java, * javax/swing/plaf/metal/MetalLookAndFeel.java, * javax/swing/plaf/metal/MetalMenuBarUI.java, * javax/swing/plaf/metal/MetalProgressBarUI.java, * javax/swing/plaf/metal/MetalRadioButtonUI.java, * javax/swing/plaf/metal/MetalRootPaneUI.java, * javax/swing/plaf/metal/MetalScrollBarUI.java, * javax/swing/plaf/metal/MetalScrollButton.java, * javax/swing/plaf/metal/MetalScrollPaneUI.java, * javax/swing/plaf/metal/MetalSeparatorUI.java, * javax/swing/plaf/metal/MetalSliderUI.java, * javax/swing/plaf/metal/MetalSplitPaneDivider.java, * javax/swing/plaf/metal/MetalSplitPaneUI.java, * javax/swing/plaf/metal/MetalTabbedPaneUI.java, * javax/swing/plaf/metal/MetalTextFieldUI.java, * javax/swing/plaf/metal/MetalTheme.java, * javax/swing/plaf/metal/MetalToggleButtonUI.java, * javax/swing/plaf/metal/MetalToolBarUI.java, * javax/swing/plaf/metal/MetalToolTipUI.java, * javax/swing/plaf/metal/MetalTreeUI.java, * javax/swing/plaf/metal/MetalUtils.java, * javax/swing/plaf/metal/OceanTheme.java, * javax/swing/plaf/multi/MultiButtonUI.java, * javax/swing/plaf/multi/MultiColorChooserUI.java, * javax/swing/plaf/multi/MultiComboBoxUI.java, * javax/swing/plaf/multi/MultiDesktopIconUI.java, * javax/swing/plaf/multi/MultiDesktopPaneUI.java, * javax/swing/plaf/multi/MultiFileChooserUI.java, * javax/swing/plaf/multi/MultiInternalFrameUI.java, * javax/swing/plaf/multi/MultiLabelUI.java, * javax/swing/plaf/multi/MultiListUI.java, * javax/swing/plaf/multi/MultiLookAndFeel.java, * javax/swing/plaf/multi/MultiMenuBarUI.java, * javax/swing/plaf/multi/MultiMenuItemUI.java, * javax/swing/plaf/multi/MultiOptionPaneUI.java, * javax/swing/plaf/multi/MultiPanelUI.java, * javax/swing/plaf/multi/MultiPopupMenuUI.java, * javax/swing/plaf/multi/MultiProgressBarUI.java, * javax/swing/plaf/multi/MultiRootPaneUI.java, * javax/swing/plaf/multi/MultiScrollBarUI.java, * javax/swing/plaf/multi/MultiScrollPaneUI.java, * javax/swing/plaf/multi/MultiSeparatorUI.java, * javax/swing/plaf/multi/MultiSliderUI.java, * javax/swing/plaf/multi/MultiSpinnerUI.java, * javax/swing/plaf/multi/MultiSplitPaneUI.java, * javax/swing/plaf/multi/MultiTabbedPaneUI.java, * javax/swing/plaf/multi/MultiTableHeaderUI.java, * javax/swing/plaf/multi/MultiTableUI.java, * javax/swing/plaf/multi/MultiTextUI.java, * javax/swing/plaf/multi/MultiToolBarUI.java, * javax/swing/plaf/multi/MultiToolTipUI.java, * javax/swing/plaf/multi/MultiTreeUI.java, * javax/swing/plaf/multi/MultiViewportUI.java, * javax/swing/plaf/synth/SynthGraphicsUtils.java, * javax/swing/plaf/synth/SynthLookAndFeel.java, * javax/swing/plaf/synth/SynthPainter.java, * javax/swing/table/AbstractTableModel.java, * javax/swing/table/DefaultTableCellRenderer.java, * javax/swing/table/DefaultTableColumnModel.java, * javax/swing/table/DefaultTableModel.java, * javax/swing/table/JTableHeader.java, * javax/swing/table/TableCellEditor.java, * javax/swing/table/TableCellRenderer.java, * javax/swing/table/TableColumn.java, * javax/swing/table/TableColumnModel.java, * javax/swing/table/TableModel.java, * javax/swing/text/AbstractDocument.java, * javax/swing/text/AbstractWriter.java, * javax/swing/text/AsyncBoxView.java, * javax/swing/text/AttributeSet.java, * javax/swing/text/BoxView.java, * javax/swing/text/Caret.java, * javax/swing/text/ComponentView.java, * javax/swing/text/CompositeView.java, * javax/swing/text/DefaultCaret.java, * javax/swing/text/DefaultEditorKit.java, * javax/swing/text/DefaultFormatter.java, * javax/swing/text/DefaultFormatterFactory.java, * javax/swing/text/DefaultHighlighter.java, * javax/swing/text/DefaultStyledDocument.java, * javax/swing/text/DocumentFilter.java, * javax/swing/text/EditorKit.java, * javax/swing/text/Element.java, * javax/swing/text/ElementIterator.java, * javax/swing/text/EmptyAttributeSet.java, * javax/swing/text/FieldView.java, * javax/swing/text/FlowView.java, * javax/swing/text/GapContent.java, * javax/swing/text/GlyphView.java, * javax/swing/text/Highlighter.java, * javax/swing/text/InternationalFormatter.java, * javax/swing/text/JTextComponent.java, * javax/swing/text/Keymap.java, * javax/swing/text/LayeredHighlighter.java, * javax/swing/text/LayoutQueue.java, * javax/swing/text/MaskFormatter.java, * javax/swing/text/MutableAttributeSet.java, * javax/swing/text/NavigationFilter.java, * javax/swing/text/NumberFormatter.java, * javax/swing/text/ParagraphView.java, * javax/swing/text/PasswordView.java, * javax/swing/text/PlainDocument.java, * javax/swing/text/PlainView.java, * javax/swing/text/Position.java, * javax/swing/text/Segment.java, * javax/swing/text/SimpleAttributeSet.java, * javax/swing/text/StringContent.java, * javax/swing/text/Style.java, * javax/swing/text/StyleConstants.java, * javax/swing/text/StyleContext.java, * javax/swing/text/StyledDocument.java, * javax/swing/text/StyledEditorKit.java, * javax/swing/text/TabExpander.java, * javax/swing/text/TabSet.java, * javax/swing/text/TabStop.java, * javax/swing/text/TabableView.java, * javax/swing/text/TableView.java, * javax/swing/text/TextAction.java, * javax/swing/text/Utilities.java, * javax/swing/text/View.java, * javax/swing/text/ViewFactory.java, * javax/swing/text/WrappedPlainView.java, * javax/swing/text/html/BRView.java, * javax/swing/text/html/BlockView.java, * javax/swing/text/html/CSS.java, * javax/swing/text/html/CSSBorder.java, * javax/swing/text/html/CSSParser.java, * javax/swing/text/html/FormView.java, * javax/swing/text/html/HRuleView.java, * javax/swing/text/html/HTMLDocument.java, * javax/swing/text/html/HTMLEditorKit.java, * javax/swing/text/html/HTMLWriter.java, * javax/swing/text/html/ImageView.java, * javax/swing/text/html/InlineView.java, * javax/swing/text/html/ListView.java, * javax/swing/text/html/MinimalHTMLWriter.java, * javax/swing/text/html/MultiAttributeSet.java, * javax/swing/text/html/MultiStyle.java, * javax/swing/text/html/ParagraphView.java, * javax/swing/text/html/StyleSheet.java, * javax/swing/text/html/TableView.java, * javax/swing/text/html/ViewAttributeSet.java, * javax/swing/text/html/parser/Entity.java, * javax/swing/text/html/parser/Parser.java, * javax/swing/text/rtf/RTFParser.java, * javax/swing/text/rtf/RTFScanner.java, * javax/swing/tree/AbstractLayoutCache.java, * javax/swing/tree/DefaultMutableTreeNode.java, * javax/swing/tree/DefaultTreeCellEditor.java, * javax/swing/tree/DefaultTreeCellRenderer.java, * javax/swing/tree/DefaultTreeModel.java, * javax/swing/tree/DefaultTreeSelectionModel.java, * javax/swing/tree/ExpandVetoException.java, * javax/swing/tree/FixedHeightLayoutCache.java, * javax/swing/tree/MutableTreeNode.java, * javax/swing/tree/RowMapper.java, * javax/swing/tree/TreeCellEditor.java, * javax/swing/tree/TreeCellRenderer.java, * javax/swing/tree/TreeNode.java, * javax/swing/tree/TreePath.java, * javax/swing/tree/TreeSelectionModel.java, * javax/swing/tree/VariableHeightLayoutCache.java, * javax/swing/undo/AbstractUndoableEdit.java, * javax/swing/undo/CompoundEdit.java, * javax/swing/undo/StateEdit.java, * javax/swing/undo/UndoManager.java, * javax/swing/undo/UndoableEdit.java, * javax/tools/FileObject.java, * javax/transaction/HeuristicCommitException.java, * javax/transaction/HeuristicMixedException.java, * javax/transaction/HeuristicRollbackException.java, * javax/transaction/InvalidTransactionException.java, * javax/transaction/NotSupportedException.java, * javax/transaction/RollbackException.java, * javax/transaction/Status.java, * javax/transaction/Synchronization.java, * javax/transaction/SystemException.java, * javax/transaction/Transaction.java, * javax/transaction/TransactionManager.java, * javax/transaction/TransactionRequiredException.java, * javax/transaction/TransactionRolledbackException.java, * javax/transaction/UserTransaction.java, * javax/transaction/xa/XAException.java, * javax/transaction/xa/XAResource.java, * javax/transaction/xa/Xid.java, * javax/xml/XMLConstants.java, * javax/xml/datatype/DatatypeConfigurationException.java, * javax/xml/datatype/DatatypeConstants.java, * javax/xml/datatype/DatatypeFactory.java, * javax/xml/datatype/Duration.java, * javax/xml/datatype/XMLGregorianCalendar.java, * javax/xml/namespace/NamespaceContext.java, * javax/xml/namespace/QName.java, * javax/xml/parsers/DocumentBuilder.java, * javax/xml/parsers/DocumentBuilderFactory.java, * javax/xml/parsers/FactoryConfigurationError.java, * javax/xml/parsers/ParserConfigurationException.java, * javax/xml/parsers/SAXParser.java, * javax/xml/parsers/SAXParserFactory.java, * javax/xml/stream/EventFilter.java, * javax/xml/stream/FactoryConfigurationError.java, * javax/xml/stream/Location.java, * javax/xml/stream/StreamFilter.java, * javax/xml/stream/XMLEventFactory.java, * javax/xml/stream/XMLEventReader.java, * javax/xml/stream/XMLEventWriter.java, * javax/xml/stream/XMLInputFactory.java, * javax/xml/stream/XMLOutputFactory.java, * javax/xml/stream/XMLReporter.java, * javax/xml/stream/XMLResolver.java, * javax/xml/stream/XMLStreamConstants.java, * javax/xml/stream/XMLStreamException.java, * javax/xml/stream/XMLStreamReader.java, * javax/xml/stream/XMLStreamWriter.java, * javax/xml/stream/events/Attribute.java, * javax/xml/stream/events/Characters.java, * javax/xml/stream/events/Comment.java, * javax/xml/stream/events/DTD.java, * javax/xml/stream/events/EndDocument.java, * javax/xml/stream/events/EndElement.java, * javax/xml/stream/events/EntityDeclaration.java, * javax/xml/stream/events/EntityReference.java, * javax/xml/stream/events/Namespace.java, * javax/xml/stream/events/NotationDeclaration.java, * javax/xml/stream/events/ProcessingInstruction.java, * javax/xml/stream/events/StartDocument.java, * javax/xml/stream/events/StartElement.java, * javax/xml/stream/events/XMLEvent.java, * javax/xml/stream/util/EventReaderDelegate.java, * javax/xml/stream/util/StreamReaderDelegate.java, * javax/xml/stream/util/XMLEventAllocator.java, * javax/xml/stream/util/XMLEventConsumer.java, * javax/xml/transform/ErrorListener.java, * javax/xml/transform/OutputKeys.java, * javax/xml/transform/Result.java, * javax/xml/transform/Source.java, * javax/xml/transform/SourceLocator.java, * javax/xml/transform/Templates.java, * javax/xml/transform/Transformer.java, * javax/xml/transform/TransformerConfigurationException.java, * javax/xml/transform/TransformerException.java, * javax/xml/transform/TransformerFactory.java, * javax/xml/transform/TransformerFactoryConfigurationError.java, * javax/xml/transform/URIResolver.java, * javax/xml/transform/dom/DOMLocator.java, * javax/xml/transform/dom/DOMResult.java, * javax/xml/transform/dom/DOMSource.java, * javax/xml/transform/sax/SAXResult.java, * javax/xml/transform/sax/SAXSource.java, * javax/xml/transform/sax/SAXTransformerFactory.java, * javax/xml/transform/sax/TemplatesHandler.java, * javax/xml/transform/sax/TransformerHandler.java, * javax/xml/transform/stream/StreamResult.java, * javax/xml/transform/stream/StreamSource.java, * javax/xml/validation/Schema.java, * javax/xml/validation/SchemaFactory.java, * javax/xml/validation/SchemaFactoryLoader.java, * javax/xml/validation/TypeInfoProvider.java, * javax/xml/validation/Validator.java, * javax/xml/validation/ValidatorHandler.java, * javax/xml/xpath/XPath.java, * javax/xml/xpath/XPathConstants.java, * javax/xml/xpath/XPathException.java, * javax/xml/xpath/XPathExpression.java, * javax/xml/xpath/XPathExpressionException.java, * javax/xml/xpath/XPathFactory.java, * javax/xml/xpath/XPathFactoryConfigurationException.java, * javax/xml/xpath/XPathFunction.java, * javax/xml/xpath/XPathFunctionException.java, * javax/xml/xpath/XPathFunctionResolver.java, * javax/xml/xpath/XPathVariableResolver.java, * org/omg/CORBA/ARG_IN.java, * org/omg/CORBA/ARG_INOUT.java, * org/omg/CORBA/ARG_OUT.java, * org/omg/CORBA/AnySeqHolder.java, * org/omg/CORBA/BAD_CONTEXT.java, * org/omg/CORBA/BAD_INV_ORDER.java, * org/omg/CORBA/BAD_OPERATION.java, * org/omg/CORBA/BAD_PARAM.java, * org/omg/CORBA/BAD_POLICY.java, * org/omg/CORBA/BAD_POLICY_TYPE.java, * org/omg/CORBA/BAD_POLICY_VALUE.java, * org/omg/CORBA/BAD_TYPECODE.java, * org/omg/CORBA/COMM_FAILURE.java, * org/omg/CORBA/CTX_RESTRICT_SCOPE.java, * org/omg/CORBA/CompletionStatus.java, * org/omg/CORBA/CompletionStatusHelper.java, * org/omg/CORBA/Context.java, * org/omg/CORBA/Current.java, * org/omg/CORBA/CurrentHelper.java, * org/omg/CORBA/CurrentHolder.java, * org/omg/CORBA/CustomMarshal.java, * org/omg/CORBA/CustomValue.java, * org/omg/CORBA/DATA_CONVERSION.java, * org/omg/CORBA/DataInputStream.java, * org/omg/CORBA/DataOutputStream.java, * org/omg/CORBA/DefinitionKind.java, * org/omg/CORBA/DefinitionKindHelper.java, * org/omg/CORBA/DynamicImplementation.java, * org/omg/CORBA/FREE_MEM.java, * org/omg/CORBA/FieldNameHelper.java, * org/omg/CORBA/IDLTypeHelper.java, * org/omg/CORBA/IMP_LIMIT.java, * org/omg/CORBA/INITIALIZE.java, * org/omg/CORBA/INTERNAL.java, * org/omg/CORBA/INTF_REPOS.java, * org/omg/CORBA/INVALID_TRANSACTION.java, * org/omg/CORBA/INV_FLAG.java, * org/omg/CORBA/INV_IDENT.java, * org/omg/CORBA/INV_OBJREF.java, * org/omg/CORBA/INV_POLICY.java, * org/omg/CORBA/IRObject.java, * org/omg/CORBA/IRObjectOperations.java, * org/omg/CORBA/IdentifierHelper.java, * org/omg/CORBA/LocalObject.java, * org/omg/CORBA/LongSeqHolder.java, * org/omg/CORBA/MARSHAL.java, * org/omg/CORBA/NO_IMPLEMENT.java, * org/omg/CORBA/NO_MEMORY.java, * org/omg/CORBA/NO_PERMISSION.java, * org/omg/CORBA/NO_RESOURCES.java, * org/omg/CORBA/NO_RESPONSE.java, * org/omg/CORBA/NVList.java, * org/omg/CORBA/OBJECT_NOT_EXIST.java, * org/omg/CORBA/OBJ_ADAPTER.java, * org/omg/CORBA/OMGVMCID.java, * org/omg/CORBA/ORB.java, * org/omg/CORBA/ObjectHelper.java, * org/omg/CORBA/ObjectHolder.java, * org/omg/CORBA/PERSIST_STORE.java, * org/omg/CORBA/ParameterMode.java, * org/omg/CORBA/ParameterModeHelper.java, * org/omg/CORBA/PolicyErrorCodeHelper.java, * org/omg/CORBA/PolicyErrorHelper.java, * org/omg/CORBA/PolicyErrorHolder.java, * org/omg/CORBA/PolicyHelper.java, * org/omg/CORBA/PolicyHolder.java, * org/omg/CORBA/PolicyListHelper.java, * org/omg/CORBA/PolicyListHolder.java, * org/omg/CORBA/PolicyOperations.java, * org/omg/CORBA/PolicyTypeHelper.java, * org/omg/CORBA/RepositoryIdHelper.java, * org/omg/CORBA/Request.java, * org/omg/CORBA/ServiceDetailHelper.java, * org/omg/CORBA/ServiceInformationHelper.java, * org/omg/CORBA/SetOverrideTypeHelper.java, * org/omg/CORBA/StringValueHelper.java, * org/omg/CORBA/StructMember.java, * org/omg/CORBA/StructMemberHelper.java, * org/omg/CORBA/SystemException.java, * org/omg/CORBA/TCKind.java, * org/omg/CORBA/TRANSACTION_REQUIRED.java, * org/omg/CORBA/TRANSACTION_ROLLEDBACK.java, * org/omg/CORBA/TRANSIENT.java, * org/omg/CORBA/TypeCode.java, * org/omg/CORBA/TypeCodePackage/BadKind.java, * org/omg/CORBA/TypeCodePackage/Bounds.java, * org/omg/CORBA/UNSUPPORTED_POLICY.java, * org/omg/CORBA/UNSUPPORTED_POLICY_VALUE.java, * org/omg/CORBA/UnionMemberHelper.java, * org/omg/CORBA/UnknownUserException.java, * org/omg/CORBA/UnknownUserExceptionHolder.java, * org/omg/CORBA/ValueBaseHelper.java, * org/omg/CORBA/ValueBaseHolder.java, * org/omg/CORBA/ValueMemberHelper.java, * org/omg/CORBA/VersionSpecHelper.java, * org/omg/CORBA/VisibilityHelper.java, * org/omg/CORBA/WStringValueHelper.java, * org/omg/CORBA/WrongTransactionHelper.java, * org/omg/CORBA/WrongTransactionHolder.java, * org/omg/CORBA/_IDLTypeStub.java, * org/omg/CORBA/_PolicyStub.java, * org/omg/CORBA/portable/CustomValue.java, * org/omg/CORBA/portable/Delegate.java, * org/omg/CORBA/portable/ObjectImpl.java, * org/omg/CORBA/portable/StreamableValue.java, * org/omg/CORBA/portable/ValueBase.java, * org/omg/CORBA_2_3/ORB.java, * org/omg/CORBA_2_3/portable/Delegate.java, * org/omg/CORBA_2_3/portable/InputStream.java, * org/omg/CORBA_2_3/portable/ObjectImpl.java, * org/omg/CORBA_2_3/portable/OutputStream.java, * org/omg/CosNaming/BindingHelper.java, * org/omg/CosNaming/BindingIterator.java, * org/omg/CosNaming/BindingIteratorHelper.java, * org/omg/CosNaming/BindingIteratorOperations.java, * org/omg/CosNaming/BindingIteratorPOA.java, * org/omg/CosNaming/BindingType.java, * org/omg/CosNaming/BindingTypeHelper.java, * org/omg/CosNaming/IstringHelper.java, * org/omg/CosNaming/NameComponentHelper.java, * org/omg/CosNaming/NameHelper.java, * org/omg/CosNaming/NamingContext.java, * org/omg/CosNaming/NamingContextExtHelper.java, * org/omg/CosNaming/NamingContextExtPOA.java, * org/omg/CosNaming/NamingContextExtPackage/InvalidAddress.java, * org/omg/CosNaming/NamingContextHelper.java, * org/omg/CosNaming/NamingContextPOA.java, * org/omg/CosNaming/NamingContextPackage/AlreadyBound.java, * org/omg/CosNaming/NamingContextPackage/CannotProceed.java, * org/omg/CosNaming/NamingContextPackage/CannotProceedHelper.java, * org/omg/CosNaming/NamingContextPackage/InvalidName.java, * org/omg/CosNaming/NamingContextPackage/InvalidNameHelper.java, * org/omg/CosNaming/NamingContextPackage/NotEmptyHelper.java, * org/omg/CosNaming/NamingContextPackage/NotFound.java, * org/omg/CosNaming/NamingContextPackage/NotFoundHelper.java, * org/omg/CosNaming/NamingContextPackage/NotFoundReason.java, * org/omg/CosNaming/NamingContextPackage/NotFoundReasonHelper.java, * org/omg/CosNaming/NamingContextPackage/NotFoundReasonHolder.java, * org/omg/CosNaming/_BindingIteratorImplBase.java, * org/omg/CosNaming/_BindingIteratorStub.java, * org/omg/CosNaming/_NamingContextExtStub.java, * org/omg/CosNaming/_NamingContextStub.java, * org/omg/Dynamic/Parameter.java, * org/omg/DynamicAny/AnySeqHelper.java, * org/omg/DynamicAny/DynAny.java, * org/omg/DynamicAny/DynAnyFactoryHelper.java, * org/omg/DynamicAny/DynAnyFactoryPackage/InconsistentTypeCode.java, * org/omg/DynamicAny/DynAnyFactoryPackage/InconsistentTypeCodeHelper.java, * org/omg/DynamicAny/DynAnyHelper.java, * org/omg/DynamicAny/DynAnyPackage/InvalidValue.java, * org/omg/DynamicAny/DynAnyPackage/InvalidValueHelper.java, * org/omg/DynamicAny/DynAnyPackage/TypeMismatch.java, * org/omg/DynamicAny/DynAnyPackage/TypeMismatchHelper.java, * org/omg/DynamicAny/DynAnySeqHelper.java, * org/omg/DynamicAny/DynArrayHelper.java, * org/omg/DynamicAny/DynEnumHelper.java, * org/omg/DynamicAny/DynFixedHelper.java, * org/omg/DynamicAny/DynSequenceHelper.java, * org/omg/DynamicAny/DynStructHelper.java, * org/omg/DynamicAny/DynUnionHelper.java, * org/omg/DynamicAny/DynValueBox.java, * org/omg/DynamicAny/DynValueCommonOperations.java, * org/omg/DynamicAny/DynValueHelper.java, * org/omg/DynamicAny/FieldNameHelper.java, * org/omg/DynamicAny/NameDynAnyPairHelper.java, * org/omg/DynamicAny/NameDynAnyPairSeqHelper.java, * org/omg/DynamicAny/NameValuePair.java, * org/omg/DynamicAny/NameValuePairHelper.java, * org/omg/DynamicAny/NameValuePairSeqHelper.java, * org/omg/DynamicAny/_DynAnyFactoryStub.java, * org/omg/DynamicAny/_DynAnyStub.java, * org/omg/DynamicAny/_DynArrayStub.java, * org/omg/DynamicAny/_DynEnumStub.java, * org/omg/DynamicAny/_DynFixedStub.java, * org/omg/DynamicAny/_DynSequenceStub.java, * org/omg/DynamicAny/_DynStructStub.java, * org/omg/DynamicAny/_DynUnionStub.java, * org/omg/DynamicAny/_DynValueStub.java, * org/omg/IOP/Codec.java, * org/omg/IOP/CodecFactory.java, * org/omg/IOP/CodecFactoryHelper.java, * org/omg/IOP/CodecFactoryOperations.java, * org/omg/IOP/CodecFactoryPackage/UnknownEncoding.java, * org/omg/IOP/CodecFactoryPackage/UnknownEncodingHelper.java, * org/omg/IOP/CodecOperations.java, * org/omg/IOP/CodecPackage/FormatMismatch.java, * org/omg/IOP/CodecPackage/FormatMismatchHelper.java, * org/omg/IOP/CodecPackage/InvalidTypeForEncoding.java, * org/omg/IOP/CodecPackage/InvalidTypeForEncodingHelper.java, * org/omg/IOP/CodecPackage/TypeMismatch.java, * org/omg/IOP/CodecPackage/TypeMismatchHelper.java, * org/omg/IOP/ComponentIdHelper.java, * org/omg/IOP/Encoding.java, * org/omg/IOP/IOR.java, * org/omg/IOP/IORHelper.java, * org/omg/IOP/IORHolder.java, * org/omg/IOP/MultipleComponentProfileHelper.java, * org/omg/IOP/MultipleComponentProfileHolder.java, * org/omg/IOP/ProfileIdHelper.java, * org/omg/IOP/ServiceContext.java, * org/omg/IOP/ServiceContextHelper.java, * org/omg/IOP/ServiceContextHolder.java, * org/omg/IOP/ServiceContextListHelper.java, * org/omg/IOP/ServiceContextListHolder.java, * org/omg/IOP/ServiceIdHelper.java, * org/omg/IOP/TaggedComponent.java, * org/omg/IOP/TaggedComponentHelper.java, * org/omg/IOP/TaggedComponentHolder.java, * org/omg/IOP/TaggedProfile.java, * org/omg/IOP/TaggedProfileHelper.java, * org/omg/IOP/TaggedProfileHolder.java, * org/omg/IOP/TransactionService.java, * org/omg/Messaging/SYNC_WITH_TRANSPORT.java, * org/omg/Messaging/SyncScopeHelper.java, * org/omg/PortableInterceptor/AdapterManagerIdHelper.java, * org/omg/PortableInterceptor/AdapterNameHelper.java, * org/omg/PortableInterceptor/AdapterStateHelper.java, * org/omg/PortableInterceptor/ClientRequestInfo.java, * org/omg/PortableInterceptor/ClientRequestInfoOperations.java, * org/omg/PortableInterceptor/ClientRequestInterceptor.java, * org/omg/PortableInterceptor/ClientRequestInterceptorOperations.java, * org/omg/PortableInterceptor/Current.java, * org/omg/PortableInterceptor/CurrentHelper.java, * org/omg/PortableInterceptor/CurrentOperations.java, * org/omg/PortableInterceptor/ForwardRequest.java, * org/omg/PortableInterceptor/ForwardRequestHelper.java, * org/omg/PortableInterceptor/IORInfo.java, * org/omg/PortableInterceptor/IORInfoOperations.java, * org/omg/PortableInterceptor/IORInterceptor.java, * org/omg/PortableInterceptor/IORInterceptorOperations.java, * org/omg/PortableInterceptor/IORInterceptor_3_0.java, * org/omg/PortableInterceptor/IORInterceptor_3_0Helper.java, * org/omg/PortableInterceptor/IORInterceptor_3_0Holder.java, * org/omg/PortableInterceptor/IORInterceptor_3_0Operations.java, * org/omg/PortableInterceptor/Interceptor.java, * org/omg/PortableInterceptor/InterceptorOperations.java, * org/omg/PortableInterceptor/InvalidSlot.java, * org/omg/PortableInterceptor/InvalidSlotHelper.java, * org/omg/PortableInterceptor/LOCATION_FORWARD.java, * org/omg/PortableInterceptor/ORBIdHelper.java, * org/omg/PortableInterceptor/ORBInitInfo.java, * org/omg/PortableInterceptor/ORBInitInfoOperations.java, * org/omg/PortableInterceptor/ORBInitInfoPackage/DuplicateName.java, * org/omg/PortableInterceptor/ORBInitInfoPackage/DuplicateNameHelper.java, * org/omg/PortableInterceptor/ORBInitInfoPackage/InvalidName.java, * org/omg/PortableInterceptor/ORBInitInfoPackage/InvalidNameHelper.java, * org/omg/PortableInterceptor/ORBInitInfoPackage/ObjectIdHelper.java, * org/omg/PortableInterceptor/ORBInitializer.java, * org/omg/PortableInterceptor/ORBInitializerOperations.java, * org/omg/PortableInterceptor/ObjectIdHelper.java, * org/omg/PortableInterceptor/ObjectReferenceFactory.java, * org/omg/PortableInterceptor/ObjectReferenceFactoryHelper.java, * org/omg/PortableInterceptor/ObjectReferenceFactoryHolder.java, * org/omg/PortableInterceptor/ObjectReferenceTemplate.java, * org/omg/PortableInterceptor/ObjectReferenceTemplateHelper.java, * org/omg/PortableInterceptor/ObjectReferenceTemplateHolder.java, * org/omg/PortableInterceptor/ObjectReferenceTemplateSeqHelper.java, * org/omg/PortableInterceptor/ObjectReferenceTemplateSeqHolder.java, * org/omg/PortableInterceptor/PolicyFactory.java, * org/omg/PortableInterceptor/PolicyFactoryOperations.java, * org/omg/PortableInterceptor/RequestInfo.java, * org/omg/PortableInterceptor/RequestInfoOperations.java, * org/omg/PortableInterceptor/SUCCESSFUL.java, * org/omg/PortableInterceptor/SYSTEM_EXCEPTION.java, * org/omg/PortableInterceptor/ServerIdHelper.java, * org/omg/PortableInterceptor/ServerRequestInfo.java, * org/omg/PortableInterceptor/ServerRequestInfoOperations.java, * org/omg/PortableInterceptor/ServerRequestInterceptor.java, * org/omg/PortableInterceptor/ServerRequestInterceptorOperations.java, * org/omg/PortableInterceptor/TRANSPORT_RETRY.java, * org/omg/PortableInterceptor/USER_EXCEPTION.java, * org/omg/PortableInterceptor/_IORInterceptor_3_0Stub.java, * org/omg/PortableServer/AdapterActivator.java, * org/omg/PortableServer/AdapterActivatorOperations.java, * org/omg/PortableServer/Current.java, * org/omg/PortableServer/CurrentHelper.java, * org/omg/PortableServer/CurrentOperations.java, * org/omg/PortableServer/CurrentPackage/NoContext.java, * org/omg/PortableServer/CurrentPackage/NoContextHelper.java, * org/omg/PortableServer/DynamicImplementation.java, * org/omg/PortableServer/ForwardRequest.java, * org/omg/PortableServer/ForwardRequestHelper.java, * org/omg/PortableServer/ID_ASSIGNMENT_POLICY_ID.java, * org/omg/PortableServer/ID_UNIQUENESS_POLICY_ID.java, * org/omg/PortableServer/IMPLICIT_ACTIVATION_POLICY_ID.java, * org/omg/PortableServer/IdAssignmentPolicy.java, * org/omg/PortableServer/IdAssignmentPolicyOperations.java, * org/omg/PortableServer/IdAssignmentPolicyValue.java, * org/omg/PortableServer/IdUniquenessPolicy.java, * org/omg/PortableServer/IdUniquenessPolicyOperations.java, * org/omg/PortableServer/IdUniquenessPolicyValue.java, * org/omg/PortableServer/ImplicitActivationPolicy.java, * org/omg/PortableServer/ImplicitActivationPolicyOperations.java, * org/omg/PortableServer/ImplicitActivationPolicyValue.java, * org/omg/PortableServer/LifespanPolicy.java, * org/omg/PortableServer/LifespanPolicyOperations.java, * org/omg/PortableServer/LifespanPolicyValue.java, * org/omg/PortableServer/POA.java, * org/omg/PortableServer/POAHelper.java, * org/omg/PortableServer/POAManager.java, * org/omg/PortableServer/POAManagerOperations.java, * org/omg/PortableServer/POAManagerPackage/AdapterInactive.java, * org/omg/PortableServer/POAManagerPackage/AdapterInactiveHelper.java, * org/omg/PortableServer/POAManagerPackage/State.java, * org/omg/PortableServer/POAOperations.java, * org/omg/PortableServer/POAPackage/AdapterAlreadyExists.java, * org/omg/PortableServer/POAPackage/AdapterAlreadyExistsHelper.java, * org/omg/PortableServer/POAPackage/AdapterNonExistent.java, * org/omg/PortableServer/POAPackage/AdapterNonExistentHelper.java, * org/omg/PortableServer/POAPackage/InvalidPolicy.java, * org/omg/PortableServer/POAPackage/InvalidPolicyHelper.java, * org/omg/PortableServer/POAPackage/NoServant.java, * org/omg/PortableServer/POAPackage/NoServantHelper.java, * org/omg/PortableServer/POAPackage/ObjectAlreadyActive.java, * org/omg/PortableServer/POAPackage/ObjectAlreadyActiveHelper.java, * org/omg/PortableServer/POAPackage/ObjectNotActive.java, * org/omg/PortableServer/POAPackage/ObjectNotActiveHelper.java, * org/omg/PortableServer/POAPackage/ServantAlreadyActive.java, * org/omg/PortableServer/POAPackage/ServantAlreadyActiveHelper.java, * org/omg/PortableServer/POAPackage/ServantNotActive.java, * org/omg/PortableServer/POAPackage/ServantNotActiveHelper.java, * org/omg/PortableServer/POAPackage/WrongAdapter.java, * org/omg/PortableServer/POAPackage/WrongAdapterHelper.java, * org/omg/PortableServer/POAPackage/WrongPolicy.java, * org/omg/PortableServer/POAPackage/WrongPolicyHelper.java, * org/omg/PortableServer/RequestProcessingPolicy.java, * org/omg/PortableServer/RequestProcessingPolicyOperations.java, * org/omg/PortableServer/RequestProcessingPolicyValue.java, * org/omg/PortableServer/Servant.java, * org/omg/PortableServer/ServantActivator.java, * org/omg/PortableServer/ServantActivatorHelper.java, * org/omg/PortableServer/ServantActivatorOperations.java, * org/omg/PortableServer/ServantActivatorPOA.java, * org/omg/PortableServer/ServantLocator.java, * org/omg/PortableServer/ServantLocatorHelper.java, * org/omg/PortableServer/ServantLocatorOperations.java, * org/omg/PortableServer/ServantLocatorPOA.java, * org/omg/PortableServer/ServantLocatorPackage/CookieHolder.java, * org/omg/PortableServer/ServantManager.java, * org/omg/PortableServer/ServantManagerOperations.java, * org/omg/PortableServer/ServantRetentionPolicy.java, * org/omg/PortableServer/ServantRetentionPolicyOperations.java, * org/omg/PortableServer/ServantRetentionPolicyValue.java, * org/omg/PortableServer/ThreadPolicy.java, * org/omg/PortableServer/ThreadPolicyOperations.java, * org/omg/PortableServer/ThreadPolicyValue.java, * org/omg/PortableServer/_ServantActivatorStub.java, * org/omg/PortableServer/_ServantLocatorStub.java, * org/omg/PortableServer/portable/Delegate.java, * org/omg/SendingContext/RunTime.java, * org/omg/SendingContext/RunTimeOperations.java, * sun/misc/Service.java, * sun/misc/ServiceConfigurationError.java, * sun/reflect/annotation/AnnotationInvocationHandler.java, * sun/reflect/annotation/AnnotationParser.java, * sun/reflect/annotation/AnnotationType.java, * sun/reflect/annotation/EnumConstantNotPresentExceptionProxy.java, * sun/reflect/annotation/ExceptionProxy.java, * tools/com/sun/javadoc/ClassDoc.java, * tools/com/sun/javadoc/ConstructorDoc.java, * tools/com/sun/javadoc/Doc.java, * tools/com/sun/javadoc/DocErrorReporter.java, * tools/com/sun/javadoc/Doclet.java, * tools/com/sun/javadoc/ExecutableMemberDoc.java, * tools/com/sun/javadoc/FieldDoc.java, * tools/com/sun/javadoc/MemberDoc.java, * tools/com/sun/javadoc/MethodDoc.java, * tools/com/sun/javadoc/PackageDoc.java, * tools/com/sun/javadoc/ParamTag.java, * tools/com/sun/javadoc/Parameter.java, * tools/com/sun/javadoc/ProgramElementDoc.java, * tools/com/sun/javadoc/RootDoc.java, * tools/com/sun/javadoc/SeeTag.java, * tools/com/sun/javadoc/SerialFieldTag.java, * tools/com/sun/javadoc/Tag.java, * tools/com/sun/javadoc/ThrowsTag.java, * tools/com/sun/javadoc/Type.java, * tools/com/sun/javadoc/TypeVariable.java, * tools/com/sun/tools/javadoc/Main.java, * tools/com/sun/tools/javah/Main.java, * tools/external/asm/org/objectweb/asm/AnnotationVisitor.java, * tools/external/asm/org/objectweb/asm/AnnotationWriter.java, * tools/external/asm/org/objectweb/asm/Attribute.java, * tools/external/asm/org/objectweb/asm/ByteVector.java, * tools/external/asm/org/objectweb/asm/ClassAdapter.java, * tools/external/asm/org/objectweb/asm/ClassReader.java, * tools/external/asm/org/objectweb/asm/ClassVisitor.java, * tools/external/asm/org/objectweb/asm/ClassWriter.java, * tools/external/asm/org/objectweb/asm/Edge.java, * tools/external/asm/org/objectweb/asm/FieldVisitor.java, * tools/external/asm/org/objectweb/asm/FieldWriter.java, * tools/external/asm/org/objectweb/asm/Handler.java, * tools/external/asm/org/objectweb/asm/Item.java, * tools/external/asm/org/objectweb/asm/Label.java, * tools/external/asm/org/objectweb/asm/MethodAdapter.java, * tools/external/asm/org/objectweb/asm/MethodVisitor.java, * tools/external/asm/org/objectweb/asm/MethodWriter.java, * tools/external/asm/org/objectweb/asm/Opcodes.java, * tools/external/asm/org/objectweb/asm/Type.java, * tools/external/asm/org/objectweb/asm/attrs/StackMapAttribute.java, * tools/external/asm/org/objectweb/asm/attrs/StackMapFrame.java, * tools/external/asm/org/objectweb/asm/attrs/StackMapTableAttribute.java, * tools/external/asm/org/objectweb/asm/attrs/StackMapType.java, * tools/external/asm/org/objectweb/asm/commons/AdviceAdapter.java, * tools/external/asm/org/objectweb/asm/commons/EmptyVisitor.java, * tools/external/asm/org/objectweb/asm/commons/GeneratorAdapter.java, * tools/external/asm/org/objectweb/asm/commons/LocalVariablesSorter.java, * tools/external/asm/org/objectweb/asm/commons/Method.java, * tools/external/asm/org/objectweb/asm/commons/SerialVersionUIDAdder.java, * tools/external/asm/org/objectweb/asm/commons/StaticInitMerger.java, * tools/external/asm/org/objectweb/asm/commons/TableSwitchGenerator.java, * tools/external/asm/org/objectweb/asm/optimizer/AnnotationConstantsCollector.java, * tools/external/asm/org/objectweb/asm/optimizer/ClassConstantsCollector.java, * tools/external/asm/org/objectweb/asm/optimizer/ClassOptimizer.java, * tools/external/asm/org/objectweb/asm/optimizer/Constant.java, * tools/external/asm/org/objectweb/asm/optimizer/ConstantPool.java, * tools/external/asm/org/objectweb/asm/optimizer/FieldConstantsCollector.java, * tools/external/asm/org/objectweb/asm/optimizer/JarOptimizer.java, * tools/external/asm/org/objectweb/asm/optimizer/MethodConstantsCollector.java, * tools/external/asm/org/objectweb/asm/optimizer/MethodOptimizer.java, * tools/external/asm/org/objectweb/asm/optimizer/NameMapping.java, * tools/external/asm/org/objectweb/asm/optimizer/Shrinker.java, * tools/external/asm/org/objectweb/asm/signature/SignatureReader.java, * tools/external/asm/org/objectweb/asm/signature/SignatureVisitor.java, * tools/external/asm/org/objectweb/asm/signature/SignatureWriter.java, * tools/external/asm/org/objectweb/asm/tree/AbstractInsnNode.java, * tools/external/asm/org/objectweb/asm/tree/AnnotationNode.java, * tools/external/asm/org/objectweb/asm/tree/ClassNode.java, * tools/external/asm/org/objectweb/asm/tree/FieldInsnNode.java, * tools/external/asm/org/objectweb/asm/tree/FieldNode.java, * tools/external/asm/org/objectweb/asm/tree/IincInsnNode.java, * tools/external/asm/org/objectweb/asm/tree/InnerClassNode.java, * tools/external/asm/org/objectweb/asm/tree/InsnNode.java, * tools/external/asm/org/objectweb/asm/tree/IntInsnNode.java, * tools/external/asm/org/objectweb/asm/tree/JumpInsnNode.java, * tools/external/asm/org/objectweb/asm/tree/LabelNode.java, * tools/external/asm/org/objectweb/asm/tree/LdcInsnNode.java, * tools/external/asm/org/objectweb/asm/tree/LineNumberNode.java, * tools/external/asm/org/objectweb/asm/tree/LocalVariableNode.java, * tools/external/asm/org/objectweb/asm/tree/LookupSwitchInsnNode.java, * tools/external/asm/org/objectweb/asm/tree/MemberNode.java, * tools/external/asm/org/objectweb/asm/tree/MethodInsnNode.java, * tools/external/asm/org/objectweb/asm/tree/MethodNode.java, * tools/external/asm/org/objectweb/asm/tree/MultiANewArrayInsnNode.java, * tools/external/asm/org/objectweb/asm/tree/TableSwitchInsnNode.java, * tools/external/asm/org/objectweb/asm/tree/TryCatchBlockNode.java, * tools/external/asm/org/objectweb/asm/tree/TypeInsnNode.java, * tools/external/asm/org/objectweb/asm/tree/VarInsnNode.java, * tools/external/asm/org/objectweb/asm/tree/analysis/Analyzer.java, * tools/external/asm/org/objectweb/asm/tree/analysis/AnalyzerException.java, * tools/external/asm/org/objectweb/asm/tree/analysis/BasicInterpreter.java, * tools/external/asm/org/objectweb/asm/tree/analysis/BasicValue.java, * tools/external/asm/org/objectweb/asm/tree/analysis/BasicVerifier.java, * tools/external/asm/org/objectweb/asm/tree/analysis/DataflowInterpreter.java, * tools/external/asm/org/objectweb/asm/tree/analysis/DataflowValue.java, * tools/external/asm/org/objectweb/asm/tree/analysis/Frame.java, * tools/external/asm/org/objectweb/asm/tree/analysis/IntMap.java, * tools/external/asm/org/objectweb/asm/tree/analysis/Interpreter.java, * tools/external/asm/org/objectweb/asm/tree/analysis/SimpleVerifier.java, * tools/external/asm/org/objectweb/asm/tree/analysis/SmallSet.java, * tools/external/asm/org/objectweb/asm/tree/analysis/Subroutine.java, * tools/external/asm/org/objectweb/asm/tree/analysis/Value.java, * tools/external/asm/org/objectweb/asm/util/ASMifierAbstractVisitor.java, * tools/external/asm/org/objectweb/asm/util/ASMifierAnnotationVisitor.java, * tools/external/asm/org/objectweb/asm/util/ASMifierClassVisitor.java, * tools/external/asm/org/objectweb/asm/util/ASMifierFieldVisitor.java, * tools/external/asm/org/objectweb/asm/util/ASMifierMethodVisitor.java, * tools/external/asm/org/objectweb/asm/util/AbstractVisitor.java, * tools/external/asm/org/objectweb/asm/util/CheckAnnotationAdapter.java, * tools/external/asm/org/objectweb/asm/util/CheckClassAdapter.java, * tools/external/asm/org/objectweb/asm/util/CheckMethodAdapter.java, * tools/external/asm/org/objectweb/asm/util/TraceAbstractVisitor.java, * tools/external/asm/org/objectweb/asm/util/TraceAnnotationVisitor.java, * tools/external/asm/org/objectweb/asm/util/TraceClassVisitor.java, * tools/external/asm/org/objectweb/asm/util/TraceFieldVisitor.java, * tools/external/asm/org/objectweb/asm/util/TraceMethodVisitor.java, * tools/external/asm/org/objectweb/asm/util/TraceSignatureVisitor.java, * tools/external/asm/org/objectweb/asm/util/attrs/ASMStackMapAttribute.java, * tools/external/asm/org/objectweb/asm/util/attrs/ASMStackMapTableAttribute.java, * tools/external/asm/org/objectweb/asm/util/attrs/ASMifiable.java, * tools/external/asm/org/objectweb/asm/util/attrs/Traceable.java, * tools/external/asm/org/objectweb/asm/xml/ASMContentHandler.java, * tools/external/asm/org/objectweb/asm/xml/Processor.java, * tools/external/asm/org/objectweb/asm/xml/SAXAdapter.java, * tools/external/asm/org/objectweb/asm/xml/SAXAnnotationAdapter.java, * tools/external/asm/org/objectweb/asm/xml/SAXClassAdapter.java, * tools/external/asm/org/objectweb/asm/xml/SAXCodeAdapter.java, * tools/external/asm/org/objectweb/asm/xml/SAXFieldAdapter.java, * tools/generated/gnu/classpath/tools/gjdoc/expr/JavaLexer.java, * tools/generated/gnu/classpath/tools/gjdoc/expr/JavaRecognizer.java, * tools/generated/gnu/classpath/tools/gjdoc/expr/JavaTokenTypes.java, * tools/gnu/classpath/tools/FileSystemClassLoader.java, * tools/gnu/classpath/tools/IOToolkit.java, * tools/gnu/classpath/tools/MalformedInputEvent.java, * tools/gnu/classpath/tools/MalformedInputListener.java, * tools/gnu/classpath/tools/NotifyingInputStreamReader.java, * tools/gnu/classpath/tools/StringToolkit.java, * tools/gnu/classpath/tools/appletviewer/AppletSecurityManager.java, * tools/gnu/classpath/tools/appletviewer/AppletTag.java, * tools/gnu/classpath/tools/appletviewer/CommonAppletContext.java, * tools/gnu/classpath/tools/appletviewer/CommonAppletStub.java, * tools/gnu/classpath/tools/appletviewer/Main.java, * tools/gnu/classpath/tools/appletviewer/PluginAppletViewer.java, * tools/gnu/classpath/tools/appletviewer/PluginAppletWindow.java, * tools/gnu/classpath/tools/appletviewer/StandaloneAppletViewer.java, * tools/gnu/classpath/tools/appletviewer/StandaloneAppletWindow.java, * tools/gnu/classpath/tools/appletviewer/TagParser.java, * tools/gnu/classpath/tools/common/CallbackUtil.java, * tools/gnu/classpath/tools/common/ClasspathToolParser.java, * tools/gnu/classpath/tools/common/Persistent.java, * tools/gnu/classpath/tools/common/ProviderUtil.java, * tools/gnu/classpath/tools/common/SecurityProviderInfo.java, * tools/gnu/classpath/tools/doclets/AbstractDoclet.java, * tools/gnu/classpath/tools/doclets/DocletConfigurationException.java, * tools/gnu/classpath/tools/doclets/DocletOption.java, * tools/gnu/classpath/tools/doclets/DocletOptionColonSeparated.java, * tools/gnu/classpath/tools/doclets/DocletOptionFile.java, * tools/gnu/classpath/tools/doclets/DocletOptionFlag.java, * tools/gnu/classpath/tools/doclets/DocletOptionPackageWildcard.java, * tools/gnu/classpath/tools/doclets/DocletOptionString.java, * tools/gnu/classpath/tools/doclets/InlineTagRenderer.java, * tools/gnu/classpath/tools/doclets/InvalidPackageWildcardException.java, * tools/gnu/classpath/tools/doclets/PackageGroup.java, * tools/gnu/classpath/tools/doclets/PackageMatcher.java, * tools/gnu/classpath/tools/doclets/StandardTaglet.java, * tools/gnu/classpath/tools/doclets/TagletPrinter.java, * tools/gnu/classpath/tools/doclets/debugdoclet/DebugDoclet.java, * tools/gnu/classpath/tools/doclets/htmldoclet/CssClass.java, * tools/gnu/classpath/tools/doclets/htmldoclet/ExternalDocSet.java, * tools/gnu/classpath/tools/doclets/htmldoclet/HtmlDoclet.java, * tools/gnu/classpath/tools/doclets/htmldoclet/HtmlPage.java, * tools/gnu/classpath/tools/doclets/htmldoclet/HtmlTagletContext.java, * tools/gnu/classpath/tools/doclets/xmldoclet/Driver.java, * tools/gnu/classpath/tools/doclets/xmldoclet/Driver1_4.java, * tools/gnu/classpath/tools/doclets/xmldoclet/HtmlRepairer.java, * tools/gnu/classpath/tools/doclets/xmldoclet/TargetContext.java, * tools/gnu/classpath/tools/doclets/xmldoclet/doctranslet/DocTranslet.java, * tools/gnu/classpath/tools/doclets/xmldoclet/doctranslet/DocTransletConfigurationException.java, * tools/gnu/classpath/tools/doclets/xmldoclet/doctranslet/DocTransletException.java, * tools/gnu/classpath/tools/doclets/xmldoclet/doctranslet/DocTransletOptions.java, * tools/gnu/classpath/tools/doclets/xmldoclet/doctranslet/JarClassLoader.java, * tools/gnu/classpath/tools/doclets/xmldoclet/doctranslet/OutputFileInfo.java, * tools/gnu/classpath/tools/getopt/FileArgumentCallback.java, * tools/gnu/classpath/tools/getopt/Option.java, * tools/gnu/classpath/tools/getopt/OptionGroup.java, * tools/gnu/classpath/tools/getopt/Parser.java, * tools/gnu/classpath/tools/gjdoc/AbstractTagImpl.java, * tools/gnu/classpath/tools/gjdoc/ArrayCharacterIterator.java, * tools/gnu/classpath/tools/gjdoc/ClassDocImpl.java, * tools/gnu/classpath/tools/gjdoc/ClassDocProxy.java, * tools/gnu/classpath/tools/gjdoc/ClassDocReflectedImpl.java, * tools/gnu/classpath/tools/gjdoc/ConstructorDocImpl.java, * tools/gnu/classpath/tools/gjdoc/Debug.java, * tools/gnu/classpath/tools/gjdoc/DirectoryTree.java, * tools/gnu/classpath/tools/gjdoc/DocImpl.java, * tools/gnu/classpath/tools/gjdoc/ErrorReporter.java, * tools/gnu/classpath/tools/gjdoc/ExecutableMemberDocImpl.java, * tools/gnu/classpath/tools/gjdoc/FieldDocImpl.java, * tools/gnu/classpath/tools/gjdoc/GjdocPackageDoc.java, * tools/gnu/classpath/tools/gjdoc/GjdocRootDoc.java, * tools/gnu/classpath/tools/gjdoc/InheritDocTagImpl.java, * tools/gnu/classpath/tools/gjdoc/JavadocWrapper.java, * tools/gnu/classpath/tools/gjdoc/LinkTagImpl.java, * tools/gnu/classpath/tools/gjdoc/Main.java, * tools/gnu/classpath/tools/gjdoc/MemberDocImpl.java, * tools/gnu/classpath/tools/gjdoc/MethodDocImpl.java, * tools/gnu/classpath/tools/gjdoc/PackageDocImpl.java, * tools/gnu/classpath/tools/gjdoc/ParamTagImpl.java, * tools/gnu/classpath/tools/gjdoc/ParameterImpl.java, * tools/gnu/classpath/tools/gjdoc/ParseException.java, * tools/gnu/classpath/tools/gjdoc/Parser.java, * tools/gnu/classpath/tools/gjdoc/ProgramElementDocImpl.java, * tools/gnu/classpath/tools/gjdoc/RootDocImpl.java, * tools/gnu/classpath/tools/gjdoc/SeeTagImpl.java, * tools/gnu/classpath/tools/gjdoc/SerialFieldTagImpl.java, * tools/gnu/classpath/tools/gjdoc/SourcePositionImpl.java, * tools/gnu/classpath/tools/gjdoc/TagContainer.java, * tools/gnu/classpath/tools/gjdoc/TagImpl.java, * tools/gnu/classpath/tools/gjdoc/TemporaryStore.java, * tools/gnu/classpath/tools/gjdoc/TextTagImpl.java, * tools/gnu/classpath/tools/gjdoc/ThrowsTagImpl.java, * tools/gnu/classpath/tools/gjdoc/Timer.java, * tools/gnu/classpath/tools/gjdoc/TimerDoclet.java, * tools/gnu/classpath/tools/gjdoc/TypeImpl.java, * tools/gnu/classpath/tools/gjdoc/TypeVariableImpl.java, * tools/gnu/classpath/tools/gjdoc/ValueTagImpl.java, * tools/gnu/classpath/tools/gjdoc/WritableType.java, * tools/gnu/classpath/tools/gjdoc/expr/AdditionExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/AndExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/BinaryBitwiseExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/BinaryComputationExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/BinaryEqualityExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/BinaryExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/BinaryLogicalExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/BinaryRelationExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/BinaryShiftExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/BitShiftRightExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/CircularExpressionException.java, * tools/gnu/classpath/tools/gjdoc/expr/ConditionalExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/ConstantBoolean.java, * tools/gnu/classpath/tools/gjdoc/expr/ConstantByte.java, * tools/gnu/classpath/tools/gjdoc/expr/ConstantChar.java, * tools/gnu/classpath/tools/gjdoc/expr/ConstantDouble.java, * tools/gnu/classpath/tools/gjdoc/expr/ConstantExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/ConstantFloat.java, * tools/gnu/classpath/tools/gjdoc/expr/ConstantInteger.java, * tools/gnu/classpath/tools/gjdoc/expr/ConstantLong.java, * tools/gnu/classpath/tools/gjdoc/expr/ConstantNull.java, * tools/gnu/classpath/tools/gjdoc/expr/ConstantShort.java, * tools/gnu/classpath/tools/gjdoc/expr/ConstantString.java, * tools/gnu/classpath/tools/gjdoc/expr/Context.java, * tools/gnu/classpath/tools/gjdoc/expr/DivisionExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/EqualExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/Evaluator.java, * tools/gnu/classpath/tools/gjdoc/expr/EvaluatorEnvironment.java, * tools/gnu/classpath/tools/gjdoc/expr/ExclusiveOrExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/Expression.java, * tools/gnu/classpath/tools/gjdoc/expr/GreaterThanExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/GreaterThanOrEqualExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/IdentifierExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/IllegalExpressionException.java, * tools/gnu/classpath/tools/gjdoc/expr/InclusiveOrExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/LessThanExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/LessThanOrEqualExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/LogicalAndExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/LogicalNotExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/LogicalOrExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/ModuloExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/MultiplicationExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/NegateExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/NotEqualExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/NotExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/ShiftLeftExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/ShiftRightExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/SubtractionExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/Type.java, * tools/gnu/classpath/tools/gjdoc/expr/TypeCastExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/UnaryExpression.java, * tools/gnu/classpath/tools/gjdoc/expr/UnknownIdentifierException.java, * tools/gnu/classpath/tools/jar/Creator.java, * tools/gnu/classpath/tools/jar/Indexer.java, * tools/gnu/classpath/tools/jar/Main.java, * tools/gnu/classpath/tools/jar/Updater.java, * tools/gnu/classpath/tools/jarsigner/JarVerifier.java, * tools/gnu/classpath/tools/jarsigner/Main.java, * tools/gnu/classpath/tools/jarsigner/SFHelper.java, * tools/gnu/classpath/tools/java2xhtml/Java2xhtml.java, * tools/gnu/classpath/tools/javah/ClassWrapper.java, * tools/gnu/classpath/tools/javah/CniPrintStream.java, * tools/gnu/classpath/tools/javah/GcjhMain.java, * tools/gnu/classpath/tools/javah/JniHelper.java, * tools/gnu/classpath/tools/javah/JniIncludePrinter.java, * tools/gnu/classpath/tools/javah/JniStubPrinter.java, * tools/gnu/classpath/tools/javah/Keywords.java, * tools/gnu/classpath/tools/javah/Main.java, * tools/gnu/classpath/tools/javah/MethodHelper.java, * tools/gnu/classpath/tools/keytool/CACertCmd.java, * tools/gnu/classpath/tools/keytool/CertReqCmd.java, * tools/gnu/classpath/tools/keytool/Command.java, * tools/gnu/classpath/tools/keytool/DeleteCmd.java, * tools/gnu/classpath/tools/keytool/ExportCmd.java, * tools/gnu/classpath/tools/keytool/GenKeyCmd.java, * tools/gnu/classpath/tools/keytool/IdentityDBCmd.java, * tools/gnu/classpath/tools/keytool/ImportCmd.java, * tools/gnu/classpath/tools/keytool/KeyCloneCmd.java, * tools/gnu/classpath/tools/keytool/KeyPasswdCmd.java, * tools/gnu/classpath/tools/keytool/ListCmd.java, * tools/gnu/classpath/tools/keytool/PrintCertCmd.java, * tools/gnu/classpath/tools/keytool/SelfCertCmd.java, * tools/gnu/classpath/tools/keytool/StorePasswdCmd.java, * tools/gnu/classpath/tools/orbd/Main.java, * tools/gnu/classpath/tools/orbd/PersistentContext.java, * tools/gnu/classpath/tools/orbd/PersistentContextMap.java, * tools/gnu/classpath/tools/orbd/PersistentMap.java, * tools/gnu/classpath/tools/rmic/AbstractMethodGenerator.java, * tools/gnu/classpath/tools/rmic/ClassRmicCompiler.java, * tools/gnu/classpath/tools/rmic/CompilationError.java, * tools/gnu/classpath/tools/rmic/Generator.java, * tools/gnu/classpath/tools/rmic/GiopIo.java, * tools/gnu/classpath/tools/rmic/HashFinder.java, * tools/gnu/classpath/tools/rmic/Main.java, * tools/gnu/classpath/tools/rmic/MethodGenerator.java, * tools/gnu/classpath/tools/rmic/RMICException.java, * tools/gnu/classpath/tools/rmic/RmiMethodGenerator.java, * tools/gnu/classpath/tools/rmic/RmicBackend.java, * tools/gnu/classpath/tools/rmic/SourceGiopRmicCompiler.java, * tools/gnu/classpath/tools/rmic/SourceRmicCompiler.java, * tools/gnu/classpath/tools/rmic/Variables.java, * tools/gnu/classpath/tools/rmic/WrapUnWrapper.java, * tools/gnu/classpath/tools/rmid/ActivationSystemImpl.java, * tools/gnu/classpath/tools/rmid/ActivationSystemImpl_Stub.java, * tools/gnu/classpath/tools/rmid/Main.java, * tools/gnu/classpath/tools/rmid/PersistentBidiHashTable.java, * tools/gnu/classpath/tools/rmiregistry/Main.java, * tools/gnu/classpath/tools/rmiregistry/PersistentHashTable.java, * tools/gnu/classpath/tools/rmiregistry/RegistryImpl.java, * tools/gnu/classpath/tools/rmiregistry/RegistryImpl_Skel.java, * tools/gnu/classpath/tools/rmiregistry/RegistryImpl_Stub.java, * tools/gnu/classpath/tools/serialver/SerialVer.java, * tools/gnu/classpath/tools/taglets/AuthorTaglet.java, * tools/gnu/classpath/tools/taglets/CodeTaglet.java, * tools/gnu/classpath/tools/taglets/CopyrightTaglet.java, * tools/gnu/classpath/tools/taglets/DeprecatedTaglet.java, * tools/gnu/classpath/tools/taglets/GenericTaglet.java, * tools/gnu/classpath/tools/taglets/GnuExtendedTaglet.java, * tools/gnu/classpath/tools/taglets/SinceTaglet.java, * tools/gnu/classpath/tools/taglets/TagletContext.java, * tools/gnu/classpath/tools/taglets/ValueTaglet.java, * tools/gnu/classpath/tools/taglets/VersionTaglet.java, * tools/gnu/classpath/tools/tnameserv/Main.java, * vm/reference/gnu/classpath/jdwp/VMFrame.java, * vm/reference/gnu/classpath/jdwp/VMIdManager.java, * vm/reference/gnu/classpath/jdwp/VMMethod.java, * vm/reference/gnu/classpath/jdwp/VMVirtualMachine.java, * vm/reference/gnu/java/lang/VMCPStringBuilder.java, * vm/reference/gnu/java/lang/VMInstrumentationImpl.java, * vm/reference/gnu/java/lang/management/VMClassLoadingMXBeanImpl.java, * vm/reference/gnu/java/lang/management/VMCompilationMXBeanImpl.java, * vm/reference/gnu/java/lang/management/VMGarbageCollectorMXBeanImpl.java, * vm/reference/gnu/java/lang/management/VMMemoryMXBeanImpl.java, * vm/reference/gnu/java/lang/management/VMMemoryManagerMXBeanImpl.java, * vm/reference/gnu/java/lang/management/VMMemoryPoolMXBeanImpl.java, * vm/reference/gnu/java/lang/management/VMThreadMXBeanImpl.java, * vm/reference/gnu/java/net/VMPlainDatagramSocketImpl.java, * vm/reference/gnu/java/net/VMPlainSocketImpl.java, * vm/reference/gnu/java/nio/VMChannel.java, * vm/reference/gnu/java/nio/VMPipe.java, * vm/reference/gnu/java/nio/VMSelector.java, * vm/reference/gnu/java/security/jce/prng/VMSecureRandom.java, * vm/reference/java/io/VMFile.java, * vm/reference/java/io/VMObjectInputStream.java, * vm/reference/java/io/VMObjectStreamClass.java, * vm/reference/java/lang/VMClass.java, * vm/reference/java/lang/VMClassLoader.java, * vm/reference/java/lang/VMDouble.java, * vm/reference/java/lang/VMFloat.java, * vm/reference/java/lang/VMMath.java, * vm/reference/java/lang/VMObject.java, * vm/reference/java/lang/VMProcess.java, * vm/reference/java/lang/VMRuntime.java, * vm/reference/java/lang/VMString.java, * vm/reference/java/lang/VMSystem.java, * vm/reference/java/lang/VMThread.java, * vm/reference/java/lang/reflect/VMConstructor.java, * vm/reference/java/lang/reflect/VMField.java, * vm/reference/java/lang/reflect/VMMethod.java, * vm/reference/java/net/VMNetworkInterface.java, * vm/reference/java/nio/channels/VMChannels.java, * vm/reference/java/security/VMAccessController.java, * vm/reference/java/security/VMSecureRandom.java, * vm/reference/java/util/VMTimeZone.java, * vm/reference/sun/misc/Unsafe.java, * vm/reference/sun/reflect/Reflection.java, * vm/reference/sun/reflect/misc/ReflectUtil.java: Normalise whitespace. From-SVN: r168680
7624 lines
239 KiB
Java
7624 lines
239 KiB
Java
/* Collections.java -- Utility class with methods to operate on collections
|
|
Copyright (C) 1998, 1999, 2000, 2001, 2002, 2004, 2005, 2006
|
|
Free Software Foundation, Inc.
|
|
|
|
This file is part of GNU Classpath.
|
|
|
|
GNU Classpath is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 2, or (at your option)
|
|
any later version.
|
|
|
|
GNU Classpath is distributed in the hope that it will be useful, but
|
|
WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with GNU Classpath; see the file COPYING. If not, write to the
|
|
Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
|
02110-1301 USA.
|
|
|
|
Linking this library statically or dynamically with other modules is
|
|
making a combined work based on this library. Thus, the terms and
|
|
conditions of the GNU General Public License cover the whole
|
|
combination.
|
|
|
|
As a special exception, the copyright holders of this library give you
|
|
permission to link this library with independent modules to produce an
|
|
executable, regardless of the license terms of these independent
|
|
modules, and to copy and distribute the resulting executable under
|
|
terms of your choice, provided that you also meet, for each linked
|
|
independent module, the terms and conditions of the license of that
|
|
module. An independent module is a module which is not derived from
|
|
or based on this library. If you modify this library, you may extend
|
|
this exception to your version of the library, but you are not
|
|
obligated to do so. If you do not wish to do so, delete this
|
|
exception statement from your version. */
|
|
|
|
|
|
package java.util;
|
|
|
|
import gnu.java.lang.CPStringBuilder;
|
|
|
|
import java.io.Serializable;
|
|
|
|
/**
|
|
* Utility class consisting of static methods that operate on, or return
|
|
* Collections. Contains methods to sort, search, reverse, fill and shuffle
|
|
* Collections, methods to facilitate interoperability with legacy APIs that
|
|
* are unaware of collections, a method to return a list which consists of
|
|
* multiple copies of one element, and methods which "wrap" collections to give
|
|
* them extra properties, such as thread-safety and unmodifiability.
|
|
* <p>
|
|
*
|
|
* All methods which take a collection throw a {@link NullPointerException} if
|
|
* that collection is null. Algorithms which can change a collection may, but
|
|
* are not required, to throw the {@link UnsupportedOperationException} that
|
|
* the underlying collection would throw during an attempt at modification.
|
|
* For example,
|
|
* <code>Collections.singleton("").addAll(Collections.EMPTY_SET)</code>
|
|
* does not throw a exception, even though addAll is an unsupported operation
|
|
* on a singleton; the reason for this is that addAll did not attempt to
|
|
* modify the set.
|
|
*
|
|
* @author Original author unknown
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
* @author Tom Tromey (tromey@redhat.com)
|
|
* @author Andrew John Hughes (gnu_andrew@member.fsf.org)
|
|
* @see Collection
|
|
* @see Set
|
|
* @see List
|
|
* @see Map
|
|
* @see Arrays
|
|
* @since 1.2
|
|
* @status updated to 1.5
|
|
*/
|
|
public class Collections
|
|
{
|
|
/**
|
|
* Constant used to decide cutoff for when a non-RandomAccess list should
|
|
* be treated as sequential-access. Basically, quadratic behavior is
|
|
* acceptable for small lists when the overhead is so small in the first
|
|
* place. I arbitrarily set it to 16, so it may need some tuning.
|
|
*/
|
|
private static final int LARGE_LIST_SIZE = 16;
|
|
|
|
/**
|
|
* Determines if a list should be treated as a sequential-access one.
|
|
* Rather than the old method of JDK 1.3 of assuming only instanceof
|
|
* AbstractSequentialList should be sequential, this uses the new method
|
|
* of JDK 1.4 of assuming anything that does NOT implement RandomAccess
|
|
* and exceeds a large (unspecified) size should be sequential.
|
|
*
|
|
* @param l the list to check
|
|
* @return <code>true</code> if it should be treated as sequential-access
|
|
*/
|
|
private static boolean isSequential(List<?> l)
|
|
{
|
|
return ! (l instanceof RandomAccess) && l.size() > LARGE_LIST_SIZE;
|
|
}
|
|
|
|
/**
|
|
* This class is non-instantiable.
|
|
*/
|
|
private Collections()
|
|
{
|
|
}
|
|
|
|
/**
|
|
* An immutable, serializable, empty Set.
|
|
* @see Serializable
|
|
*/
|
|
public static final Set EMPTY_SET = new EmptySet();
|
|
|
|
/**
|
|
* Returns an immutable, serializable parameterized empty set.
|
|
* Unlike the constant <code>EMPTY_SET</code>, the set returned by
|
|
* this method is type-safe.
|
|
*
|
|
* @return an empty parameterized set.
|
|
* @since 1.5
|
|
*/
|
|
public static final <T> Set<T> emptySet()
|
|
{
|
|
/* FIXME: Could this be optimized? */
|
|
return new EmptySet<T>();
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #EMPTY_SET}. This class name is required
|
|
* for compatibility with Sun's JDK serializability.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static final class EmptySet<T> extends AbstractSet<T>
|
|
implements Serializable
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = 1582296315990362920L;
|
|
|
|
/**
|
|
* A private constructor adds overhead.
|
|
*/
|
|
EmptySet()
|
|
{
|
|
}
|
|
|
|
/**
|
|
* The size: always 0!
|
|
* @return 0.
|
|
*/
|
|
public int size()
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
/**
|
|
* Returns an iterator that does not iterate.
|
|
* @return A non-iterating iterator.
|
|
*/
|
|
// This is really cheating! I think it's perfectly valid, though.
|
|
public Iterator<T> iterator()
|
|
{
|
|
return (Iterator<T>) EMPTY_LIST.iterator();
|
|
}
|
|
|
|
// The remaining methods are optional, but provide a performance
|
|
// advantage by not allocating unnecessary iterators in AbstractSet.
|
|
/**
|
|
* The empty set never contains anything.
|
|
* @param o The object to search for.
|
|
* @return <code>false</code>.
|
|
*/
|
|
public boolean contains(Object o)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* This is true only if the given collection is also empty.
|
|
* @param c The collection of objects which are to be compared
|
|
* against the members of this set.
|
|
* @return <code>true</code> if c is empty.
|
|
*/
|
|
public boolean containsAll(Collection<?> c)
|
|
{
|
|
return c.isEmpty();
|
|
}
|
|
|
|
/**
|
|
* Equal only if the other set is empty.
|
|
* @param o The object to compare with this set.
|
|
* @return <code>true</code> if o is an empty instance of <code>Set</code>.
|
|
*/
|
|
public boolean equals(Object o)
|
|
{
|
|
return o instanceof Set && ((Set) o).isEmpty();
|
|
}
|
|
|
|
/**
|
|
* The hashcode is always 0.
|
|
* @return 0.
|
|
*/
|
|
public int hashCode()
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
/**
|
|
* Always succeeds with a <code>false</code> result.
|
|
* @param o The object to remove.
|
|
* @return <code>false</code>.
|
|
*/
|
|
public boolean remove(Object o)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Always succeeds with a <code>false</code> result.
|
|
* @param c The collection of objects which should
|
|
* all be removed from this set.
|
|
* @return <code>false</code>.
|
|
*/
|
|
public boolean removeAll(Collection<?> c)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Always succeeds with a <code>false</code> result.
|
|
* @param c The collection of objects which should
|
|
* all be retained within this set.
|
|
* @return <code>false</code>.
|
|
*/
|
|
public boolean retainAll(Collection<?> c)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* The array is always empty.
|
|
* @return A new array with a size of 0.
|
|
*/
|
|
public Object[] toArray()
|
|
{
|
|
return new Object[0];
|
|
}
|
|
|
|
/**
|
|
* We don't even need to use reflection!
|
|
* @param a An existing array, which can be empty.
|
|
* @return The original array with any existing
|
|
* initial element set to null.
|
|
*/
|
|
public <E> E[] toArray(E[] a)
|
|
{
|
|
if (a.length > 0)
|
|
a[0] = null;
|
|
return a;
|
|
}
|
|
|
|
/**
|
|
* The string never changes.
|
|
*
|
|
* @return the string "[]".
|
|
*/
|
|
public String toString()
|
|
{
|
|
return "[]";
|
|
}
|
|
} // class EmptySet
|
|
|
|
/**
|
|
* An immutable, serializable, empty List, which implements RandomAccess.
|
|
* @see Serializable
|
|
* @see RandomAccess
|
|
*/
|
|
public static final List EMPTY_LIST = new EmptyList();
|
|
|
|
/**
|
|
* Returns an immutable, serializable parameterized empty list.
|
|
* Unlike the constant <code>EMPTY_LIST</code>, the list returned by
|
|
* this method is type-safe.
|
|
*
|
|
* @return an empty parameterized list.
|
|
* @since 1.5
|
|
*/
|
|
public static final <T> List<T> emptyList()
|
|
{
|
|
/* FIXME: Could this be optimized? */
|
|
return new EmptyList<T>();
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #EMPTY_LIST}. This class name is required
|
|
* for compatibility with Sun's JDK serializability.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static final class EmptyList<T> extends AbstractList<T>
|
|
implements Serializable, RandomAccess
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = 8842843931221139166L;
|
|
|
|
/**
|
|
* A private constructor adds overhead.
|
|
*/
|
|
EmptyList()
|
|
{
|
|
}
|
|
|
|
/**
|
|
* The size is always 0.
|
|
* @return 0.
|
|
*/
|
|
public int size()
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
/**
|
|
* No matter the index, it is out of bounds. This
|
|
* method never returns, throwing an exception instead.
|
|
*
|
|
* @param index The index of the element to retrieve.
|
|
* @return the object at the specified index.
|
|
* @throws IndexOutOfBoundsException as any given index
|
|
* is outside the bounds of an empty array.
|
|
*/
|
|
public T get(int index)
|
|
{
|
|
throw new IndexOutOfBoundsException();
|
|
}
|
|
|
|
// The remaining methods are optional, but provide a performance
|
|
// advantage by not allocating unnecessary iterators in AbstractList.
|
|
/**
|
|
* Never contains anything.
|
|
* @param o The object to search for.
|
|
* @return <code>false</code>.
|
|
*/
|
|
public boolean contains(Object o)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* This is true only if the given collection is also empty.
|
|
* @param c The collection of objects, which should be compared
|
|
* against the members of this list.
|
|
* @return <code>true</code> if c is also empty.
|
|
*/
|
|
public boolean containsAll(Collection<?> c)
|
|
{
|
|
return c.isEmpty();
|
|
}
|
|
|
|
/**
|
|
* Equal only if the other list is empty.
|
|
* @param o The object to compare against this list.
|
|
* @return <code>true</code> if o is also an empty instance of
|
|
* <code>List</code>.
|
|
*/
|
|
public boolean equals(Object o)
|
|
{
|
|
return o instanceof List && ((List) o).isEmpty();
|
|
}
|
|
|
|
/**
|
|
* The hashcode is always 1.
|
|
* @return 1.
|
|
*/
|
|
public int hashCode()
|
|
{
|
|
return 1;
|
|
}
|
|
|
|
/**
|
|
* Returns -1.
|
|
* @param o The object to search for.
|
|
* @return -1.
|
|
*/
|
|
public int indexOf(Object o)
|
|
{
|
|
return -1;
|
|
}
|
|
|
|
/**
|
|
* Returns -1.
|
|
* @param o The object to search for.
|
|
* @return -1.
|
|
*/
|
|
public int lastIndexOf(Object o)
|
|
{
|
|
return -1;
|
|
}
|
|
|
|
/**
|
|
* Always succeeds with <code>false</code> result.
|
|
* @param o The object to remove.
|
|
* @return -1.
|
|
*/
|
|
public boolean remove(Object o)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Always succeeds with <code>false</code> result.
|
|
* @param c The collection of objects which should
|
|
* all be removed from this list.
|
|
* @return <code>false</code>.
|
|
*/
|
|
public boolean removeAll(Collection<?> c)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Always succeeds with <code>false</code> result.
|
|
* @param c The collection of objects which should
|
|
* all be retained within this list.
|
|
* @return <code>false</code>.
|
|
*/
|
|
public boolean retainAll(Collection<?> c)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* The array is always empty.
|
|
* @return A new array with a size of 0.
|
|
*/
|
|
public Object[] toArray()
|
|
{
|
|
return new Object[0];
|
|
}
|
|
|
|
/**
|
|
* We don't even need to use reflection!
|
|
* @param a An existing array, which can be empty.
|
|
* @return The original array with any existing
|
|
* initial element set to null.
|
|
*/
|
|
public <E> E[] toArray(E[] a)
|
|
{
|
|
if (a.length > 0)
|
|
a[0] = null;
|
|
return a;
|
|
}
|
|
|
|
/**
|
|
* The string never changes.
|
|
*
|
|
* @return the string "[]".
|
|
*/
|
|
public String toString()
|
|
{
|
|
return "[]";
|
|
}
|
|
} // class EmptyList
|
|
|
|
/**
|
|
* An immutable, serializable, empty Map.
|
|
* @see Serializable
|
|
*/
|
|
public static final Map EMPTY_MAP = new EmptyMap();
|
|
|
|
/**
|
|
* Returns an immutable, serializable parameterized empty map.
|
|
* Unlike the constant <code>EMPTY_MAP</code>, the map returned by
|
|
* this method is type-safe.
|
|
*
|
|
* @return an empty parameterized map.
|
|
* @since 1.5
|
|
*/
|
|
public static final <K,V> Map<K,V> emptyMap()
|
|
{
|
|
/* FIXME: Could this be optimized? */
|
|
return new EmptyMap<K,V>();
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #EMPTY_MAP}. This class name is required
|
|
* for compatibility with Sun's JDK serializability.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static final class EmptyMap<K, V> extends AbstractMap<K, V>
|
|
implements Serializable
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = 6428348081105594320L;
|
|
|
|
/**
|
|
* A private constructor adds overhead.
|
|
*/
|
|
EmptyMap()
|
|
{
|
|
}
|
|
|
|
/**
|
|
* There are no entries.
|
|
* @return The empty set.
|
|
*/
|
|
public Set<Map.Entry<K, V>> entrySet()
|
|
{
|
|
return EMPTY_SET;
|
|
}
|
|
|
|
// The remaining methods are optional, but provide a performance
|
|
// advantage by not allocating unnecessary iterators in AbstractMap.
|
|
/**
|
|
* No entries!
|
|
* @param key The key to search for.
|
|
* @return <code>false</code>.
|
|
*/
|
|
public boolean containsKey(Object key)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* No entries!
|
|
* @param value The value to search for.
|
|
* @return <code>false</code>.
|
|
*/
|
|
public boolean containsValue(Object value)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Equal to all empty maps.
|
|
* @param o The object o to compare against this map.
|
|
* @return <code>true</code> if o is also an empty instance of
|
|
* <code>Map</code>.
|
|
*/
|
|
public boolean equals(Object o)
|
|
{
|
|
return o instanceof Map && ((Map) o).isEmpty();
|
|
}
|
|
|
|
/**
|
|
* No mappings, so this returns null.
|
|
* @param o The key of the object to retrieve.
|
|
* @return null.
|
|
*/
|
|
public V get(Object o)
|
|
{
|
|
return null;
|
|
}
|
|
|
|
/**
|
|
* The hashcode is always 0.
|
|
* @return 0.
|
|
*/
|
|
public int hashCode()
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
/**
|
|
* No entries.
|
|
* @return The empty set.
|
|
*/
|
|
public Set<K> keySet()
|
|
{
|
|
return EMPTY_SET;
|
|
}
|
|
|
|
/**
|
|
* Remove always succeeds, with null result.
|
|
* @param o The key of the mapping to remove.
|
|
* @return null, as there is never a mapping for o.
|
|
*/
|
|
public V remove(Object o)
|
|
{
|
|
return null;
|
|
}
|
|
|
|
/**
|
|
* Size is always 0.
|
|
* @return 0.
|
|
*/
|
|
public int size()
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
/**
|
|
* No entries. Technically, EMPTY_SET, while more specific than a general
|
|
* Collection, will work. Besides, that's what the JDK uses!
|
|
* @return The empty set.
|
|
*/
|
|
public Collection<V> values()
|
|
{
|
|
return EMPTY_SET;
|
|
}
|
|
|
|
/**
|
|
* The string never changes.
|
|
*
|
|
* @return the string "[]".
|
|
*/
|
|
public String toString()
|
|
{
|
|
return "[]";
|
|
}
|
|
} // class EmptyMap
|
|
|
|
|
|
/**
|
|
* Compare two objects with or without a Comparator. If c is null, uses the
|
|
* natural ordering. Slightly slower than doing it inline if the JVM isn't
|
|
* clever, but worth it for removing a duplicate of the search code.
|
|
* Note: This code is also used in Arrays (for sort as well as search).
|
|
*/
|
|
static final <T> int compare(T o1, T o2, Comparator<? super T> c)
|
|
{
|
|
return c == null ? ((Comparable) o1).compareTo(o2) : c.compare(o1, o2);
|
|
}
|
|
|
|
/**
|
|
* Perform a binary search of a List for a key, using the natural ordering of
|
|
* the elements. The list must be sorted (as by the sort() method) - if it is
|
|
* not, the behavior of this method is undefined, and may be an infinite
|
|
* loop. Further, the key must be comparable with every item in the list. If
|
|
* the list contains the key more than once, any one of them may be found.
|
|
* <p>
|
|
*
|
|
* This algorithm behaves in log(n) time for {@link RandomAccess} lists,
|
|
* and uses a linear search with O(n) link traversals and log(n) comparisons
|
|
* with {@link AbstractSequentialList} lists. Note: although the
|
|
* specification allows for an infinite loop if the list is unsorted, it will
|
|
* not happen in this (Classpath) implementation.
|
|
*
|
|
* @param l the list to search (must be sorted)
|
|
* @param key the value to search for
|
|
* @return the index at which the key was found, or -n-1 if it was not
|
|
* found, where n is the index of the first value higher than key or
|
|
* a.length if there is no such value
|
|
* @throws ClassCastException if key could not be compared with one of the
|
|
* elements of l
|
|
* @throws NullPointerException if a null element has compareTo called
|
|
* @see #sort(List)
|
|
*/
|
|
public static <T> int binarySearch(List<? extends Comparable<? super T>> l,
|
|
T key)
|
|
{
|
|
return binarySearch(l, key, null);
|
|
}
|
|
|
|
/**
|
|
* Perform a binary search of a List for a key, using a supplied Comparator.
|
|
* The list must be sorted (as by the sort() method with the same Comparator)
|
|
* - if it is not, the behavior of this method is undefined, and may be an
|
|
* infinite loop. Further, the key must be comparable with every item in the
|
|
* list. If the list contains the key more than once, any one of them may be
|
|
* found. If the comparator is null, the elements' natural ordering is used.
|
|
* <p>
|
|
*
|
|
* This algorithm behaves in log(n) time for {@link RandomAccess} lists,
|
|
* and uses a linear search with O(n) link traversals and log(n) comparisons
|
|
* with {@link AbstractSequentialList} lists. Note: although the
|
|
* specification allows for an infinite loop if the list is unsorted, it will
|
|
* not happen in this (Classpath) implementation.
|
|
*
|
|
* @param l the list to search (must be sorted)
|
|
* @param key the value to search for
|
|
* @param c the comparator by which the list is sorted
|
|
* @return the index at which the key was found, or -n-1 if it was not
|
|
* found, where n is the index of the first value higher than key or
|
|
* a.length if there is no such value
|
|
* @throws ClassCastException if key could not be compared with one of the
|
|
* elements of l
|
|
* @throws NullPointerException if a null element is compared with natural
|
|
* ordering (only possible when c is null)
|
|
* @see #sort(List, Comparator)
|
|
*/
|
|
public static <T> int binarySearch(List<? extends T> l, T key,
|
|
Comparator<? super T> c)
|
|
{
|
|
int pos = 0;
|
|
int low = 0;
|
|
int hi = l.size() - 1;
|
|
|
|
// We use a linear search with log(n) comparisons using an iterator
|
|
// if the list is sequential-access.
|
|
if (isSequential(l))
|
|
{
|
|
ListIterator<T> itr = ((List<T>) l).listIterator();
|
|
int i = 0;
|
|
T o = itr.next(); // Assumes list is not empty (see isSequential)
|
|
boolean forward = true;
|
|
while (low <= hi)
|
|
{
|
|
pos = (low + hi) >>> 1;
|
|
if (i < pos)
|
|
{
|
|
if (!forward)
|
|
itr.next(); // Changing direction first.
|
|
for ( ; i != pos; i++, o = itr.next())
|
|
;
|
|
forward = true;
|
|
}
|
|
else
|
|
{
|
|
if (forward)
|
|
itr.previous(); // Changing direction first.
|
|
for ( ; i != pos; i--, o = itr.previous())
|
|
;
|
|
forward = false;
|
|
}
|
|
final int d = compare(o, key, c);
|
|
if (d == 0)
|
|
return pos;
|
|
else if (d > 0)
|
|
hi = pos - 1;
|
|
else
|
|
// This gets the insertion point right on the last loop
|
|
low = ++pos;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
while (low <= hi)
|
|
{
|
|
pos = (low + hi) >>> 1;
|
|
final int d = compare(((List<T>) l).get(pos), key, c);
|
|
if (d == 0)
|
|
return pos;
|
|
else if (d > 0)
|
|
hi = pos - 1;
|
|
else
|
|
// This gets the insertion point right on the last loop
|
|
low = ++pos;
|
|
}
|
|
}
|
|
|
|
// If we failed to find it, we do the same whichever search we did.
|
|
return -pos - 1;
|
|
}
|
|
|
|
/**
|
|
* Copy one list to another. If the destination list is longer than the
|
|
* source list, the remaining elements are unaffected. This method runs in
|
|
* linear time.
|
|
*
|
|
* @param dest the destination list
|
|
* @param source the source list
|
|
* @throws IndexOutOfBoundsException if the destination list is shorter
|
|
* than the source list (the destination will be unmodified)
|
|
* @throws UnsupportedOperationException if dest.listIterator() does not
|
|
* support the set operation
|
|
*/
|
|
public static <T> void copy(List<? super T> dest, List<? extends T> source)
|
|
{
|
|
int pos = source.size();
|
|
if (dest.size() < pos)
|
|
throw new IndexOutOfBoundsException("Source does not fit in dest");
|
|
|
|
Iterator<? extends T> i1 = source.iterator();
|
|
ListIterator<? super T> i2 = dest.listIterator();
|
|
|
|
while (--pos >= 0)
|
|
{
|
|
i2.next();
|
|
i2.set(i1.next());
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns an Enumeration over a collection. This allows interoperability
|
|
* with legacy APIs that require an Enumeration as input.
|
|
*
|
|
* @param c the Collection to iterate over
|
|
* @return an Enumeration backed by an Iterator over c
|
|
*/
|
|
public static <T> Enumeration<T> enumeration(Collection<T> c)
|
|
{
|
|
final Iterator<T> i = c.iterator();
|
|
return new Enumeration<T>()
|
|
{
|
|
/**
|
|
* Returns <code>true</code> if there are more elements to
|
|
* be enumerated.
|
|
*
|
|
* @return The result of <code>hasNext()</code>
|
|
* called on the underlying iterator.
|
|
*/
|
|
public final boolean hasMoreElements()
|
|
{
|
|
return i.hasNext();
|
|
}
|
|
|
|
/**
|
|
* Returns the next element to be enumerated.
|
|
*
|
|
* @return The result of <code>next()</code>
|
|
* called on the underlying iterator.
|
|
*/
|
|
public final T nextElement()
|
|
{
|
|
return i.next();
|
|
}
|
|
};
|
|
}
|
|
|
|
/**
|
|
* Replace every element of a list with a given value. This method runs in
|
|
* linear time.
|
|
*
|
|
* @param l the list to fill.
|
|
* @param val the object to vill the list with.
|
|
* @throws UnsupportedOperationException if l.listIterator() does not
|
|
* support the set operation.
|
|
*/
|
|
public static <T> void fill(List<? super T> l, T val)
|
|
{
|
|
ListIterator<? super T> itr = l.listIterator();
|
|
for (int i = l.size() - 1; i >= 0; --i)
|
|
{
|
|
itr.next();
|
|
itr.set(val);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns the starting index where the specified sublist first occurs
|
|
* in a larger list, or -1 if there is no matching position. If
|
|
* <code>target.size() > source.size()</code>, this returns -1,
|
|
* otherwise this implementation uses brute force, checking for
|
|
* <code>source.sublist(i, i + target.size()).equals(target)</code>
|
|
* for all possible i.
|
|
*
|
|
* @param source the list to search
|
|
* @param target the sublist to search for
|
|
* @return the index where found, or -1
|
|
* @since 1.4
|
|
*/
|
|
public static int indexOfSubList(List<?> source, List<?> target)
|
|
{
|
|
int ssize = source.size();
|
|
for (int i = 0, j = target.size(); j <= ssize; i++, j++)
|
|
if (source.subList(i, j).equals(target))
|
|
return i;
|
|
return -1;
|
|
}
|
|
|
|
/**
|
|
* Returns the starting index where the specified sublist last occurs
|
|
* in a larger list, or -1 if there is no matching position. If
|
|
* <code>target.size() > source.size()</code>, this returns -1,
|
|
* otherwise this implementation uses brute force, checking for
|
|
* <code>source.sublist(i, i + target.size()).equals(target)</code>
|
|
* for all possible i.
|
|
*
|
|
* @param source the list to search
|
|
* @param target the sublist to search for
|
|
* @return the index where found, or -1
|
|
* @since 1.4
|
|
*/
|
|
public static int lastIndexOfSubList(List<?> source, List<?> target)
|
|
{
|
|
int ssize = source.size();
|
|
for (int i = ssize - target.size(), j = ssize; i >= 0; i--, j--)
|
|
if (source.subList(i, j).equals(target))
|
|
return i;
|
|
return -1;
|
|
}
|
|
|
|
/**
|
|
* Returns an ArrayList holding the elements visited by a given
|
|
* Enumeration. This method exists for interoperability between legacy
|
|
* APIs and the new Collection API.
|
|
*
|
|
* @param e the enumeration to put in a list
|
|
* @return a list containing the enumeration elements
|
|
* @see ArrayList
|
|
* @since 1.4
|
|
*/
|
|
public static <T> ArrayList<T> list(Enumeration<T> e)
|
|
{
|
|
ArrayList<T> l = new ArrayList<T>();
|
|
while (e.hasMoreElements())
|
|
l.add(e.nextElement());
|
|
return l;
|
|
}
|
|
|
|
/**
|
|
* Find the maximum element in a Collection, according to the natural
|
|
* ordering of the elements. This implementation iterates over the
|
|
* Collection, so it works in linear time.
|
|
*
|
|
* @param c the Collection to find the maximum element of
|
|
* @return the maximum element of c
|
|
* @exception NoSuchElementException if c is empty
|
|
* @exception ClassCastException if elements in c are not mutually comparable
|
|
* @exception NullPointerException if null.compareTo is called
|
|
*/
|
|
public static <T extends Object & Comparable<? super T>>
|
|
T max(Collection<? extends T> c)
|
|
{
|
|
return max(c, null);
|
|
}
|
|
|
|
/**
|
|
* Find the maximum element in a Collection, according to a specified
|
|
* Comparator. This implementation iterates over the Collection, so it
|
|
* works in linear time.
|
|
*
|
|
* @param c the Collection to find the maximum element of
|
|
* @param order the Comparator to order the elements by, or null for natural
|
|
* ordering
|
|
* @return the maximum element of c
|
|
* @throws NoSuchElementException if c is empty
|
|
* @throws ClassCastException if elements in c are not mutually comparable
|
|
* @throws NullPointerException if null is compared by natural ordering
|
|
* (only possible when order is null)
|
|
*/
|
|
public static <T> T max(Collection<? extends T> c,
|
|
Comparator<? super T> order)
|
|
{
|
|
Iterator<? extends T> itr = c.iterator();
|
|
T max = itr.next(); // throws NoSuchElementException
|
|
int csize = c.size();
|
|
for (int i = 1; i < csize; i++)
|
|
{
|
|
T o = itr.next();
|
|
if (compare(max, o, order) < 0)
|
|
max = o;
|
|
}
|
|
return max;
|
|
}
|
|
|
|
/**
|
|
* Find the minimum element in a Collection, according to the natural
|
|
* ordering of the elements. This implementation iterates over the
|
|
* Collection, so it works in linear time.
|
|
*
|
|
* @param c the Collection to find the minimum element of
|
|
* @return the minimum element of c
|
|
* @throws NoSuchElementException if c is empty
|
|
* @throws ClassCastException if elements in c are not mutually comparable
|
|
* @throws NullPointerException if null.compareTo is called
|
|
*/
|
|
public static <T extends Object & Comparable<? super T>>
|
|
T min(Collection<? extends T> c)
|
|
{
|
|
return min(c, null);
|
|
}
|
|
|
|
/**
|
|
* Find the minimum element in a Collection, according to a specified
|
|
* Comparator. This implementation iterates over the Collection, so it
|
|
* works in linear time.
|
|
*
|
|
* @param c the Collection to find the minimum element of
|
|
* @param order the Comparator to order the elements by, or null for natural
|
|
* ordering
|
|
* @return the minimum element of c
|
|
* @throws NoSuchElementException if c is empty
|
|
* @throws ClassCastException if elements in c are not mutually comparable
|
|
* @throws NullPointerException if null is compared by natural ordering
|
|
* (only possible when order is null)
|
|
*/
|
|
public static <T> T min(Collection<? extends T> c,
|
|
Comparator<? super T> order)
|
|
{
|
|
Iterator<? extends T> itr = c.iterator();
|
|
T min = itr.next(); // throws NoSuchElementExcception
|
|
int csize = c.size();
|
|
for (int i = 1; i < csize; i++)
|
|
{
|
|
T o = itr.next();
|
|
if (compare(min, o, order) > 0)
|
|
min = o;
|
|
}
|
|
return min;
|
|
}
|
|
|
|
/**
|
|
* Creates an immutable list consisting of the same object repeated n times.
|
|
* The returned object is tiny, consisting of only a single reference to the
|
|
* object and a count of the number of elements. It is Serializable, and
|
|
* implements RandomAccess. You can use it in tandem with List.addAll for
|
|
* fast list construction.
|
|
*
|
|
* @param n the number of times to repeat the object
|
|
* @param o the object to repeat
|
|
* @return a List consisting of n copies of o
|
|
* @throws IllegalArgumentException if n < 0
|
|
* @see List#addAll(Collection)
|
|
* @see Serializable
|
|
* @see RandomAccess
|
|
*/
|
|
public static <T> List<T> nCopies(final int n, final T o)
|
|
{
|
|
return new CopiesList<T>(n, o);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #nCopies(int, Object)}. This class name
|
|
* is required for compatibility with Sun's JDK serializability.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static final class CopiesList<T> extends AbstractList<T>
|
|
implements Serializable, RandomAccess
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = 2739099268398711800L;
|
|
|
|
/**
|
|
* The count of elements in this list.
|
|
* @serial the list size
|
|
*/
|
|
private final int n;
|
|
|
|
/**
|
|
* The repeated list element.
|
|
* @serial the list contents
|
|
*/
|
|
private final T element;
|
|
|
|
/**
|
|
* Constructs the list.
|
|
*
|
|
* @param n the count
|
|
* @param o the object
|
|
* @throws IllegalArgumentException if n < 0
|
|
*/
|
|
CopiesList(int n, T o)
|
|
{
|
|
if (n < 0)
|
|
throw new IllegalArgumentException();
|
|
this.n = n;
|
|
element = o;
|
|
}
|
|
|
|
/**
|
|
* The size is fixed.
|
|
* @return The size of the list.
|
|
*/
|
|
public int size()
|
|
{
|
|
return n;
|
|
}
|
|
|
|
/**
|
|
* The same element is returned.
|
|
* @param index The index of the element to be returned (irrelevant
|
|
* as the list contains only copies of <code>element</code>).
|
|
* @return The element used by this list.
|
|
*/
|
|
public T get(int index)
|
|
{
|
|
if (index < 0 || index >= n)
|
|
throw new IndexOutOfBoundsException();
|
|
return element;
|
|
}
|
|
|
|
// The remaining methods are optional, but provide a performance
|
|
// advantage by not allocating unnecessary iterators in AbstractList.
|
|
/**
|
|
* This list only contains one element.
|
|
* @param o The object to search for.
|
|
* @return <code>true</code> if o is the element used by this list.
|
|
*/
|
|
public boolean contains(Object o)
|
|
{
|
|
return n > 0 && equals(o, element);
|
|
}
|
|
|
|
/**
|
|
* The index is either 0 or -1.
|
|
* @param o The object to find the index of.
|
|
* @return 0 if <code>o == element</code>, -1 if not.
|
|
*/
|
|
public int indexOf(Object o)
|
|
{
|
|
return (n > 0 && equals(o, element)) ? 0 : -1;
|
|
}
|
|
|
|
/**
|
|
* The index is either n-1 or -1.
|
|
* @param o The object to find the last index of.
|
|
* @return The last index in the list if <code>o == element</code>,
|
|
* -1 if not.
|
|
*/
|
|
public int lastIndexOf(Object o)
|
|
{
|
|
return equals(o, element) ? n - 1 : -1;
|
|
}
|
|
|
|
/**
|
|
* A subList is just another CopiesList.
|
|
* @param from The starting bound of the sublist.
|
|
* @param to The ending bound of the sublist.
|
|
* @return A list of copies containing <code>from - to</code>
|
|
* elements, all of which are equal to the element
|
|
* used by this list.
|
|
*/
|
|
public List<T> subList(int from, int to)
|
|
{
|
|
if (from < 0 || to > n)
|
|
throw new IndexOutOfBoundsException();
|
|
return new CopiesList<T>(to - from, element);
|
|
}
|
|
|
|
/**
|
|
* The array is easy.
|
|
* @return An array of size n filled with copies of
|
|
* the element used by this list.
|
|
*/
|
|
public Object[] toArray()
|
|
{
|
|
Object[] a = new Object[n];
|
|
Arrays.fill(a, element);
|
|
return a;
|
|
}
|
|
|
|
/**
|
|
* The string is easy to generate.
|
|
* @return A string representation of the list.
|
|
*/
|
|
public String toString()
|
|
{
|
|
CPStringBuilder r = new CPStringBuilder("{");
|
|
for (int i = n - 1; --i > 0; )
|
|
r.append(element).append(", ");
|
|
r.append(element).append("}");
|
|
return r.toString();
|
|
}
|
|
} // class CopiesList
|
|
|
|
/**
|
|
* Replace all instances of one object with another in the specified list.
|
|
* The list does not change size. An element e is replaced if
|
|
* <code>oldval == null ? e == null : oldval.equals(e)</code>.
|
|
*
|
|
* @param list the list to iterate over
|
|
* @param oldval the element to replace
|
|
* @param newval the new value for the element
|
|
* @return <code>true</code> if a replacement occurred.
|
|
* @throws UnsupportedOperationException if the list iterator does not allow
|
|
* for the set operation
|
|
* @throws ClassCastException if newval is of a type which cannot be added
|
|
* to the list
|
|
* @throws IllegalArgumentException if some other aspect of newval stops
|
|
* it being added to the list
|
|
* @since 1.4
|
|
*/
|
|
public static <T> boolean replaceAll(List<T> list, T oldval, T newval)
|
|
{
|
|
ListIterator<T> itr = list.listIterator();
|
|
boolean replace_occured = false;
|
|
for (int i = list.size(); --i >= 0; )
|
|
if (AbstractCollection.equals(oldval, itr.next()))
|
|
{
|
|
itr.set(newval);
|
|
replace_occured = true;
|
|
}
|
|
return replace_occured;
|
|
}
|
|
|
|
/**
|
|
* Reverse a given list. This method works in linear time.
|
|
*
|
|
* @param l the list to reverse
|
|
* @throws UnsupportedOperationException if l.listIterator() does not
|
|
* support the set operation
|
|
*/
|
|
public static void reverse(List<?> l)
|
|
{
|
|
ListIterator i1 = l.listIterator();
|
|
int pos1 = 1;
|
|
int pos2 = l.size();
|
|
ListIterator i2 = l.listIterator(pos2);
|
|
while (pos1 < pos2)
|
|
{
|
|
Object o1 = i1.next();
|
|
Object o2 = i2.previous();
|
|
i1.set(o2);
|
|
i2.set(o1);
|
|
++pos1;
|
|
--pos2;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Get a comparator that implements the reverse of the ordering
|
|
* specified by the given Comparator. If the Comparator is null,
|
|
* this is equivalent to {@link #reverseOrder()}. The return value
|
|
* of this method is Serializable, if the specified Comparator is
|
|
* either Serializable or null.
|
|
*
|
|
* @param c the comparator to invert
|
|
* @return a comparator that imposes reverse ordering
|
|
* @see Comparable
|
|
* @see Serializable
|
|
*
|
|
* @since 1.5
|
|
*/
|
|
public static <T> Comparator<T> reverseOrder(final Comparator<T> c)
|
|
{
|
|
if (c == null)
|
|
return (Comparator<T>) rcInstance;
|
|
return new ReverseComparator<T> ()
|
|
{
|
|
public int compare(T a, T b)
|
|
{
|
|
return - c.compare(a, b);
|
|
}
|
|
};
|
|
}
|
|
|
|
/**
|
|
* Get a comparator that implements the reverse of natural ordering. In
|
|
* other words, this sorts Comparable objects opposite of how their
|
|
* compareTo method would sort. This makes it easy to sort into reverse
|
|
* order, by simply passing Collections.reverseOrder() to the sort method.
|
|
* The return value of this method is Serializable.
|
|
*
|
|
* @return a comparator that imposes reverse natural ordering
|
|
* @see Comparable
|
|
* @see Serializable
|
|
*/
|
|
public static <T> Comparator<T> reverseOrder()
|
|
{
|
|
return (Comparator<T>) rcInstance;
|
|
}
|
|
|
|
/**
|
|
* The object for {@link #reverseOrder()}.
|
|
*/
|
|
private static final ReverseComparator rcInstance = new ReverseComparator();
|
|
|
|
/**
|
|
* The implementation of {@link #reverseOrder()}. This class name
|
|
* is required for compatibility with Sun's JDK serializability.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static class ReverseComparator<T>
|
|
implements Comparator<T>, Serializable
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = 7207038068494060240L;
|
|
|
|
/**
|
|
* A private constructor adds overhead.
|
|
*/
|
|
ReverseComparator()
|
|
{
|
|
}
|
|
|
|
/**
|
|
* Compare two objects in reverse natural order.
|
|
*
|
|
* @param a the first object
|
|
* @param b the second object
|
|
* @return <, ==, or > 0 according to b.compareTo(a)
|
|
*/
|
|
public int compare(T a, T b)
|
|
{
|
|
return ((Comparable) b).compareTo(a);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Rotate the elements in a list by a specified distance. After calling this
|
|
* method, the element now at index <code>i</code> was formerly at index
|
|
* <code>(i - distance) mod list.size()</code>. The list size is unchanged.
|
|
* <p>
|
|
*
|
|
* For example, suppose a list contains <code>[t, a, n, k, s]</code>. After
|
|
* either <code>Collections.rotate(l, 4)</code> or
|
|
* <code>Collections.rotate(l, -1)</code>, the new contents are
|
|
* <code>[s, t, a, n, k]</code>. This can be applied to sublists to rotate
|
|
* just a portion of the list. For example, to move element <code>a</code>
|
|
* forward two positions in the original example, use
|
|
* <code>Collections.rotate(l.subList(1, 3+1), -1)</code>, which will
|
|
* result in <code>[t, n, k, a, s]</code>.
|
|
* <p>
|
|
*
|
|
* If the list is small or implements {@link RandomAccess}, the
|
|
* implementation exchanges the first element to its destination, then the
|
|
* displaced element, and so on until a circuit has been completed. The
|
|
* process is repeated if needed on the second element, and so forth, until
|
|
* all elements have been swapped. For large non-random lists, the
|
|
* implementation breaks the list into two sublists at index
|
|
* <code>-distance mod size</code>, calls {@link #reverse(List)} on the
|
|
* pieces, then reverses the overall list.
|
|
*
|
|
* @param list the list to rotate
|
|
* @param distance the distance to rotate by; unrestricted in value
|
|
* @throws UnsupportedOperationException if the list does not support set
|
|
* @since 1.4
|
|
*/
|
|
public static void rotate(List<?> list, int distance)
|
|
{
|
|
int size = list.size();
|
|
if (size == 0)
|
|
return;
|
|
distance %= size;
|
|
if (distance == 0)
|
|
return;
|
|
if (distance < 0)
|
|
distance += size;
|
|
|
|
if (isSequential(list))
|
|
{
|
|
reverse(list);
|
|
reverse(list.subList(0, distance));
|
|
reverse(list.subList(distance, size));
|
|
}
|
|
else
|
|
{
|
|
// Determine the least common multiple of distance and size, as there
|
|
// are (distance / LCM) loops to cycle through.
|
|
int a = size;
|
|
int lcm = distance;
|
|
int b = a % lcm;
|
|
while (b != 0)
|
|
{
|
|
a = lcm;
|
|
lcm = b;
|
|
b = a % lcm;
|
|
}
|
|
|
|
// Now, make the swaps. We must take the remainder every time through
|
|
// the inner loop so that we don't overflow i to negative values.
|
|
List<Object> objList = (List<Object>) list;
|
|
while (--lcm >= 0)
|
|
{
|
|
Object o = objList.get(lcm);
|
|
for (int i = lcm + distance; i != lcm; i = (i + distance) % size)
|
|
o = objList.set(i, o);
|
|
objList.set(lcm, o);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Shuffle a list according to a default source of randomness. The algorithm
|
|
* used iterates backwards over the list, swapping each element with an
|
|
* element randomly selected from the elements in positions less than or
|
|
* equal to it (using r.nextInt(int)).
|
|
* <p>
|
|
*
|
|
* This algorithm would result in a perfectly fair shuffle (that is, each
|
|
* element would have an equal chance of ending up in any position) if r were
|
|
* a perfect source of randomness. In practice the results are merely very
|
|
* close to perfect.
|
|
* <p>
|
|
*
|
|
* This method operates in linear time. To do this on large lists which do
|
|
* not implement {@link RandomAccess}, a temporary array is used to acheive
|
|
* this speed, since it would be quadratic access otherwise.
|
|
*
|
|
* @param l the list to shuffle
|
|
* @throws UnsupportedOperationException if l.listIterator() does not
|
|
* support the set operation
|
|
*/
|
|
public static void shuffle(List<?> l)
|
|
{
|
|
if (defaultRandom == null)
|
|
{
|
|
synchronized (Collections.class)
|
|
{
|
|
if (defaultRandom == null)
|
|
defaultRandom = new Random();
|
|
}
|
|
}
|
|
shuffle(l, defaultRandom);
|
|
}
|
|
|
|
/**
|
|
* Cache a single Random object for use by shuffle(List). This improves
|
|
* performance as well as ensuring that sequential calls to shuffle() will
|
|
* not result in the same shuffle order occurring: the resolution of
|
|
* System.currentTimeMillis() is not sufficient to guarantee a unique seed.
|
|
*/
|
|
private static Random defaultRandom = null;
|
|
|
|
/**
|
|
* Shuffle a list according to a given source of randomness. The algorithm
|
|
* used iterates backwards over the list, swapping each element with an
|
|
* element randomly selected from the elements in positions less than or
|
|
* equal to it (using r.nextInt(int)).
|
|
* <p>
|
|
*
|
|
* This algorithm would result in a perfectly fair shuffle (that is, each
|
|
* element would have an equal chance of ending up in any position) if r were
|
|
* a perfect source of randomness. In practise (eg if r = new Random()) the
|
|
* results are merely very close to perfect.
|
|
* <p>
|
|
*
|
|
* This method operates in linear time. To do this on large lists which do
|
|
* not implement {@link RandomAccess}, a temporary array is used to acheive
|
|
* this speed, since it would be quadratic access otherwise.
|
|
*
|
|
* @param l the list to shuffle
|
|
* @param r the source of randomness to use for the shuffle
|
|
* @throws UnsupportedOperationException if l.listIterator() does not
|
|
* support the set operation
|
|
*/
|
|
public static void shuffle(List<?> l, Random r)
|
|
{
|
|
int lsize = l.size();
|
|
List<Object> list = (List<Object>) l;
|
|
ListIterator<Object> i = list.listIterator(lsize);
|
|
boolean sequential = isSequential(l);
|
|
Object[] a = null; // stores a copy of the list for the sequential case
|
|
|
|
if (sequential)
|
|
a = list.toArray();
|
|
|
|
for (int pos = lsize - 1; pos > 0; --pos)
|
|
{
|
|
// Obtain a random position to swap with. pos + 1 is used so that the
|
|
// range of the random number includes the current position.
|
|
int swap = r.nextInt(pos + 1);
|
|
|
|
// Swap the desired element.
|
|
Object o;
|
|
if (sequential)
|
|
{
|
|
o = a[swap];
|
|
a[swap] = i.previous();
|
|
}
|
|
else
|
|
o = list.set(swap, i.previous());
|
|
|
|
i.set(o);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns the frequency of the specified object within the supplied
|
|
* collection. The frequency represents the number of occurrences of
|
|
* elements within the collection which return <code>true</code> when
|
|
* compared with the object using the <code>equals</code> method.
|
|
*
|
|
* @param c the collection to scan for occurrences of the object.
|
|
* @param o the object to locate occurrances of within the collection.
|
|
* @throws NullPointerException if the collection is <code>null</code>.
|
|
* @since 1.5
|
|
*/
|
|
public static int frequency (Collection<?> c, Object o)
|
|
{
|
|
int result = 0;
|
|
final Iterator<?> it = c.iterator();
|
|
while (it.hasNext())
|
|
{
|
|
Object v = it.next();
|
|
if (AbstractCollection.equals(o, v))
|
|
++result;
|
|
}
|
|
return result;
|
|
}
|
|
|
|
/**
|
|
* Adds all the specified elements to the given collection, in a similar
|
|
* way to the <code>addAll</code> method of the <code>Collection</code>.
|
|
* However, this is a variable argument method which allows the new elements
|
|
* to be specified individually or in array form, as opposed to the list
|
|
* required by the collection's <code>addAll</code> method. This has
|
|
* benefits in both simplicity (multiple elements can be added without
|
|
* having to be wrapped inside a grouping structure) and efficiency
|
|
* (as a redundant list doesn't have to be created to add an individual
|
|
* set of elements or an array).
|
|
*
|
|
* @param c the collection to which the elements should be added.
|
|
* @param a the elements to be added to the collection.
|
|
* @return true if the collection changed its contents as a result.
|
|
* @throws UnsupportedOperationException if the collection does not support
|
|
* addition.
|
|
* @throws NullPointerException if one or more elements in a are null,
|
|
* and the collection does not allow null
|
|
* elements. This exception is also thrown
|
|
* if either <code>c</code> or <code>a</code>
|
|
* are null.
|
|
* @throws IllegalArgumentException if the collection won't allow an element
|
|
* to be added for some other reason.
|
|
* @since 1.5
|
|
*/
|
|
public static <T> boolean addAll(Collection<? super T> c, T... a)
|
|
{
|
|
boolean overall = false;
|
|
|
|
for (T element : a)
|
|
{
|
|
boolean result = c.add(element);
|
|
if (result)
|
|
overall = true;
|
|
}
|
|
return overall;
|
|
}
|
|
|
|
/**
|
|
* Returns true if the two specified collections have no elements in
|
|
* common. This method may give unusual results if one or both collections
|
|
* use a non-standard equality test. In the trivial case of comparing
|
|
* a collection with itself, this method returns true if, and only if,
|
|
* the collection is empty.
|
|
*
|
|
* @param c1 the first collection to compare.
|
|
* @param c2 the second collection to compare.
|
|
* @return true if the collections are disjoint.
|
|
* @throws NullPointerException if either collection is null.
|
|
* @since 1.5
|
|
*/
|
|
public static boolean disjoint(Collection<?> c1, Collection<?> c2)
|
|
{
|
|
Collection<Object> oc1 = (Collection<Object>) c1;
|
|
final Iterator<Object> it = oc1.iterator();
|
|
while (it.hasNext())
|
|
if (c2.contains(it.next()))
|
|
return false;
|
|
return true;
|
|
}
|
|
|
|
|
|
/**
|
|
* Obtain an immutable Set consisting of a single element. The return value
|
|
* of this method is Serializable.
|
|
*
|
|
* @param o the single element
|
|
* @return an immutable Set containing only o
|
|
* @see Serializable
|
|
*/
|
|
public static <T> Set<T> singleton(T o)
|
|
{
|
|
return new SingletonSet<T>(o);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #singleton(Object)}. This class name
|
|
* is required for compatibility with Sun's JDK serializability.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static final class SingletonSet<T> extends AbstractSet<T>
|
|
implements Serializable
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = 3193687207550431679L;
|
|
|
|
|
|
/**
|
|
* The single element; package visible for use in nested class.
|
|
* @serial the singleton
|
|
*/
|
|
final T element;
|
|
|
|
/**
|
|
* Construct a singleton.
|
|
* @param o the element
|
|
*/
|
|
SingletonSet(T o)
|
|
{
|
|
element = o;
|
|
}
|
|
|
|
/**
|
|
* The size: always 1!
|
|
* @return 1.
|
|
*/
|
|
public int size()
|
|
{
|
|
return 1;
|
|
}
|
|
|
|
/**
|
|
* Returns an iterator over the lone element.
|
|
*/
|
|
public Iterator<T> iterator()
|
|
{
|
|
return new Iterator<T>()
|
|
{
|
|
/**
|
|
* Flag to indicate whether or not the element has
|
|
* been retrieved.
|
|
*/
|
|
private boolean hasNext = true;
|
|
|
|
/**
|
|
* Returns <code>true</code> if elements still remain to be
|
|
* iterated through.
|
|
*
|
|
* @return <code>true</code> if the element has not yet been returned.
|
|
*/
|
|
public boolean hasNext()
|
|
{
|
|
return hasNext;
|
|
}
|
|
|
|
/**
|
|
* Returns the element.
|
|
*
|
|
* @return The element used by this singleton.
|
|
* @throws NoSuchElementException if the object
|
|
* has already been retrieved.
|
|
*/
|
|
public T next()
|
|
{
|
|
if (hasNext)
|
|
{
|
|
hasNext = false;
|
|
return element;
|
|
}
|
|
else
|
|
throw new NoSuchElementException();
|
|
}
|
|
|
|
/**
|
|
* Removes the element from the singleton.
|
|
* As this set is immutable, this will always
|
|
* throw an exception.
|
|
*
|
|
* @throws UnsupportedOperationException as the
|
|
* singleton set doesn't support
|
|
* <code>remove()</code>.
|
|
*/
|
|
public void remove()
|
|
{
|
|
throw new UnsupportedOperationException();
|
|
}
|
|
};
|
|
}
|
|
|
|
// The remaining methods are optional, but provide a performance
|
|
// advantage by not allocating unnecessary iterators in AbstractSet.
|
|
/**
|
|
* The set only contains one element.
|
|
*
|
|
* @param o The object to search for.
|
|
* @return <code>true</code> if o == the element of the singleton.
|
|
*/
|
|
public boolean contains(Object o)
|
|
{
|
|
return equals(o, element);
|
|
}
|
|
|
|
/**
|
|
* This is true if the other collection only contains the element.
|
|
*
|
|
* @param c A collection to compare against this singleton.
|
|
* @return <code>true</code> if c only contains either no elements or
|
|
* elements equal to the element in this singleton.
|
|
*/
|
|
public boolean containsAll(Collection<?> c)
|
|
{
|
|
Iterator<?> i = c.iterator();
|
|
int pos = c.size();
|
|
while (--pos >= 0)
|
|
if (! equals(i.next(), element))
|
|
return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* The hash is just that of the element.
|
|
*
|
|
* @return The hashcode of the element.
|
|
*/
|
|
public int hashCode()
|
|
{
|
|
return hashCode(element);
|
|
}
|
|
|
|
/**
|
|
* Returning an array is simple.
|
|
*
|
|
* @return An array containing the element.
|
|
*/
|
|
public Object[] toArray()
|
|
{
|
|
return new Object[] {element};
|
|
}
|
|
|
|
/**
|
|
* Obvious string.
|
|
*
|
|
* @return The string surrounded by enclosing
|
|
* square brackets.
|
|
*/
|
|
public String toString()
|
|
{
|
|
return "[" + element + "]";
|
|
}
|
|
} // class SingletonSet
|
|
|
|
/**
|
|
* Obtain an immutable List consisting of a single element. The return value
|
|
* of this method is Serializable, and implements RandomAccess.
|
|
*
|
|
* @param o the single element
|
|
* @return an immutable List containing only o
|
|
* @see Serializable
|
|
* @see RandomAccess
|
|
* @since 1.3
|
|
*/
|
|
public static <T> List<T> singletonList(T o)
|
|
{
|
|
return new SingletonList<T>(o);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #singletonList(Object)}. This class name
|
|
* is required for compatibility with Sun's JDK serializability.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static final class SingletonList<T> extends AbstractList<T>
|
|
implements Serializable, RandomAccess
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = 3093736618740652951L;
|
|
|
|
/**
|
|
* The single element.
|
|
* @serial the singleton
|
|
*/
|
|
private final T element;
|
|
|
|
/**
|
|
* Construct a singleton.
|
|
* @param o the element
|
|
*/
|
|
SingletonList(T o)
|
|
{
|
|
element = o;
|
|
}
|
|
|
|
/**
|
|
* The size: always 1!
|
|
* @return 1.
|
|
*/
|
|
public int size()
|
|
{
|
|
return 1;
|
|
}
|
|
|
|
/**
|
|
* Only index 0 is valid.
|
|
* @param index The index of the element
|
|
* to retrieve.
|
|
* @return The singleton's element if the
|
|
* index is 0.
|
|
* @throws IndexOutOfBoundsException if
|
|
* index is not 0.
|
|
*/
|
|
public T get(int index)
|
|
{
|
|
if (index == 0)
|
|
return element;
|
|
throw new IndexOutOfBoundsException();
|
|
}
|
|
|
|
// The remaining methods are optional, but provide a performance
|
|
// advantage by not allocating unnecessary iterators in AbstractList.
|
|
/**
|
|
* The set only contains one element.
|
|
*
|
|
* @param o The object to search for.
|
|
* @return <code>true</code> if o == the singleton element.
|
|
*/
|
|
public boolean contains(Object o)
|
|
{
|
|
return equals(o, element);
|
|
}
|
|
|
|
/**
|
|
* This is true if the other collection only contains the element.
|
|
*
|
|
* @param c A collection to compare against this singleton.
|
|
* @return <code>true</code> if c only contains either no elements or
|
|
* elements equal to the element in this singleton.
|
|
*/
|
|
public boolean containsAll(Collection<?> c)
|
|
{
|
|
Iterator<?> i = c.iterator();
|
|
int pos = c.size();
|
|
while (--pos >= 0)
|
|
if (! equals(i.next(), element))
|
|
return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Speed up the hashcode computation.
|
|
*
|
|
* @return The hashcode of the list, based
|
|
* on the hashcode of the singleton element.
|
|
*/
|
|
public int hashCode()
|
|
{
|
|
return 31 + hashCode(element);
|
|
}
|
|
|
|
/**
|
|
* Either the list has it or not.
|
|
*
|
|
* @param o The object to find the first index of.
|
|
* @return 0 if o is the singleton element, -1 if not.
|
|
*/
|
|
public int indexOf(Object o)
|
|
{
|
|
return equals(o, element) ? 0 : -1;
|
|
}
|
|
|
|
/**
|
|
* Either the list has it or not.
|
|
*
|
|
* @param o The object to find the last index of.
|
|
* @return 0 if o is the singleton element, -1 if not.
|
|
*/
|
|
public int lastIndexOf(Object o)
|
|
{
|
|
return equals(o, element) ? 0 : -1;
|
|
}
|
|
|
|
/**
|
|
* Sublists are limited in scope.
|
|
*
|
|
* @param from The starting bound for the sublist.
|
|
* @param to The ending bound for the sublist.
|
|
* @return Either an empty list if both bounds are
|
|
* 0 or 1, or this list if the bounds are 0 and 1.
|
|
* @throws IllegalArgumentException if <code>from > to</code>
|
|
* @throws IndexOutOfBoundsException if either bound is greater
|
|
* than 1.
|
|
*/
|
|
public List<T> subList(int from, int to)
|
|
{
|
|
if (from == to && (to == 0 || to == 1))
|
|
return EMPTY_LIST;
|
|
if (from == 0 && to == 1)
|
|
return this;
|
|
if (from > to)
|
|
throw new IllegalArgumentException();
|
|
throw new IndexOutOfBoundsException();
|
|
}
|
|
|
|
/**
|
|
* Returning an array is simple.
|
|
*
|
|
* @return An array containing the element.
|
|
*/
|
|
public Object[] toArray()
|
|
{
|
|
return new Object[] {element};
|
|
}
|
|
|
|
/**
|
|
* Obvious string.
|
|
*
|
|
* @return The string surrounded by enclosing
|
|
* square brackets.
|
|
*/
|
|
public String toString()
|
|
{
|
|
return "[" + element + "]";
|
|
}
|
|
} // class SingletonList
|
|
|
|
/**
|
|
* Obtain an immutable Map consisting of a single key-value pair.
|
|
* The return value of this method is Serializable.
|
|
*
|
|
* @param key the single key
|
|
* @param value the single value
|
|
* @return an immutable Map containing only the single key-value pair
|
|
* @see Serializable
|
|
* @since 1.3
|
|
*/
|
|
public static <K, V> Map<K, V> singletonMap(K key, V value)
|
|
{
|
|
return new SingletonMap<K, V>(key, value);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #singletonMap(Object, Object)}. This class
|
|
* name is required for compatibility with Sun's JDK serializability.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static final class SingletonMap<K, V> extends AbstractMap<K, V>
|
|
implements Serializable
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = -6979724477215052911L;
|
|
|
|
/**
|
|
* The single key.
|
|
* @serial the singleton key
|
|
*/
|
|
private final K k;
|
|
|
|
/**
|
|
* The corresponding value.
|
|
* @serial the singleton value
|
|
*/
|
|
private final V v;
|
|
|
|
/**
|
|
* Cache the entry set.
|
|
*/
|
|
private transient Set<Map.Entry<K, V>> entries;
|
|
|
|
/**
|
|
* Construct a singleton.
|
|
* @param key the key
|
|
* @param value the value
|
|
*/
|
|
SingletonMap(K key, V value)
|
|
{
|
|
k = key;
|
|
v = value;
|
|
}
|
|
|
|
/**
|
|
* There is a single immutable entry.
|
|
*
|
|
* @return A singleton containing the map entry.
|
|
*/
|
|
public Set<Map.Entry<K, V>> entrySet()
|
|
{
|
|
if (entries == null)
|
|
{
|
|
Map.Entry<K,V> entry = new AbstractMap.SimpleEntry<K, V>(k, v)
|
|
{
|
|
/**
|
|
* Sets the value of the map entry to the supplied value.
|
|
* An exception is always thrown, as the map is immutable.
|
|
*
|
|
* @param o The new value.
|
|
* @return The old value.
|
|
* @throws UnsupportedOperationException as setting the value
|
|
* is not supported.
|
|
*/
|
|
public V setValue(V o)
|
|
{
|
|
throw new UnsupportedOperationException();
|
|
}
|
|
};
|
|
entries = singleton(entry);
|
|
}
|
|
return entries;
|
|
}
|
|
|
|
// The remaining methods are optional, but provide a performance
|
|
// advantage by not allocating unnecessary iterators in AbstractMap.
|
|
/**
|
|
* Single entry.
|
|
*
|
|
* @param key The key to look for.
|
|
* @return <code>true</code> if the key is the same as the one used by
|
|
* this map.
|
|
*/
|
|
public boolean containsKey(Object key)
|
|
{
|
|
return equals(key, k);
|
|
}
|
|
|
|
/**
|
|
* Single entry.
|
|
*
|
|
* @param value The value to look for.
|
|
* @return <code>true</code> if the value is the same as the one used by
|
|
* this map.
|
|
*/
|
|
public boolean containsValue(Object value)
|
|
{
|
|
return equals(value, v);
|
|
}
|
|
|
|
/**
|
|
* Single entry.
|
|
*
|
|
* @param key The key of the value to be retrieved.
|
|
* @return The singleton value if the key is the same as the
|
|
* singleton key, null otherwise.
|
|
*/
|
|
public V get(Object key)
|
|
{
|
|
return equals(key, k) ? v : null;
|
|
}
|
|
|
|
/**
|
|
* Calculate the hashcode directly.
|
|
*
|
|
* @return The hashcode computed from the singleton key
|
|
* and the singleton value.
|
|
*/
|
|
public int hashCode()
|
|
{
|
|
return hashCode(k) ^ hashCode(v);
|
|
}
|
|
|
|
/**
|
|
* Return the keyset.
|
|
*
|
|
* @return A singleton containing the key.
|
|
*/
|
|
public Set<K> keySet()
|
|
{
|
|
if (keys == null)
|
|
keys = singleton(k);
|
|
return keys;
|
|
}
|
|
|
|
/**
|
|
* The size: always 1!
|
|
*
|
|
* @return 1.
|
|
*/
|
|
public int size()
|
|
{
|
|
return 1;
|
|
}
|
|
|
|
/**
|
|
* Return the values. Technically, a singleton, while more specific than
|
|
* a general Collection, will work. Besides, that's what the JDK uses!
|
|
*
|
|
* @return A singleton containing the value.
|
|
*/
|
|
public Collection<V> values()
|
|
{
|
|
if (values == null)
|
|
values = singleton(v);
|
|
return values;
|
|
}
|
|
|
|
/**
|
|
* Obvious string.
|
|
*
|
|
* @return A string containing the string representations of the key
|
|
* and its associated value.
|
|
*/
|
|
public String toString()
|
|
{
|
|
return "{" + k + "=" + v + "}";
|
|
}
|
|
} // class SingletonMap
|
|
|
|
/**
|
|
* Sort a list according to the natural ordering of its elements. The list
|
|
* must be modifiable, but can be of fixed size. The sort algorithm is
|
|
* precisely that used by Arrays.sort(Object[]), which offers guaranteed
|
|
* nlog(n) performance. This implementation dumps the list into an array,
|
|
* sorts the array, and then iterates over the list setting each element from
|
|
* the array.
|
|
*
|
|
* @param l the List to sort (<code>null</code> not permitted)
|
|
* @throws ClassCastException if some items are not mutually comparable
|
|
* @throws UnsupportedOperationException if the List is not modifiable
|
|
* @throws NullPointerException if the list is <code>null</code>, or contains
|
|
* some element that is <code>null</code>.
|
|
* @see Arrays#sort(Object[])
|
|
*/
|
|
public static <T extends Comparable<? super T>> void sort(List<T> l)
|
|
{
|
|
sort(l, null);
|
|
}
|
|
|
|
/**
|
|
* Sort a list according to a specified Comparator. The list must be
|
|
* modifiable, but can be of fixed size. The sort algorithm is precisely that
|
|
* used by Arrays.sort(Object[], Comparator), which offers guaranteed
|
|
* nlog(n) performance. This implementation dumps the list into an array,
|
|
* sorts the array, and then iterates over the list setting each element from
|
|
* the array.
|
|
*
|
|
* @param l the List to sort (<code>null</code> not permitted)
|
|
* @param c the Comparator specifying the ordering for the elements, or
|
|
* <code>null</code> for natural ordering
|
|
* @throws ClassCastException if c will not compare some pair of items
|
|
* @throws UnsupportedOperationException if the List is not modifiable
|
|
* @throws NullPointerException if the List is <code>null</code> or
|
|
* <code>null</code> is compared by natural ordering (only possible
|
|
* when c is <code>null</code>)
|
|
*
|
|
* @see Arrays#sort(Object[], Comparator)
|
|
*/
|
|
public static <T> void sort(List<T> l, Comparator<? super T> c)
|
|
{
|
|
T[] a = (T[]) l.toArray();
|
|
Arrays.sort(a, c);
|
|
ListIterator<T> i = l.listIterator();
|
|
for (int pos = 0, alen = a.length; pos < alen; pos++)
|
|
{
|
|
i.next();
|
|
i.set(a[pos]);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Swaps the elements at the specified positions within the list. Equal
|
|
* positions have no effect.
|
|
*
|
|
* @param l the list to work on
|
|
* @param i the first index to swap
|
|
* @param j the second index
|
|
* @throws UnsupportedOperationException if list.set is not supported
|
|
* @throws IndexOutOfBoundsException if either i or j is < 0 or >=
|
|
* list.size()
|
|
* @since 1.4
|
|
*/
|
|
public static void swap(List<?> l, int i, int j)
|
|
{
|
|
List<Object> list = (List<Object>) l;
|
|
list.set(i, list.set(j, list.get(i)));
|
|
}
|
|
|
|
|
|
/**
|
|
* Returns a synchronized (thread-safe) collection wrapper backed by the
|
|
* given collection. Notice that element access through the iterators
|
|
* is thread-safe, but if the collection can be structurally modified
|
|
* (adding or removing elements) then you should synchronize around the
|
|
* iteration to avoid non-deterministic behavior:<br>
|
|
* <pre>
|
|
* Collection c = Collections.synchronizedCollection(new Collection(...));
|
|
* ...
|
|
* synchronized (c)
|
|
* {
|
|
* Iterator i = c.iterator();
|
|
* while (i.hasNext())
|
|
* foo(i.next());
|
|
* }
|
|
* </pre><p>
|
|
*
|
|
* Since the collection might be a List or a Set, and those have incompatible
|
|
* equals and hashCode requirements, this relies on Object's implementation
|
|
* rather than passing those calls on to the wrapped collection. The returned
|
|
* Collection implements Serializable, but can only be serialized if
|
|
* the collection it wraps is likewise Serializable.
|
|
*
|
|
* @param c the collection to wrap
|
|
* @return a synchronized view of the collection
|
|
* @see Serializable
|
|
*/
|
|
public static <T> Collection<T> synchronizedCollection(Collection<T> c)
|
|
{
|
|
return new SynchronizedCollection<T>(c);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #synchronizedCollection(Collection)}. This
|
|
* class name is required for compatibility with Sun's JDK serializability.
|
|
* Package visible, so that collections such as the one for
|
|
* Hashtable.values() can specify which object to synchronize on.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
static class SynchronizedCollection<T>
|
|
implements Collection<T>, Serializable
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = 3053995032091335093L;
|
|
|
|
/**
|
|
* The wrapped collection. Package visible for use by subclasses.
|
|
* @serial the real collection
|
|
*/
|
|
final Collection<T> c;
|
|
|
|
/**
|
|
* The object to synchronize on. When an instance is created via public
|
|
* methods, it will be this; but other uses like SynchronizedMap.values()
|
|
* must specify another mutex. Package visible for use by subclasses.
|
|
* @serial the lock
|
|
*/
|
|
final Object mutex;
|
|
|
|
/**
|
|
* Wrap a given collection.
|
|
* @param c the collection to wrap
|
|
* @throws NullPointerException if c is null
|
|
*/
|
|
SynchronizedCollection(Collection<T> c)
|
|
{
|
|
this.c = c;
|
|
mutex = this;
|
|
if (c == null)
|
|
throw new NullPointerException();
|
|
}
|
|
|
|
/**
|
|
* Called only by trusted code to specify the mutex as well as the
|
|
* collection.
|
|
* @param sync the mutex
|
|
* @param c the collection
|
|
*/
|
|
SynchronizedCollection(Object sync, Collection<T> c)
|
|
{
|
|
this.c = c;
|
|
mutex = sync;
|
|
}
|
|
|
|
/**
|
|
* Adds the object to the underlying collection, first
|
|
* obtaining a lock on the mutex.
|
|
*
|
|
* @param o The object to add.
|
|
* @return <code>true</code> if the collection was modified as a result
|
|
* of this action.
|
|
* @throws UnsupportedOperationException if this collection does not
|
|
* support the add operation.
|
|
* @throws ClassCastException if o cannot be added to this collection due
|
|
* to its type.
|
|
* @throws NullPointerException if o is null and this collection doesn't
|
|
* support the addition of null values.
|
|
* @throws IllegalArgumentException if o cannot be added to this
|
|
* collection for some other reason.
|
|
*/
|
|
public boolean add(T o)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return c.add(o);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Adds the objects in col to the underlying collection, first
|
|
* obtaining a lock on the mutex.
|
|
*
|
|
* @param col The collection to take the new objects from.
|
|
* @return <code>true</code> if the collection was modified as a result
|
|
* of this action.
|
|
* @throws UnsupportedOperationException if this collection does not
|
|
* support the addAll operation.
|
|
* @throws ClassCastException if some element of col cannot be added to this
|
|
* collection due to its type.
|
|
* @throws NullPointerException if some element of col is null and this
|
|
* collection does not support the addition of null values.
|
|
* @throws NullPointerException if col itself is null.
|
|
* @throws IllegalArgumentException if some element of col cannot be added
|
|
* to this collection for some other reason.
|
|
*/
|
|
public boolean addAll(Collection<? extends T> col)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return c.addAll(col);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Removes all objects from the underlying collection,
|
|
* first obtaining a lock on the mutex.
|
|
*
|
|
* @throws UnsupportedOperationException if this collection does not
|
|
* support the clear operation.
|
|
*/
|
|
public void clear()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
c.clear();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Checks for the existence of o within the underlying
|
|
* collection, first obtaining a lock on the mutex.
|
|
*
|
|
* @param o the element to look for.
|
|
* @return <code>true</code> if this collection contains at least one
|
|
* element e such that <code>o == null ? e == null : o.equals(e)</code>.
|
|
* @throws ClassCastException if the type of o is not a valid type for this
|
|
* collection.
|
|
* @throws NullPointerException if o is null and this collection doesn't
|
|
* support null values.
|
|
*/
|
|
public boolean contains(Object o)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return c.contains(o);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Checks for the existence of each object in cl
|
|
* within the underlying collection, first obtaining
|
|
* a lock on the mutex.
|
|
*
|
|
* @param c1 the collection to test for.
|
|
* @return <code>true</code> if for every element o in c, contains(o)
|
|
* would return <code>true</code>.
|
|
* @throws ClassCastException if the type of any element in cl is not a valid
|
|
* type for this collection.
|
|
* @throws NullPointerException if some element of cl is null and this
|
|
* collection does not support null values.
|
|
* @throws NullPointerException if cl itself is null.
|
|
*/
|
|
public boolean containsAll(Collection<?> c1)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return c.containsAll(c1);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns <code>true</code> if there are no objects in the underlying
|
|
* collection. A lock on the mutex is obtained before the
|
|
* check is performed.
|
|
*
|
|
* @return <code>true</code> if this collection contains no elements.
|
|
*/
|
|
public boolean isEmpty()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return c.isEmpty();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns a synchronized iterator wrapper around the underlying
|
|
* collection's iterator. A lock on the mutex is obtained before
|
|
* retrieving the collection's iterator.
|
|
*
|
|
* @return An iterator over the elements in the underlying collection,
|
|
* which returns each element in any order.
|
|
*/
|
|
public Iterator<T> iterator()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return new SynchronizedIterator<T>(mutex, c.iterator());
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Removes the specified object from the underlying collection,
|
|
* first obtaining a lock on the mutex.
|
|
*
|
|
* @param o The object to remove.
|
|
* @return <code>true</code> if the collection changed as a result of this call, that is,
|
|
* if the collection contained at least one occurrence of o.
|
|
* @throws UnsupportedOperationException if this collection does not
|
|
* support the remove operation.
|
|
* @throws ClassCastException if the type of o is not a valid type
|
|
* for this collection.
|
|
* @throws NullPointerException if o is null and the collection doesn't
|
|
* support null values.
|
|
*/
|
|
public boolean remove(Object o)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return c.remove(o);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Removes all elements, e, of the underlying
|
|
* collection for which <code>col.contains(e)</code>
|
|
* returns <code>true</code>. A lock on the mutex is obtained
|
|
* before the operation proceeds.
|
|
*
|
|
* @param col The collection of objects to be removed.
|
|
* @return <code>true</code> if this collection was modified as a result of this call.
|
|
* @throws UnsupportedOperationException if this collection does not
|
|
* support the removeAll operation.
|
|
* @throws ClassCastException if the type of any element in c is not a valid
|
|
* type for this collection.
|
|
* @throws NullPointerException if some element of c is null and this
|
|
* collection does not support removing null values.
|
|
* @throws NullPointerException if c itself is null.
|
|
*/
|
|
public boolean removeAll(Collection<?> col)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return c.removeAll(col);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Retains all elements, e, of the underlying
|
|
* collection for which <code>col.contains(e)</code>
|
|
* returns <code>true</code>. That is, every element that doesn't
|
|
* exist in col is removed. A lock on the mutex is obtained
|
|
* before the operation proceeds.
|
|
*
|
|
* @param col The collection of objects to be removed.
|
|
* @return <code>true</code> if this collection was modified as a result of this call.
|
|
* @throws UnsupportedOperationException if this collection does not
|
|
* support the removeAll operation.
|
|
* @throws ClassCastException if the type of any element in c is not a valid
|
|
* type for this collection.
|
|
* @throws NullPointerException if some element of c is null and this
|
|
* collection does not support removing null values.
|
|
* @throws NullPointerException if c itself is null.
|
|
*/
|
|
public boolean retainAll(Collection<?> col)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return c.retainAll(col);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Retrieves the size of the underlying collection.
|
|
* A lock on the mutex is obtained before the collection
|
|
* is accessed.
|
|
*
|
|
* @return The size of the collection.
|
|
*/
|
|
public int size()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return c.size();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns an array containing each object within the underlying
|
|
* collection. A lock is obtained on the mutex before the collection
|
|
* is accessed.
|
|
*
|
|
* @return An array of objects, matching the collection in size. The
|
|
* elements occur in any order.
|
|
*/
|
|
public Object[] toArray()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return c.toArray();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Copies the elements in the underlying collection to the supplied
|
|
* array. If <code>a.length < size()</code>, a new array of the
|
|
* same run-time type is created, with a size equal to that of
|
|
* the collection. If <code>a.length > size()</code>, then the
|
|
* elements from 0 to <code>size() - 1</code> contain the elements
|
|
* from this collection. The following element is set to null
|
|
* to indicate the end of the collection objects. However, this
|
|
* only makes a difference if null is not a permitted value within
|
|
* the collection.
|
|
* Before the copying takes place, a lock is obtained on the mutex.
|
|
*
|
|
* @param a An array to copy elements to.
|
|
* @return An array containing the elements of the underlying collection.
|
|
* @throws ArrayStoreException if the type of any element of the
|
|
* collection is not a subtype of the element type of a.
|
|
*/
|
|
public <T> T[] toArray(T[] a)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return c.toArray(a);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns a string representation of the underlying collection.
|
|
* A lock is obtained on the mutex before the string is created.
|
|
*
|
|
* @return A string representation of the collection.
|
|
*/
|
|
public String toString()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return c.toString();
|
|
}
|
|
}
|
|
} // class SynchronizedCollection
|
|
|
|
/**
|
|
* The implementation of the various iterator methods in the
|
|
* synchronized classes. These iterators must "sync" on the same object
|
|
* as the collection they iterate over.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static class SynchronizedIterator<T> implements Iterator<T>
|
|
{
|
|
/**
|
|
* The object to synchronize on. Package visible for use by subclass.
|
|
*/
|
|
final Object mutex;
|
|
|
|
/**
|
|
* The wrapped iterator.
|
|
*/
|
|
private final Iterator<T> i;
|
|
|
|
/**
|
|
* Only trusted code creates a wrapper, with the specified sync.
|
|
* @param sync the mutex
|
|
* @param i the wrapped iterator
|
|
*/
|
|
SynchronizedIterator(Object sync, Iterator<T> i)
|
|
{
|
|
this.i = i;
|
|
mutex = sync;
|
|
}
|
|
|
|
/**
|
|
* Retrieves the next object in the underlying collection.
|
|
* A lock is obtained on the mutex before the collection is accessed.
|
|
*
|
|
* @return The next object in the collection.
|
|
* @throws NoSuchElementException if there are no more elements
|
|
*/
|
|
public T next()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return i.next();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns <code>true</code> if objects can still be retrieved from the iterator
|
|
* using <code>next()</code>. A lock is obtained on the mutex before
|
|
* the collection is accessed.
|
|
*
|
|
* @return <code>true</code> if at least one element is still to be returned by
|
|
* <code>next()</code>.
|
|
*/
|
|
public boolean hasNext()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return i.hasNext();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Removes the object that was last returned by <code>next()</code>
|
|
* from the underlying collection. Only one call to this method is
|
|
* allowed per call to the <code>next()</code> method, and it does
|
|
* not affect the value that will be returned by <code>next()</code>.
|
|
* Thus, if element n was retrieved from the collection by
|
|
* <code>next()</code>, it is this element that gets removed.
|
|
* Regardless of whether this takes place or not, element n+1 is
|
|
* still returned on the subsequent <code>next()</code> call.
|
|
*
|
|
* @throws IllegalStateException if next has not yet been called or remove
|
|
* has already been called since the last call to next.
|
|
* @throws UnsupportedOperationException if this Iterator does not support
|
|
* the remove operation.
|
|
*/
|
|
public void remove()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
i.remove();
|
|
}
|
|
}
|
|
} // class SynchronizedIterator
|
|
|
|
/**
|
|
* Returns a synchronized (thread-safe) list wrapper backed by the
|
|
* given list. Notice that element access through the iterators
|
|
* is thread-safe, but if the list can be structurally modified
|
|
* (adding or removing elements) then you should synchronize around the
|
|
* iteration to avoid non-deterministic behavior:<br>
|
|
* <pre>
|
|
* List l = Collections.synchronizedList(new List(...));
|
|
* ...
|
|
* synchronized (l)
|
|
* {
|
|
* Iterator i = l.iterator();
|
|
* while (i.hasNext())
|
|
* foo(i.next());
|
|
* }
|
|
* </pre><p>
|
|
*
|
|
* The returned List implements Serializable, but can only be serialized if
|
|
* the list it wraps is likewise Serializable. In addition, if the wrapped
|
|
* list implements RandomAccess, this does too.
|
|
*
|
|
* @param l the list to wrap
|
|
* @return a synchronized view of the list
|
|
* @see Serializable
|
|
* @see RandomAccess
|
|
*/
|
|
public static <T> List<T> synchronizedList(List<T> l)
|
|
{
|
|
if (l instanceof RandomAccess)
|
|
return new SynchronizedRandomAccessList<T>(l);
|
|
return new SynchronizedList<T>(l);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #synchronizedList(List)} for sequential
|
|
* lists. This class name is required for compatibility with Sun's JDK
|
|
* serializability. Package visible, so that lists such as Vector.subList()
|
|
* can specify which object to synchronize on.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
static class SynchronizedList<T> extends SynchronizedCollection<T>
|
|
implements List<T>
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = -7754090372962971524L;
|
|
|
|
/**
|
|
* The wrapped list; stored both here and in the superclass to avoid
|
|
* excessive casting. Package visible for use by subclass.
|
|
* @serial the wrapped list
|
|
*/
|
|
final List<T> list;
|
|
|
|
/**
|
|
* Wrap a given list.
|
|
* @param l the list to wrap
|
|
* @throws NullPointerException if l is null
|
|
*/
|
|
SynchronizedList(List<T> l)
|
|
{
|
|
super(l);
|
|
list = l;
|
|
}
|
|
|
|
/**
|
|
* Called only by trusted code to specify the mutex as well as the list.
|
|
* @param sync the mutex
|
|
* @param l the list
|
|
*/
|
|
SynchronizedList(Object sync, List<T> l)
|
|
{
|
|
super(sync, l);
|
|
list = l;
|
|
}
|
|
|
|
/**
|
|
* Insert an element into the underlying list at a given position (optional
|
|
* operation). This shifts all existing elements from that position to the
|
|
* end one index to the right. This version of add has no return, since it is
|
|
* assumed to always succeed if there is no exception. Before the
|
|
* addition takes place, a lock is obtained on the mutex.
|
|
*
|
|
* @param index the location to insert the item
|
|
* @param o the object to insert
|
|
* @throws UnsupportedOperationException if this list does not support the
|
|
* add operation
|
|
* @throws IndexOutOfBoundsException if index < 0 || index > size()
|
|
* @throws ClassCastException if o cannot be added to this list due to its
|
|
* type
|
|
* @throws IllegalArgumentException if o cannot be added to this list for
|
|
* some other reason
|
|
* @throws NullPointerException if o is null and this list doesn't support
|
|
* the addition of null values.
|
|
*/
|
|
public void add(int index, T o)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
list.add(index, o);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Add the contents of a collection to the underlying list at the given
|
|
* index (optional operation). If the list imposes restraints on what
|
|
* can be inserted, such as no null elements, this should be documented.
|
|
* A lock is obtained on the mutex before any of the elements are added.
|
|
*
|
|
* @param index the index at which to insert
|
|
* @param c the collection to add
|
|
* @return <code>true</code>, as defined by Collection for a modified list
|
|
* @throws UnsupportedOperationException if this list does not support the
|
|
* add operation
|
|
* @throws ClassCastException if o cannot be added to this list due to its
|
|
* type
|
|
* @throws IllegalArgumentException if o cannot be added to this list for
|
|
* some other reason
|
|
* @throws NullPointerException if o is null and this list doesn't support
|
|
* the addition of null values.
|
|
*/
|
|
public boolean addAll(int index, Collection<? extends T> c)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return list.addAll(index, c);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Tests whether the underlying list is equal to the supplied object.
|
|
* The object is deemed to be equal if it is also a <code>List</code>
|
|
* of equal size and with the same elements (i.e. each element, e1,
|
|
* in list, l1, and each element, e2, in l2, must return <code>true</code> for
|
|
* <code>e1 == null ? e2 == null : e1.equals(e2)</code>. Before the
|
|
* comparison is made, a lock is obtained on the mutex.
|
|
*
|
|
* @param o The object to test for equality with the underlying list.
|
|
* @return <code>true</code> if o is equal to the underlying list under the above
|
|
* definition.
|
|
*/
|
|
public boolean equals(Object o)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return list.equals(o);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Retrieves the object at the specified index. A lock
|
|
* is obtained on the mutex before the list is accessed.
|
|
*
|
|
* @param index the index of the element to be returned
|
|
* @return the element at index index in this list
|
|
* @throws IndexOutOfBoundsException if index < 0 || index >= size()
|
|
*/
|
|
public T get(int index)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return list.get(index);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Obtains a hashcode for the underlying list, first obtaining
|
|
* a lock on the mutex. The calculation of the hashcode is
|
|
* detailed in the documentation for the <code>List</code>
|
|
* interface.
|
|
*
|
|
* @return The hashcode of the underlying list.
|
|
* @see List#hashCode()
|
|
*/
|
|
public int hashCode()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return list.hashCode();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Obtain the first index at which a given object is to be found in the
|
|
* underlying list. A lock is obtained on the mutex before the list is
|
|
* accessed.
|
|
*
|
|
* @param o the object to search for
|
|
* @return the least integer n such that <code>o == null ? get(n) == null :
|
|
* o.equals(get(n))</code>, or -1 if there is no such index.
|
|
* @throws ClassCastException if the type of o is not a valid
|
|
* type for this list.
|
|
* @throws NullPointerException if o is null and this
|
|
* list does not support null values.
|
|
*/
|
|
|
|
public int indexOf(Object o)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return list.indexOf(o);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Obtain the last index at which a given object is to be found in this
|
|
* underlying list. A lock is obtained on the mutex before the list
|
|
* is accessed.
|
|
*
|
|
* @return the greatest integer n such that <code>o == null ? get(n) == null
|
|
* : o.equals(get(n))</code>, or -1 if there is no such index.
|
|
* @throws ClassCastException if the type of o is not a valid
|
|
* type for this list.
|
|
* @throws NullPointerException if o is null and this
|
|
* list does not support null values.
|
|
*/
|
|
public int lastIndexOf(Object o)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return list.lastIndexOf(o);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Retrieves a synchronized wrapper around the underlying list's
|
|
* list iterator. A lock is obtained on the mutex before the
|
|
* list iterator is retrieved.
|
|
*
|
|
* @return A list iterator over the elements in the underlying list.
|
|
* The list iterator allows additional list-specific operations
|
|
* to be performed, in addition to those supplied by the
|
|
* standard iterator.
|
|
*/
|
|
public ListIterator<T> listIterator()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return new SynchronizedListIterator<T>(mutex, list.listIterator());
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Retrieves a synchronized wrapper around the underlying list's
|
|
* list iterator. A lock is obtained on the mutex before the
|
|
* list iterator is retrieved. The iterator starts at the
|
|
* index supplied, leading to the element at that index being
|
|
* the first one returned by <code>next()</code>. Calling
|
|
* <code>previous()</code> from this initial position returns
|
|
* index - 1.
|
|
*
|
|
* @param index the position, between 0 and size() inclusive, to begin the
|
|
* iteration from
|
|
* @return A list iterator over the elements in the underlying list.
|
|
* The list iterator allows additional list-specific operations
|
|
* to be performed, in addition to those supplied by the
|
|
* standard iterator.
|
|
* @throws IndexOutOfBoundsException if index < 0 || index > size()
|
|
*/
|
|
public ListIterator<T> listIterator(int index)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return new SynchronizedListIterator<T>(mutex,
|
|
list.listIterator(index));
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Remove the element at a given position in the underlying list (optional
|
|
* operation). All remaining elements are shifted to the left to fill the gap.
|
|
* A lock on the mutex is obtained before the element is removed.
|
|
*
|
|
* @param index the position within the list of the object to remove
|
|
* @return the object that was removed
|
|
* @throws UnsupportedOperationException if this list does not support the
|
|
* remove operation
|
|
* @throws IndexOutOfBoundsException if index < 0 || index >= size()
|
|
*/
|
|
public T remove(int index)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return list.remove(index);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Replace an element of the underlying list with another object (optional
|
|
* operation). A lock is obtained on the mutex before the element is
|
|
* replaced.
|
|
*
|
|
* @param index the position within this list of the element to be replaced
|
|
* @param o the object to replace it with
|
|
* @return the object that was replaced
|
|
* @throws UnsupportedOperationException if this list does not support the
|
|
* set operation.
|
|
* @throws IndexOutOfBoundsException if index < 0 || index >= size()
|
|
* @throws ClassCastException if o cannot be added to this list due to its
|
|
* type
|
|
* @throws IllegalArgumentException if o cannot be added to this list for
|
|
* some other reason
|
|
* @throws NullPointerException if o is null and this
|
|
* list does not support null values.
|
|
*/
|
|
public T set(int index, T o)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return list.set(index, o);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Obtain a List view of a subsection of the underlying list, from fromIndex
|
|
* (inclusive) to toIndex (exclusive). If the two indices are equal, the
|
|
* sublist is empty. The returned list should be modifiable if and only
|
|
* if this list is modifiable. Changes to the returned list should be
|
|
* reflected in this list. If this list is structurally modified in
|
|
* any way other than through the returned list, the result of any subsequent
|
|
* operations on the returned list is undefined. A lock is obtained
|
|
* on the mutex before the creation of the sublist. The returned list
|
|
* is also synchronized, using the same mutex.
|
|
*
|
|
* @param fromIndex the index that the returned list should start from
|
|
* (inclusive)
|
|
* @param toIndex the index that the returned list should go to (exclusive)
|
|
* @return a List backed by a subsection of this list
|
|
* @throws IndexOutOfBoundsException if fromIndex < 0
|
|
* || toIndex > size() || fromIndex > toIndex
|
|
*/
|
|
public List<T> subList(int fromIndex, int toIndex)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return new SynchronizedList<T>(mutex,
|
|
list.subList(fromIndex, toIndex));
|
|
}
|
|
}
|
|
} // class SynchronizedList
|
|
|
|
/**
|
|
* The implementation of {@link #synchronizedList(List)} for random-access
|
|
* lists. This class name is required for compatibility with Sun's JDK
|
|
* serializability.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static final class SynchronizedRandomAccessList<T>
|
|
extends SynchronizedList<T> implements RandomAccess
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = 1530674583602358482L;
|
|
|
|
/**
|
|
* Wrap a given list.
|
|
* @param l the list to wrap
|
|
* @throws NullPointerException if l is null
|
|
*/
|
|
SynchronizedRandomAccessList(List<T> l)
|
|
{
|
|
super(l);
|
|
}
|
|
|
|
/**
|
|
* Called only by trusted code to specify the mutex as well as the
|
|
* collection.
|
|
* @param sync the mutex
|
|
* @param l the list
|
|
*/
|
|
SynchronizedRandomAccessList(Object sync, List<T> l)
|
|
{
|
|
super(sync, l);
|
|
}
|
|
|
|
/**
|
|
* Obtain a List view of a subsection of the underlying list, from fromIndex
|
|
* (inclusive) to toIndex (exclusive). If the two indices are equal, the
|
|
* sublist is empty. The returned list should be modifiable if and only
|
|
* if this list is modifiable. Changes to the returned list should be
|
|
* reflected in this list. If this list is structurally modified in
|
|
* any way other than through the returned list, the result of any subsequent
|
|
* operations on the returned list is undefined. A lock is obtained
|
|
* on the mutex before the creation of the sublist. The returned list
|
|
* is also synchronized, using the same mutex. Random accessibility
|
|
* is also extended to the new list.
|
|
*
|
|
* @param fromIndex the index that the returned list should start from
|
|
* (inclusive)
|
|
* @param toIndex the index that the returned list should go to (exclusive)
|
|
* @return a List backed by a subsection of this list
|
|
* @throws IndexOutOfBoundsException if fromIndex < 0
|
|
* || toIndex > size() || fromIndex > toIndex
|
|
*/
|
|
public List<T> subList(int fromIndex, int toIndex)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return new SynchronizedRandomAccessList<T>(mutex,
|
|
list.subList(fromIndex,
|
|
toIndex));
|
|
}
|
|
}
|
|
} // class SynchronizedRandomAccessList
|
|
|
|
/**
|
|
* The implementation of {@link SynchronizedList#listIterator()}. This
|
|
* iterator must "sync" on the same object as the list it iterates over.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static final class SynchronizedListIterator<T>
|
|
extends SynchronizedIterator<T> implements ListIterator<T>
|
|
{
|
|
/**
|
|
* The wrapped iterator, stored both here and in the superclass to
|
|
* avoid excessive casting.
|
|
*/
|
|
private final ListIterator<T> li;
|
|
|
|
/**
|
|
* Only trusted code creates a wrapper, with the specified sync.
|
|
* @param sync the mutex
|
|
* @param li the wrapped iterator
|
|
*/
|
|
SynchronizedListIterator(Object sync, ListIterator<T> li)
|
|
{
|
|
super(sync, li);
|
|
this.li = li;
|
|
}
|
|
|
|
/**
|
|
* Insert an element into the underlying list at the current position of
|
|
* the iterator (optional operation). The element is inserted in between
|
|
* the element that would be returned by <code>previous()</code> and the
|
|
* element that would be returned by <code>next()</code>. After the
|
|
* insertion, a subsequent call to next is unaffected, but
|
|
* a call to previous returns the item that was added. The values returned
|
|
* by nextIndex() and previousIndex() are incremented. A lock is obtained
|
|
* on the mutex before the addition takes place.
|
|
*
|
|
* @param o the object to insert into the list
|
|
* @throws ClassCastException if the object is of a type which cannot be added
|
|
* to this list.
|
|
* @throws IllegalArgumentException if some other aspect of the object stops
|
|
* it being added to this list.
|
|
* @throws UnsupportedOperationException if this ListIterator does not
|
|
* support the add operation.
|
|
*/
|
|
public void add(T o)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
li.add(o);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Tests whether there are elements remaining in the underlying list
|
|
* in the reverse direction. In other words, <code>previous()</code>
|
|
* will not fail with a NoSuchElementException. A lock is obtained
|
|
* on the mutex before the check takes place.
|
|
*
|
|
* @return <code>true</code> if the list continues in the reverse direction
|
|
*/
|
|
public boolean hasPrevious()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return li.hasPrevious();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Find the index of the element that would be returned by a call to
|
|
* <code>next()</code>. If hasNext() returns <code>false</code>, this
|
|
* returns the list size. A lock is obtained on the mutex before the
|
|
* query takes place.
|
|
*
|
|
* @return the index of the element that would be returned by next()
|
|
*/
|
|
public int nextIndex()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return li.nextIndex();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Obtain the previous element from the underlying list. Repeated
|
|
* calls to previous may be used to iterate backwards over the entire list,
|
|
* or calls to next and previous may be used together to go forwards and
|
|
* backwards. Alternating calls to next and previous will return the same
|
|
* element. A lock is obtained on the mutex before the object is retrieved.
|
|
*
|
|
* @return the next element in the list in the reverse direction
|
|
* @throws NoSuchElementException if there are no more elements
|
|
*/
|
|
public T previous()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return li.previous();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Find the index of the element that would be returned by a call to
|
|
* previous. If hasPrevious() returns <code>false</code>, this returns -1.
|
|
* A lock is obtained on the mutex before the query takes place.
|
|
*
|
|
* @return the index of the element that would be returned by previous()
|
|
*/
|
|
public int previousIndex()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return li.previousIndex();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Replace the element last returned by a call to <code>next()</code> or
|
|
* <code>previous()</code> with a given object (optional operation). This
|
|
* method may only be called if neither <code>add()</code> nor
|
|
* <code>remove()</code> have been called since the last call to
|
|
* <code>next()</code> or <code>previous</code>. A lock is obtained
|
|
* on the mutex before the list is modified.
|
|
*
|
|
* @param o the object to replace the element with
|
|
* @throws ClassCastException the object is of a type which cannot be added
|
|
* to this list
|
|
* @throws IllegalArgumentException some other aspect of the object stops
|
|
* it being added to this list
|
|
* @throws IllegalStateException if neither next or previous have been
|
|
* called, or if add or remove has been called since the last call
|
|
* to next or previous
|
|
* @throws UnsupportedOperationException if this ListIterator does not
|
|
* support the set operation
|
|
*/
|
|
public void set(T o)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
li.set(o);
|
|
}
|
|
}
|
|
} // class SynchronizedListIterator
|
|
|
|
/**
|
|
* Returns a synchronized (thread-safe) map wrapper backed by the given
|
|
* map. Notice that element access through the collection views and their
|
|
* iterators are thread-safe, but if the map can be structurally modified
|
|
* (adding or removing elements) then you should synchronize around the
|
|
* iteration to avoid non-deterministic behavior:<br>
|
|
* <pre>
|
|
* Map m = Collections.synchronizedMap(new Map(...));
|
|
* ...
|
|
* Set s = m.keySet(); // safe outside a synchronized block
|
|
* synchronized (m) // synch on m, not s
|
|
* {
|
|
* Iterator i = s.iterator();
|
|
* while (i.hasNext())
|
|
* foo(i.next());
|
|
* }
|
|
* </pre><p>
|
|
*
|
|
* The returned Map implements Serializable, but can only be serialized if
|
|
* the map it wraps is likewise Serializable.
|
|
*
|
|
* @param m the map to wrap
|
|
* @return a synchronized view of the map
|
|
* @see Serializable
|
|
*/
|
|
public static <K, V> Map<K, V> synchronizedMap(Map<K, V> m)
|
|
{
|
|
return new SynchronizedMap<K, V>(m);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #synchronizedMap(Map)}. This
|
|
* class name is required for compatibility with Sun's JDK serializability.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static class SynchronizedMap<K, V> implements Map<K, V>, Serializable
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = 1978198479659022715L;
|
|
|
|
/**
|
|
* The wrapped map.
|
|
* @serial the real map
|
|
*/
|
|
private final Map<K, V> m;
|
|
|
|
/**
|
|
* The object to synchronize on. When an instance is created via public
|
|
* methods, it will be this; but other uses like
|
|
* SynchronizedSortedMap.subMap() must specify another mutex. Package
|
|
* visible for use by subclass.
|
|
* @serial the lock
|
|
*/
|
|
final Object mutex;
|
|
|
|
/**
|
|
* Cache the entry set.
|
|
*/
|
|
private transient Set<Map.Entry<K, V>> entries;
|
|
|
|
/**
|
|
* Cache the key set.
|
|
*/
|
|
private transient Set<K> keys;
|
|
|
|
/**
|
|
* Cache the value collection.
|
|
*/
|
|
private transient Collection<V> values;
|
|
|
|
/**
|
|
* Wrap a given map.
|
|
* @param m the map to wrap
|
|
* @throws NullPointerException if m is null
|
|
*/
|
|
SynchronizedMap(Map<K, V> m)
|
|
{
|
|
this.m = m;
|
|
mutex = this;
|
|
if (m == null)
|
|
throw new NullPointerException();
|
|
}
|
|
|
|
/**
|
|
* Called only by trusted code to specify the mutex as well as the map.
|
|
* @param sync the mutex
|
|
* @param m the map
|
|
*/
|
|
SynchronizedMap(Object sync, Map<K, V> m)
|
|
{
|
|
this.m = m;
|
|
mutex = sync;
|
|
}
|
|
|
|
/**
|
|
* Clears all the entries from the underlying map. A lock is obtained
|
|
* on the mutex before the map is cleared.
|
|
*
|
|
* @throws UnsupportedOperationException if clear is not supported
|
|
*/
|
|
public void clear()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
m.clear();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns <code>true</code> if the underlying map contains a entry for the given key.
|
|
* A lock is obtained on the mutex before the map is queried.
|
|
*
|
|
* @param key the key to search for.
|
|
* @return <code>true</code> if the underlying map contains the key.
|
|
* @throws ClassCastException if the key is of an inappropriate type.
|
|
* @throws NullPointerException if key is <code>null</code> but the map
|
|
* does not permit null keys.
|
|
*/
|
|
public boolean containsKey(Object key)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return m.containsKey(key);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns <code>true</code> if the underlying map contains at least one entry with the
|
|
* given value. In other words, returns <code>true</code> if a value v exists where
|
|
* <code>(value == null ? v == null : value.equals(v))</code>. This usually
|
|
* requires linear time. A lock is obtained on the mutex before the map
|
|
* is queried.
|
|
*
|
|
* @param value the value to search for
|
|
* @return <code>true</code> if the map contains the value
|
|
* @throws ClassCastException if the type of the value is not a valid type
|
|
* for this map.
|
|
* @throws NullPointerException if the value is null and the map doesn't
|
|
* support null values.
|
|
*/
|
|
public boolean containsValue(Object value)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return m.containsValue(value);
|
|
}
|
|
}
|
|
|
|
// This is one of the ickiest cases of nesting I've ever seen. It just
|
|
// means "return a SynchronizedSet, except that the iterator() method
|
|
// returns an SynchronizedIterator whose next() method returns a
|
|
// synchronized wrapper around its normal return value".
|
|
public Set<Map.Entry<K, V>> entrySet()
|
|
{
|
|
// Define this here to spare some nesting.
|
|
class SynchronizedMapEntry<K, V> implements Map.Entry<K, V>
|
|
{
|
|
final Map.Entry<K, V> e;
|
|
SynchronizedMapEntry(Map.Entry<K, V> o)
|
|
{
|
|
e = o;
|
|
}
|
|
|
|
/**
|
|
* Returns <code>true</code> if the object, o, implements <code>Map.Entry</code>
|
|
* with the same key and value as the underlying entry. A lock is
|
|
* obtained on the mutex before the comparison takes place.
|
|
*
|
|
* @param o The object to compare with this entry.
|
|
* @return <code>true</code> if o is equivalent to the underlying map entry.
|
|
*/
|
|
public boolean equals(Object o)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return e.equals(o);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns the key used in the underlying map entry. A lock is obtained
|
|
* on the mutex before the key is retrieved.
|
|
*
|
|
* @return The key of the underlying map entry.
|
|
*/
|
|
public K getKey()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return e.getKey();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns the value used in the underlying map entry. A lock is obtained
|
|
* on the mutex before the value is retrieved.
|
|
*
|
|
* @return The value of the underlying map entry.
|
|
*/
|
|
public V getValue()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return e.getValue();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Computes the hash code for the underlying map entry.
|
|
* This computation is described in the documentation for the
|
|
* <code>Map</code> interface. A lock is obtained on the mutex
|
|
* before the underlying map is accessed.
|
|
*
|
|
* @return The hash code of the underlying map entry.
|
|
* @see Map#hashCode()
|
|
*/
|
|
public int hashCode()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return e.hashCode();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Replaces the value in the underlying map entry with the specified
|
|
* object (optional operation). A lock is obtained on the mutex
|
|
* before the map is altered. The map entry, in turn, will alter
|
|
* the underlying map object. The operation is undefined if the
|
|
* <code>remove()</code> method of the iterator has been called
|
|
* beforehand.
|
|
*
|
|
* @param value the new value to store
|
|
* @return the old value
|
|
* @throws UnsupportedOperationException if the operation is not supported.
|
|
* @throws ClassCastException if the value is of the wrong type.
|
|
* @throws IllegalArgumentException if something about the value
|
|
* prevents it from existing in this map.
|
|
* @throws NullPointerException if the map forbids null values.
|
|
*/
|
|
public V setValue(V value)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return e.setValue(value);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns a textual representation of the underlying map entry.
|
|
* A lock is obtained on the mutex before the entry is accessed.
|
|
*
|
|
* @return The contents of the map entry in <code>String</code> form.
|
|
*/
|
|
public String toString()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return e.toString();
|
|
}
|
|
}
|
|
} // class SynchronizedMapEntry
|
|
|
|
// Now the actual code.
|
|
if (entries == null)
|
|
synchronized (mutex)
|
|
{
|
|
entries = new SynchronizedSet<Map.Entry<K, V>>(mutex, m.entrySet())
|
|
{
|
|
/**
|
|
* Returns an iterator over the set. The iterator has no specific order,
|
|
* unless further specified. A lock is obtained on the set's mutex
|
|
* before the iterator is created. The created iterator is also
|
|
* thread-safe.
|
|
*
|
|
* @return A synchronized set iterator.
|
|
*/
|
|
public Iterator<Map.Entry<K, V>> iterator()
|
|
{
|
|
synchronized (super.mutex)
|
|
{
|
|
return new SynchronizedIterator<Map.Entry<K, V>>(super.mutex,
|
|
c.iterator())
|
|
{
|
|
/**
|
|
* Retrieves the next map entry from the iterator.
|
|
* A lock is obtained on the iterator's mutex before
|
|
* the entry is created. The new map entry is enclosed in
|
|
* a thread-safe wrapper.
|
|
*
|
|
* @return A synchronized map entry.
|
|
*/
|
|
public Map.Entry<K, V> next()
|
|
{
|
|
synchronized (super.mutex)
|
|
{
|
|
return new SynchronizedMapEntry<K, V>(super.next());
|
|
}
|
|
}
|
|
};
|
|
}
|
|
}
|
|
};
|
|
}
|
|
return entries;
|
|
}
|
|
|
|
/**
|
|
* Returns <code>true</code> if the object, o, is also an instance
|
|
* of <code>Map</code> and contains an equivalent
|
|
* entry set to that of the underlying map. A lock
|
|
* is obtained on the mutex before the objects are
|
|
* compared.
|
|
*
|
|
* @param o The object to compare.
|
|
* @return <code>true</code> if o and the underlying map are equivalent.
|
|
*/
|
|
public boolean equals(Object o)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return m.equals(o);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns the value associated with the given key, or null
|
|
* if no such mapping exists. An ambiguity exists with maps
|
|
* that accept null values as a return value of null could
|
|
* be due to a non-existent mapping or simply a null value
|
|
* for that key. To resolve this, <code>containsKey</code>
|
|
* should be used. A lock is obtained on the mutex before
|
|
* the value is retrieved from the underlying map.
|
|
*
|
|
* @param key The key of the required mapping.
|
|
* @return The value associated with the given key, or
|
|
* null if no such mapping exists.
|
|
* @throws ClassCastException if the key is an inappropriate type.
|
|
* @throws NullPointerException if this map does not accept null keys.
|
|
*/
|
|
public V get(Object key)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return m.get(key);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Calculates the hash code of the underlying map as the
|
|
* sum of the hash codes of all entries. A lock is obtained
|
|
* on the mutex before the hash code is computed.
|
|
*
|
|
* @return The hash code of the underlying map.
|
|
*/
|
|
public int hashCode()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return m.hashCode();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns <code>true</code> if the underlying map contains no entries.
|
|
* A lock is obtained on the mutex before the map is examined.
|
|
*
|
|
* @return <code>true</code> if the map is empty.
|
|
*/
|
|
public boolean isEmpty()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return m.isEmpty();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns a thread-safe set view of the keys in the underlying map. The
|
|
* set is backed by the map, so that changes in one show up in the other.
|
|
* Modifications made while an iterator is in progress cause undefined
|
|
* behavior. If the set supports removal, these methods remove the
|
|
* underlying mapping from the map: <code>Iterator.remove</code>,
|
|
* <code>Set.remove</code>, <code>removeAll</code>, <code>retainAll</code>,
|
|
* and <code>clear</code>. Element addition, via <code>add</code> or
|
|
* <code>addAll</code>, is not supported via this set. A lock is obtained
|
|
* on the mutex before the set is created.
|
|
*
|
|
* @return A synchronized set containing the keys of the underlying map.
|
|
*/
|
|
public Set<K> keySet()
|
|
{
|
|
if (keys == null)
|
|
synchronized (mutex)
|
|
{
|
|
keys = new SynchronizedSet<K>(mutex, m.keySet());
|
|
}
|
|
return keys;
|
|
}
|
|
|
|
/**
|
|
* Associates the given key to the given value (optional operation). If the
|
|
* underlying map already contains the key, its value is replaced. Be aware
|
|
* that in a map that permits <code>null</code> values, a null return does not
|
|
* always imply that the mapping was created. A lock is obtained on the mutex
|
|
* before the modification is made.
|
|
*
|
|
* @param key the key to map.
|
|
* @param value the value to be mapped.
|
|
* @return the previous value of the key, or null if there was no mapping
|
|
* @throws UnsupportedOperationException if the operation is not supported
|
|
* @throws ClassCastException if the key or value is of the wrong type
|
|
* @throws IllegalArgumentException if something about this key or value
|
|
* prevents it from existing in this map
|
|
* @throws NullPointerException if either the key or the value is null,
|
|
* and the map forbids null keys or values
|
|
* @see #containsKey(Object)
|
|
*/
|
|
public V put(K key, V value)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return m.put(key, value);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Copies all entries of the given map to the underlying one (optional
|
|
* operation). If the map already contains a key, its value is replaced.
|
|
* A lock is obtained on the mutex before the operation proceeds.
|
|
*
|
|
* @param map the mapping to load into this map
|
|
* @throws UnsupportedOperationException if the operation is not supported
|
|
* @throws ClassCastException if a key or value is of the wrong type
|
|
* @throws IllegalArgumentException if something about a key or value
|
|
* prevents it from existing in this map
|
|
* @throws NullPointerException if the map forbids null keys or values, or
|
|
* if <code>m</code> is null.
|
|
* @see #put(Object, Object)
|
|
*/
|
|
public void putAll(Map<? extends K, ? extends V> map)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
m.putAll(map);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Removes the mapping for the key, o, if present (optional operation). If
|
|
* the key is not present, this returns null. Note that maps which permit
|
|
* null values may also return null if the key was removed. A prior
|
|
* <code>containsKey()</code> check is required to avoid this ambiguity.
|
|
* Before the mapping is removed, a lock is obtained on the mutex.
|
|
*
|
|
* @param o the key to remove
|
|
* @return the value the key mapped to, or null if not present
|
|
* @throws UnsupportedOperationException if deletion is unsupported
|
|
* @throws NullPointerException if the key is null and this map doesn't
|
|
* support null keys.
|
|
* @throws ClassCastException if the type of the key is not a valid type
|
|
* for this map.
|
|
*/
|
|
public V remove(Object o)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return m.remove(o);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Retrieves the size of the underlying map. A lock
|
|
* is obtained on the mutex before access takes place.
|
|
* Maps with a size greater than <code>Integer.MAX_VALUE</code>
|
|
* return <code>Integer.MAX_VALUE</code> instead.
|
|
*
|
|
* @return The size of the underlying map.
|
|
*/
|
|
public int size()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return m.size();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns a textual representation of the underlying
|
|
* map. A lock is obtained on the mutex before the map
|
|
* is accessed.
|
|
*
|
|
* @return The map in <code>String</code> form.
|
|
*/
|
|
public String toString()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return m.toString();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns a synchronized collection view of the values in the underlying
|
|
* map. The collection is backed by the map, so that changes in one show up in
|
|
* the other. Modifications made while an iterator is in progress cause
|
|
* undefined behavior. If the collection supports removal, these methods
|
|
* remove the underlying mapping from the map: <code>Iterator.remove</code>,
|
|
* <code>Collection.remove</code>, <code>removeAll</code>,
|
|
* <code>retainAll</code>, and <code>clear</code>. Element addition, via
|
|
* <code>add</code> or <code>addAll</code>, is not supported via this
|
|
* collection. A lock is obtained on the mutex before the collection
|
|
* is created.
|
|
*
|
|
* @return the collection of all values in the underlying map.
|
|
*/
|
|
public Collection<V> values()
|
|
{
|
|
if (values == null)
|
|
synchronized (mutex)
|
|
{
|
|
values = new SynchronizedCollection<V>(mutex, m.values());
|
|
}
|
|
return values;
|
|
}
|
|
} // class SynchronizedMap
|
|
|
|
/**
|
|
* Returns a synchronized (thread-safe) set wrapper backed by the given
|
|
* set. Notice that element access through the iterator is thread-safe, but
|
|
* if the set can be structurally modified (adding or removing elements)
|
|
* then you should synchronize around the iteration to avoid
|
|
* non-deterministic behavior:<br>
|
|
* <pre>
|
|
* Set s = Collections.synchronizedSet(new Set(...));
|
|
* ...
|
|
* synchronized (s)
|
|
* {
|
|
* Iterator i = s.iterator();
|
|
* while (i.hasNext())
|
|
* foo(i.next());
|
|
* }
|
|
* </pre><p>
|
|
*
|
|
* The returned Set implements Serializable, but can only be serialized if
|
|
* the set it wraps is likewise Serializable.
|
|
*
|
|
* @param s the set to wrap
|
|
* @return a synchronized view of the set
|
|
* @see Serializable
|
|
*/
|
|
public static <T> Set<T> synchronizedSet(Set<T> s)
|
|
{
|
|
return new SynchronizedSet<T>(s);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #synchronizedSet(Set)}. This class
|
|
* name is required for compatibility with Sun's JDK serializability.
|
|
* Package visible, so that sets such as Hashtable.keySet()
|
|
* can specify which object to synchronize on.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
static class SynchronizedSet<T> extends SynchronizedCollection<T>
|
|
implements Set<T>
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = 487447009682186044L;
|
|
|
|
/**
|
|
* Wrap a given set.
|
|
* @param s the set to wrap
|
|
* @throws NullPointerException if s is null
|
|
*/
|
|
SynchronizedSet(Set<T> s)
|
|
{
|
|
super(s);
|
|
}
|
|
|
|
/**
|
|
* Called only by trusted code to specify the mutex as well as the set.
|
|
* @param sync the mutex
|
|
* @param s the set
|
|
*/
|
|
SynchronizedSet(Object sync, Set<T> s)
|
|
{
|
|
super(sync, s);
|
|
}
|
|
|
|
/**
|
|
* Returns <code>true</code> if the object, o, is a <code>Set</code>
|
|
* of the same size as the underlying set, and contains
|
|
* each element, e, which occurs in the underlying set.
|
|
* A lock is obtained on the mutex before the comparison
|
|
* takes place.
|
|
*
|
|
* @param o The object to compare against.
|
|
* @return <code>true</code> if o is an equivalent set.
|
|
*/
|
|
public boolean equals(Object o)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return c.equals(o);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Computes the hash code for the underlying set as the
|
|
* sum of the hash code of all elements within the set.
|
|
* A lock is obtained on the mutex before the computation
|
|
* occurs.
|
|
*
|
|
* @return The hash code for the underlying set.
|
|
*/
|
|
public int hashCode()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return c.hashCode();
|
|
}
|
|
}
|
|
} // class SynchronizedSet
|
|
|
|
/**
|
|
* Returns a synchronized (thread-safe) sorted map wrapper backed by the
|
|
* given map. Notice that element access through the collection views,
|
|
* subviews, and their iterators are thread-safe, but if the map can be
|
|
* structurally modified (adding or removing elements) then you should
|
|
* synchronize around the iteration to avoid non-deterministic behavior:<br>
|
|
* <pre>
|
|
* SortedMap m = Collections.synchronizedSortedMap(new SortedMap(...));
|
|
* ...
|
|
* Set s = m.keySet(); // safe outside a synchronized block
|
|
* SortedMap m2 = m.headMap(foo); // safe outside a synchronized block
|
|
* Set s2 = m2.keySet(); // safe outside a synchronized block
|
|
* synchronized (m) // synch on m, not m2, s or s2
|
|
* {
|
|
* Iterator i = s.iterator();
|
|
* while (i.hasNext())
|
|
* foo(i.next());
|
|
* i = s2.iterator();
|
|
* while (i.hasNext())
|
|
* bar(i.next());
|
|
* }
|
|
* </pre><p>
|
|
*
|
|
* The returned SortedMap implements Serializable, but can only be
|
|
* serialized if the map it wraps is likewise Serializable.
|
|
*
|
|
* @param m the sorted map to wrap
|
|
* @return a synchronized view of the sorted map
|
|
* @see Serializable
|
|
*/
|
|
public static <K, V> SortedMap<K, V> synchronizedSortedMap(SortedMap<K, V> m)
|
|
{
|
|
return new SynchronizedSortedMap<K, V>(m);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #synchronizedSortedMap(SortedMap)}. This
|
|
* class name is required for compatibility with Sun's JDK serializability.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static final class SynchronizedSortedMap<K, V>
|
|
extends SynchronizedMap<K, V>
|
|
implements SortedMap<K, V>
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = -8798146769416483793L;
|
|
|
|
/**
|
|
* The wrapped map; stored both here and in the superclass to avoid
|
|
* excessive casting.
|
|
* @serial the wrapped map
|
|
*/
|
|
private final SortedMap<K, V> sm;
|
|
|
|
/**
|
|
* Wrap a given map.
|
|
* @param sm the map to wrap
|
|
* @throws NullPointerException if sm is null
|
|
*/
|
|
SynchronizedSortedMap(SortedMap<K, V> sm)
|
|
{
|
|
super(sm);
|
|
this.sm = sm;
|
|
}
|
|
|
|
/**
|
|
* Called only by trusted code to specify the mutex as well as the map.
|
|
* @param sync the mutex
|
|
* @param sm the map
|
|
*/
|
|
SynchronizedSortedMap(Object sync, SortedMap<K, V> sm)
|
|
{
|
|
super(sync, sm);
|
|
this.sm = sm;
|
|
}
|
|
|
|
/**
|
|
* Returns the comparator used in sorting the underlying map, or null if
|
|
* it is the keys' natural ordering. A lock is obtained on the mutex
|
|
* before the comparator is retrieved.
|
|
*
|
|
* @return the sorting comparator.
|
|
*/
|
|
public Comparator<? super K> comparator()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return sm.comparator();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns the first, lowest sorted, key from the underlying map.
|
|
* A lock is obtained on the mutex before the map is accessed.
|
|
*
|
|
* @return the first key.
|
|
* @throws NoSuchElementException if this map is empty.
|
|
*/
|
|
public K firstKey()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return sm.firstKey();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns a submap containing the keys from the first
|
|
* key (as returned by <code>firstKey()</code>) to
|
|
* the key before that specified. The submap supports all
|
|
* operations supported by the underlying map and all actions
|
|
* taking place on the submap are also reflected in the underlying
|
|
* map. A lock is obtained on the mutex prior to submap creation.
|
|
* This operation is equivalent to <code>subMap(firstKey(), toKey)</code>.
|
|
* The submap retains the thread-safe status of this map.
|
|
*
|
|
* @param toKey the exclusive upper range of the submap.
|
|
* @return a submap from <code>firstKey()</code> to the
|
|
* the key preceding toKey.
|
|
* @throws ClassCastException if toKey is not comparable to the underlying
|
|
* map's contents.
|
|
* @throws IllegalArgumentException if toKey is outside the map's range.
|
|
* @throws NullPointerException if toKey is null. but the map does not allow
|
|
* null keys.
|
|
*/
|
|
public SortedMap<K, V> headMap(K toKey)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return new SynchronizedSortedMap<K, V>(mutex, sm.headMap(toKey));
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns the last, highest sorted, key from the underlying map.
|
|
* A lock is obtained on the mutex before the map is accessed.
|
|
*
|
|
* @return the last key.
|
|
* @throws NoSuchElementException if this map is empty.
|
|
*/
|
|
public K lastKey()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return sm.lastKey();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns a submap containing the keys from fromKey to
|
|
* the key before toKey. The submap supports all
|
|
* operations supported by the underlying map and all actions
|
|
* taking place on the submap are also reflected in the underlying
|
|
* map. A lock is obtained on the mutex prior to submap creation.
|
|
* The submap retains the thread-safe status of this map.
|
|
*
|
|
* @param fromKey the inclusive lower range of the submap.
|
|
* @param toKey the exclusive upper range of the submap.
|
|
* @return a submap from fromKey to the key preceding toKey.
|
|
* @throws ClassCastException if fromKey or toKey is not comparable
|
|
* to the underlying map's contents.
|
|
* @throws IllegalArgumentException if fromKey or toKey is outside the map's
|
|
* range.
|
|
* @throws NullPointerException if fromKey or toKey is null. but the map does
|
|
* not allow null keys.
|
|
*/
|
|
public SortedMap<K, V> subMap(K fromKey, K toKey)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return new SynchronizedSortedMap<K, V>(mutex,
|
|
sm.subMap(fromKey, toKey));
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns a submap containing all the keys from fromKey onwards.
|
|
* The submap supports all operations supported by the underlying
|
|
* map and all actions taking place on the submap are also reflected
|
|
* in the underlying map. A lock is obtained on the mutex prior to
|
|
* submap creation. The submap retains the thread-safe status of
|
|
* this map.
|
|
*
|
|
* @param fromKey the inclusive lower range of the submap.
|
|
* @return a submap from fromKey to <code>lastKey()</code>.
|
|
* @throws ClassCastException if fromKey is not comparable to the underlying
|
|
* map's contents.
|
|
* @throws IllegalArgumentException if fromKey is outside the map's range.
|
|
* @throws NullPointerException if fromKey is null. but the map does not allow
|
|
* null keys.
|
|
*/
|
|
public SortedMap<K, V> tailMap(K fromKey)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return new SynchronizedSortedMap<K, V>(mutex, sm.tailMap(fromKey));
|
|
}
|
|
}
|
|
} // class SynchronizedSortedMap
|
|
|
|
/**
|
|
* Returns a synchronized (thread-safe) sorted set wrapper backed by the
|
|
* given set. Notice that element access through the iterator and through
|
|
* subviews are thread-safe, but if the set can be structurally modified
|
|
* (adding or removing elements) then you should synchronize around the
|
|
* iteration to avoid non-deterministic behavior:<br>
|
|
* <pre>
|
|
* SortedSet s = Collections.synchronizedSortedSet(new SortedSet(...));
|
|
* ...
|
|
* SortedSet s2 = s.headSet(foo); // safe outside a synchronized block
|
|
* synchronized (s) // synch on s, not s2
|
|
* {
|
|
* Iterator i = s2.iterator();
|
|
* while (i.hasNext())
|
|
* foo(i.next());
|
|
* }
|
|
* </pre><p>
|
|
*
|
|
* The returned SortedSet implements Serializable, but can only be
|
|
* serialized if the set it wraps is likewise Serializable.
|
|
*
|
|
* @param s the sorted set to wrap
|
|
* @return a synchronized view of the sorted set
|
|
* @see Serializable
|
|
*/
|
|
public static <T> SortedSet<T> synchronizedSortedSet(SortedSet<T> s)
|
|
{
|
|
return new SynchronizedSortedSet<T>(s);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #synchronizedSortedSet(SortedSet)}. This
|
|
* class name is required for compatibility with Sun's JDK serializability.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static final class SynchronizedSortedSet<T>
|
|
extends SynchronizedSet<T>
|
|
implements SortedSet<T>
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = 8695801310862127406L;
|
|
|
|
/**
|
|
* The wrapped set; stored both here and in the superclass to avoid
|
|
* excessive casting.
|
|
* @serial the wrapped set
|
|
*/
|
|
private final SortedSet<T> ss;
|
|
|
|
/**
|
|
* Wrap a given set.
|
|
* @param ss the set to wrap
|
|
* @throws NullPointerException if ss is null
|
|
*/
|
|
SynchronizedSortedSet(SortedSet<T> ss)
|
|
{
|
|
super(ss);
|
|
this.ss = ss;
|
|
}
|
|
|
|
/**
|
|
* Called only by trusted code to specify the mutex as well as the set.
|
|
* @param sync the mutex
|
|
* @param ss the set
|
|
*/
|
|
SynchronizedSortedSet(Object sync, SortedSet<T> ss)
|
|
{
|
|
super(sync, ss);
|
|
this.ss = ss;
|
|
}
|
|
|
|
/**
|
|
* Returns the comparator used in sorting the underlying set, or null if
|
|
* it is the elements' natural ordering. A lock is obtained on the mutex
|
|
* before the comparator is retrieved.
|
|
*
|
|
* @return the sorting comparator.
|
|
*/
|
|
public Comparator<? super T> comparator()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return ss.comparator();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns the first, lowest sorted, element from the underlying set.
|
|
* A lock is obtained on the mutex before the set is accessed.
|
|
*
|
|
* @return the first element.
|
|
* @throws NoSuchElementException if this set is empty.
|
|
*/
|
|
public T first()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return ss.first();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns a subset containing the element from the first
|
|
* element (as returned by <code>first()</code>) to
|
|
* the element before that specified. The subset supports all
|
|
* operations supported by the underlying set and all actions
|
|
* taking place on the subset are also reflected in the underlying
|
|
* set. A lock is obtained on the mutex prior to subset creation.
|
|
* This operation is equivalent to <code>subSet(first(), toElement)</code>.
|
|
* The subset retains the thread-safe status of this set.
|
|
*
|
|
* @param toElement the exclusive upper range of the subset.
|
|
* @return a subset from <code>first()</code> to the
|
|
* the element preceding toElement.
|
|
* @throws ClassCastException if toElement is not comparable to the underlying
|
|
* set's contents.
|
|
* @throws IllegalArgumentException if toElement is outside the set's range.
|
|
* @throws NullPointerException if toElement is null. but the set does not allow
|
|
* null elements.
|
|
*/
|
|
public SortedSet<T> headSet(T toElement)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return new SynchronizedSortedSet<T>(mutex, ss.headSet(toElement));
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns the last, highest sorted, element from the underlying set.
|
|
* A lock is obtained on the mutex before the set is accessed.
|
|
*
|
|
* @return the last element.
|
|
* @throws NoSuchElementException if this set is empty.
|
|
*/
|
|
public T last()
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return ss.last();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns a subset containing the elements from fromElement to
|
|
* the element before toElement. The subset supports all
|
|
* operations supported by the underlying set and all actions
|
|
* taking place on the subset are also reflected in the underlying
|
|
* set. A lock is obtained on the mutex prior to subset creation.
|
|
* The subset retains the thread-safe status of this set.
|
|
*
|
|
* @param fromElement the inclusive lower range of the subset.
|
|
* @param toElement the exclusive upper range of the subset.
|
|
* @return a subset from fromElement to the element preceding toElement.
|
|
* @throws ClassCastException if fromElement or toElement is not comparable
|
|
* to the underlying set's contents.
|
|
* @throws IllegalArgumentException if fromElement or toElement is outside the set's
|
|
* range.
|
|
* @throws NullPointerException if fromElement or toElement is null. but the set does
|
|
* not allow null elements.
|
|
*/
|
|
public SortedSet<T> subSet(T fromElement, T toElement)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return new SynchronizedSortedSet<T>(mutex,
|
|
ss.subSet(fromElement,
|
|
toElement));
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns a subset containing all the elements from fromElement onwards.
|
|
* The subset supports all operations supported by the underlying
|
|
* set and all actions taking place on the subset are also reflected
|
|
* in the underlying set. A lock is obtained on the mutex prior to
|
|
* subset creation. The subset retains the thread-safe status of
|
|
* this set.
|
|
*
|
|
* @param fromElement the inclusive lower range of the subset.
|
|
* @return a subset from fromElement to <code>last()</code>.
|
|
* @throws ClassCastException if fromElement is not comparable to the underlying
|
|
* set's contents.
|
|
* @throws IllegalArgumentException if fromElement is outside the set's range.
|
|
* @throws NullPointerException if fromElement is null. but the set does not allow
|
|
* null elements.
|
|
*/
|
|
public SortedSet<T> tailSet(T fromElement)
|
|
{
|
|
synchronized (mutex)
|
|
{
|
|
return new SynchronizedSortedSet<T>(mutex, ss.tailSet(fromElement));
|
|
}
|
|
}
|
|
} // class SynchronizedSortedSet
|
|
|
|
|
|
/**
|
|
* Returns an unmodifiable view of the given collection. This allows
|
|
* "read-only" access, although changes in the backing collection show up
|
|
* in this view. Attempts to modify the collection directly or via iterators
|
|
* will fail with {@link UnsupportedOperationException}. Although this view
|
|
* prevents changes to the structure of the collection and its elements, the values
|
|
* referenced by the objects in the collection can still be modified.
|
|
* <p>
|
|
*
|
|
* Since the collection might be a List or a Set, and those have incompatible
|
|
* equals and hashCode requirements, this relies on Object's implementation
|
|
* rather than passing those calls on to the wrapped collection. The returned
|
|
* Collection implements Serializable, but can only be serialized if
|
|
* the collection it wraps is likewise Serializable.
|
|
*
|
|
* @param c the collection to wrap
|
|
* @return a read-only view of the collection
|
|
* @see Serializable
|
|
*/
|
|
public static <T> Collection<T> unmodifiableCollection(Collection<? extends T> c)
|
|
{
|
|
return new UnmodifiableCollection<T>(c);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #unmodifiableCollection(Collection)}. This
|
|
* class name is required for compatibility with Sun's JDK serializability.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static class UnmodifiableCollection<T>
|
|
implements Collection<T>, Serializable
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = 1820017752578914078L;
|
|
|
|
/**
|
|
* The wrapped collection. Package visible for use by subclasses.
|
|
* @serial the real collection
|
|
*/
|
|
final Collection<? extends T> c;
|
|
|
|
/**
|
|
* Wrap a given collection.
|
|
* @param c the collection to wrap
|
|
* @throws NullPointerException if c is null
|
|
*/
|
|
UnmodifiableCollection(Collection<? extends T> c)
|
|
{
|
|
this.c = c;
|
|
if (c == null)
|
|
throw new NullPointerException();
|
|
}
|
|
|
|
/**
|
|
* Blocks the addition of elements to the underlying collection.
|
|
* This method never returns, throwing an exception instead.
|
|
*
|
|
* @param o the object to add.
|
|
* @return <code>true</code> if the collection was modified as a result of this action.
|
|
* @throws UnsupportedOperationException as an unmodifiable collection does not
|
|
* support the add operation.
|
|
*/
|
|
public boolean add(T o)
|
|
{
|
|
throw new UnsupportedOperationException();
|
|
}
|
|
|
|
/**
|
|
* Blocks the addition of a collection of elements to the underlying
|
|
* collection. This method never returns, throwing an exception instead.
|
|
*
|
|
* @param c the collection to add.
|
|
* @return <code>true</code> if the collection was modified as a result of this action.
|
|
* @throws UnsupportedOperationException as an unmodifiable collection does not
|
|
* support the <code>addAll</code> operation.
|
|
*/
|
|
public boolean addAll(Collection<? extends T> c)
|
|
{
|
|
throw new UnsupportedOperationException();
|
|
}
|
|
|
|
/**
|
|
* Blocks the clearing of the underlying collection. This method never
|
|
* returns, throwing an exception instead.
|
|
*
|
|
* @throws UnsupportedOperationException as an unmodifiable collection does
|
|
* not support the <code>clear()</code> operation.
|
|
*/
|
|
public void clear()
|
|
{
|
|
throw new UnsupportedOperationException();
|
|
}
|
|
|
|
/**
|
|
* Test whether the underlying collection contains a given object as one of its
|
|
* elements.
|
|
*
|
|
* @param o the element to look for.
|
|
* @return <code>true</code> if the underlying collection contains at least
|
|
* one element e such that
|
|
* <code>o == null ? e == null : o.equals(e)</code>.
|
|
* @throws ClassCastException if the type of o is not a valid type for the
|
|
* underlying collection.
|
|
* @throws NullPointerException if o is null and the underlying collection
|
|
* doesn't support null values.
|
|
*/
|
|
public boolean contains(Object o)
|
|
{
|
|
return c.contains(o);
|
|
}
|
|
|
|
/**
|
|
* Test whether the underlying collection contains every element in a given
|
|
* collection.
|
|
*
|
|
* @param c1 the collection to test for.
|
|
* @return <code>true</code> if for every element o in c, contains(o) would
|
|
* return <code>true</code>.
|
|
* @throws ClassCastException if the type of any element in c is not a valid
|
|
* type for the underlying collection.
|
|
* @throws NullPointerException if some element of c is null and the underlying
|
|
* collection does not support null values.
|
|
* @throws NullPointerException if c itself is null.
|
|
*/
|
|
public boolean containsAll(Collection<?> c1)
|
|
{
|
|
return c.containsAll(c1);
|
|
}
|
|
|
|
/**
|
|
* Tests whether the underlying collection is empty, that is,
|
|
* if size() == 0.
|
|
*
|
|
* @return <code>true</code> if this collection contains no elements.
|
|
*/
|
|
public boolean isEmpty()
|
|
{
|
|
return c.isEmpty();
|
|
}
|
|
|
|
/**
|
|
* Obtain an Iterator over the underlying collection, which maintains
|
|
* its unmodifiable nature.
|
|
*
|
|
* @return an UnmodifiableIterator over the elements of the underlying
|
|
* collection, in any order.
|
|
*/
|
|
public Iterator<T> iterator()
|
|
{
|
|
return new UnmodifiableIterator<T>(c.iterator());
|
|
}
|
|
|
|
/**
|
|
* Blocks the removal of an object from the underlying collection.
|
|
* This method never returns, throwing an exception instead.
|
|
*
|
|
* @param o The object to remove.
|
|
* @return <code>true</code> if the object was removed (i.e. the underlying
|
|
* collection returned 1 or more instances of o).
|
|
* @throws UnsupportedOperationException as an unmodifiable collection
|
|
* does not support the <code>remove()</code> operation.
|
|
*/
|
|
public boolean remove(Object o)
|
|
{
|
|
throw new UnsupportedOperationException();
|
|
}
|
|
|
|
/**
|
|
* Blocks the removal of a collection of objects from the underlying
|
|
* collection. This method never returns, throwing an exception
|
|
* instead.
|
|
*
|
|
* @param c The collection of objects to remove.
|
|
* @return <code>true</code> if the collection was modified.
|
|
* @throws UnsupportedOperationException as an unmodifiable collection
|
|
* does not support the <code>removeAll()</code> operation.
|
|
*/
|
|
public boolean removeAll(Collection<?> c)
|
|
{
|
|
throw new UnsupportedOperationException();
|
|
}
|
|
|
|
/**
|
|
* Blocks the removal of all elements from the underlying collection,
|
|
* except those in the supplied collection. This method never returns,
|
|
* throwing an exception instead.
|
|
*
|
|
* @param c The collection of objects to retain.
|
|
* @return <code>true</code> if the collection was modified.
|
|
* @throws UnsupportedOperationException as an unmodifiable collection
|
|
* does not support the <code>retainAll()</code> operation.
|
|
*/
|
|
public boolean retainAll(Collection<?> c)
|
|
{
|
|
throw new UnsupportedOperationException();
|
|
}
|
|
|
|
/**
|
|
* Retrieves the number of elements in the underlying collection.
|
|
*
|
|
* @return the number of elements in the collection.
|
|
*/
|
|
public int size()
|
|
{
|
|
return c.size();
|
|
}
|
|
|
|
/**
|
|
* Copy the current contents of the underlying collection into an array.
|
|
*
|
|
* @return an array of type Object[] with a length equal to the size of the
|
|
* underlying collection and containing the elements currently in
|
|
* the underlying collection, in any order.
|
|
*/
|
|
public Object[] toArray()
|
|
{
|
|
return c.toArray();
|
|
}
|
|
|
|
/**
|
|
* Copy the current contents of the underlying collection into an array. If
|
|
* the array passed as an argument has length less than the size of the
|
|
* underlying collection, an array of the same run-time type as a, with a length
|
|
* equal to the size of the underlying collection, is allocated using reflection.
|
|
* Otherwise, a itself is used. The elements of the underlying collection are
|
|
* copied into it, and if there is space in the array, the following element is
|
|
* set to null. The resultant array is returned.
|
|
* Note: The fact that the following element is set to null is only useful
|
|
* if it is known that this collection does not contain any null elements.
|
|
*
|
|
* @param a the array to copy this collection into.
|
|
* @return an array containing the elements currently in the underlying
|
|
* collection, in any order.
|
|
* @throws ArrayStoreException if the type of any element of the
|
|
* collection is not a subtype of the element type of a.
|
|
*/
|
|
public <S> S[] toArray(S[] a)
|
|
{
|
|
return c.toArray(a);
|
|
}
|
|
|
|
/**
|
|
* A textual representation of the unmodifiable collection.
|
|
*
|
|
* @return The unmodifiable collection in the form of a <code>String</code>.
|
|
*/
|
|
public String toString()
|
|
{
|
|
return c.toString();
|
|
}
|
|
} // class UnmodifiableCollection
|
|
|
|
/**
|
|
* The implementation of the various iterator methods in the
|
|
* unmodifiable classes.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static class UnmodifiableIterator<T> implements Iterator<T>
|
|
{
|
|
/**
|
|
* The wrapped iterator.
|
|
*/
|
|
private final Iterator<? extends T> i;
|
|
|
|
/**
|
|
* Only trusted code creates a wrapper.
|
|
* @param i the wrapped iterator
|
|
*/
|
|
UnmodifiableIterator(Iterator<? extends T> i)
|
|
{
|
|
this.i = i;
|
|
}
|
|
|
|
/**
|
|
* Obtains the next element in the underlying collection.
|
|
*
|
|
* @return the next element in the collection.
|
|
* @throws NoSuchElementException if there are no more elements.
|
|
*/
|
|
public T next()
|
|
{
|
|
return i.next();
|
|
}
|
|
|
|
/**
|
|
* Tests whether there are still elements to be retrieved from the
|
|
* underlying collection by <code>next()</code>. When this method
|
|
* returns <code>true</code>, an exception will not be thrown on calling
|
|
* <code>next()</code>.
|
|
*
|
|
* @return <code>true</code> if there is at least one more element in the underlying
|
|
* collection.
|
|
*/
|
|
public boolean hasNext()
|
|
{
|
|
return i.hasNext();
|
|
}
|
|
|
|
/**
|
|
* Blocks the removal of elements from the underlying collection by the
|
|
* iterator.
|
|
*
|
|
* @throws UnsupportedOperationException as an unmodifiable collection
|
|
* does not support the removal of elements by its iterator.
|
|
*/
|
|
public void remove()
|
|
{
|
|
throw new UnsupportedOperationException();
|
|
}
|
|
} // class UnmodifiableIterator
|
|
|
|
/**
|
|
* Returns an unmodifiable view of the given list. This allows
|
|
* "read-only" access, although changes in the backing list show up
|
|
* in this view. Attempts to modify the list directly, via iterators, or
|
|
* via sublists, will fail with {@link UnsupportedOperationException}.
|
|
* Although this view prevents changes to the structure of the list and
|
|
* its elements, the values referenced by the objects in the list can
|
|
* still be modified.
|
|
* <p>
|
|
*
|
|
* The returned List implements Serializable, but can only be serialized if
|
|
* the list it wraps is likewise Serializable. In addition, if the wrapped
|
|
* list implements RandomAccess, this does too.
|
|
*
|
|
* @param l the list to wrap
|
|
* @return a read-only view of the list
|
|
* @see Serializable
|
|
* @see RandomAccess
|
|
*/
|
|
public static <T> List<T> unmodifiableList(List<? extends T> l)
|
|
{
|
|
if (l instanceof RandomAccess)
|
|
return new UnmodifiableRandomAccessList<T>(l);
|
|
return new UnmodifiableList<T>(l);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #unmodifiableList(List)} for sequential
|
|
* lists. This class name is required for compatibility with Sun's JDK
|
|
* serializability.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static class UnmodifiableList<T> extends UnmodifiableCollection<T>
|
|
implements List<T>
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = -283967356065247728L;
|
|
|
|
|
|
/**
|
|
* The wrapped list; stored both here and in the superclass to avoid
|
|
* excessive casting. Package visible for use by subclass.
|
|
* @serial the wrapped list
|
|
*/
|
|
final List<T> list;
|
|
|
|
/**
|
|
* Wrap a given list.
|
|
* @param l the list to wrap
|
|
* @throws NullPointerException if l is null
|
|
*/
|
|
UnmodifiableList(List<? extends T> l)
|
|
{
|
|
super(l);
|
|
list = (List<T>) l;
|
|
}
|
|
|
|
/**
|
|
* Blocks the addition of an element to the underlying
|
|
* list at a specific index. This method never returns,
|
|
* throwing an exception instead.
|
|
*
|
|
* @param index The index at which to place the new element.
|
|
* @param o the object to add.
|
|
* @throws UnsupportedOperationException as an unmodifiable
|
|
* list doesn't support the <code>add()</code> operation.
|
|
*/
|
|
public void add(int index, T o)
|
|
{
|
|
throw new UnsupportedOperationException();
|
|
}
|
|
|
|
/**
|
|
* Blocks the addition of a collection of elements to the
|
|
* underlying list at a specific index. This method never
|
|
* returns, throwing an exception instead.
|
|
*
|
|
* @param index The index at which to place the new element.
|
|
* @param c the collections of objects to add.
|
|
* @throws UnsupportedOperationException as an unmodifiable
|
|
* list doesn't support the <code>addAll()</code> operation.
|
|
*/
|
|
public boolean addAll(int index, Collection<? extends T> c)
|
|
{
|
|
throw new UnsupportedOperationException();
|
|
}
|
|
|
|
/**
|
|
* Returns <code>true</code> if the object, o, is an instance of
|
|
* <code>List</code> with the same size and elements
|
|
* as the underlying list.
|
|
*
|
|
* @param o The object to compare.
|
|
* @return <code>true</code> if o is equivalent to the underlying list.
|
|
*/
|
|
public boolean equals(Object o)
|
|
{
|
|
return list.equals(o);
|
|
}
|
|
|
|
/**
|
|
* Retrieves the element at a given index in the underlying list.
|
|
*
|
|
* @param index the index of the element to be returned
|
|
* @return the element at index index in this list
|
|
* @throws IndexOutOfBoundsException if index < 0 || index >= size()
|
|
*/
|
|
public T get(int index)
|
|
{
|
|
return list.get(index);
|
|
}
|
|
|
|
/**
|
|
* Computes the hash code for the underlying list.
|
|
* The exact computation is described in the documentation
|
|
* of the <code>List</code> interface.
|
|
*
|
|
* @return The hash code of the underlying list.
|
|
* @see List#hashCode()
|
|
*/
|
|
public int hashCode()
|
|
{
|
|
return list.hashCode();
|
|
}
|
|
|
|
/**
|
|
* Obtain the first index at which a given object is to be found in the
|
|
* underlying list.
|
|
*
|
|
* @param o the object to search for
|
|
* @return the least integer n such that <code>o == null ? get(n) == null :
|
|
* o.equals(get(n))</code>, or -1 if there is no such index.
|
|
* @throws ClassCastException if the type of o is not a valid
|
|
* type for the underlying list.
|
|
* @throws NullPointerException if o is null and the underlying
|
|
* list does not support null values.
|
|
*/
|
|
public int indexOf(Object o)
|
|
{
|
|
return list.indexOf(o);
|
|
}
|
|
|
|
/**
|
|
* Obtain the last index at which a given object is to be found in the
|
|
* underlying list.
|
|
*
|
|
* @return the greatest integer n such that <code>o == null ? get(n) == null
|
|
* : o.equals(get(n))</code>, or -1 if there is no such index.
|
|
* @throws ClassCastException if the type of o is not a valid
|
|
* type for the underlying list.
|
|
* @throws NullPointerException if o is null and the underlying
|
|
* list does not support null values.
|
|
*/
|
|
public int lastIndexOf(Object o)
|
|
{
|
|
return list.lastIndexOf(o);
|
|
}
|
|
|
|
/**
|
|
* Obtains a list iterator over the underlying list, starting at the beginning
|
|
* and maintaining the unmodifiable nature of this list.
|
|
*
|
|
* @return a <code>UnmodifiableListIterator</code> over the elements of the
|
|
* underlying list, in order, starting at the beginning.
|
|
*/
|
|
public ListIterator<T> listIterator()
|
|
{
|
|
return new UnmodifiableListIterator<T>(list.listIterator());
|
|
}
|
|
|
|
/**
|
|
* Obtains a list iterator over the underlying list, starting at the specified
|
|
* index and maintaining the unmodifiable nature of this list. An initial call
|
|
* to <code>next()</code> will retrieve the element at the specified index,
|
|
* and an initial call to <code>previous()</code> will retrieve the element
|
|
* at index - 1.
|
|
*
|
|
*
|
|
* @param index the position, between 0 and size() inclusive, to begin the
|
|
* iteration from.
|
|
* @return a <code>UnmodifiableListIterator</code> over the elements of the
|
|
* underlying list, in order, starting at the specified index.
|
|
* @throws IndexOutOfBoundsException if index < 0 || index > size()
|
|
*/
|
|
public ListIterator<T> listIterator(int index)
|
|
{
|
|
return new UnmodifiableListIterator<T>(list.listIterator(index));
|
|
}
|
|
|
|
/**
|
|
* Blocks the removal of the element at the specified index.
|
|
* This method never returns, throwing an exception instead.
|
|
*
|
|
* @param index The index of the element to remove.
|
|
* @return the removed element.
|
|
* @throws UnsupportedOperationException as an unmodifiable
|
|
* list does not support the <code>remove()</code>
|
|
* operation.
|
|
*/
|
|
public T remove(int index)
|
|
{
|
|
throw new UnsupportedOperationException();
|
|
}
|
|
|
|
/**
|
|
* Blocks the replacement of the element at the specified index.
|
|
* This method never returns, throwing an exception instead.
|
|
*
|
|
* @param index The index of the element to replace.
|
|
* @param o The new object to place at the specified index.
|
|
* @return the replaced element.
|
|
* @throws UnsupportedOperationException as an unmodifiable
|
|
* list does not support the <code>set()</code>
|
|
* operation.
|
|
*/
|
|
public T set(int index, T o)
|
|
{
|
|
throw new UnsupportedOperationException();
|
|
}
|
|
|
|
/**
|
|
* Obtain a List view of a subsection of the underlying list, from
|
|
* fromIndex (inclusive) to toIndex (exclusive). If the two indices
|
|
* are equal, the sublist is empty. The returned list will be
|
|
* unmodifiable, like this list. Changes to the elements of the
|
|
* returned list will be reflected in the underlying list. No structural
|
|
* modifications can take place in either list.
|
|
*
|
|
* @param fromIndex the index that the returned list should start from
|
|
* (inclusive).
|
|
* @param toIndex the index that the returned list should go to (exclusive).
|
|
* @return a List backed by a subsection of the underlying list.
|
|
* @throws IndexOutOfBoundsException if fromIndex < 0
|
|
* || toIndex > size() || fromIndex > toIndex.
|
|
*/
|
|
public List<T> subList(int fromIndex, int toIndex)
|
|
{
|
|
return unmodifiableList(list.subList(fromIndex, toIndex));
|
|
}
|
|
} // class UnmodifiableList
|
|
|
|
/**
|
|
* The implementation of {@link #unmodifiableList(List)} for random-access
|
|
* lists. This class name is required for compatibility with Sun's JDK
|
|
* serializability.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static final class UnmodifiableRandomAccessList<T>
|
|
extends UnmodifiableList<T> implements RandomAccess
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = -2542308836966382001L;
|
|
|
|
/**
|
|
* Wrap a given list.
|
|
* @param l the list to wrap
|
|
* @throws NullPointerException if l is null
|
|
*/
|
|
UnmodifiableRandomAccessList(List<? extends T> l)
|
|
{
|
|
super(l);
|
|
}
|
|
} // class UnmodifiableRandomAccessList
|
|
|
|
/**
|
|
* The implementation of {@link UnmodifiableList#listIterator()}.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static final class UnmodifiableListIterator<T>
|
|
extends UnmodifiableIterator<T> implements ListIterator<T>
|
|
{
|
|
/**
|
|
* The wrapped iterator, stored both here and in the superclass to
|
|
* avoid excessive casting.
|
|
*/
|
|
private final ListIterator<T> li;
|
|
|
|
/**
|
|
* Only trusted code creates a wrapper.
|
|
* @param li the wrapped iterator
|
|
*/
|
|
UnmodifiableListIterator(ListIterator<T> li)
|
|
{
|
|
super(li);
|
|
this.li = li;
|
|
}
|
|
|
|
/**
|
|
* Blocks the addition of an object to the list underlying this iterator.
|
|
* This method never returns, throwing an exception instead.
|
|
*
|
|
* @param o The object to add.
|
|
* @throws UnsupportedOperationException as the iterator of an unmodifiable
|
|
* list does not support the <code>add()</code> operation.
|
|
*/
|
|
public void add(T o)
|
|
{
|
|
throw new UnsupportedOperationException();
|
|
}
|
|
|
|
/**
|
|
* Tests whether there are still elements to be retrieved from the
|
|
* underlying collection by <code>previous()</code>. When this method
|
|
* returns <code>true</code>, an exception will not be thrown on calling
|
|
* <code>previous()</code>.
|
|
*
|
|
* @return <code>true</code> if there is at least one more element prior to the
|
|
* current position in the underlying list.
|
|
*/
|
|
public boolean hasPrevious()
|
|
{
|
|
return li.hasPrevious();
|
|
}
|
|
|
|
/**
|
|
* Find the index of the element that would be returned by a call to next.
|
|
* If <code>hasNext()</code> returns <code>false</code>, this returns the list size.
|
|
*
|
|
* @return the index of the element that would be returned by
|
|
* <code>next()</code>.
|
|
*/
|
|
public int nextIndex()
|
|
{
|
|
return li.nextIndex();
|
|
}
|
|
|
|
/**
|
|
* Obtains the previous element in the underlying list.
|
|
*
|
|
* @return the previous element in the list.
|
|
* @throws NoSuchElementException if there are no more prior elements.
|
|
*/
|
|
public T previous()
|
|
{
|
|
return li.previous();
|
|
}
|
|
|
|
/**
|
|
* Find the index of the element that would be returned by a call to
|
|
* previous. If <code>hasPrevious()</code> returns <code>false</code>,
|
|
* this returns -1.
|
|
*
|
|
* @return the index of the element that would be returned by
|
|
* <code>previous()</code>.
|
|
*/
|
|
public int previousIndex()
|
|
{
|
|
return li.previousIndex();
|
|
}
|
|
|
|
/**
|
|
* Blocks the replacement of an element in the list underlying this
|
|
* iterator. This method never returns, throwing an exception instead.
|
|
*
|
|
* @param o The new object to replace the existing one.
|
|
* @throws UnsupportedOperationException as the iterator of an unmodifiable
|
|
* list does not support the <code>set()</code> operation.
|
|
*/
|
|
public void set(T o)
|
|
{
|
|
throw new UnsupportedOperationException();
|
|
}
|
|
} // class UnmodifiableListIterator
|
|
|
|
/**
|
|
* Returns an unmodifiable view of the given map. This allows "read-only"
|
|
* access, although changes in the backing map show up in this view.
|
|
* Attempts to modify the map directly, or via collection views or their
|
|
* iterators will fail with {@link UnsupportedOperationException}.
|
|
* Although this view prevents changes to the structure of the map and its
|
|
* entries, the values referenced by the objects in the map can still be
|
|
* modified.
|
|
* <p>
|
|
*
|
|
* The returned Map implements Serializable, but can only be serialized if
|
|
* the map it wraps is likewise Serializable.
|
|
*
|
|
* @param m the map to wrap
|
|
* @return a read-only view of the map
|
|
* @see Serializable
|
|
*/
|
|
public static <K, V> Map<K, V> unmodifiableMap(Map<? extends K,
|
|
? extends V> m)
|
|
{
|
|
return new UnmodifiableMap<K, V>(m);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #unmodifiableMap(Map)}. This
|
|
* class name is required for compatibility with Sun's JDK serializability.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static class UnmodifiableMap<K, V> implements Map<K, V>, Serializable
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = -1034234728574286014L;
|
|
|
|
/**
|
|
* The wrapped map.
|
|
* @serial the real map
|
|
*/
|
|
private final Map<K, V> m;
|
|
|
|
/**
|
|
* Cache the entry set.
|
|
*/
|
|
private transient Set<Map.Entry<K, V>> entries;
|
|
|
|
/**
|
|
* Cache the key set.
|
|
*/
|
|
private transient Set<K> keys;
|
|
|
|
/**
|
|
* Cache the value collection.
|
|
*/
|
|
private transient Collection<V> values;
|
|
|
|
/**
|
|
* Wrap a given map.
|
|
* @param m the map to wrap
|
|
* @throws NullPointerException if m is null
|
|
*/
|
|
UnmodifiableMap(Map<? extends K, ? extends V> m)
|
|
{
|
|
this.m = (Map<K,V>) m;
|
|
if (m == null)
|
|
throw new NullPointerException();
|
|
}
|
|
|
|
/**
|
|
* Blocks the clearing of entries from the underlying map.
|
|
* This method never returns, throwing an exception instead.
|
|
*
|
|
* @throws UnsupportedOperationException as an unmodifiable
|
|
* map does not support the <code>clear()</code> operation.
|
|
*/
|
|
public void clear()
|
|
{
|
|
throw new UnsupportedOperationException();
|
|
}
|
|
|
|
/**
|
|
* Returns <code>true</code> if the underlying map contains a mapping for
|
|
* the given key.
|
|
*
|
|
* @param key the key to search for
|
|
* @return <code>true</code> if the map contains the key
|
|
* @throws ClassCastException if the key is of an inappropriate type
|
|
* @throws NullPointerException if key is <code>null</code> but the map
|
|
* does not permit null keys
|
|
*/
|
|
public boolean containsKey(Object key)
|
|
{
|
|
return m.containsKey(key);
|
|
}
|
|
|
|
/**
|
|
* Returns <code>true</code> if the underlying map contains at least one mapping with
|
|
* the given value. In other words, it returns <code>true</code> if a value v exists where
|
|
* <code>(value == null ? v == null : value.equals(v))</code>. This usually
|
|
* requires linear time.
|
|
*
|
|
* @param value the value to search for
|
|
* @return <code>true</code> if the map contains the value
|
|
* @throws ClassCastException if the type of the value is not a valid type
|
|
* for this map.
|
|
* @throws NullPointerException if the value is null and the map doesn't
|
|
* support null values.
|
|
*/
|
|
public boolean containsValue(Object value)
|
|
{
|
|
return m.containsValue(value);
|
|
}
|
|
|
|
/**
|
|
* Returns a unmodifiable set view of the entries in the underlying map.
|
|
* Each element in the set is a unmodifiable variant of <code>Map.Entry</code>.
|
|
* The set is backed by the map, so that changes in one show up in the other.
|
|
* Modifications made while an iterator is in progress cause undefined
|
|
* behavior. These modifications are again limited to the values of
|
|
* the objects.
|
|
*
|
|
* @return the unmodifiable set view of all mapping entries.
|
|
* @see Map.Entry
|
|
*/
|
|
public Set<Map.Entry<K, V>> entrySet()
|
|
{
|
|
if (entries == null)
|
|
entries = new UnmodifiableEntrySet<K,V>(m.entrySet());
|
|
return entries;
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link UnmodifiableMap#entrySet()}. This class
|
|
* name is required for compatibility with Sun's JDK serializability.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static final class UnmodifiableEntrySet<K,V>
|
|
extends UnmodifiableSet<Map.Entry<K,V>>
|
|
implements Serializable
|
|
{
|
|
// Unmodifiable implementation of Map.Entry used as return value for
|
|
// UnmodifiableEntrySet accessors (iterator, toArray, toArray(Object[]))
|
|
private static final class UnmodifiableMapEntry<K,V>
|
|
implements Map.Entry<K,V>
|
|
{
|
|
private final Map.Entry<K,V> e;
|
|
|
|
private UnmodifiableMapEntry(Map.Entry<K,V> e)
|
|
{
|
|
super();
|
|
this.e = e;
|
|
}
|
|
|
|
/**
|
|
* Returns <code>true</code> if the object, o, is also a map entry
|
|
* with an identical key and value.
|
|
*
|
|
* @param o the object to compare.
|
|
* @return <code>true</code> if o is an equivalent map entry.
|
|
*/
|
|
public boolean equals(Object o)
|
|
{
|
|
return e.equals(o);
|
|
}
|
|
|
|
/**
|
|
* Returns the key of this map entry.
|
|
*
|
|
* @return the key.
|
|
*/
|
|
public K getKey()
|
|
{
|
|
return e.getKey();
|
|
}
|
|
|
|
/**
|
|
* Returns the value of this map entry.
|
|
*
|
|
* @return the value.
|
|
*/
|
|
public V getValue()
|
|
{
|
|
return e.getValue();
|
|
}
|
|
|
|
/**
|
|
* Computes the hash code of this map entry. The computation is
|
|
* described in the <code>Map</code> interface documentation.
|
|
*
|
|
* @return the hash code of this entry.
|
|
* @see Map#hashCode()
|
|
*/
|
|
public int hashCode()
|
|
{
|
|
return e.hashCode();
|
|
}
|
|
|
|
/**
|
|
* Blocks the alteration of the value of this map entry. This method
|
|
* never returns, throwing an exception instead.
|
|
*
|
|
* @param value The new value.
|
|
* @throws UnsupportedOperationException as an unmodifiable map entry
|
|
* does not support the <code>setValue()</code> operation.
|
|
*/
|
|
public V setValue(V value)
|
|
{
|
|
throw new UnsupportedOperationException();
|
|
}
|
|
|
|
/**
|
|
* Returns a textual representation of the map entry.
|
|
*
|
|
* @return The map entry as a <code>String</code>.
|
|
*/
|
|
public String toString()
|
|
{
|
|
return e.toString();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = 7854390611657943733L;
|
|
|
|
/**
|
|
* Wrap a given set.
|
|
* @param s the set to wrap
|
|
*/
|
|
UnmodifiableEntrySet(Set<Map.Entry<K,V>> s)
|
|
{
|
|
super(s);
|
|
}
|
|
|
|
// The iterator must return unmodifiable map entries.
|
|
public Iterator<Map.Entry<K,V>> iterator()
|
|
{
|
|
return new UnmodifiableIterator<Map.Entry<K,V>>(c.iterator())
|
|
{
|
|
/**
|
|
* Obtains the next element from the underlying set of
|
|
* map entries.
|
|
*
|
|
* @return the next element in the collection.
|
|
* @throws NoSuchElementException if there are no more elements.
|
|
*/
|
|
public Map.Entry<K,V> next()
|
|
{
|
|
final Map.Entry<K,V> e = super.next();
|
|
return new UnmodifiableMapEntry<K,V>(e);
|
|
}
|
|
};
|
|
}
|
|
|
|
// The array returned is an array of UnmodifiableMapEntry instead of
|
|
// Map.Entry
|
|
public Object[] toArray()
|
|
{
|
|
Object[] mapEntryResult = super.toArray();
|
|
UnmodifiableMapEntry<K,V> result[] = null;
|
|
|
|
if (mapEntryResult != null)
|
|
{
|
|
result = (UnmodifiableMapEntry<K,V>[])
|
|
new UnmodifiableMapEntry[mapEntryResult.length];
|
|
for (int i = 0; i < mapEntryResult.length; ++i)
|
|
result[i] = new UnmodifiableMapEntry<K,V>((Map.Entry<K,V>)mapEntryResult[i]);
|
|
}
|
|
return result;
|
|
}
|
|
|
|
// The array returned is an array of UnmodifiableMapEntry instead of
|
|
// Map.Entry
|
|
public <S> S[] toArray(S[] array)
|
|
{
|
|
S[] result = super.toArray(array);
|
|
|
|
if (result != null)
|
|
for (int i = 0; i < result.length; i++)
|
|
array[i] =
|
|
(S) new UnmodifiableMapEntry<K,V>((Map.Entry<K,V>) result[i]);
|
|
return array;
|
|
}
|
|
|
|
|
|
} // class UnmodifiableEntrySet
|
|
|
|
/**
|
|
* Returns <code>true</code> if the object, o, is also an instance
|
|
* of <code>Map</code> with an equal set of map entries.
|
|
*
|
|
* @param o The object to compare.
|
|
* @return <code>true</code> if o is an equivalent map.
|
|
*/
|
|
public boolean equals(Object o)
|
|
{
|
|
return m.equals(o);
|
|
}
|
|
|
|
/**
|
|
* Returns the value associated with the supplied key or
|
|
* null if no such mapping exists. An ambiguity can occur
|
|
* if null values are accepted by the underlying map.
|
|
* In this case, <code>containsKey()</code> can be used
|
|
* to separate the two possible cases of a null result.
|
|
*
|
|
* @param key The key to look up.
|
|
* @return the value associated with the key, or null if key not in map.
|
|
* @throws ClassCastException if the key is an inappropriate type.
|
|
* @throws NullPointerException if this map does not accept null keys.
|
|
* @see #containsKey(Object)
|
|
*/
|
|
public V get(Object key)
|
|
{
|
|
return m.get(key);
|
|
}
|
|
|
|
/**
|
|
* Blocks the addition of a new entry to the underlying map.
|
|
* This method never returns, throwing an exception instead.
|
|
*
|
|
* @param key The new key.
|
|
* @param value The new value.
|
|
* @return the previous value of the key, or null if there was no mapping.
|
|
* @throws UnsupportedOperationException as an unmodifiable
|
|
* map does not support the <code>put()</code> operation.
|
|
*/
|
|
public V put(K key, V value)
|
|
{
|
|
throw new UnsupportedOperationException();
|
|
}
|
|
|
|
/**
|
|
* Computes the hash code for the underlying map, as the sum
|
|
* of the hash codes of all entries.
|
|
*
|
|
* @return The hash code of the underlying map.
|
|
* @see Map.Entry#hashCode()
|
|
*/
|
|
public int hashCode()
|
|
{
|
|
return m.hashCode();
|
|
}
|
|
|
|
/**
|
|
* Returns <code>true</code> if the underlying map contains no entries.
|
|
*
|
|
* @return <code>true</code> if the map is empty.
|
|
*/
|
|
public boolean isEmpty()
|
|
{
|
|
return m.isEmpty();
|
|
}
|
|
|
|
/**
|
|
* Returns a unmodifiable set view of the keys in the underlying map.
|
|
* The set is backed by the map, so that changes in one show up in the other.
|
|
* Modifications made while an iterator is in progress cause undefined
|
|
* behavior. These modifications are again limited to the values of
|
|
* the keys.
|
|
*
|
|
* @return the set view of all keys.
|
|
*/
|
|
public Set<K> keySet()
|
|
{
|
|
if (keys == null)
|
|
keys = new UnmodifiableSet<K>(m.keySet());
|
|
return keys;
|
|
}
|
|
|
|
/**
|
|
* Blocks the addition of the entries in the supplied map.
|
|
* This method never returns, throwing an exception instead.
|
|
*
|
|
* @param m The map, the entries of which should be added
|
|
* to the underlying map.
|
|
* @throws UnsupportedOperationException as an unmodifiable
|
|
* map does not support the <code>putAll</code> operation.
|
|
*/
|
|
public void putAll(Map<? extends K, ? extends V> m)
|
|
{
|
|
throw new UnsupportedOperationException();
|
|
}
|
|
|
|
/**
|
|
* Blocks the removal of an entry from the map.
|
|
* This method never returns, throwing an exception instead.
|
|
*
|
|
* @param o The key of the entry to remove.
|
|
* @return The value the key was associated with, or null
|
|
* if no such mapping existed. Null is also returned
|
|
* if the removed entry had a null key.
|
|
* @throws UnsupportedOperationException as an unmodifiable
|
|
* map does not support the <code>remove</code> operation.
|
|
*/
|
|
public V remove(Object o)
|
|
{
|
|
throw new UnsupportedOperationException();
|
|
}
|
|
|
|
|
|
/**
|
|
* Returns the number of key-value mappings in the underlying map.
|
|
* If there are more than Integer.MAX_VALUE mappings, Integer.MAX_VALUE
|
|
* is returned.
|
|
*
|
|
* @return the number of mappings.
|
|
*/
|
|
public int size()
|
|
{
|
|
return m.size();
|
|
}
|
|
|
|
/**
|
|
* Returns a textual representation of the map.
|
|
*
|
|
* @return The map in the form of a <code>String</code>.
|
|
*/
|
|
public String toString()
|
|
{
|
|
return m.toString();
|
|
}
|
|
|
|
/**
|
|
* Returns a unmodifiable collection view of the values in the underlying map.
|
|
* The collection is backed by the map, so that changes in one show up in the other.
|
|
* Modifications made while an iterator is in progress cause undefined
|
|
* behavior. These modifications are again limited to the values of
|
|
* the keys.
|
|
*
|
|
* @return the collection view of all values.
|
|
*/
|
|
public Collection<V> values()
|
|
{
|
|
if (values == null)
|
|
values = new UnmodifiableCollection<V>(m.values());
|
|
return values;
|
|
}
|
|
} // class UnmodifiableMap
|
|
|
|
/**
|
|
* Returns an unmodifiable view of the given set. This allows
|
|
* "read-only" access, although changes in the backing set show up
|
|
* in this view. Attempts to modify the set directly or via iterators
|
|
* will fail with {@link UnsupportedOperationException}.
|
|
* Although this view prevents changes to the structure of the set and its
|
|
* entries, the values referenced by the objects in the set can still be
|
|
* modified.
|
|
* <p>
|
|
*
|
|
* The returned Set implements Serializable, but can only be serialized if
|
|
* the set it wraps is likewise Serializable.
|
|
*
|
|
* @param s the set to wrap
|
|
* @return a read-only view of the set
|
|
* @see Serializable
|
|
*/
|
|
public static <T> Set<T> unmodifiableSet(Set<? extends T> s)
|
|
{
|
|
return new UnmodifiableSet<T>(s);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #unmodifiableSet(Set)}. This class
|
|
* name is required for compatibility with Sun's JDK serializability.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static class UnmodifiableSet<T> extends UnmodifiableCollection<T>
|
|
implements Set<T>
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = -9215047833775013803L;
|
|
|
|
/**
|
|
* Wrap a given set.
|
|
* @param s the set to wrap
|
|
* @throws NullPointerException if s is null
|
|
*/
|
|
UnmodifiableSet(Set<? extends T> s)
|
|
{
|
|
super(s);
|
|
}
|
|
|
|
/**
|
|
* Returns <code>true</code> if the object, o, is also an instance of
|
|
* <code>Set</code> of the same size and with the same entries.
|
|
*
|
|
* @return <code>true</code> if o is an equivalent set.
|
|
*/
|
|
public boolean equals(Object o)
|
|
{
|
|
return c.equals(o);
|
|
}
|
|
|
|
/**
|
|
* Computes the hash code of this set, as the sum of the
|
|
* hash codes of all elements within the set.
|
|
*
|
|
* @return the hash code of the set.
|
|
*/
|
|
public int hashCode()
|
|
{
|
|
return c.hashCode();
|
|
}
|
|
} // class UnmodifiableSet
|
|
|
|
/**
|
|
* Returns an unmodifiable view of the given sorted map. This allows
|
|
* "read-only" access, although changes in the backing map show up in this
|
|
* view. Attempts to modify the map directly, via subviews, via collection
|
|
* views, or iterators, will fail with {@link UnsupportedOperationException}.
|
|
* Although this view prevents changes to the structure of the map and its
|
|
* entries, the values referenced by the objects in the map can still be
|
|
* modified.
|
|
* <p>
|
|
*
|
|
* The returned SortedMap implements Serializable, but can only be
|
|
* serialized if the map it wraps is likewise Serializable.
|
|
*
|
|
* @param m the map to wrap
|
|
* @return a read-only view of the map
|
|
* @see Serializable
|
|
*/
|
|
public static <K, V> SortedMap<K, V> unmodifiableSortedMap(SortedMap<K,
|
|
? extends V> m)
|
|
{
|
|
return new UnmodifiableSortedMap<K, V>(m);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #unmodifiableSortedMap(SortedMap)}. This
|
|
* class name is required for compatibility with Sun's JDK serializability.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static class UnmodifiableSortedMap<K, V>
|
|
extends UnmodifiableMap<K, V>
|
|
implements SortedMap<K, V>
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = -8806743815996713206L;
|
|
|
|
/**
|
|
* The wrapped map; stored both here and in the superclass to avoid
|
|
* excessive casting.
|
|
* @serial the wrapped map
|
|
*/
|
|
private final SortedMap<K, V> sm;
|
|
|
|
/**
|
|
* Wrap a given map.
|
|
* @param sm the map to wrap
|
|
* @throws NullPointerException if sm is null
|
|
*/
|
|
UnmodifiableSortedMap(SortedMap<K, ? extends V> sm)
|
|
{
|
|
super(sm);
|
|
this.sm = (SortedMap<K,V>) sm;
|
|
}
|
|
|
|
/**
|
|
* Returns the comparator used in sorting the underlying map,
|
|
* or null if it is the keys' natural ordering.
|
|
*
|
|
* @return the sorting comparator.
|
|
*/
|
|
public Comparator<? super K> comparator()
|
|
{
|
|
return sm.comparator();
|
|
}
|
|
|
|
/**
|
|
* Returns the first (lowest sorted) key in the map.
|
|
*
|
|
* @return the first key.
|
|
* @throws NoSuchElementException if this map is empty.
|
|
*/
|
|
public K firstKey()
|
|
{
|
|
return sm.firstKey();
|
|
}
|
|
|
|
/**
|
|
* Returns a unmodifiable view of the portion of the map strictly less
|
|
* than toKey. The view is backed by the underlying map, so changes in
|
|
* one show up in the other. The submap supports all optional operations
|
|
* of the original. This operation is equivalent to
|
|
* <code>subMap(firstKey(), toKey)</code>.
|
|
* <p>
|
|
*
|
|
* The returned map throws an IllegalArgumentException any time a key is
|
|
* used which is out of the range of toKey. Note that the endpoint, toKey,
|
|
* is not included; if you want this value to be included, pass its successor
|
|
* object in to toKey. For example, for Integers, you could request
|
|
* <code>headMap(new Integer(limit.intValue() + 1))</code>.
|
|
*
|
|
* @param toKey the exclusive upper range of the submap.
|
|
* @return the submap.
|
|
* @throws ClassCastException if toKey is not comparable to the map contents.
|
|
* @throws IllegalArgumentException if this is a subMap, and toKey is out
|
|
* of range.
|
|
* @throws NullPointerException if toKey is null but the map does not allow
|
|
* null keys.
|
|
*/
|
|
public SortedMap<K, V> headMap(K toKey)
|
|
{
|
|
return new UnmodifiableSortedMap<K, V>(sm.headMap(toKey));
|
|
}
|
|
|
|
/**
|
|
* Returns the last (highest sorted) key in the map.
|
|
*
|
|
* @return the last key.
|
|
* @throws NoSuchElementException if this map is empty.
|
|
*/
|
|
public K lastKey()
|
|
{
|
|
return sm.lastKey();
|
|
}
|
|
|
|
/**
|
|
* Returns a unmodifiable view of the portion of the map greater than or
|
|
* equal to fromKey, and strictly less than toKey. The view is backed by
|
|
* the underlying map, so changes in one show up in the other. The submap
|
|
* supports all optional operations of the original.
|
|
* <p>
|
|
*
|
|
* The returned map throws an IllegalArgumentException any time a key is
|
|
* used which is out of the range of fromKey and toKey. Note that the
|
|
* lower endpoint is included, but the upper is not; if you want to
|
|
* change the inclusion or exclusion of an endpoint, pass its successor
|
|
* object in instead. For example, for Integers, you could request
|
|
* <code>subMap(new Integer(lowlimit.intValue() + 1),
|
|
* new Integer(highlimit.intValue() + 1))</code> to reverse
|
|
* the inclusiveness of both endpoints.
|
|
*
|
|
* @param fromKey the inclusive lower range of the submap.
|
|
* @param toKey the exclusive upper range of the submap.
|
|
* @return the submap.
|
|
* @throws ClassCastException if fromKey or toKey is not comparable to
|
|
* the map contents.
|
|
* @throws IllegalArgumentException if this is a subMap, and fromKey or
|
|
* toKey is out of range.
|
|
* @throws NullPointerException if fromKey or toKey is null but the map
|
|
* does not allow null keys.
|
|
*/
|
|
public SortedMap<K, V> subMap(K fromKey, K toKey)
|
|
{
|
|
return new UnmodifiableSortedMap<K, V>(sm.subMap(fromKey, toKey));
|
|
}
|
|
|
|
/**
|
|
* Returns a unmodifiable view of the portion of the map greater than or
|
|
* equal to fromKey. The view is backed by the underlying map, so changes
|
|
* in one show up in the other. The submap supports all optional operations
|
|
* of the original.
|
|
* <p>
|
|
*
|
|
* The returned map throws an IllegalArgumentException any time a key is
|
|
* used which is out of the range of fromKey. Note that the endpoint, fromKey, is
|
|
* included; if you do not want this value to be included, pass its successor object in
|
|
* to fromKey. For example, for Integers, you could request
|
|
* <code>tailMap(new Integer(limit.intValue() + 1))</code>.
|
|
*
|
|
* @param fromKey the inclusive lower range of the submap
|
|
* @return the submap
|
|
* @throws ClassCastException if fromKey is not comparable to the map
|
|
* contents
|
|
* @throws IllegalArgumentException if this is a subMap, and fromKey is out
|
|
* of range
|
|
* @throws NullPointerException if fromKey is null but the map does not allow
|
|
* null keys
|
|
*/
|
|
public SortedMap<K, V> tailMap(K fromKey)
|
|
{
|
|
return new UnmodifiableSortedMap<K, V>(sm.tailMap(fromKey));
|
|
}
|
|
} // class UnmodifiableSortedMap
|
|
|
|
/**
|
|
* Returns an unmodifiable view of the given sorted set. This allows
|
|
* "read-only" access, although changes in the backing set show up
|
|
* in this view. Attempts to modify the set directly, via subsets, or via
|
|
* iterators, will fail with {@link UnsupportedOperationException}.
|
|
* Although this view prevents changes to the structure of the set and its
|
|
* entries, the values referenced by the objects in the set can still be
|
|
* modified.
|
|
* <p>
|
|
*
|
|
* The returns SortedSet implements Serializable, but can only be
|
|
* serialized if the set it wraps is likewise Serializable.
|
|
*
|
|
* @param s the set to wrap
|
|
* @return a read-only view of the set
|
|
* @see Serializable
|
|
*/
|
|
public static <T> SortedSet<T> unmodifiableSortedSet(SortedSet<T> s)
|
|
{
|
|
return new UnmodifiableSortedSet<T>(s);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #synchronizedSortedMap(SortedMap)}. This
|
|
* class name is required for compatibility with Sun's JDK serializability.
|
|
*
|
|
* @author Eric Blake (ebb9@email.byu.edu)
|
|
*/
|
|
private static class UnmodifiableSortedSet<T> extends UnmodifiableSet<T>
|
|
implements SortedSet<T>
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = -4929149591599911165L;
|
|
|
|
/**
|
|
* The wrapped set; stored both here and in the superclass to avoid
|
|
* excessive casting.
|
|
* @serial the wrapped set
|
|
*/
|
|
private SortedSet<T> ss;
|
|
|
|
/**
|
|
* Wrap a given set.
|
|
* @param ss the set to wrap
|
|
* @throws NullPointerException if ss is null
|
|
*/
|
|
UnmodifiableSortedSet(SortedSet<T> ss)
|
|
{
|
|
super(ss);
|
|
this.ss = ss;
|
|
}
|
|
|
|
/**
|
|
* Returns the comparator used in sorting the underlying set,
|
|
* or null if it is the elements' natural ordering.
|
|
*
|
|
* @return the sorting comparator
|
|
*/
|
|
public Comparator<? super T> comparator()
|
|
{
|
|
return ss.comparator();
|
|
}
|
|
|
|
/**
|
|
* Returns the first (lowest sorted) element in the underlying
|
|
* set.
|
|
*
|
|
* @return the first element.
|
|
* @throws NoSuchElementException if the set is empty.
|
|
*/
|
|
public T first()
|
|
{
|
|
return ss.first();
|
|
}
|
|
|
|
/**
|
|
* Returns a unmodifiable view of the portion of the set strictly
|
|
* less than toElement. The view is backed by the underlying set,
|
|
* so changes in one show up in the other. The subset supports
|
|
* all optional operations of the original. This operation
|
|
* is equivalent to <code>subSet(first(), toElement)</code>.
|
|
* <p>
|
|
*
|
|
* The returned set throws an IllegalArgumentException any time an element is
|
|
* used which is out of the range of toElement. Note that the endpoint, toElement,
|
|
* is not included; if you want this value included, pass its successor object in to
|
|
* toElement. For example, for Integers, you could request
|
|
* <code>headSet(new Integer(limit.intValue() + 1))</code>.
|
|
*
|
|
* @param toElement the exclusive upper range of the subset
|
|
* @return the subset.
|
|
* @throws ClassCastException if toElement is not comparable to the set
|
|
* contents.
|
|
* @throws IllegalArgumentException if this is a subSet, and toElement is out
|
|
* of range.
|
|
* @throws NullPointerException if toElement is null but the set does not
|
|
* allow null elements.
|
|
*/
|
|
public SortedSet<T> headSet(T toElement)
|
|
{
|
|
return new UnmodifiableSortedSet<T>(ss.headSet(toElement));
|
|
}
|
|
|
|
/**
|
|
* Returns the last (highest sorted) element in the underlying
|
|
* set.
|
|
*
|
|
* @return the last element.
|
|
* @throws NoSuchElementException if the set is empty.
|
|
*/
|
|
public T last()
|
|
{
|
|
return ss.last();
|
|
}
|
|
|
|
/**
|
|
* Returns a unmodifiable view of the portion of the set greater than or
|
|
* equal to fromElement, and strictly less than toElement. The view is backed by
|
|
* the underlying set, so changes in one show up in the other. The subset
|
|
* supports all optional operations of the original.
|
|
* <p>
|
|
*
|
|
* The returned set throws an IllegalArgumentException any time an element is
|
|
* used which is out of the range of fromElement and toElement. Note that the
|
|
* lower endpoint is included, but the upper is not; if you want to
|
|
* change the inclusion or exclusion of an endpoint, pass its successor
|
|
* object in instead. For example, for Integers, you can request
|
|
* <code>subSet(new Integer(lowlimit.intValue() + 1),
|
|
* new Integer(highlimit.intValue() + 1))</code> to reverse
|
|
* the inclusiveness of both endpoints.
|
|
*
|
|
* @param fromElement the inclusive lower range of the subset.
|
|
* @param toElement the exclusive upper range of the subset.
|
|
* @return the subset.
|
|
* @throws ClassCastException if fromElement or toElement is not comparable
|
|
* to the set contents.
|
|
* @throws IllegalArgumentException if this is a subSet, and fromElement or
|
|
* toElement is out of range.
|
|
* @throws NullPointerException if fromElement or toElement is null but the
|
|
* set does not allow null elements.
|
|
*/
|
|
public SortedSet<T> subSet(T fromElement, T toElement)
|
|
{
|
|
return new UnmodifiableSortedSet<T>(ss.subSet(fromElement, toElement));
|
|
}
|
|
|
|
/**
|
|
* Returns a unmodifiable view of the portion of the set greater than or equal to
|
|
* fromElement. The view is backed by the underlying set, so changes in one show up
|
|
* in the other. The subset supports all optional operations of the original.
|
|
* <p>
|
|
*
|
|
* The returned set throws an IllegalArgumentException any time an element is
|
|
* used which is out of the range of fromElement. Note that the endpoint,
|
|
* fromElement, is included; if you do not want this value to be included, pass its
|
|
* successor object in to fromElement. For example, for Integers, you could request
|
|
* <code>tailSet(new Integer(limit.intValue() + 1))</code>.
|
|
*
|
|
* @param fromElement the inclusive lower range of the subset
|
|
* @return the subset.
|
|
* @throws ClassCastException if fromElement is not comparable to the set
|
|
* contents.
|
|
* @throws IllegalArgumentException if this is a subSet, and fromElement is
|
|
* out of range.
|
|
* @throws NullPointerException if fromElement is null but the set does not
|
|
* allow null elements.
|
|
*/
|
|
public SortedSet<T> tailSet(T fromElement)
|
|
{
|
|
return new UnmodifiableSortedSet<T>(ss.tailSet(fromElement));
|
|
}
|
|
} // class UnmodifiableSortedSet
|
|
|
|
/**
|
|
* <p>
|
|
* Returns a dynamically typesafe view of the given collection,
|
|
* where any modification is first checked to ensure that the type
|
|
* of the new data is appropriate. Although the addition of
|
|
* generics and parametrically-typed collections prevents an
|
|
* incorrect type of element being added to a collection at
|
|
* compile-time, via static type checking, this can be overridden by
|
|
* casting. In contrast, wrapping the collection within a
|
|
* dynamically-typesafe wrapper, using this and associated methods,
|
|
* <emph>guarantees</emph> that the collection will only contain
|
|
* elements of an appropriate type (provided it only contains such
|
|
* at the type of wrapping, and all subsequent access is via the
|
|
* wrapper). This can be useful for debugging the cause of a
|
|
* <code>ClassCastException</code> caused by erroneous casting, or
|
|
* for protecting collections from corruption by external libraries.
|
|
* </p>
|
|
* <p>
|
|
* Since the collection might be a List or a Set, and those
|
|
* have incompatible equals and hashCode requirements, this relies
|
|
* on Object's implementation rather than passing those calls on to
|
|
* the wrapped collection. The returned Collection implements
|
|
* Serializable, but can only be serialized if the collection it
|
|
* wraps is likewise Serializable.
|
|
* </p>
|
|
*
|
|
* @param c the collection to wrap in a dynamically typesafe wrapper
|
|
* @param type the type of elements the collection should hold.
|
|
* @return a dynamically typesafe view of the collection.
|
|
* @see Serializable
|
|
* @since 1.5
|
|
*/
|
|
public static <E> Collection<E> checkedCollection(Collection<E> c,
|
|
Class<E> type)
|
|
{
|
|
return new CheckedCollection<E>(c, type);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #checkedCollection(Collection,Class)}. This
|
|
* class name is required for compatibility with Sun's JDK serializability.
|
|
*
|
|
* @author Andrew John Hughes (gnu_andrew@member.fsf.org)
|
|
* @since 1.5
|
|
*/
|
|
private static class CheckedCollection<E>
|
|
implements Collection<E>, Serializable
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.5.
|
|
*/
|
|
private static final long serialVersionUID = 1578914078182001775L;
|
|
|
|
/**
|
|
* The wrapped collection. Package visible for use by subclasses.
|
|
* @serial the real collection
|
|
*/
|
|
final Collection<E> c;
|
|
|
|
/**
|
|
* The type of the elements of this collection.
|
|
* @serial the element type.
|
|
*/
|
|
final Class<E> type;
|
|
|
|
/**
|
|
* Wrap a given collection.
|
|
* @param c the collection to wrap
|
|
* @param type the type to wrap
|
|
* @throws NullPointerException if c is null
|
|
*/
|
|
CheckedCollection(Collection<E> c, Class<E> type)
|
|
{
|
|
this.c = c;
|
|
this.type = type;
|
|
if (c == null)
|
|
throw new NullPointerException();
|
|
}
|
|
|
|
/**
|
|
* Adds the supplied object to the collection, on the condition that
|
|
* it is of the correct type.
|
|
*
|
|
* @param o the object to add.
|
|
* @return <code>true</code> if the collection was modified as a result
|
|
* of this action.
|
|
* @throws ClassCastException if the object is not of the correct type.
|
|
*/
|
|
public boolean add(E o)
|
|
{
|
|
if (type.isInstance(o))
|
|
return c.add(o);
|
|
else
|
|
throw new ClassCastException("The element is of the incorrect type.");
|
|
}
|
|
|
|
/**
|
|
* Adds the elements of the specified collection to the backing collection,
|
|
* provided they are all of the correct type.
|
|
*
|
|
* @param coll the collection to add.
|
|
* @return <code>true</code> if the collection was modified as a result
|
|
* of this action.
|
|
* @throws ClassCastException if <code>c</code> contained elements of an
|
|
* incorrect type.
|
|
*/
|
|
public boolean addAll(Collection<? extends E> coll)
|
|
{
|
|
Collection<E> typedColl = (Collection<E>) c;
|
|
final Iterator<E> it = typedColl.iterator();
|
|
while (it.hasNext())
|
|
{
|
|
final E element = it.next();
|
|
if (!type.isInstance(element))
|
|
throw new ClassCastException("A member of the collection is not of the correct type.");
|
|
}
|
|
return c.addAll(typedColl);
|
|
}
|
|
|
|
/**
|
|
* Removes all elements from the underlying collection.
|
|
*/
|
|
public void clear()
|
|
{
|
|
c.clear();
|
|
}
|
|
|
|
/**
|
|
* Test whether the underlying collection contains a given object as one
|
|
* of its elements.
|
|
*
|
|
* @param o the element to look for.
|
|
* @return <code>true</code> if the underlying collection contains at least
|
|
* one element e such that
|
|
* <code>o == null ? e == null : o.equals(e)</code>.
|
|
* @throws ClassCastException if the type of o is not a valid type for the
|
|
* underlying collection.
|
|
* @throws NullPointerException if o is null and the underlying collection
|
|
* doesn't support null values.
|
|
*/
|
|
public boolean contains(Object o)
|
|
{
|
|
return c.contains(o);
|
|
}
|
|
|
|
/**
|
|
* Test whether the underlying collection contains every element in a given
|
|
* collection.
|
|
*
|
|
* @param coll the collection to test for.
|
|
* @return <code>true</code> if for every element o in c, contains(o) would
|
|
* return <code>true</code>.
|
|
* @throws ClassCastException if the type of any element in c is not a
|
|
* valid type for the underlying collection.
|
|
* @throws NullPointerException if some element of c is null and the
|
|
* underlying collection does not support
|
|
* null values.
|
|
* @throws NullPointerException if c itself is null.
|
|
*/
|
|
public boolean containsAll(Collection<?> coll)
|
|
{
|
|
return c.containsAll(coll);
|
|
}
|
|
|
|
/**
|
|
* Tests whether the underlying collection is empty, that is,
|
|
* if size() == 0.
|
|
*
|
|
* @return <code>true</code> if this collection contains no elements.
|
|
*/
|
|
public boolean isEmpty()
|
|
{
|
|
return c.isEmpty();
|
|
}
|
|
|
|
/**
|
|
* Obtain an Iterator over the underlying collection, which maintains
|
|
* its checked nature.
|
|
*
|
|
* @return a Iterator over the elements of the underlying
|
|
* collection, in any order.
|
|
*/
|
|
public Iterator<E> iterator()
|
|
{
|
|
return new CheckedIterator<E>(c.iterator(), type);
|
|
}
|
|
|
|
/**
|
|
* Removes the supplied object from the collection, if it exists.
|
|
*
|
|
* @param o The object to remove.
|
|
* @return <code>true</code> if the object was removed (i.e. the underlying
|
|
* collection returned 1 or more instances of o).
|
|
*/
|
|
public boolean remove(Object o)
|
|
{
|
|
return c.remove(o);
|
|
}
|
|
|
|
/**
|
|
* Removes all objects in the supplied collection from the backing
|
|
* collection, if they exist within it.
|
|
*
|
|
* @param coll the collection of objects to remove.
|
|
* @return <code>true</code> if the collection was modified.
|
|
*/
|
|
public boolean removeAll(Collection<?> coll)
|
|
{
|
|
return c.removeAll(coll);
|
|
}
|
|
|
|
/**
|
|
* Retains all objects specified by the supplied collection which exist
|
|
* within the backing collection, and removes all others.
|
|
*
|
|
* @param coll the collection of objects to retain.
|
|
* @return <code>true</code> if the collection was modified.
|
|
*/
|
|
public boolean retainAll(Collection<?> coll)
|
|
{
|
|
return c.retainAll(coll);
|
|
}
|
|
|
|
/**
|
|
* Retrieves the number of elements in the underlying collection.
|
|
*
|
|
* @return the number of elements in the collection.
|
|
*/
|
|
public int size()
|
|
{
|
|
return c.size();
|
|
}
|
|
|
|
/**
|
|
* Copy the current contents of the underlying collection into an array.
|
|
*
|
|
* @return an array of type Object[] with a length equal to the size of the
|
|
* underlying collection and containing the elements currently in
|
|
* the underlying collection, in any order.
|
|
*/
|
|
public Object[] toArray()
|
|
{
|
|
return c.toArray();
|
|
}
|
|
|
|
/**
|
|
* <p>
|
|
* Copy the current contents of the underlying collection into an array. If
|
|
* the array passed as an argument has length less than the size of the
|
|
* underlying collection, an array of the same run-time type as a, with a
|
|
* length equal to the size of the underlying collection, is allocated
|
|
* using reflection.
|
|
* </p>
|
|
* <p>
|
|
* Otherwise, a itself is used. The elements of the underlying collection
|
|
* are copied into it, and if there is space in the array, the following
|
|
* element is set to null. The resultant array is returned.
|
|
* </p>
|
|
* <p>
|
|
* <emph>Note</emph>: The fact that the following element is set to null
|
|
* is only useful if it is known that this collection does not contain
|
|
* any null elements.
|
|
*
|
|
* @param a the array to copy this collection into.
|
|
* @return an array containing the elements currently in the underlying
|
|
* collection, in any order.
|
|
* @throws ArrayStoreException if the type of any element of the
|
|
* collection is not a subtype of the element type of a.
|
|
*/
|
|
public <S> S[] toArray(S[] a)
|
|
{
|
|
return c.toArray(a);
|
|
}
|
|
|
|
/**
|
|
* A textual representation of the unmodifiable collection.
|
|
*
|
|
* @return The checked collection in the form of a <code>String</code>.
|
|
*/
|
|
public String toString()
|
|
{
|
|
return c.toString();
|
|
}
|
|
} // class CheckedCollection
|
|
|
|
/**
|
|
* The implementation of the various iterator methods in the
|
|
* checked classes.
|
|
*
|
|
* @author Andrew John Hughes (gnu_andrew@member.fsf.org)
|
|
* @since 1.5
|
|
*/
|
|
private static class CheckedIterator<E>
|
|
implements Iterator<E>
|
|
{
|
|
/**
|
|
* The wrapped iterator.
|
|
*/
|
|
private final Iterator<E> i;
|
|
|
|
/**
|
|
* The type of the elements of this collection.
|
|
* @serial the element type.
|
|
*/
|
|
final Class<E> type;
|
|
|
|
/**
|
|
* Only trusted code creates a wrapper.
|
|
* @param i the wrapped iterator
|
|
* @param type the type of the elements within the checked list.
|
|
*/
|
|
CheckedIterator(Iterator<E> i, Class<E> type)
|
|
{
|
|
this.i = i;
|
|
this.type = type;
|
|
}
|
|
|
|
/**
|
|
* Obtains the next element in the underlying collection.
|
|
*
|
|
* @return the next element in the collection.
|
|
* @throws NoSuchElementException if there are no more elements.
|
|
*/
|
|
public E next()
|
|
{
|
|
return i.next();
|
|
}
|
|
|
|
/**
|
|
* Tests whether there are still elements to be retrieved from the
|
|
* underlying collection by <code>next()</code>. When this method
|
|
* returns <code>true</code>, an exception will not be thrown on calling
|
|
* <code>next()</code>.
|
|
*
|
|
* @return <code>true</code> if there is at least one more element in the
|
|
* underlying collection.
|
|
*/
|
|
public boolean hasNext()
|
|
{
|
|
return i.hasNext();
|
|
}
|
|
|
|
/**
|
|
* Removes the next element from the collection.
|
|
*/
|
|
public void remove()
|
|
{
|
|
i.remove();
|
|
}
|
|
} // class CheckedIterator
|
|
|
|
/**
|
|
* <p>
|
|
* Returns a dynamically typesafe view of the given list,
|
|
* where any modification is first checked to ensure that the type
|
|
* of the new data is appropriate. Although the addition of
|
|
* generics and parametrically-typed collections prevents an
|
|
* incorrect type of element being added to a collection at
|
|
* compile-time, via static type checking, this can be overridden by
|
|
* casting. In contrast, wrapping the collection within a
|
|
* dynamically-typesafe wrapper, using this and associated methods,
|
|
* <emph>guarantees</emph> that the collection will only contain
|
|
* elements of an appropriate type (provided it only contains such
|
|
* at the type of wrapping, and all subsequent access is via the
|
|
* wrapper). This can be useful for debugging the cause of a
|
|
* <code>ClassCastException</code> caused by erroneous casting, or
|
|
* for protecting collections from corruption by external libraries.
|
|
* </p>
|
|
* <p>
|
|
* The returned List implements Serializable, but can only be serialized if
|
|
* the list it wraps is likewise Serializable. In addition, if the wrapped
|
|
* list implements RandomAccess, this does too.
|
|
* </p>
|
|
*
|
|
* @param l the list to wrap
|
|
* @param type the type of the elements within the checked list.
|
|
* @return a dynamically typesafe view of the list
|
|
* @see Serializable
|
|
* @see RandomAccess
|
|
*/
|
|
public static <E> List<E> checkedList(List<E> l, Class<E> type)
|
|
{
|
|
if (l instanceof RandomAccess)
|
|
return new CheckedRandomAccessList<E>(l, type);
|
|
return new CheckedList<E>(l, type);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #checkedList(List,Class)} for sequential
|
|
* lists. This class name is required for compatibility with Sun's JDK
|
|
* serializability.
|
|
*
|
|
* @author Andrew John Hughes (gnu_andrew@member.fsf.org)
|
|
* @since 1.5
|
|
*/
|
|
private static class CheckedList<E>
|
|
extends CheckedCollection<E>
|
|
implements List<E>
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.5.
|
|
*/
|
|
private static final long serialVersionUID = 65247728283967356L;
|
|
|
|
/**
|
|
* The wrapped list; stored both here and in the superclass to avoid
|
|
* excessive casting. Package visible for use by subclass.
|
|
* @serial the wrapped list
|
|
*/
|
|
final List<E> list;
|
|
|
|
/**
|
|
* Wrap a given list.
|
|
* @param l the list to wrap
|
|
* @param type the type of the elements within the checked list.
|
|
* @throws NullPointerException if l is null
|
|
*/
|
|
CheckedList(List<E> l, Class<E> type)
|
|
{
|
|
super(l, type);
|
|
list = l;
|
|
}
|
|
|
|
/**
|
|
* Adds the supplied element to the underlying list at the specified
|
|
* index, provided it is of the right type.
|
|
*
|
|
* @param index The index at which to place the new element.
|
|
* @param o the object to add.
|
|
* @throws ClassCastException if the type of the object is not a
|
|
* valid type for the underlying collection.
|
|
*/
|
|
public void add(int index, E o)
|
|
{
|
|
if (type.isInstance(o))
|
|
list.add(index, o);
|
|
else
|
|
throw new ClassCastException("The object is of the wrong type.");
|
|
}
|
|
|
|
/**
|
|
* Adds the members of the supplied collection to the underlying
|
|
* collection at the specified index, provided they are all of the
|
|
* correct type.
|
|
*
|
|
* @param index the index at which to place the new element.
|
|
* @param coll the collections of objects to add.
|
|
* @throws ClassCastException if the type of any element in c is not a
|
|
* valid type for the underlying collection.
|
|
*/
|
|
public boolean addAll(int index, Collection<? extends E> coll)
|
|
{
|
|
Collection<E> typedColl = (Collection<E>) coll;
|
|
final Iterator<E> it = typedColl.iterator();
|
|
while (it.hasNext())
|
|
{
|
|
if (!type.isInstance(it.next()))
|
|
throw new ClassCastException("A member of the collection is not of the correct type.");
|
|
}
|
|
return list.addAll(index, coll);
|
|
}
|
|
|
|
/**
|
|
* Returns <code>true</code> if the object, o, is an instance of
|
|
* <code>List</code> with the same size and elements
|
|
* as the underlying list.
|
|
*
|
|
* @param o The object to compare.
|
|
* @return <code>true</code> if o is equivalent to the underlying list.
|
|
*/
|
|
public boolean equals(Object o)
|
|
{
|
|
return list.equals(o);
|
|
}
|
|
|
|
/**
|
|
* Retrieves the element at a given index in the underlying list.
|
|
*
|
|
* @param index the index of the element to be returned
|
|
* @return the element at the specified index in the underlying list
|
|
* @throws IndexOutOfBoundsException if index < 0 || index >= size()
|
|
*/
|
|
public E get(int index)
|
|
{
|
|
return list.get(index);
|
|
}
|
|
|
|
/**
|
|
* Computes the hash code for the underlying list.
|
|
* The exact computation is described in the documentation
|
|
* of the <code>List</code> interface.
|
|
*
|
|
* @return The hash code of the underlying list.
|
|
* @see List#hashCode()
|
|
*/
|
|
public int hashCode()
|
|
{
|
|
return list.hashCode();
|
|
}
|
|
|
|
/**
|
|
* Obtain the first index at which a given object is to be found in the
|
|
* underlying list.
|
|
*
|
|
* @param o the object to search for
|
|
* @return the least integer n such that <code>o == null ? get(n) == null :
|
|
* o.equals(get(n))</code>, or -1 if there is no such index.
|
|
* @throws ClassCastException if the type of o is not a valid
|
|
* type for the underlying list.
|
|
* @throws NullPointerException if o is null and the underlying
|
|
* list does not support null values.
|
|
*/
|
|
public int indexOf(Object o)
|
|
{
|
|
return list.indexOf(o);
|
|
}
|
|
|
|
/**
|
|
* Obtain the last index at which a given object is to be found in the
|
|
* underlying list.
|
|
*
|
|
* @return the greatest integer n such that
|
|
* <code>o == null ? get(n) == null : o.equals(get(n))</code>,
|
|
* or -1 if there is no such index.
|
|
* @throws ClassCastException if the type of o is not a valid
|
|
* type for the underlying list.
|
|
* @throws NullPointerException if o is null and the underlying
|
|
* list does not support null values.
|
|
*/
|
|
public int lastIndexOf(Object o)
|
|
{
|
|
return list.lastIndexOf(o);
|
|
}
|
|
|
|
/**
|
|
* Obtains a list iterator over the underlying list, starting at the
|
|
* beginning and maintaining the checked nature of this list.
|
|
*
|
|
* @return a <code>CheckedListIterator</code> over the elements of the
|
|
* underlying list, in order, starting at the beginning.
|
|
*/
|
|
public ListIterator<E> listIterator()
|
|
{
|
|
return new CheckedListIterator<E>(list.listIterator(), type);
|
|
}
|
|
|
|
/**
|
|
* Obtains a list iterator over the underlying list, starting at the
|
|
* specified index and maintaining the checked nature of this list. An
|
|
* initial call to <code>next()</code> will retrieve the element at the
|
|
* specified index, and an initial call to <code>previous()</code> will
|
|
* retrieve the element at index - 1.
|
|
*
|
|
* @param index the position, between 0 and size() inclusive, to begin the
|
|
* iteration from.
|
|
* @return a <code>CheckedListIterator</code> over the elements of the
|
|
* underlying list, in order, starting at the specified index.
|
|
* @throws IndexOutOfBoundsException if index < 0 || index > size()
|
|
*/
|
|
public ListIterator<E> listIterator(int index)
|
|
{
|
|
return new CheckedListIterator<E>(list.listIterator(index), type);
|
|
}
|
|
|
|
/**
|
|
* Removes the element at the specified index.
|
|
*
|
|
* @param index The index of the element to remove.
|
|
* @return the removed element.
|
|
*/
|
|
public E remove(int index)
|
|
{
|
|
return list.remove(index);
|
|
}
|
|
|
|
/**
|
|
* Replaces the element at the specified index in the underlying list
|
|
* with that supplied.
|
|
*
|
|
* @param index the index of the element to replace.
|
|
* @param o the new object to place at the specified index.
|
|
* @return the replaced element.
|
|
*/
|
|
public E set(int index, E o)
|
|
{
|
|
return list.set(index, o);
|
|
}
|
|
|
|
/**
|
|
* Obtain a List view of a subsection of the underlying list, from
|
|
* fromIndex (inclusive) to toIndex (exclusive). If the two indices
|
|
* are equal, the sublist is empty. The returned list will be
|
|
* checked, like this list. Changes to the elements of the
|
|
* returned list will be reflected in the underlying list. The effect
|
|
* of structural modifications is undefined.
|
|
*
|
|
* @param fromIndex the index that the returned list should start from
|
|
* (inclusive).
|
|
* @param toIndex the index that the returned list should go
|
|
* to (exclusive).
|
|
* @return a List backed by a subsection of the underlying list.
|
|
* @throws IndexOutOfBoundsException if fromIndex < 0
|
|
* || toIndex > size() || fromIndex > toIndex.
|
|
*/
|
|
public List<E> subList(int fromIndex, int toIndex)
|
|
{
|
|
return checkedList(list.subList(fromIndex, toIndex), type);
|
|
}
|
|
} // class CheckedList
|
|
|
|
/**
|
|
* The implementation of {@link #checkedList(List)} for random-access
|
|
* lists. This class name is required for compatibility with Sun's JDK
|
|
* serializability.
|
|
*
|
|
* @author Andrew John Hughes (gnu_andrew@member.fsf.org)
|
|
* @since 1.5
|
|
*/
|
|
private static final class CheckedRandomAccessList<E>
|
|
extends CheckedList<E>
|
|
implements RandomAccess
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.5.
|
|
*/
|
|
private static final long serialVersionUID = 1638200125423088369L;
|
|
|
|
/**
|
|
* Wrap a given list.
|
|
* @param l the list to wrap
|
|
* @param type the type of the elements within the checked list.
|
|
* @throws NullPointerException if l is null
|
|
*/
|
|
CheckedRandomAccessList(List<E> l, Class<E> type)
|
|
{
|
|
super(l, type);
|
|
}
|
|
} // class CheckedRandomAccessList
|
|
|
|
/**
|
|
* The implementation of {@link CheckedList#listIterator()}.
|
|
*
|
|
* @author Andrew John Hughes (gnu_andrew@member.fsf.org)
|
|
* @since 1.5
|
|
*/
|
|
private static final class CheckedListIterator<E>
|
|
extends CheckedIterator<E>
|
|
implements ListIterator<E>
|
|
{
|
|
/**
|
|
* The wrapped iterator, stored both here and in the superclass to
|
|
* avoid excessive casting.
|
|
*/
|
|
private final ListIterator<E> li;
|
|
|
|
/**
|
|
* Only trusted code creates a wrapper.
|
|
* @param li the wrapped iterator
|
|
*/
|
|
CheckedListIterator(ListIterator<E> li, Class<E> type)
|
|
{
|
|
super(li, type);
|
|
this.li = li;
|
|
}
|
|
|
|
/**
|
|
* Adds the supplied object at the current iterator position, provided
|
|
* it is of the correct type.
|
|
*
|
|
* @param o the object to add.
|
|
* @throws ClassCastException if the type of the object is not a
|
|
* valid type for the underlying collection.
|
|
*/
|
|
public void add(E o)
|
|
{
|
|
if (type.isInstance(o))
|
|
li.add(o);
|
|
else
|
|
throw new ClassCastException("The object is of the wrong type.");
|
|
}
|
|
|
|
/**
|
|
* Tests whether there are still elements to be retrieved from the
|
|
* underlying collection by <code>previous()</code>. When this method
|
|
* returns <code>true</code>, an exception will not be thrown on calling
|
|
* <code>previous()</code>.
|
|
*
|
|
* @return <code>true</code> if there is at least one more element prior
|
|
* to the current position in the underlying list.
|
|
*/
|
|
public boolean hasPrevious()
|
|
{
|
|
return li.hasPrevious();
|
|
}
|
|
|
|
/**
|
|
* Find the index of the element that would be returned by a call to next.
|
|
* If <code>hasNext()</code> returns <code>false</code>, this returns the
|
|
* list size.
|
|
*
|
|
* @return the index of the element that would be returned by
|
|
* <code>next()</code>.
|
|
*/
|
|
public int nextIndex()
|
|
{
|
|
return li.nextIndex();
|
|
}
|
|
|
|
/**
|
|
* Obtains the previous element in the underlying list.
|
|
*
|
|
* @return the previous element in the list.
|
|
* @throws NoSuchElementException if there are no more prior elements.
|
|
*/
|
|
public E previous()
|
|
{
|
|
return li.previous();
|
|
}
|
|
|
|
/**
|
|
* Find the index of the element that would be returned by a call to
|
|
* previous. If <code>hasPrevious()</code> returns <code>false</code>,
|
|
* this returns -1.
|
|
*
|
|
* @return the index of the element that would be returned by
|
|
* <code>previous()</code>.
|
|
*/
|
|
public int previousIndex()
|
|
{
|
|
return li.previousIndex();
|
|
}
|
|
|
|
/**
|
|
* Sets the next element to that supplied, provided that it is of the
|
|
* correct type.
|
|
*
|
|
* @param o The new object to replace the existing one.
|
|
* @throws ClassCastException if the type of the object is not a
|
|
* valid type for the underlying collection.
|
|
*/
|
|
public void set(E o)
|
|
{
|
|
if (type.isInstance(o))
|
|
li.set(o);
|
|
else
|
|
throw new ClassCastException("The object is of the wrong type.");
|
|
}
|
|
} // class CheckedListIterator
|
|
|
|
/**
|
|
* <p>
|
|
* Returns a dynamically typesafe view of the given map,
|
|
* where any modification is first checked to ensure that the type
|
|
* of the new data is appropriate. Although the addition of
|
|
* generics and parametrically-typed collections prevents an
|
|
* incorrect type of element being added to a collection at
|
|
* compile-time, via static type checking, this can be overridden by
|
|
* casting. In contrast, wrapping the collection within a
|
|
* dynamically-typesafe wrapper, using this and associated methods,
|
|
* <emph>guarantees</emph> that the collection will only contain
|
|
* elements of an appropriate type (provided it only contains such
|
|
* at the type of wrapping, and all subsequent access is via the
|
|
* wrapper). This can be useful for debugging the cause of a
|
|
* <code>ClassCastException</code> caused by erroneous casting, or
|
|
* for protecting collections from corruption by external libraries.
|
|
* </p>
|
|
* <p>
|
|
* The returned Map implements Serializable, but can only be serialized if
|
|
* the map it wraps is likewise Serializable.
|
|
* </p>
|
|
*
|
|
* @param m the map to wrap
|
|
* @param keyType the dynamic type of the map's keys.
|
|
* @param valueType the dynamic type of the map's values.
|
|
* @return a dynamically typesafe view of the map
|
|
* @see Serializable
|
|
*/
|
|
public static <K, V> Map<K, V> checkedMap(Map<K, V> m, Class<K> keyType,
|
|
Class<V> valueType)
|
|
{
|
|
return new CheckedMap<K, V>(m, keyType, valueType);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #checkedMap(Map)}. This
|
|
* class name is required for compatibility with Sun's JDK serializability.
|
|
*
|
|
* @author Andrew John Hughes (gnu_andrew@member.fsf.org)
|
|
* @since 1.5
|
|
*/
|
|
private static class CheckedMap<K, V>
|
|
implements Map<K, V>, Serializable
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.5.
|
|
*/
|
|
private static final long serialVersionUID = 5742860141034234728L;
|
|
|
|
/**
|
|
* The wrapped map.
|
|
* @serial the real map
|
|
*/
|
|
private final Map<K, V> m;
|
|
|
|
/**
|
|
* The type of the map's keys.
|
|
* @serial the key type.
|
|
*/
|
|
final Class<K> keyType;
|
|
|
|
/**
|
|
* The type of the map's values.
|
|
* @serial the value type.
|
|
*/
|
|
final Class<V> valueType;
|
|
|
|
/**
|
|
* Cache the entry set.
|
|
*/
|
|
private transient Set<Map.Entry<K, V>> entries;
|
|
|
|
/**
|
|
* Cache the key set.
|
|
*/
|
|
private transient Set<K> keys;
|
|
|
|
/**
|
|
* Cache the value collection.
|
|
*/
|
|
private transient Collection<V> values;
|
|
|
|
/**
|
|
* Wrap a given map.
|
|
* @param m the map to wrap
|
|
* @param keyType the dynamic type of the map's keys.
|
|
* @param valueType the dynamic type of the map's values.
|
|
* @throws NullPointerException if m is null
|
|
*/
|
|
CheckedMap(Map<K, V> m, Class<K> keyType, Class<V> valueType)
|
|
{
|
|
this.m = m;
|
|
this.keyType = keyType;
|
|
this.valueType = valueType;
|
|
if (m == null)
|
|
throw new NullPointerException();
|
|
}
|
|
|
|
/**
|
|
* Clears all pairs from the map.
|
|
*/
|
|
public void clear()
|
|
{
|
|
m.clear();
|
|
}
|
|
|
|
/**
|
|
* Returns <code>true</code> if the underlying map contains a mapping for
|
|
* the given key.
|
|
*
|
|
* @param key the key to search for
|
|
* @return <code>true</code> if the map contains the key
|
|
* @throws ClassCastException if the key is of an inappropriate type
|
|
* @throws NullPointerException if key is <code>null</code> but the map
|
|
* does not permit null keys
|
|
*/
|
|
public boolean containsKey(Object key)
|
|
{
|
|
return m.containsKey(key);
|
|
}
|
|
|
|
/**
|
|
* Returns <code>true</code> if the underlying map contains at least one
|
|
* mapping with the given value. In other words, it returns
|
|
* <code>true</code> if a value v exists where
|
|
* <code>(value == null ? v == null : value.equals(v))</code>.
|
|
* This usually requires linear time.
|
|
*
|
|
* @param value the value to search for
|
|
* @return <code>true</code> if the map contains the value
|
|
* @throws ClassCastException if the type of the value is not a valid type
|
|
* for this map.
|
|
* @throws NullPointerException if the value is null and the map doesn't
|
|
* support null values.
|
|
*/
|
|
public boolean containsValue(Object value)
|
|
{
|
|
return m.containsValue(value);
|
|
}
|
|
|
|
/**
|
|
* <p>
|
|
* Returns a checked set view of the entries in the underlying map.
|
|
* Each element in the set is a unmodifiable variant of
|
|
* <code>Map.Entry</code>.
|
|
* </p>
|
|
* <p>
|
|
* The set is backed by the map, so that changes in one show up in the
|
|
* other. Modifications made while an iterator is in progress cause
|
|
* undefined behavior.
|
|
* </p>
|
|
*
|
|
* @return the checked set view of all mapping entries.
|
|
* @see Map.Entry
|
|
*/
|
|
public Set<Map.Entry<K, V>> entrySet()
|
|
{
|
|
if (entries == null)
|
|
{
|
|
Class<Map.Entry<K,V>> klass =
|
|
(Class<Map.Entry<K,V>>) (Class) Map.Entry.class;
|
|
entries = new CheckedEntrySet<Map.Entry<K,V>,K,V>(m.entrySet(),
|
|
klass,
|
|
keyType,
|
|
valueType);
|
|
}
|
|
return entries;
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link CheckedMap#entrySet()}. This class
|
|
* is <emph>not</emph> serializable.
|
|
*
|
|
* @author Andrew John Hughes (gnu_andrew@member.fsf.org)
|
|
* @since 1.5
|
|
*/
|
|
private static final class CheckedEntrySet<E,SK,SV>
|
|
extends CheckedSet<E>
|
|
{
|
|
/**
|
|
* The type of the map's keys.
|
|
* @serial the key type.
|
|
*/
|
|
private final Class<SK> keyType;
|
|
|
|
/**
|
|
* The type of the map's values.
|
|
* @serial the value type.
|
|
*/
|
|
private final Class<SV> valueType;
|
|
|
|
/**
|
|
* Wrap a given set of map entries.
|
|
*
|
|
* @param s the set to wrap.
|
|
* @param type the type of the set's entries.
|
|
* @param keyType the type of the map's keys.
|
|
* @param valueType the type of the map's values.
|
|
*/
|
|
CheckedEntrySet(Set<E> s, Class<E> type, Class<SK> keyType,
|
|
Class<SV> valueType)
|
|
{
|
|
super(s, type);
|
|
this.keyType = keyType;
|
|
this.valueType = valueType;
|
|
}
|
|
|
|
// The iterator must return checked map entries.
|
|
public Iterator<E> iterator()
|
|
{
|
|
return new CheckedIterator<E>(c.iterator(), type)
|
|
{
|
|
/**
|
|
* Obtains the next element from the underlying set of
|
|
* map entries.
|
|
*
|
|
* @return the next element in the collection.
|
|
* @throws NoSuchElementException if there are no more elements.
|
|
*/
|
|
public E next()
|
|
{
|
|
final Map.Entry e = (Map.Entry) super.next();
|
|
return (E) new Map.Entry()
|
|
{
|
|
/**
|
|
* Returns <code>true</code> if the object, o, is also a map
|
|
* entry with an identical key and value.
|
|
*
|
|
* @param o the object to compare.
|
|
* @return <code>true</code> if o is an equivalent map entry.
|
|
*/
|
|
public boolean equals(Object o)
|
|
{
|
|
return e.equals(o);
|
|
}
|
|
|
|
/**
|
|
* Returns the key of this map entry.
|
|
*
|
|
* @return the key.
|
|
*/
|
|
public Object getKey()
|
|
{
|
|
return e.getKey();
|
|
}
|
|
|
|
/**
|
|
* Returns the value of this map entry.
|
|
*
|
|
* @return the value.
|
|
*/
|
|
public Object getValue()
|
|
{
|
|
return e.getValue();
|
|
}
|
|
|
|
/**
|
|
* Computes the hash code of this map entry.
|
|
* The computation is described in the <code>Map</code>
|
|
* interface documentation.
|
|
*
|
|
* @return the hash code of this entry.
|
|
* @see Map#hashCode()
|
|
*/
|
|
public int hashCode()
|
|
{
|
|
return e.hashCode();
|
|
}
|
|
|
|
/**
|
|
* Sets the value of this map entry, provided it is of the
|
|
* right type.
|
|
*
|
|
* @param value The new value.
|
|
* @throws ClassCastException if the type of the value is not
|
|
* a valid type for the underlying
|
|
* map.
|
|
*/
|
|
public Object setValue(Object value)
|
|
{
|
|
if (valueType.isInstance(value))
|
|
return e.setValue(value);
|
|
else
|
|
throw new ClassCastException("The value is of the wrong type.");
|
|
}
|
|
|
|
/**
|
|
* Returns a textual representation of the map entry.
|
|
*
|
|
* @return The map entry as a <code>String</code>.
|
|
*/
|
|
public String toString()
|
|
{
|
|
return e.toString();
|
|
}
|
|
};
|
|
}
|
|
};
|
|
}
|
|
} // class CheckedEntrySet
|
|
|
|
/**
|
|
* Returns <code>true</code> if the object, o, is also an instance
|
|
* of <code>Map</code> with an equal set of map entries.
|
|
*
|
|
* @param o The object to compare.
|
|
* @return <code>true</code> if o is an equivalent map.
|
|
*/
|
|
public boolean equals(Object o)
|
|
{
|
|
return m.equals(o);
|
|
}
|
|
|
|
/**
|
|
* Returns the value associated with the supplied key or
|
|
* null if no such mapping exists. An ambiguity can occur
|
|
* if null values are accepted by the underlying map.
|
|
* In this case, <code>containsKey()</code> can be used
|
|
* to separate the two possible cases of a null result.
|
|
*
|
|
* @param key The key to look up.
|
|
* @return the value associated with the key, or null if key not in map.
|
|
* @throws ClassCastException if the key is an inappropriate type.
|
|
* @throws NullPointerException if this map does not accept null keys.
|
|
* @see #containsKey(Object)
|
|
*/
|
|
public V get(Object key)
|
|
{
|
|
return m.get(key);
|
|
}
|
|
|
|
/**
|
|
* Adds a new pair to the map, provided both the key and the value are
|
|
* of the correct types.
|
|
*
|
|
* @param key The new key.
|
|
* @param value The new value.
|
|
* @return the previous value of the key, or null if there was no mapping.
|
|
* @throws ClassCastException if the type of the key or the value is
|
|
* not a valid type for the underlying map.
|
|
*/
|
|
public V put(K key, V value)
|
|
{
|
|
if (keyType.isInstance(key))
|
|
{
|
|
if (valueType.isInstance(value))
|
|
return m.put(key,value);
|
|
else
|
|
throw new ClassCastException("The value is of the wrong type.");
|
|
}
|
|
throw new ClassCastException("The key is of the wrong type.");
|
|
}
|
|
|
|
/**
|
|
* Computes the hash code for the underlying map, as the sum
|
|
* of the hash codes of all entries.
|
|
*
|
|
* @return The hash code of the underlying map.
|
|
* @see Map.Entry#hashCode()
|
|
*/
|
|
public int hashCode()
|
|
{
|
|
return m.hashCode();
|
|
}
|
|
|
|
/**
|
|
* Returns <code>true</code> if the underlying map contains no entries.
|
|
*
|
|
* @return <code>true</code> if the map is empty.
|
|
*/
|
|
public boolean isEmpty()
|
|
{
|
|
return m.isEmpty();
|
|
}
|
|
|
|
/**
|
|
* <p>
|
|
* Returns a checked set view of the keys in the underlying map.
|
|
* The set is backed by the map, so that changes in one show up in the
|
|
* other.
|
|
* </p>
|
|
* <p>
|
|
* Modifications made while an iterator is in progress cause undefined
|
|
* behavior. These modifications are again limited to the values of
|
|
* the keys.
|
|
* </p>
|
|
*
|
|
* @return the set view of all keys.
|
|
*/
|
|
public Set<K> keySet()
|
|
{
|
|
if (keys == null)
|
|
keys = new CheckedSet<K>(m.keySet(), keyType);
|
|
return keys;
|
|
}
|
|
|
|
/**
|
|
* Adds all pairs within the supplied map to the underlying map,
|
|
* provided they are all have the correct key and value types.
|
|
*
|
|
* @param map the map, the entries of which should be added
|
|
* to the underlying map.
|
|
* @throws ClassCastException if the type of a key or value is
|
|
* not a valid type for the underlying map.
|
|
*/
|
|
public void putAll(Map<? extends K, ? extends V> map)
|
|
{
|
|
Map<K,V> typedMap = (Map<K,V>) map;
|
|
final Iterator<Map.Entry<K,V>> it = typedMap.entrySet().iterator();
|
|
while (it.hasNext())
|
|
{
|
|
final Map.Entry<K,V> entry = it.next();
|
|
if (!keyType.isInstance(entry.getKey()))
|
|
throw new ClassCastException("A key is of the wrong type.");
|
|
if (!valueType.isInstance(entry.getValue()))
|
|
throw new ClassCastException("A value is of the wrong type.");
|
|
}
|
|
m.putAll(typedMap);
|
|
}
|
|
|
|
/**
|
|
* Removes a pair from the map.
|
|
*
|
|
* @param o The key of the entry to remove.
|
|
* @return The value the key was associated with, or null
|
|
* if no such mapping existed. Null is also returned
|
|
* if the removed entry had a null key.
|
|
* @throws UnsupportedOperationException as an unmodifiable
|
|
* map does not support the <code>remove</code> operation.
|
|
*/
|
|
public V remove(Object o)
|
|
{
|
|
return m.remove(o);
|
|
}
|
|
|
|
|
|
/**
|
|
* Returns the number of key-value mappings in the underlying map.
|
|
* If there are more than Integer.MAX_VALUE mappings, Integer.MAX_VALUE
|
|
* is returned.
|
|
*
|
|
* @return the number of mappings.
|
|
*/
|
|
public int size()
|
|
{
|
|
return m.size();
|
|
}
|
|
|
|
/**
|
|
* Returns a textual representation of the map.
|
|
*
|
|
* @return The map in the form of a <code>String</code>.
|
|
*/
|
|
public String toString()
|
|
{
|
|
return m.toString();
|
|
}
|
|
|
|
/**
|
|
* <p>
|
|
* Returns a unmodifiable collection view of the values in the underlying
|
|
* map. The collection is backed by the map, so that changes in one show
|
|
* up in the other.
|
|
* </p>
|
|
* <p>
|
|
* Modifications made while an iterator is in progress cause undefined
|
|
* behavior. These modifications are again limited to the values of
|
|
* the keys.
|
|
* </p>
|
|
*
|
|
* @return the collection view of all values.
|
|
*/
|
|
public Collection<V> values()
|
|
{
|
|
if (values == null)
|
|
values = new CheckedCollection<V>(m.values(), valueType);
|
|
return values;
|
|
}
|
|
} // class CheckedMap
|
|
|
|
/**
|
|
* <p>
|
|
* Returns a dynamically typesafe view of the given set,
|
|
* where any modification is first checked to ensure that the type
|
|
* of the new data is appropriate. Although the addition of
|
|
* generics and parametrically-typed collections prevents an
|
|
* incorrect type of element being added to a collection at
|
|
* compile-time, via static type checking, this can be overridden by
|
|
* casting. In contrast, wrapping the collection within a
|
|
* dynamically-typesafe wrapper, using this and associated methods,
|
|
* <emph>guarantees</emph> that the collection will only contain
|
|
* elements of an appropriate type (provided it only contains such
|
|
* at the type of wrapping, and all subsequent access is via the
|
|
* wrapper). This can be useful for debugging the cause of a
|
|
* <code>ClassCastException</code> caused by erroneous casting, or
|
|
* for protecting collections from corruption by external libraries.
|
|
* </p>
|
|
* <p>
|
|
* The returned Set implements Serializable, but can only be serialized if
|
|
* the set it wraps is likewise Serializable.
|
|
* </p>
|
|
*
|
|
* @param s the set to wrap.
|
|
* @param type the type of the elements within the checked list.
|
|
* @return a dynamically typesafe view of the set
|
|
* @see Serializable
|
|
*/
|
|
public static <E> Set<E> checkedSet(Set<E> s, Class<E> type)
|
|
{
|
|
return new CheckedSet<E>(s, type);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #checkedSet(Set)}. This class
|
|
* name is required for compatibility with Sun's JDK serializability.
|
|
*
|
|
* @author Andrew John Hughes (gnu_andrew@member.fsf.org)
|
|
* @since 1.5
|
|
*/
|
|
private static class CheckedSet<E>
|
|
extends CheckedCollection<E>
|
|
implements Set<E>
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.5.
|
|
*/
|
|
private static final long serialVersionUID = 4694047833775013803L;
|
|
|
|
/**
|
|
* Wrap a given set.
|
|
*
|
|
* @param s the set to wrap
|
|
* @throws NullPointerException if s is null
|
|
*/
|
|
CheckedSet(Set<E> s, Class<E> type)
|
|
{
|
|
super(s, type);
|
|
}
|
|
|
|
/**
|
|
* Returns <code>true</code> if the object, o, is also an instance of
|
|
* <code>Set</code> of the same size and with the same entries.
|
|
*
|
|
* @return <code>true</code> if o is an equivalent set.
|
|
*/
|
|
public boolean equals(Object o)
|
|
{
|
|
return c.equals(o);
|
|
}
|
|
|
|
/**
|
|
* Computes the hash code of this set, as the sum of the
|
|
* hash codes of all elements within the set.
|
|
*
|
|
* @return the hash code of the set.
|
|
*/
|
|
public int hashCode()
|
|
{
|
|
return c.hashCode();
|
|
}
|
|
} // class CheckedSet
|
|
|
|
/**
|
|
* <p>
|
|
* Returns a dynamically typesafe view of the given sorted map,
|
|
* where any modification is first checked to ensure that the type
|
|
* of the new data is appropriate. Although the addition of
|
|
* generics and parametrically-typed collections prevents an
|
|
* incorrect type of element being added to a collection at
|
|
* compile-time, via static type checking, this can be overridden by
|
|
* casting. In contrast, wrapping the collection within a
|
|
* dynamically-typesafe wrapper, using this and associated methods,
|
|
* <emph>guarantees</emph> that the collection will only contain
|
|
* elements of an appropriate type (provided it only contains such
|
|
* at the type of wrapping, and all subsequent access is via the
|
|
* wrapper). This can be useful for debugging the cause of a
|
|
* <code>ClassCastException</code> caused by erroneous casting, or
|
|
* for protecting collections from corruption by external libraries.
|
|
* </p>
|
|
* <p>
|
|
* The returned SortedMap implements Serializable, but can only be
|
|
* serialized if the map it wraps is likewise Serializable.
|
|
* </p>
|
|
*
|
|
* @param m the map to wrap.
|
|
* @param keyType the dynamic type of the map's keys.
|
|
* @param valueType the dynamic type of the map's values.
|
|
* @return a dynamically typesafe view of the map
|
|
* @see Serializable
|
|
*/
|
|
public static <K, V> SortedMap<K, V> checkedSortedMap(SortedMap<K, V> m,
|
|
Class<K> keyType,
|
|
Class<V> valueType)
|
|
{
|
|
return new CheckedSortedMap<K, V>(m, keyType, valueType);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #checkedSortedMap(SortedMap,Class,Class)}.
|
|
* This class name is required for compatibility with Sun's JDK
|
|
* serializability.
|
|
*
|
|
* @author Andrew John Hughes (gnu_andrew@member.fsf.org)
|
|
*/
|
|
private static class CheckedSortedMap<K, V>
|
|
extends CheckedMap<K, V>
|
|
implements SortedMap<K, V>
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.5.
|
|
*/
|
|
private static final long serialVersionUID = 1599671320688067438L;
|
|
|
|
/**
|
|
* The wrapped map; stored both here and in the superclass to avoid
|
|
* excessive casting.
|
|
* @serial the wrapped map
|
|
*/
|
|
private final SortedMap<K, V> sm;
|
|
|
|
/**
|
|
* Wrap a given map.
|
|
*
|
|
* @param sm the map to wrap
|
|
* @param keyType the dynamic type of the map's keys.
|
|
* @param valueType the dynamic type of the map's values.
|
|
* @throws NullPointerException if sm is null
|
|
*/
|
|
CheckedSortedMap(SortedMap<K, V> sm, Class<K> keyType, Class<V> valueType)
|
|
{
|
|
super(sm, keyType, valueType);
|
|
this.sm = sm;
|
|
}
|
|
|
|
/**
|
|
* Returns the comparator used in sorting the underlying map,
|
|
* or null if it is the keys' natural ordering.
|
|
*
|
|
* @return the sorting comparator.
|
|
*/
|
|
public Comparator<? super K> comparator()
|
|
{
|
|
return sm.comparator();
|
|
}
|
|
|
|
/**
|
|
* Returns the first (lowest sorted) key in the map.
|
|
*
|
|
* @return the first key.
|
|
* @throws NoSuchElementException if this map is empty.
|
|
*/
|
|
public K firstKey()
|
|
{
|
|
return sm.firstKey();
|
|
}
|
|
|
|
/**
|
|
* <p>
|
|
* Returns a checked view of the portion of the map strictly less
|
|
* than toKey. The view is backed by the underlying map, so changes in
|
|
* one show up in the other. The submap supports all optional operations
|
|
* of the original. This operation is equivalent to
|
|
* <code>subMap(firstKey(), toKey)</code>.
|
|
* </p>
|
|
* <p>
|
|
* The returned map throws an IllegalArgumentException any time a key is
|
|
* used which is out of the range of toKey. Note that the endpoint, toKey,
|
|
* is not included; if you want this value to be included, pass its
|
|
* successor object in to toKey. For example, for Integers, you could
|
|
* request <code>headMap(new Integer(limit.intValue() + 1))</code>.
|
|
* </p>
|
|
*
|
|
* @param toKey the exclusive upper range of the submap.
|
|
* @return the submap.
|
|
* @throws ClassCastException if toKey is not comparable to the map
|
|
* contents.
|
|
* @throws IllegalArgumentException if this is a subMap, and toKey is out
|
|
* of range.
|
|
* @throws NullPointerException if toKey is null but the map does not allow
|
|
* null keys.
|
|
*/
|
|
public SortedMap<K, V> headMap(K toKey)
|
|
{
|
|
return new CheckedSortedMap<K, V>(sm.headMap(toKey), keyType, valueType);
|
|
}
|
|
|
|
/**
|
|
* Returns the last (highest sorted) key in the map.
|
|
*
|
|
* @return the last key.
|
|
* @throws NoSuchElementException if this map is empty.
|
|
*/
|
|
public K lastKey()
|
|
{
|
|
return sm.lastKey();
|
|
}
|
|
|
|
/**
|
|
* <p>
|
|
* Returns a checked view of the portion of the map greater than or
|
|
* equal to fromKey, and strictly less than toKey. The view is backed by
|
|
* the underlying map, so changes in one show up in the other. The submap
|
|
* supports all optional operations of the original.
|
|
* </p>
|
|
* <p>
|
|
* The returned map throws an IllegalArgumentException any time a key is
|
|
* used which is out of the range of fromKey and toKey. Note that the
|
|
* lower endpoint is included, but the upper is not; if you want to
|
|
* change the inclusion or exclusion of an endpoint, pass its successor
|
|
* object in instead. For example, for Integers, you could request
|
|
* <code>subMap(new Integer(lowlimit.intValue() + 1),
|
|
* new Integer(highlimit.intValue() + 1))</code> to reverse
|
|
* the inclusiveness of both endpoints.
|
|
* </p>
|
|
*
|
|
* @param fromKey the inclusive lower range of the submap.
|
|
* @param toKey the exclusive upper range of the submap.
|
|
* @return the submap.
|
|
* @throws ClassCastException if fromKey or toKey is not comparable to
|
|
* the map contents.
|
|
* @throws IllegalArgumentException if this is a subMap, and fromKey or
|
|
* toKey is out of range.
|
|
* @throws NullPointerException if fromKey or toKey is null but the map
|
|
* does not allow null keys.
|
|
*/
|
|
public SortedMap<K, V> subMap(K fromKey, K toKey)
|
|
{
|
|
return new CheckedSortedMap<K, V>(sm.subMap(fromKey, toKey), keyType,
|
|
valueType);
|
|
}
|
|
|
|
/**
|
|
* <p>
|
|
* Returns a checked view of the portion of the map greater than or
|
|
* equal to fromKey. The view is backed by the underlying map, so changes
|
|
* in one show up in the other. The submap supports all optional operations
|
|
* of the original.
|
|
* </p>
|
|
* <p>
|
|
* The returned map throws an IllegalArgumentException any time a key is
|
|
* used which is out of the range of fromKey. Note that the endpoint,
|
|
* fromKey, is included; if you do not want this value to be included,
|
|
* pass its successor object in to fromKey. For example, for Integers,
|
|
* you could request
|
|
* <code>tailMap(new Integer(limit.intValue() + 1))</code>.
|
|
* </p>
|
|
*
|
|
* @param fromKey the inclusive lower range of the submap
|
|
* @return the submap
|
|
* @throws ClassCastException if fromKey is not comparable to the map
|
|
* contents
|
|
* @throws IllegalArgumentException if this is a subMap, and fromKey is out
|
|
* of range
|
|
* @throws NullPointerException if fromKey is null but the map does not
|
|
* allow null keys
|
|
*/
|
|
public SortedMap<K, V> tailMap(K fromKey)
|
|
{
|
|
return new CheckedSortedMap<K, V>(sm.tailMap(fromKey), keyType,
|
|
valueType);
|
|
}
|
|
} // class CheckedSortedMap
|
|
|
|
/**
|
|
* <p>
|
|
* Returns a dynamically typesafe view of the given sorted set,
|
|
* where any modification is first checked to ensure that the type
|
|
* of the new data is appropriate. Although the addition of
|
|
* generics and parametrically-typed collections prevents an
|
|
* incorrect type of element being added to a collection at
|
|
* compile-time, via static type checking, this can be overridden by
|
|
* casting. In contrast, wrapping the collection within a
|
|
* dynamically-typesafe wrapper, using this and associated methods,
|
|
* <emph>guarantees</emph> that the collection will only contain
|
|
* elements of an appropriate type (provided it only contains such
|
|
* at the type of wrapping, and all subsequent access is via the
|
|
* wrapper). This can be useful for debugging the cause of a
|
|
* <code>ClassCastException</code> caused by erroneous casting, or
|
|
* for protecting collections from corruption by external libraries.
|
|
* </p>
|
|
* <p>
|
|
* The returned SortedSet implements Serializable, but can only be
|
|
* serialized if the set it wraps is likewise Serializable.
|
|
* </p>
|
|
*
|
|
* @param s the set to wrap.
|
|
* @param type the type of the set's elements.
|
|
* @return a dynamically typesafe view of the set
|
|
* @see Serializable
|
|
*/
|
|
public static <E> SortedSet<E> checkedSortedSet(SortedSet<E> s,
|
|
Class<E> type)
|
|
{
|
|
return new CheckedSortedSet<E>(s, type);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #checkedSortedSet(SortedSet,Class)}. This
|
|
* class name is required for compatibility with Sun's JDK serializability.
|
|
*
|
|
* @author Andrew John Hughes (gnu_andrew@member.fsf.org)
|
|
* @since 1.5
|
|
*/
|
|
private static class CheckedSortedSet<E>
|
|
extends CheckedSet<E>
|
|
implements SortedSet<E>
|
|
{
|
|
/**
|
|
* Compatible with JDK 1.4.
|
|
*/
|
|
private static final long serialVersionUID = 1599911165492914959L;
|
|
|
|
/**
|
|
* The wrapped set; stored both here and in the superclass to avoid
|
|
* excessive casting.
|
|
*
|
|
* @serial the wrapped set
|
|
*/
|
|
private SortedSet<E> ss;
|
|
|
|
/**
|
|
* Wrap a given set.
|
|
*
|
|
* @param ss the set to wrap.
|
|
* @param type the type of the set's elements.
|
|
* @throws NullPointerException if ss is null
|
|
*/
|
|
CheckedSortedSet(SortedSet<E> ss, Class<E> type)
|
|
{
|
|
super(ss, type);
|
|
this.ss = ss;
|
|
}
|
|
|
|
/**
|
|
* Returns the comparator used in sorting the underlying set,
|
|
* or null if it is the elements' natural ordering.
|
|
*
|
|
* @return the sorting comparator
|
|
*/
|
|
public Comparator<? super E> comparator()
|
|
{
|
|
return ss.comparator();
|
|
}
|
|
|
|
/**
|
|
* Returns the first (lowest sorted) element in the underlying
|
|
* set.
|
|
*
|
|
* @return the first element.
|
|
* @throws NoSuchElementException if the set is empty.
|
|
*/
|
|
public E first()
|
|
{
|
|
return ss.first();
|
|
}
|
|
|
|
/**
|
|
* <p>
|
|
* Returns a checked view of the portion of the set strictly
|
|
* less than toElement. The view is backed by the underlying set,
|
|
* so changes in one show up in the other. The subset supports
|
|
* all optional operations of the original. This operation
|
|
* is equivalent to <code>subSet(first(), toElement)</code>.
|
|
* </p>
|
|
* <p>
|
|
* The returned set throws an IllegalArgumentException any time an
|
|
* element is used which is out of the range of toElement. Note that
|
|
* the endpoint, toElement, is not included; if you want this value
|
|
* included, pass its successor object in to toElement. For example,
|
|
* for Integers, you could request
|
|
* <code>headSet(new Integer(limit.intValue() + 1))</code>.
|
|
* </p>
|
|
*
|
|
* @param toElement the exclusive upper range of the subset
|
|
* @return the subset.
|
|
* @throws ClassCastException if toElement is not comparable to the set
|
|
* contents.
|
|
* @throws IllegalArgumentException if this is a subSet, and toElement is
|
|
* out of range.
|
|
* @throws NullPointerException if toElement is null but the set does not
|
|
* allow null elements.
|
|
*/
|
|
public SortedSet<E> headSet(E toElement)
|
|
{
|
|
return new CheckedSortedSet<E>(ss.headSet(toElement), type);
|
|
}
|
|
|
|
/**
|
|
* Returns the last (highest sorted) element in the underlying
|
|
* set.
|
|
*
|
|
* @return the last element.
|
|
* @throws NoSuchElementException if the set is empty.
|
|
*/
|
|
public E last()
|
|
{
|
|
return ss.last();
|
|
}
|
|
|
|
/**
|
|
* <p>
|
|
* Returns a checked view of the portion of the set greater than or
|
|
* equal to fromElement, and strictly less than toElement. The view is
|
|
* backed by the underlying set, so changes in one show up in the other.
|
|
* The subset supports all optional operations of the original.
|
|
* </p>
|
|
* <p>
|
|
* The returned set throws an IllegalArgumentException any time an
|
|
* element is used which is out of the range of fromElement and toElement.
|
|
* Note that the lower endpoint is included, but the upper is not; if you
|
|
* want to change the inclusion or exclusion of an endpoint, pass its
|
|
* successor object in instead. For example, for Integers, you can request
|
|
* <code>subSet(new Integer(lowlimit.intValue() + 1),
|
|
* new Integer(highlimit.intValue() + 1))</code> to reverse
|
|
* the inclusiveness of both endpoints.
|
|
* </p>
|
|
*
|
|
* @param fromElement the inclusive lower range of the subset.
|
|
* @param toElement the exclusive upper range of the subset.
|
|
* @return the subset.
|
|
* @throws ClassCastException if fromElement or toElement is not comparable
|
|
* to the set contents.
|
|
* @throws IllegalArgumentException if this is a subSet, and fromElement or
|
|
* toElement is out of range.
|
|
* @throws NullPointerException if fromElement or toElement is null but the
|
|
* set does not allow null elements.
|
|
*/
|
|
public SortedSet<E> subSet(E fromElement, E toElement)
|
|
{
|
|
return new CheckedSortedSet<E>(ss.subSet(fromElement, toElement), type);
|
|
}
|
|
|
|
/**
|
|
* <p>
|
|
* Returns a checked view of the portion of the set greater than or equal
|
|
* to fromElement. The view is backed by the underlying set, so changes in
|
|
* one show up in the other. The subset supports all optional operations
|
|
* of the original.
|
|
* </p>
|
|
* <p>
|
|
* The returned set throws an IllegalArgumentException any time an
|
|
* element is used which is out of the range of fromElement. Note that
|
|
* the endpoint, fromElement, is included; if you do not want this value
|
|
* to be included, pass its successor object in to fromElement. For
|
|
* example, for Integers, you could request
|
|
* <code>tailSet(new Integer(limit.intValue() + 1))</code>.
|
|
* </p>
|
|
*
|
|
* @param fromElement the inclusive lower range of the subset
|
|
* @return the subset.
|
|
* @throws ClassCastException if fromElement is not comparable to the set
|
|
* contents.
|
|
* @throws IllegalArgumentException if this is a subSet, and fromElement is
|
|
* out of range.
|
|
* @throws NullPointerException if fromElement is null but the set does not
|
|
* allow null elements.
|
|
*/
|
|
public SortedSet<E> tailSet(E fromElement)
|
|
{
|
|
return new CheckedSortedSet<E>(ss.tailSet(fromElement), type);
|
|
}
|
|
} // class CheckedSortedSet
|
|
|
|
/**
|
|
* Returns a view of a {@link Deque} as a stack or LIFO (Last-In-First-Out)
|
|
* {@link Queue}. Each call to the LIFO queue corresponds to one
|
|
* equivalent method call to the underlying deque, with the exception
|
|
* of {@link Collection#addAll(Collection)}, which is emulated by a series
|
|
* of {@link Deque#push(E)} calls.
|
|
*
|
|
* @param deque the deque to convert to a LIFO queue.
|
|
* @return a LIFO queue.
|
|
* @since 1.6
|
|
*/
|
|
public static <T> Queue<T> asLifoQueue(Deque<T> deque)
|
|
{
|
|
return new LIFOQueue<T>(deque);
|
|
}
|
|
|
|
/**
|
|
* Returns a set backed by the supplied map. The resulting set
|
|
* has the same performance, concurrency and ordering characteristics
|
|
* as the original map. The supplied map must be empty and should not
|
|
* be used after the set is created. Each call to the set corresponds
|
|
* to one equivalent method call to the underlying map, with the exception
|
|
* of {@link Set#addAll(Collection)} which is emulated by a series of
|
|
* calls to <code>put</code>.
|
|
*
|
|
* @param map the map to convert to a set.
|
|
* @return a set backed by the supplied map.
|
|
* @throws IllegalArgumentException if the map is not empty.
|
|
* @since 1.6
|
|
*/
|
|
public static <E> Set<E> newSetFromMap(Map<E,Boolean> map)
|
|
{
|
|
return new MapSet<E>(map);
|
|
}
|
|
|
|
/**
|
|
* The implementation of {@link #asLIFOQueue(Deque)}.
|
|
*
|
|
* @author Andrew John Hughes (gnu_andrew@member.fsf.org)
|
|
* @since 1.6
|
|
*/
|
|
private static class LIFOQueue<T>
|
|
extends AbstractQueue<T>
|
|
{
|
|
|
|
/**
|
|
* The backing deque.
|
|
*/
|
|
private Deque<T> deque;
|
|
|
|
/**
|
|
* Constructs a new {@link LIFOQueue} with the specified
|
|
* backing {@link Deque}.
|
|
*
|
|
* @param deque the backing deque.
|
|
*/
|
|
public LIFOQueue(Deque<T> deque)
|
|
{
|
|
this.deque = deque;
|
|
}
|
|
|
|
public boolean add(T e)
|
|
{
|
|
return deque.offerFirst(e);
|
|
}
|
|
|
|
public boolean addAll(Collection<? extends T> c)
|
|
{
|
|
boolean result = false;
|
|
final Iterator<? extends T> it = c.iterator();
|
|
while (it.hasNext())
|
|
result |= deque.offerFirst(it.next());
|
|
return result;
|
|
}
|
|
|
|
public void clear()
|
|
{
|
|
deque.clear();
|
|
}
|
|
|
|
public boolean isEmpty()
|
|
{
|
|
return deque.isEmpty();
|
|
}
|
|
|
|
public Iterator<T> iterator()
|
|
{
|
|
return deque.iterator();
|
|
}
|
|
|
|
public boolean offer(T e)
|
|
{
|
|
return deque.offerFirst(e);
|
|
}
|
|
|
|
public T peek()
|
|
{
|
|
return deque.peek();
|
|
}
|
|
|
|
public T poll()
|
|
{
|
|
return deque.poll();
|
|
}
|
|
|
|
public int size()
|
|
{
|
|
return deque.size();
|
|
}
|
|
} // class LIFOQueue
|
|
|
|
/**
|
|
* The implementation of {@link #newSetFromMap(Map)}.
|
|
*
|
|
* @author Andrew John Hughes (gnu_andrew@member.fsf.org)
|
|
* @since 1.6
|
|
*/
|
|
private static class MapSet<E>
|
|
extends AbstractSet<E>
|
|
{
|
|
|
|
/**
|
|
* The backing map.
|
|
*/
|
|
private Map<E,Boolean> map;
|
|
|
|
/**
|
|
* Constructs a new {@link MapSet} using the specified
|
|
* backing {@link Map}.
|
|
*
|
|
* @param map the backing map.
|
|
* @throws IllegalArgumentException if the map is not empty.
|
|
*/
|
|
public MapSet(Map<E,Boolean> map)
|
|
{
|
|
if (!map.isEmpty())
|
|
throw new IllegalArgumentException("The map must be empty.");
|
|
this.map = map;
|
|
}
|
|
|
|
public boolean add(E e)
|
|
{
|
|
return map.put(e, true) == null;
|
|
}
|
|
|
|
public boolean addAll(Collection<? extends E> c)
|
|
{
|
|
boolean result = false;
|
|
final Iterator<? extends E> it = c.iterator();
|
|
while (it.hasNext())
|
|
result |= (map.put(it.next(), true) == null);
|
|
return result;
|
|
}
|
|
|
|
public void clear()
|
|
{
|
|
map.clear();
|
|
}
|
|
|
|
public boolean contains(Object o)
|
|
{
|
|
return map.containsKey(o);
|
|
}
|
|
|
|
public boolean isEmpty()
|
|
{
|
|
return map.isEmpty();
|
|
}
|
|
|
|
public Iterator<E> iterator()
|
|
{
|
|
return map.keySet().iterator();
|
|
}
|
|
|
|
public boolean remove(Object o)
|
|
{
|
|
return map.remove(o) != null;
|
|
}
|
|
|
|
public int size()
|
|
{
|
|
return map.size();
|
|
}
|
|
} // class MapSet
|
|
|
|
} // class Collections
|