Attributes.java, [...]: Imported from Classpath.
Sat Aug 19 11:00:53 2000 Anthony Green <green@redhat.com> * java/util/jar/Attributes.java, java/util/jar/JarEntry.java, java/util/jar/JarException.java, java/util/jar/JarFile.java, java/util/jar/JarInputStream.java, java/util/jar/JarOutputStream.java, java/util/jar/Manifest.java, java/util/Set.java, java/util/Map.java, java/util/Bucket.java, java/util/AbstractSet.java, java/util/BasicMapEntry.java, java/security/cert/CRL.java, java/security/cert/CRLException.java, java/security/cert/Certificate.java, java/security/cert/CertificateEncodingException.java, java/security/cert/CertificateException.java, java/security/cert/CertificateExpiredException.java, java/security/cert/CertificateFactory.java, java/security/cert/CertificateFactorySpi.java, java/security/cert/CertificateNotYetValidException.java, java/security/cert/CertificateParsingException.java, java/security/cert/X509CRL.java, java/security/cert/X509CRLEntry.java, java/security/cert/X509Certificate.java, java/security/cert/X509Extension.java: Imported from Classpath. * java/util/Hashtable.java: Imported from Classpath. * java/util/zip/ZipInputStream.java: Create stub for createZipEntry. * gcj/javaprims.h: Updated class list. * Makefile.in, gcj/Makefile.in: Rebuilt. * Makefile.am (ordinary_java_source_files): Add these new classes. From-SVN: r35809
This commit is contained in:
parent
e76d9acbe9
commit
a729a4e9ab
35 changed files with 5943 additions and 768 deletions
|
@ -1,3 +1,34 @@
|
||||||
|
Sat Aug 19 11:00:53 2000 Anthony Green <green@redhat.com>
|
||||||
|
|
||||||
|
* java/util/jar/Attributes.java, java/util/jar/JarEntry.java,
|
||||||
|
java/util/jar/JarException.java, java/util/jar/JarFile.java,
|
||||||
|
java/util/jar/JarInputStream.java,
|
||||||
|
java/util/jar/JarOutputStream.java, java/util/jar/Manifest.java,
|
||||||
|
java/util/Set.java, java/util/Map.java, java/util/Bucket.java,
|
||||||
|
java/util/AbstractSet.java, java/util/BasicMapEntry.java,
|
||||||
|
java/security/cert/CRL.java, java/security/cert/CRLException.java,
|
||||||
|
java/security/cert/Certificate.java,
|
||||||
|
java/security/cert/CertificateEncodingException.java,
|
||||||
|
java/security/cert/CertificateException.java,
|
||||||
|
java/security/cert/CertificateExpiredException.java,
|
||||||
|
java/security/cert/CertificateFactory.java,
|
||||||
|
java/security/cert/CertificateFactorySpi.java,
|
||||||
|
java/security/cert/CertificateNotYetValidException.java,
|
||||||
|
java/security/cert/CertificateParsingException.java,
|
||||||
|
java/security/cert/X509CRL.java,
|
||||||
|
java/security/cert/X509CRLEntry.java,
|
||||||
|
java/security/cert/X509Certificate.java,
|
||||||
|
java/security/cert/X509Extension.java: Imported from Classpath.
|
||||||
|
* java/util/Hashtable.java: Imported from Classpath.
|
||||||
|
|
||||||
|
* java/util/zip/ZipInputStream.java: Create stub for
|
||||||
|
createZipEntry.
|
||||||
|
|
||||||
|
* gcj/javaprims.h: Updated class list.
|
||||||
|
|
||||||
|
* Makefile.in, gcj/Makefile.in: Rebuilt.
|
||||||
|
* Makefile.am (ordinary_java_source_files): Add these new classes.
|
||||||
|
|
||||||
2000-08-16 Rolf W. Rasmussen <rolfwr@ii.uib.no>
|
2000-08-16 Rolf W. Rasmussen <rolfwr@ii.uib.no>
|
||||||
|
|
||||||
* gnu/gcj/awt/ComponentDataBlitOp.java: New file.
|
* gnu/gcj/awt/ComponentDataBlitOp.java: New file.
|
||||||
|
|
|
@ -718,12 +718,20 @@ built_java_source_files = java/lang/ConcreteProcess.java
|
||||||
## header, please list it in special_java_source_files.
|
## header, please list it in special_java_source_files.
|
||||||
ordinary_java_source_files = $(convert_source_files) \
|
ordinary_java_source_files = $(convert_source_files) \
|
||||||
$(awt_java_source_files) \
|
$(awt_java_source_files) \
|
||||||
gnu/gcj/protocol/http/Connection.java \
|
gnu/gcj/RawData.java \
|
||||||
gnu/gcj/protocol/http/Handler.java \
|
gnu/gcj/io/DefaultMimeTypes.java \
|
||||||
|
gnu/gcj/io/MimeTypes.java \
|
||||||
|
gnu/gcj/io/SimpleSHSStream.java \
|
||||||
|
gnu/gcj/jni/NativeThread.java \
|
||||||
|
gnu/gcj/math/MPN.java \
|
||||||
gnu/gcj/protocol/file/Connection.java \
|
gnu/gcj/protocol/file/Connection.java \
|
||||||
gnu/gcj/protocol/file/Handler.java \
|
gnu/gcj/protocol/file/Handler.java \
|
||||||
|
gnu/gcj/protocol/http/Connection.java \
|
||||||
|
gnu/gcj/protocol/http/Handler.java \
|
||||||
gnu/gcj/protocol/jar/Connection.java \
|
gnu/gcj/protocol/jar/Connection.java \
|
||||||
gnu/gcj/protocol/jar/Handler.java \
|
gnu/gcj/protocol/jar/Handler.java \
|
||||||
|
gnu/gcj/runtime/FirstThread.java \
|
||||||
|
gnu/gcj/runtime/VMClassLoader.java \
|
||||||
gnu/gcj/text/BaseBreakIterator.java \
|
gnu/gcj/text/BaseBreakIterator.java \
|
||||||
gnu/gcj/text/CharacterBreakIterator.java \
|
gnu/gcj/text/CharacterBreakIterator.java \
|
||||||
gnu/gcj/text/LineBreakIterator.java \
|
gnu/gcj/text/LineBreakIterator.java \
|
||||||
|
@ -732,23 +740,16 @@ gnu/gcj/text/LocaleData_en_US.java \
|
||||||
gnu/gcj/text/SentenceBreakIterator.java \
|
gnu/gcj/text/SentenceBreakIterator.java \
|
||||||
gnu/gcj/text/WordBreakIterator.java \
|
gnu/gcj/text/WordBreakIterator.java \
|
||||||
gnu/gcj/util/EnumerationChain.java \
|
gnu/gcj/util/EnumerationChain.java \
|
||||||
gnu/gcj/RawData.java \
|
|
||||||
gnu/gcj/math/MPN.java \
|
|
||||||
gnu/gcj/runtime/VMClassLoader.java \
|
|
||||||
gnu/gcj/runtime/FirstThread.java \
|
|
||||||
gnu/gcj/jni/NativeThread.java \
|
|
||||||
gnu/gcj/io/DefaultMimeTypes.java \
|
|
||||||
gnu/gcj/io/MimeTypes.java \
|
|
||||||
gnu/gcj/io/SimpleSHSStream.java \
|
|
||||||
gnu/java/io/ClassLoaderObjectInputStream.java \
|
gnu/java/io/ClassLoaderObjectInputStream.java \
|
||||||
gnu/java/io/NullOutputStream.java \
|
gnu/java/io/NullOutputStream.java \
|
||||||
gnu/java/io/ObjectIdentityWrapper.java \
|
gnu/java/io/ObjectIdentityWrapper.java \
|
||||||
gnu/java/lang/reflect/TypeSignature.java \
|
|
||||||
gnu/java/lang/ArrayHelper.java \
|
gnu/java/lang/ArrayHelper.java \
|
||||||
gnu/java/lang/ClassHelper.java \
|
gnu/java/lang/ClassHelper.java \
|
||||||
|
gnu/java/lang/reflect/TypeSignature.java \
|
||||||
gnu/java/security/provider/Gnu.java \
|
gnu/java/security/provider/Gnu.java \
|
||||||
gnu/java/security/provider/SHA.java \
|
gnu/java/security/provider/SHA.java \
|
||||||
gnu/java/security/provider/SHA1PRNG.java \
|
gnu/java/security/provider/SHA1PRNG.java \
|
||||||
|
java/io/BlockDataException.java \
|
||||||
java/io/BufferedInputStream.java \
|
java/io/BufferedInputStream.java \
|
||||||
java/io/BufferedOutputStream.java \
|
java/io/BufferedOutputStream.java \
|
||||||
java/io/BufferedReader.java \
|
java/io/BufferedReader.java \
|
||||||
|
@ -763,7 +764,9 @@ java/io/DataInputStream.java \
|
||||||
java/io/DataOutput.java \
|
java/io/DataOutput.java \
|
||||||
java/io/DataOutputStream.java \
|
java/io/DataOutputStream.java \
|
||||||
java/io/EOFException.java \
|
java/io/EOFException.java \
|
||||||
|
java/io/Externalizable.java \
|
||||||
java/io/File.java \
|
java/io/File.java \
|
||||||
|
java/io/FileDescriptor.java \
|
||||||
java/io/FileInputStream.java \
|
java/io/FileInputStream.java \
|
||||||
java/io/FileNotFoundException.java \
|
java/io/FileNotFoundException.java \
|
||||||
java/io/FileOutputStream.java \
|
java/io/FileOutputStream.java \
|
||||||
|
@ -778,37 +781,10 @@ java/io/IOException.java \
|
||||||
java/io/InputStream.java \
|
java/io/InputStream.java \
|
||||||
java/io/InputStreamReader.java \
|
java/io/InputStreamReader.java \
|
||||||
java/io/InterruptedIOException.java \
|
java/io/InterruptedIOException.java \
|
||||||
java/io/LineNumberInputStream.java \
|
|
||||||
java/io/LineNumberReader.java \
|
|
||||||
java/io/OutputStream.java \
|
|
||||||
java/io/OutputStreamWriter.java \
|
|
||||||
java/io/Externalizable.java \
|
|
||||||
java/io/FileDescriptor.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/StreamTokenizer.java \
|
|
||||||
java/io/StringBufferInputStream.java \
|
|
||||||
java/io/StringReader.java \
|
|
||||||
java/io/StringWriter.java \
|
|
||||||
java/io/SyncFailedException.java \
|
|
||||||
java/io/UTFDataFormatException.java \
|
|
||||||
java/io/UnsupportedEncodingException.java \
|
|
||||||
java/io/Writer.java \
|
|
||||||
java/io/ObjectStreamException.java \
|
|
||||||
java/io/OptionalDataException.java \
|
|
||||||
java/io/StreamCorruptedException.java \
|
|
||||||
java/io/BlockDataException.java \
|
|
||||||
java/io/InvalidClassException.java \
|
java/io/InvalidClassException.java \
|
||||||
java/io/InvalidObjectException.java \
|
java/io/InvalidObjectException.java \
|
||||||
|
java/io/LineNumberInputStream.java \
|
||||||
|
java/io/LineNumberReader.java \
|
||||||
java/io/NotActiveException.java \
|
java/io/NotActiveException.java \
|
||||||
java/io/NotSerializableException.java \
|
java/io/NotSerializableException.java \
|
||||||
java/io/ObjectInput.java \
|
java/io/ObjectInput.java \
|
||||||
|
@ -818,20 +794,36 @@ java/io/ObjectOutput.java \
|
||||||
java/io/ObjectOutputStream.java \
|
java/io/ObjectOutputStream.java \
|
||||||
java/io/ObjectStreamClass.java \
|
java/io/ObjectStreamClass.java \
|
||||||
java/io/ObjectStreamConstants.java \
|
java/io/ObjectStreamConstants.java \
|
||||||
|
java/io/ObjectStreamException.java \
|
||||||
java/io/ObjectStreamField.java \
|
java/io/ObjectStreamField.java \
|
||||||
|
java/io/OptionalDataException.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/Replaceable.java \
|
java/io/Replaceable.java \
|
||||||
java/io/Resolvable.java \
|
java/io/Resolvable.java \
|
||||||
|
java/io/SequenceInputStream.java \
|
||||||
|
java/io/Serializable.java \
|
||||||
java/io/SerializablePermission.java \
|
java/io/SerializablePermission.java \
|
||||||
|
java/io/StreamCorruptedException.java \
|
||||||
|
java/io/StreamTokenizer.java \
|
||||||
|
java/io/StringBufferInputStream.java \
|
||||||
|
java/io/StringReader.java \
|
||||||
|
java/io/StringWriter.java \
|
||||||
|
java/io/SyncFailedException.java \
|
||||||
|
java/io/UTFDataFormatException.java \
|
||||||
|
java/io/UnsupportedEncodingException.java \
|
||||||
java/io/WriteAbortedException.java \
|
java/io/WriteAbortedException.java \
|
||||||
java/io/PipedInputStream.java \
|
java/io/Writer.java \
|
||||||
java/lang/reflect/Constructor.java \
|
|
||||||
java/lang/reflect/AccessibleObject.java \
|
|
||||||
java/lang/reflect/Array.java \
|
|
||||||
java/lang/reflect/Method.java \
|
|
||||||
java/lang/reflect/Field.java \
|
|
||||||
java/lang/reflect/InvocationTargetException.java \
|
|
||||||
java/lang/reflect/Member.java \
|
|
||||||
java/lang/reflect/Modifier.java \
|
|
||||||
java/lang/AbstractMethodError.java \
|
java/lang/AbstractMethodError.java \
|
||||||
java/lang/ArithmeticException.java \
|
java/lang/ArithmeticException.java \
|
||||||
java/lang/ArrayIndexOutOfBoundsException.java \
|
java/lang/ArrayIndexOutOfBoundsException.java \
|
||||||
|
@ -860,10 +852,10 @@ java/lang/IllegalMonitorStateException.java \
|
||||||
java/lang/IllegalStateException.java \
|
java/lang/IllegalStateException.java \
|
||||||
java/lang/IllegalThreadStateException.java \
|
java/lang/IllegalThreadStateException.java \
|
||||||
java/lang/IncompatibleClassChangeError.java \
|
java/lang/IncompatibleClassChangeError.java \
|
||||||
java/lang/InstantiationError.java \
|
|
||||||
java/lang/Integer.java \
|
|
||||||
java/lang/IndexOutOfBoundsException.java \
|
java/lang/IndexOutOfBoundsException.java \
|
||||||
|
java/lang/InstantiationError.java \
|
||||||
java/lang/InstantiationException.java \
|
java/lang/InstantiationException.java \
|
||||||
|
java/lang/Integer.java \
|
||||||
java/lang/InternalError.java \
|
java/lang/InternalError.java \
|
||||||
java/lang/InterruptedException.java \
|
java/lang/InterruptedException.java \
|
||||||
java/lang/LinkageError.java \
|
java/lang/LinkageError.java \
|
||||||
|
@ -901,126 +893,54 @@ java/lang/UnsupportedOperationException.java \
|
||||||
java/lang/VerifyError.java \
|
java/lang/VerifyError.java \
|
||||||
java/lang/VirtualMachineError.java \
|
java/lang/VirtualMachineError.java \
|
||||||
java/lang/Void.java \
|
java/lang/Void.java \
|
||||||
|
java/lang/reflect/AccessibleObject.java \
|
||||||
|
java/lang/reflect/Array.java \
|
||||||
|
java/lang/reflect/Constructor.java \
|
||||||
|
java/lang/reflect/Field.java \
|
||||||
|
java/lang/reflect/InvocationTargetException.java \
|
||||||
|
java/lang/reflect/Member.java \
|
||||||
|
java/lang/reflect/Method.java \
|
||||||
|
java/lang/reflect/Modifier.java \
|
||||||
|
java/math/BigDecimal.java \
|
||||||
|
java/math/BigInteger.java \
|
||||||
java/net/BindException.java \
|
java/net/BindException.java \
|
||||||
java/net/ConnectException.java \
|
java/net/ConnectException.java \
|
||||||
java/net/ContentHandler.java \
|
java/net/ContentHandler.java \
|
||||||
java/net/ContentHandlerFactory.java \
|
java/net/ContentHandlerFactory.java \
|
||||||
|
java/net/DatagramPacket.java \
|
||||||
|
java/net/DatagramSocket.java \
|
||||||
|
java/net/DatagramSocketImpl.java \
|
||||||
java/net/FileNameMap.java \
|
java/net/FileNameMap.java \
|
||||||
java/net/HttpURLConnection.java \
|
java/net/HttpURLConnection.java \
|
||||||
java/net/InetAddress.java \
|
java/net/InetAddress.java \
|
||||||
|
java/net/JarURLConnection.java \
|
||||||
java/net/MalformedURLException.java \
|
java/net/MalformedURLException.java \
|
||||||
|
java/net/MulticastSocket.java \
|
||||||
java/net/NoRouteToHostException.java \
|
java/net/NoRouteToHostException.java \
|
||||||
|
java/net/PlainDatagramSocketImpl.java \
|
||||||
java/net/PlainSocketImpl.java \
|
java/net/PlainSocketImpl.java \
|
||||||
java/net/ProtocolException.java \
|
java/net/ProtocolException.java \
|
||||||
java/net/ServerSocket.java \
|
java/net/ServerSocket.java \
|
||||||
java/net/URL.java \
|
|
||||||
java/net/Socket.java \
|
java/net/Socket.java \
|
||||||
java/net/SocketException.java \
|
java/net/SocketException.java \
|
||||||
java/net/SocketImpl.java \
|
java/net/SocketImpl.java \
|
||||||
java/net/SocketImplFactory.java \
|
java/net/SocketImplFactory.java \
|
||||||
|
java/net/SocketOptions.java \
|
||||||
|
java/net/URL.java \
|
||||||
|
java/net/URLClassLoader.java \
|
||||||
java/net/URLConnection.java \
|
java/net/URLConnection.java \
|
||||||
|
java/net/URLDecoder.java \
|
||||||
|
java/net/URLEncoder.java \
|
||||||
java/net/URLStreamHandler.java \
|
java/net/URLStreamHandler.java \
|
||||||
java/net/URLStreamHandlerFactory.java \
|
java/net/URLStreamHandlerFactory.java \
|
||||||
java/net/UnknownHostException.java \
|
java/net/UnknownHostException.java \
|
||||||
java/net/UnknownServiceException.java \
|
java/net/UnknownServiceException.java \
|
||||||
java/net/URLDecoder.java \
|
|
||||||
java/net/URLEncoder.java \
|
|
||||||
java/net/DatagramPacket.java \
|
|
||||||
java/net/DatagramSocket.java \
|
|
||||||
java/net/DatagramSocketImpl.java \
|
|
||||||
java/net/MulticastSocket.java \
|
|
||||||
java/net/PlainDatagramSocketImpl.java \
|
|
||||||
java/net/SocketOptions.java \
|
|
||||||
java/net/JarURLConnection.java \
|
|
||||||
java/net/URLClassLoader.java \
|
|
||||||
java/text/Collator.java \
|
|
||||||
java/text/BreakIterator.java \
|
|
||||||
java/text/CharacterIterator.java \
|
|
||||||
java/text/ChoiceFormat.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/ParseException.java \
|
|
||||||
java/text/ParsePosition.java \
|
|
||||||
java/text/SimpleDateFormat.java \
|
|
||||||
java/text/StringCharacterIterator.java \
|
|
||||||
java/text/CollationElementIterator.java \
|
|
||||||
java/text/CollationKey.java \
|
|
||||||
java/text/RuleBasedCollator.java \
|
|
||||||
java/util/zip/Adler32.java \
|
|
||||||
java/util/zip/CRC32.java \
|
|
||||||
java/util/zip/Checksum.java \
|
|
||||||
java/util/zip/Deflater.java \
|
|
||||||
java/util/zip/DeflaterOutputStream.java \
|
|
||||||
java/util/zip/ZipConstants.java \
|
|
||||||
java/util/zip/ZipEntry.java \
|
|
||||||
java/util/zip/ZipException.java \
|
|
||||||
java/util/zip/ZipFile.java \
|
|
||||||
java/util/zip/ZipOutputStream.java \
|
|
||||||
java/util/zip/InflaterInputStream.java \
|
|
||||||
java/util/zip/ZipInputStream.java \
|
|
||||||
java/util/zip/DataFormatException.java \
|
|
||||||
java/util/zip/CheckedInputStream.java \
|
|
||||||
java/util/zip/CheckedOutputStream.java \
|
|
||||||
java/util/zip/Inflater.java \
|
|
||||||
java/util/zip/GZIPInputStream.java \
|
|
||||||
java/util/zip/GZIPOutputStream.java \
|
|
||||||
java/util/jar/JarEntry.java \
|
|
||||||
java/util/jar/JarFile.java \
|
|
||||||
java/util/jar/JarInputStream.java \
|
|
||||||
java/util/BitSet.java \
|
|
||||||
java/util/Calendar.java \
|
|
||||||
java/util/ConcurrentModificationException.java \
|
|
||||||
java/util/Date.java \
|
|
||||||
java/util/Dictionary.java \
|
|
||||||
java/util/EmptyStackException.java \
|
|
||||||
java/util/Enumeration.java \
|
|
||||||
java/util/EventListener.java \
|
|
||||||
java/util/EventObject.java \
|
|
||||||
java/util/GregorianCalendar.java \
|
|
||||||
java/util/Hashtable.java \
|
|
||||||
java/util/ListResourceBundle.java \
|
|
||||||
java/util/Locale.java \
|
|
||||||
java/util/MissingResourceException.java \
|
|
||||||
java/util/NoSuchElementException.java \
|
|
||||||
java/util/Observable.java \
|
|
||||||
java/util/Observer.java \
|
|
||||||
java/util/Properties.java \
|
|
||||||
java/util/Random.java \
|
|
||||||
java/util/ResourceBundle.java \
|
|
||||||
java/util/SimpleTimeZone.java \
|
|
||||||
java/util/Stack.java \
|
|
||||||
java/util/StringTokenizer.java \
|
|
||||||
java/util/TimeZone.java \
|
|
||||||
java/util/TooManyListenersException.java \
|
|
||||||
java/util/Vector.java \
|
|
||||||
java/util/List.java \
|
|
||||||
java/util/Collection.java \
|
|
||||||
java/util/Comparator.java \
|
|
||||||
java/util/Iterator.java \
|
|
||||||
java/util/PropertyResourceBundle.java \
|
|
||||||
java/util/Arrays.java \
|
|
||||||
java/util/ListIterator.java \
|
|
||||||
java/util/AbstractCollection.java \
|
|
||||||
java/util/AbstractList.java \
|
|
||||||
java/security/MessageDigest.java \
|
|
||||||
java/security/NoSuchAlgorithmException.java \
|
|
||||||
java/security/SecureClassLoader.java \
|
|
||||||
java/security/interfaces/DSAKey.java \
|
|
||||||
java/security/interfaces/DSAParams.java \
|
|
||||||
java/security/interfaces/DSAPrivateKey.java \
|
|
||||||
java/security/interfaces/DSAPublicKey.java \
|
|
||||||
java/security/interfaces/RSAPrivateCrtKey.java \
|
|
||||||
java/security/interfaces/RSAPrivateKey.java \
|
|
||||||
java/security/interfaces/RSAPublicKey.java \
|
|
||||||
java/security/AlgorithmParameterGeneratorSpi.java \
|
java/security/AlgorithmParameterGeneratorSpi.java \
|
||||||
|
java/security/BasicPermission.java \
|
||||||
java/security/DigestException.java \
|
java/security/DigestException.java \
|
||||||
|
java/security/DigestOutputStream.java \
|
||||||
java/security/GeneralSecurityException.java \
|
java/security/GeneralSecurityException.java \
|
||||||
|
java/security/Guard.java \
|
||||||
java/security/InvalidAlgorithmParameterException.java \
|
java/security/InvalidAlgorithmParameterException.java \
|
||||||
java/security/InvalidKeyException.java \
|
java/security/InvalidKeyException.java \
|
||||||
java/security/InvalidParameterException.java \
|
java/security/InvalidParameterException.java \
|
||||||
|
@ -1029,15 +949,41 @@ java/security/KeyException.java \
|
||||||
java/security/KeyPair.java \
|
java/security/KeyPair.java \
|
||||||
java/security/KeyPairGenerator.java \
|
java/security/KeyPairGenerator.java \
|
||||||
java/security/KeyPairGeneratorSpi.java \
|
java/security/KeyPairGeneratorSpi.java \
|
||||||
|
java/security/MessageDigest.java \
|
||||||
|
java/security/NoSuchAlgorithmException.java \
|
||||||
java/security/NoSuchProviderException.java \
|
java/security/NoSuchProviderException.java \
|
||||||
|
java/security/Permission.java \
|
||||||
|
java/security/PermissionCollection.java \
|
||||||
java/security/Principal.java \
|
java/security/Principal.java \
|
||||||
java/security/PrivateKey.java \
|
java/security/PrivateKey.java \
|
||||||
java/security/Provider.java \
|
java/security/Provider.java \
|
||||||
java/security/PublicKey.java \
|
java/security/PublicKey.java \
|
||||||
|
java/security/SecureClassLoader.java \
|
||||||
java/security/SecureRandom.java \
|
java/security/SecureRandom.java \
|
||||||
java/security/Security.java \
|
java/security/Security.java \
|
||||||
java/security/Signature.java \
|
java/security/Signature.java \
|
||||||
java/security/SignatureException.java \
|
java/security/SignatureException.java \
|
||||||
|
java/security/cert/CRL.java \
|
||||||
|
java/security/cert/CRLException.java \
|
||||||
|
java/security/cert/Certificate.java \
|
||||||
|
java/security/cert/CertificateEncodingException.java \
|
||||||
|
java/security/cert/CertificateException.java \
|
||||||
|
java/security/cert/CertificateExpiredException.java \
|
||||||
|
java/security/cert/CertificateFactory.java \
|
||||||
|
java/security/cert/CertificateFactorySpi.java \
|
||||||
|
java/security/cert/CertificateNotYetValidException.java \
|
||||||
|
java/security/cert/CertificateParsingException.java \
|
||||||
|
java/security/cert/X509CRL.java \
|
||||||
|
java/security/cert/X509CRLEntry.java \
|
||||||
|
java/security/cert/X509Certificate.java \
|
||||||
|
java/security/cert/X509Extension.java \
|
||||||
|
java/security/interfaces/DSAKey.java \
|
||||||
|
java/security/interfaces/DSAParams.java \
|
||||||
|
java/security/interfaces/DSAPrivateKey.java \
|
||||||
|
java/security/interfaces/DSAPublicKey.java \
|
||||||
|
java/security/interfaces/RSAPrivateCrtKey.java \
|
||||||
|
java/security/interfaces/RSAPrivateKey.java \
|
||||||
|
java/security/interfaces/RSAPublicKey.java \
|
||||||
java/security/spec/AlgorithmParameterSpec.java \
|
java/security/spec/AlgorithmParameterSpec.java \
|
||||||
java/security/spec/InvalidKeySpecException.java \
|
java/security/spec/InvalidKeySpecException.java \
|
||||||
java/security/spec/InvalidParameterSpecException.java \
|
java/security/spec/InvalidParameterSpecException.java \
|
||||||
|
@ -1045,13 +991,6 @@ java/security/spec/KeySpec.java \
|
||||||
java/security/spec/RSAPrivateCrtKeySpec.java \
|
java/security/spec/RSAPrivateCrtKeySpec.java \
|
||||||
java/security/spec/RSAPrivateKeySpec.java \
|
java/security/spec/RSAPrivateKeySpec.java \
|
||||||
java/security/spec/RSAPublicKeySpec.java \
|
java/security/spec/RSAPublicKeySpec.java \
|
||||||
java/security/BasicPermission.java \
|
|
||||||
java/security/Guard.java \
|
|
||||||
java/security/DigestOutputStream.java \
|
|
||||||
java/security/Permission.java \
|
|
||||||
java/security/PermissionCollection.java \
|
|
||||||
java/math/BigDecimal.java \
|
|
||||||
java/math/BigInteger.java \
|
|
||||||
java/sql/CallableStatement.java \
|
java/sql/CallableStatement.java \
|
||||||
java/sql/Connection.java \
|
java/sql/Connection.java \
|
||||||
java/sql/DataTruncation.java \
|
java/sql/DataTruncation.java \
|
||||||
|
@ -1068,7 +1007,91 @@ java/sql/SQLWarning.java \
|
||||||
java/sql/Statement.java \
|
java/sql/Statement.java \
|
||||||
java/sql/Time.java \
|
java/sql/Time.java \
|
||||||
java/sql/Timestamp.java \
|
java/sql/Timestamp.java \
|
||||||
java/sql/Types.java
|
java/sql/Types.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/ParseException.java \
|
||||||
|
java/text/ParsePosition.java \
|
||||||
|
java/text/RuleBasedCollator.java \
|
||||||
|
java/text/SimpleDateFormat.java \
|
||||||
|
java/text/StringCharacterIterator.java \
|
||||||
|
java/util/AbstractCollection.java \
|
||||||
|
java/util/AbstractList.java \
|
||||||
|
java/util/AbstractSet.java \
|
||||||
|
java/util/Arrays.java \
|
||||||
|
java/util/BasicMapEntry.java \
|
||||||
|
java/util/BitSet.java \
|
||||||
|
java/util/Bucket.java \
|
||||||
|
java/util/Calendar.java \
|
||||||
|
java/util/Collection.java \
|
||||||
|
java/util/Comparator.java \
|
||||||
|
java/util/ConcurrentModificationException.java \
|
||||||
|
java/util/Date.java \
|
||||||
|
java/util/Dictionary.java \
|
||||||
|
java/util/EmptyStackException.java \
|
||||||
|
java/util/Enumeration.java \
|
||||||
|
java/util/EventListener.java \
|
||||||
|
java/util/EventObject.java \
|
||||||
|
java/util/GregorianCalendar.java \
|
||||||
|
java/util/Hashtable.java \
|
||||||
|
java/util/Iterator.java \
|
||||||
|
java/util/List.java \
|
||||||
|
java/util/ListIterator.java \
|
||||||
|
java/util/ListResourceBundle.java \
|
||||||
|
java/util/Locale.java \
|
||||||
|
java/util/Map.java \
|
||||||
|
java/util/MissingResourceException.java \
|
||||||
|
java/util/NoSuchElementException.java \
|
||||||
|
java/util/Observable.java \
|
||||||
|
java/util/Observer.java \
|
||||||
|
java/util/Properties.java \
|
||||||
|
java/util/PropertyResourceBundle.java \
|
||||||
|
java/util/Random.java \
|
||||||
|
java/util/ResourceBundle.java \
|
||||||
|
java/util/Set.java \
|
||||||
|
java/util/SimpleTimeZone.java \
|
||||||
|
java/util/Stack.java \
|
||||||
|
java/util/StringTokenizer.java \
|
||||||
|
java/util/TimeZone.java \
|
||||||
|
java/util/TooManyListenersException.java \
|
||||||
|
java/util/Vector.java \
|
||||||
|
java/util/jar/Attributes.java \
|
||||||
|
java/util/jar/JarEntry.java \
|
||||||
|
java/util/jar/JarException.java \
|
||||||
|
java/util/jar/JarFile.java \
|
||||||
|
java/util/jar/JarInputStream.java \
|
||||||
|
java/util/jar/JarOutputStream.java \
|
||||||
|
java/util/jar/Manifest.java \
|
||||||
|
java/util/zip/Adler32.java \
|
||||||
|
java/util/zip/CRC32.java \
|
||||||
|
java/util/zip/CheckedInputStream.java \
|
||||||
|
java/util/zip/CheckedOutputStream.java \
|
||||||
|
java/util/zip/Checksum.java \
|
||||||
|
java/util/zip/DataFormatException.java \
|
||||||
|
java/util/zip/Deflater.java \
|
||||||
|
java/util/zip/DeflaterOutputStream.java \
|
||||||
|
java/util/zip/GZIPInputStream.java \
|
||||||
|
java/util/zip/GZIPOutputStream.java \
|
||||||
|
java/util/zip/Inflater.java \
|
||||||
|
java/util/zip/InflaterInputStream.java \
|
||||||
|
java/util/zip/ZipConstants.java \
|
||||||
|
java/util/zip/ZipEntry.java \
|
||||||
|
java/util/zip/ZipException.java \
|
||||||
|
java/util/zip/ZipFile.java \
|
||||||
|
java/util/zip/ZipInputStream.java \
|
||||||
|
java/util/zip/ZipOutputStream.java
|
||||||
|
|
||||||
java_source_files = $(ordinary_java_source_files) $(special_java_source_files)
|
java_source_files = $(ordinary_java_source_files) $(special_java_source_files)
|
||||||
|
|
||||||
|
|
|
@ -488,12 +488,20 @@ built_java_source_files = java/lang/ConcreteProcess.java
|
||||||
|
|
||||||
ordinary_java_source_files = $(convert_source_files) \
|
ordinary_java_source_files = $(convert_source_files) \
|
||||||
$(awt_java_source_files) \
|
$(awt_java_source_files) \
|
||||||
gnu/gcj/protocol/http/Connection.java \
|
gnu/gcj/RawData.java \
|
||||||
gnu/gcj/protocol/http/Handler.java \
|
gnu/gcj/io/DefaultMimeTypes.java \
|
||||||
|
gnu/gcj/io/MimeTypes.java \
|
||||||
|
gnu/gcj/io/SimpleSHSStream.java \
|
||||||
|
gnu/gcj/jni/NativeThread.java \
|
||||||
|
gnu/gcj/math/MPN.java \
|
||||||
gnu/gcj/protocol/file/Connection.java \
|
gnu/gcj/protocol/file/Connection.java \
|
||||||
gnu/gcj/protocol/file/Handler.java \
|
gnu/gcj/protocol/file/Handler.java \
|
||||||
|
gnu/gcj/protocol/http/Connection.java \
|
||||||
|
gnu/gcj/protocol/http/Handler.java \
|
||||||
gnu/gcj/protocol/jar/Connection.java \
|
gnu/gcj/protocol/jar/Connection.java \
|
||||||
gnu/gcj/protocol/jar/Handler.java \
|
gnu/gcj/protocol/jar/Handler.java \
|
||||||
|
gnu/gcj/runtime/FirstThread.java \
|
||||||
|
gnu/gcj/runtime/VMClassLoader.java \
|
||||||
gnu/gcj/text/BaseBreakIterator.java \
|
gnu/gcj/text/BaseBreakIterator.java \
|
||||||
gnu/gcj/text/CharacterBreakIterator.java \
|
gnu/gcj/text/CharacterBreakIterator.java \
|
||||||
gnu/gcj/text/LineBreakIterator.java \
|
gnu/gcj/text/LineBreakIterator.java \
|
||||||
|
@ -502,23 +510,16 @@ gnu/gcj/text/LocaleData_en_US.java \
|
||||||
gnu/gcj/text/SentenceBreakIterator.java \
|
gnu/gcj/text/SentenceBreakIterator.java \
|
||||||
gnu/gcj/text/WordBreakIterator.java \
|
gnu/gcj/text/WordBreakIterator.java \
|
||||||
gnu/gcj/util/EnumerationChain.java \
|
gnu/gcj/util/EnumerationChain.java \
|
||||||
gnu/gcj/RawData.java \
|
|
||||||
gnu/gcj/math/MPN.java \
|
|
||||||
gnu/gcj/runtime/VMClassLoader.java \
|
|
||||||
gnu/gcj/runtime/FirstThread.java \
|
|
||||||
gnu/gcj/jni/NativeThread.java \
|
|
||||||
gnu/gcj/io/DefaultMimeTypes.java \
|
|
||||||
gnu/gcj/io/MimeTypes.java \
|
|
||||||
gnu/gcj/io/SimpleSHSStream.java \
|
|
||||||
gnu/java/io/ClassLoaderObjectInputStream.java \
|
gnu/java/io/ClassLoaderObjectInputStream.java \
|
||||||
gnu/java/io/NullOutputStream.java \
|
gnu/java/io/NullOutputStream.java \
|
||||||
gnu/java/io/ObjectIdentityWrapper.java \
|
gnu/java/io/ObjectIdentityWrapper.java \
|
||||||
gnu/java/lang/reflect/TypeSignature.java \
|
|
||||||
gnu/java/lang/ArrayHelper.java \
|
gnu/java/lang/ArrayHelper.java \
|
||||||
gnu/java/lang/ClassHelper.java \
|
gnu/java/lang/ClassHelper.java \
|
||||||
|
gnu/java/lang/reflect/TypeSignature.java \
|
||||||
gnu/java/security/provider/Gnu.java \
|
gnu/java/security/provider/Gnu.java \
|
||||||
gnu/java/security/provider/SHA.java \
|
gnu/java/security/provider/SHA.java \
|
||||||
gnu/java/security/provider/SHA1PRNG.java \
|
gnu/java/security/provider/SHA1PRNG.java \
|
||||||
|
java/io/BlockDataException.java \
|
||||||
java/io/BufferedInputStream.java \
|
java/io/BufferedInputStream.java \
|
||||||
java/io/BufferedOutputStream.java \
|
java/io/BufferedOutputStream.java \
|
||||||
java/io/BufferedReader.java \
|
java/io/BufferedReader.java \
|
||||||
|
@ -533,7 +534,9 @@ java/io/DataInputStream.java \
|
||||||
java/io/DataOutput.java \
|
java/io/DataOutput.java \
|
||||||
java/io/DataOutputStream.java \
|
java/io/DataOutputStream.java \
|
||||||
java/io/EOFException.java \
|
java/io/EOFException.java \
|
||||||
|
java/io/Externalizable.java \
|
||||||
java/io/File.java \
|
java/io/File.java \
|
||||||
|
java/io/FileDescriptor.java \
|
||||||
java/io/FileInputStream.java \
|
java/io/FileInputStream.java \
|
||||||
java/io/FileNotFoundException.java \
|
java/io/FileNotFoundException.java \
|
||||||
java/io/FileOutputStream.java \
|
java/io/FileOutputStream.java \
|
||||||
|
@ -548,37 +551,10 @@ java/io/IOException.java \
|
||||||
java/io/InputStream.java \
|
java/io/InputStream.java \
|
||||||
java/io/InputStreamReader.java \
|
java/io/InputStreamReader.java \
|
||||||
java/io/InterruptedIOException.java \
|
java/io/InterruptedIOException.java \
|
||||||
java/io/LineNumberInputStream.java \
|
|
||||||
java/io/LineNumberReader.java \
|
|
||||||
java/io/OutputStream.java \
|
|
||||||
java/io/OutputStreamWriter.java \
|
|
||||||
java/io/Externalizable.java \
|
|
||||||
java/io/FileDescriptor.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/StreamTokenizer.java \
|
|
||||||
java/io/StringBufferInputStream.java \
|
|
||||||
java/io/StringReader.java \
|
|
||||||
java/io/StringWriter.java \
|
|
||||||
java/io/SyncFailedException.java \
|
|
||||||
java/io/UTFDataFormatException.java \
|
|
||||||
java/io/UnsupportedEncodingException.java \
|
|
||||||
java/io/Writer.java \
|
|
||||||
java/io/ObjectStreamException.java \
|
|
||||||
java/io/OptionalDataException.java \
|
|
||||||
java/io/StreamCorruptedException.java \
|
|
||||||
java/io/BlockDataException.java \
|
|
||||||
java/io/InvalidClassException.java \
|
java/io/InvalidClassException.java \
|
||||||
java/io/InvalidObjectException.java \
|
java/io/InvalidObjectException.java \
|
||||||
|
java/io/LineNumberInputStream.java \
|
||||||
|
java/io/LineNumberReader.java \
|
||||||
java/io/NotActiveException.java \
|
java/io/NotActiveException.java \
|
||||||
java/io/NotSerializableException.java \
|
java/io/NotSerializableException.java \
|
||||||
java/io/ObjectInput.java \
|
java/io/ObjectInput.java \
|
||||||
|
@ -588,20 +564,36 @@ java/io/ObjectOutput.java \
|
||||||
java/io/ObjectOutputStream.java \
|
java/io/ObjectOutputStream.java \
|
||||||
java/io/ObjectStreamClass.java \
|
java/io/ObjectStreamClass.java \
|
||||||
java/io/ObjectStreamConstants.java \
|
java/io/ObjectStreamConstants.java \
|
||||||
|
java/io/ObjectStreamException.java \
|
||||||
java/io/ObjectStreamField.java \
|
java/io/ObjectStreamField.java \
|
||||||
|
java/io/OptionalDataException.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/Replaceable.java \
|
java/io/Replaceable.java \
|
||||||
java/io/Resolvable.java \
|
java/io/Resolvable.java \
|
||||||
|
java/io/SequenceInputStream.java \
|
||||||
|
java/io/Serializable.java \
|
||||||
java/io/SerializablePermission.java \
|
java/io/SerializablePermission.java \
|
||||||
|
java/io/StreamCorruptedException.java \
|
||||||
|
java/io/StreamTokenizer.java \
|
||||||
|
java/io/StringBufferInputStream.java \
|
||||||
|
java/io/StringReader.java \
|
||||||
|
java/io/StringWriter.java \
|
||||||
|
java/io/SyncFailedException.java \
|
||||||
|
java/io/UTFDataFormatException.java \
|
||||||
|
java/io/UnsupportedEncodingException.java \
|
||||||
java/io/WriteAbortedException.java \
|
java/io/WriteAbortedException.java \
|
||||||
java/io/PipedInputStream.java \
|
java/io/Writer.java \
|
||||||
java/lang/reflect/Constructor.java \
|
|
||||||
java/lang/reflect/AccessibleObject.java \
|
|
||||||
java/lang/reflect/Array.java \
|
|
||||||
java/lang/reflect/Method.java \
|
|
||||||
java/lang/reflect/Field.java \
|
|
||||||
java/lang/reflect/InvocationTargetException.java \
|
|
||||||
java/lang/reflect/Member.java \
|
|
||||||
java/lang/reflect/Modifier.java \
|
|
||||||
java/lang/AbstractMethodError.java \
|
java/lang/AbstractMethodError.java \
|
||||||
java/lang/ArithmeticException.java \
|
java/lang/ArithmeticException.java \
|
||||||
java/lang/ArrayIndexOutOfBoundsException.java \
|
java/lang/ArrayIndexOutOfBoundsException.java \
|
||||||
|
@ -630,10 +622,10 @@ java/lang/IllegalMonitorStateException.java \
|
||||||
java/lang/IllegalStateException.java \
|
java/lang/IllegalStateException.java \
|
||||||
java/lang/IllegalThreadStateException.java \
|
java/lang/IllegalThreadStateException.java \
|
||||||
java/lang/IncompatibleClassChangeError.java \
|
java/lang/IncompatibleClassChangeError.java \
|
||||||
java/lang/InstantiationError.java \
|
|
||||||
java/lang/Integer.java \
|
|
||||||
java/lang/IndexOutOfBoundsException.java \
|
java/lang/IndexOutOfBoundsException.java \
|
||||||
|
java/lang/InstantiationError.java \
|
||||||
java/lang/InstantiationException.java \
|
java/lang/InstantiationException.java \
|
||||||
|
java/lang/Integer.java \
|
||||||
java/lang/InternalError.java \
|
java/lang/InternalError.java \
|
||||||
java/lang/InterruptedException.java \
|
java/lang/InterruptedException.java \
|
||||||
java/lang/LinkageError.java \
|
java/lang/LinkageError.java \
|
||||||
|
@ -671,126 +663,54 @@ java/lang/UnsupportedOperationException.java \
|
||||||
java/lang/VerifyError.java \
|
java/lang/VerifyError.java \
|
||||||
java/lang/VirtualMachineError.java \
|
java/lang/VirtualMachineError.java \
|
||||||
java/lang/Void.java \
|
java/lang/Void.java \
|
||||||
|
java/lang/reflect/AccessibleObject.java \
|
||||||
|
java/lang/reflect/Array.java \
|
||||||
|
java/lang/reflect/Constructor.java \
|
||||||
|
java/lang/reflect/Field.java \
|
||||||
|
java/lang/reflect/InvocationTargetException.java \
|
||||||
|
java/lang/reflect/Member.java \
|
||||||
|
java/lang/reflect/Method.java \
|
||||||
|
java/lang/reflect/Modifier.java \
|
||||||
|
java/math/BigDecimal.java \
|
||||||
|
java/math/BigInteger.java \
|
||||||
java/net/BindException.java \
|
java/net/BindException.java \
|
||||||
java/net/ConnectException.java \
|
java/net/ConnectException.java \
|
||||||
java/net/ContentHandler.java \
|
java/net/ContentHandler.java \
|
||||||
java/net/ContentHandlerFactory.java \
|
java/net/ContentHandlerFactory.java \
|
||||||
|
java/net/DatagramPacket.java \
|
||||||
|
java/net/DatagramSocket.java \
|
||||||
|
java/net/DatagramSocketImpl.java \
|
||||||
java/net/FileNameMap.java \
|
java/net/FileNameMap.java \
|
||||||
java/net/HttpURLConnection.java \
|
java/net/HttpURLConnection.java \
|
||||||
java/net/InetAddress.java \
|
java/net/InetAddress.java \
|
||||||
|
java/net/JarURLConnection.java \
|
||||||
java/net/MalformedURLException.java \
|
java/net/MalformedURLException.java \
|
||||||
|
java/net/MulticastSocket.java \
|
||||||
java/net/NoRouteToHostException.java \
|
java/net/NoRouteToHostException.java \
|
||||||
|
java/net/PlainDatagramSocketImpl.java \
|
||||||
java/net/PlainSocketImpl.java \
|
java/net/PlainSocketImpl.java \
|
||||||
java/net/ProtocolException.java \
|
java/net/ProtocolException.java \
|
||||||
java/net/ServerSocket.java \
|
java/net/ServerSocket.java \
|
||||||
java/net/URL.java \
|
|
||||||
java/net/Socket.java \
|
java/net/Socket.java \
|
||||||
java/net/SocketException.java \
|
java/net/SocketException.java \
|
||||||
java/net/SocketImpl.java \
|
java/net/SocketImpl.java \
|
||||||
java/net/SocketImplFactory.java \
|
java/net/SocketImplFactory.java \
|
||||||
|
java/net/SocketOptions.java \
|
||||||
|
java/net/URL.java \
|
||||||
|
java/net/URLClassLoader.java \
|
||||||
java/net/URLConnection.java \
|
java/net/URLConnection.java \
|
||||||
|
java/net/URLDecoder.java \
|
||||||
|
java/net/URLEncoder.java \
|
||||||
java/net/URLStreamHandler.java \
|
java/net/URLStreamHandler.java \
|
||||||
java/net/URLStreamHandlerFactory.java \
|
java/net/URLStreamHandlerFactory.java \
|
||||||
java/net/UnknownHostException.java \
|
java/net/UnknownHostException.java \
|
||||||
java/net/UnknownServiceException.java \
|
java/net/UnknownServiceException.java \
|
||||||
java/net/URLDecoder.java \
|
|
||||||
java/net/URLEncoder.java \
|
|
||||||
java/net/DatagramPacket.java \
|
|
||||||
java/net/DatagramSocket.java \
|
|
||||||
java/net/DatagramSocketImpl.java \
|
|
||||||
java/net/MulticastSocket.java \
|
|
||||||
java/net/PlainDatagramSocketImpl.java \
|
|
||||||
java/net/SocketOptions.java \
|
|
||||||
java/net/JarURLConnection.java \
|
|
||||||
java/net/URLClassLoader.java \
|
|
||||||
java/text/Collator.java \
|
|
||||||
java/text/BreakIterator.java \
|
|
||||||
java/text/CharacterIterator.java \
|
|
||||||
java/text/ChoiceFormat.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/ParseException.java \
|
|
||||||
java/text/ParsePosition.java \
|
|
||||||
java/text/SimpleDateFormat.java \
|
|
||||||
java/text/StringCharacterIterator.java \
|
|
||||||
java/text/CollationElementIterator.java \
|
|
||||||
java/text/CollationKey.java \
|
|
||||||
java/text/RuleBasedCollator.java \
|
|
||||||
java/util/zip/Adler32.java \
|
|
||||||
java/util/zip/CRC32.java \
|
|
||||||
java/util/zip/Checksum.java \
|
|
||||||
java/util/zip/Deflater.java \
|
|
||||||
java/util/zip/DeflaterOutputStream.java \
|
|
||||||
java/util/zip/ZipConstants.java \
|
|
||||||
java/util/zip/ZipEntry.java \
|
|
||||||
java/util/zip/ZipException.java \
|
|
||||||
java/util/zip/ZipFile.java \
|
|
||||||
java/util/zip/ZipOutputStream.java \
|
|
||||||
java/util/zip/InflaterInputStream.java \
|
|
||||||
java/util/zip/ZipInputStream.java \
|
|
||||||
java/util/zip/DataFormatException.java \
|
|
||||||
java/util/zip/CheckedInputStream.java \
|
|
||||||
java/util/zip/CheckedOutputStream.java \
|
|
||||||
java/util/zip/Inflater.java \
|
|
||||||
java/util/zip/GZIPInputStream.java \
|
|
||||||
java/util/zip/GZIPOutputStream.java \
|
|
||||||
java/util/jar/JarEntry.java \
|
|
||||||
java/util/jar/JarFile.java \
|
|
||||||
java/util/jar/JarInputStream.java \
|
|
||||||
java/util/BitSet.java \
|
|
||||||
java/util/Calendar.java \
|
|
||||||
java/util/ConcurrentModificationException.java \
|
|
||||||
java/util/Date.java \
|
|
||||||
java/util/Dictionary.java \
|
|
||||||
java/util/EmptyStackException.java \
|
|
||||||
java/util/Enumeration.java \
|
|
||||||
java/util/EventListener.java \
|
|
||||||
java/util/EventObject.java \
|
|
||||||
java/util/GregorianCalendar.java \
|
|
||||||
java/util/Hashtable.java \
|
|
||||||
java/util/ListResourceBundle.java \
|
|
||||||
java/util/Locale.java \
|
|
||||||
java/util/MissingResourceException.java \
|
|
||||||
java/util/NoSuchElementException.java \
|
|
||||||
java/util/Observable.java \
|
|
||||||
java/util/Observer.java \
|
|
||||||
java/util/Properties.java \
|
|
||||||
java/util/Random.java \
|
|
||||||
java/util/ResourceBundle.java \
|
|
||||||
java/util/SimpleTimeZone.java \
|
|
||||||
java/util/Stack.java \
|
|
||||||
java/util/StringTokenizer.java \
|
|
||||||
java/util/TimeZone.java \
|
|
||||||
java/util/TooManyListenersException.java \
|
|
||||||
java/util/Vector.java \
|
|
||||||
java/util/List.java \
|
|
||||||
java/util/Collection.java \
|
|
||||||
java/util/Comparator.java \
|
|
||||||
java/util/Iterator.java \
|
|
||||||
java/util/PropertyResourceBundle.java \
|
|
||||||
java/util/Arrays.java \
|
|
||||||
java/util/ListIterator.java \
|
|
||||||
java/util/AbstractCollection.java \
|
|
||||||
java/util/AbstractList.java \
|
|
||||||
java/security/MessageDigest.java \
|
|
||||||
java/security/NoSuchAlgorithmException.java \
|
|
||||||
java/security/SecureClassLoader.java \
|
|
||||||
java/security/interfaces/DSAKey.java \
|
|
||||||
java/security/interfaces/DSAParams.java \
|
|
||||||
java/security/interfaces/DSAPrivateKey.java \
|
|
||||||
java/security/interfaces/DSAPublicKey.java \
|
|
||||||
java/security/interfaces/RSAPrivateCrtKey.java \
|
|
||||||
java/security/interfaces/RSAPrivateKey.java \
|
|
||||||
java/security/interfaces/RSAPublicKey.java \
|
|
||||||
java/security/AlgorithmParameterGeneratorSpi.java \
|
java/security/AlgorithmParameterGeneratorSpi.java \
|
||||||
|
java/security/BasicPermission.java \
|
||||||
java/security/DigestException.java \
|
java/security/DigestException.java \
|
||||||
|
java/security/DigestOutputStream.java \
|
||||||
java/security/GeneralSecurityException.java \
|
java/security/GeneralSecurityException.java \
|
||||||
|
java/security/Guard.java \
|
||||||
java/security/InvalidAlgorithmParameterException.java \
|
java/security/InvalidAlgorithmParameterException.java \
|
||||||
java/security/InvalidKeyException.java \
|
java/security/InvalidKeyException.java \
|
||||||
java/security/InvalidParameterException.java \
|
java/security/InvalidParameterException.java \
|
||||||
|
@ -799,15 +719,41 @@ java/security/KeyException.java \
|
||||||
java/security/KeyPair.java \
|
java/security/KeyPair.java \
|
||||||
java/security/KeyPairGenerator.java \
|
java/security/KeyPairGenerator.java \
|
||||||
java/security/KeyPairGeneratorSpi.java \
|
java/security/KeyPairGeneratorSpi.java \
|
||||||
|
java/security/MessageDigest.java \
|
||||||
|
java/security/NoSuchAlgorithmException.java \
|
||||||
java/security/NoSuchProviderException.java \
|
java/security/NoSuchProviderException.java \
|
||||||
|
java/security/Permission.java \
|
||||||
|
java/security/PermissionCollection.java \
|
||||||
java/security/Principal.java \
|
java/security/Principal.java \
|
||||||
java/security/PrivateKey.java \
|
java/security/PrivateKey.java \
|
||||||
java/security/Provider.java \
|
java/security/Provider.java \
|
||||||
java/security/PublicKey.java \
|
java/security/PublicKey.java \
|
||||||
|
java/security/SecureClassLoader.java \
|
||||||
java/security/SecureRandom.java \
|
java/security/SecureRandom.java \
|
||||||
java/security/Security.java \
|
java/security/Security.java \
|
||||||
java/security/Signature.java \
|
java/security/Signature.java \
|
||||||
java/security/SignatureException.java \
|
java/security/SignatureException.java \
|
||||||
|
java/security/cert/CRL.java \
|
||||||
|
java/security/cert/CRLException.java \
|
||||||
|
java/security/cert/Certificate.java \
|
||||||
|
java/security/cert/CertificateEncodingException.java \
|
||||||
|
java/security/cert/CertificateException.java \
|
||||||
|
java/security/cert/CertificateExpiredException.java \
|
||||||
|
java/security/cert/CertificateFactory.java \
|
||||||
|
java/security/cert/CertificateFactorySpi.java \
|
||||||
|
java/security/cert/CertificateNotYetValidException.java \
|
||||||
|
java/security/cert/CertificateParsingException.java \
|
||||||
|
java/security/cert/X509CRL.java \
|
||||||
|
java/security/cert/X509CRLEntry.java \
|
||||||
|
java/security/cert/X509Certificate.java \
|
||||||
|
java/security/cert/X509Extension.java \
|
||||||
|
java/security/interfaces/DSAKey.java \
|
||||||
|
java/security/interfaces/DSAParams.java \
|
||||||
|
java/security/interfaces/DSAPrivateKey.java \
|
||||||
|
java/security/interfaces/DSAPublicKey.java \
|
||||||
|
java/security/interfaces/RSAPrivateCrtKey.java \
|
||||||
|
java/security/interfaces/RSAPrivateKey.java \
|
||||||
|
java/security/interfaces/RSAPublicKey.java \
|
||||||
java/security/spec/AlgorithmParameterSpec.java \
|
java/security/spec/AlgorithmParameterSpec.java \
|
||||||
java/security/spec/InvalidKeySpecException.java \
|
java/security/spec/InvalidKeySpecException.java \
|
||||||
java/security/spec/InvalidParameterSpecException.java \
|
java/security/spec/InvalidParameterSpecException.java \
|
||||||
|
@ -815,13 +761,6 @@ java/security/spec/KeySpec.java \
|
||||||
java/security/spec/RSAPrivateCrtKeySpec.java \
|
java/security/spec/RSAPrivateCrtKeySpec.java \
|
||||||
java/security/spec/RSAPrivateKeySpec.java \
|
java/security/spec/RSAPrivateKeySpec.java \
|
||||||
java/security/spec/RSAPublicKeySpec.java \
|
java/security/spec/RSAPublicKeySpec.java \
|
||||||
java/security/BasicPermission.java \
|
|
||||||
java/security/Guard.java \
|
|
||||||
java/security/DigestOutputStream.java \
|
|
||||||
java/security/Permission.java \
|
|
||||||
java/security/PermissionCollection.java \
|
|
||||||
java/math/BigDecimal.java \
|
|
||||||
java/math/BigInteger.java \
|
|
||||||
java/sql/CallableStatement.java \
|
java/sql/CallableStatement.java \
|
||||||
java/sql/Connection.java \
|
java/sql/Connection.java \
|
||||||
java/sql/DataTruncation.java \
|
java/sql/DataTruncation.java \
|
||||||
|
@ -838,7 +777,91 @@ java/sql/SQLWarning.java \
|
||||||
java/sql/Statement.java \
|
java/sql/Statement.java \
|
||||||
java/sql/Time.java \
|
java/sql/Time.java \
|
||||||
java/sql/Timestamp.java \
|
java/sql/Timestamp.java \
|
||||||
java/sql/Types.java
|
java/sql/Types.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/ParseException.java \
|
||||||
|
java/text/ParsePosition.java \
|
||||||
|
java/text/RuleBasedCollator.java \
|
||||||
|
java/text/SimpleDateFormat.java \
|
||||||
|
java/text/StringCharacterIterator.java \
|
||||||
|
java/util/AbstractCollection.java \
|
||||||
|
java/util/AbstractList.java \
|
||||||
|
java/util/AbstractSet.java \
|
||||||
|
java/util/Arrays.java \
|
||||||
|
java/util/BasicMapEntry.java \
|
||||||
|
java/util/BitSet.java \
|
||||||
|
java/util/Bucket.java \
|
||||||
|
java/util/Calendar.java \
|
||||||
|
java/util/Collection.java \
|
||||||
|
java/util/Comparator.java \
|
||||||
|
java/util/ConcurrentModificationException.java \
|
||||||
|
java/util/Date.java \
|
||||||
|
java/util/Dictionary.java \
|
||||||
|
java/util/EmptyStackException.java \
|
||||||
|
java/util/Enumeration.java \
|
||||||
|
java/util/EventListener.java \
|
||||||
|
java/util/EventObject.java \
|
||||||
|
java/util/GregorianCalendar.java \
|
||||||
|
java/util/Hashtable.java \
|
||||||
|
java/util/Iterator.java \
|
||||||
|
java/util/List.java \
|
||||||
|
java/util/ListIterator.java \
|
||||||
|
java/util/ListResourceBundle.java \
|
||||||
|
java/util/Locale.java \
|
||||||
|
java/util/Map.java \
|
||||||
|
java/util/MissingResourceException.java \
|
||||||
|
java/util/NoSuchElementException.java \
|
||||||
|
java/util/Observable.java \
|
||||||
|
java/util/Observer.java \
|
||||||
|
java/util/Properties.java \
|
||||||
|
java/util/PropertyResourceBundle.java \
|
||||||
|
java/util/Random.java \
|
||||||
|
java/util/ResourceBundle.java \
|
||||||
|
java/util/Set.java \
|
||||||
|
java/util/SimpleTimeZone.java \
|
||||||
|
java/util/Stack.java \
|
||||||
|
java/util/StringTokenizer.java \
|
||||||
|
java/util/TimeZone.java \
|
||||||
|
java/util/TooManyListenersException.java \
|
||||||
|
java/util/Vector.java \
|
||||||
|
java/util/jar/Attributes.java \
|
||||||
|
java/util/jar/JarEntry.java \
|
||||||
|
java/util/jar/JarException.java \
|
||||||
|
java/util/jar/JarFile.java \
|
||||||
|
java/util/jar/JarInputStream.java \
|
||||||
|
java/util/jar/JarOutputStream.java \
|
||||||
|
java/util/jar/Manifest.java \
|
||||||
|
java/util/zip/Adler32.java \
|
||||||
|
java/util/zip/CRC32.java \
|
||||||
|
java/util/zip/CheckedInputStream.java \
|
||||||
|
java/util/zip/CheckedOutputStream.java \
|
||||||
|
java/util/zip/Checksum.java \
|
||||||
|
java/util/zip/DataFormatException.java \
|
||||||
|
java/util/zip/Deflater.java \
|
||||||
|
java/util/zip/DeflaterOutputStream.java \
|
||||||
|
java/util/zip/GZIPInputStream.java \
|
||||||
|
java/util/zip/GZIPOutputStream.java \
|
||||||
|
java/util/zip/Inflater.java \
|
||||||
|
java/util/zip/InflaterInputStream.java \
|
||||||
|
java/util/zip/ZipConstants.java \
|
||||||
|
java/util/zip/ZipEntry.java \
|
||||||
|
java/util/zip/ZipException.java \
|
||||||
|
java/util/zip/ZipFile.java \
|
||||||
|
java/util/zip/ZipInputStream.java \
|
||||||
|
java/util/zip/ZipOutputStream.java
|
||||||
|
|
||||||
|
|
||||||
java_source_files = $(ordinary_java_source_files) $(special_java_source_files)
|
java_source_files = $(ordinary_java_source_files) $(special_java_source_files)
|
||||||
|
@ -1001,7 +1024,7 @@ libgcj-test.spec.in libgcj.spec.in
|
||||||
|
|
||||||
DISTFILES = $(DIST_COMMON) $(SOURCES) $(HEADERS) $(TEXINFOS) $(EXTRA_DIST)
|
DISTFILES = $(DIST_COMMON) $(SOURCES) $(HEADERS) $(TEXINFOS) $(EXTRA_DIST)
|
||||||
|
|
||||||
TAR = tar
|
TAR = gtar
|
||||||
GZIP_ENV = --best
|
GZIP_ENV = --best
|
||||||
DIST_SUBDIRS = @DIRLTDL@ testsuite gcj include @DIRLTDL@ gcj include
|
DIST_SUBDIRS = @DIRLTDL@ testsuite gcj include @DIRLTDL@ gcj include
|
||||||
DEP_FILES = .deps/$(srcdir)/$(CONVERT_DIR)/gen-from-JIS.P \
|
DEP_FILES = .deps/$(srcdir)/$(CONVERT_DIR)/gen-from-JIS.P \
|
||||||
|
@ -1357,7 +1380,20 @@ DEP_FILES = .deps/$(srcdir)/$(CONVERT_DIR)/gen-from-JIS.P \
|
||||||
.deps/java/security/SecureClassLoader.P \
|
.deps/java/security/SecureClassLoader.P \
|
||||||
.deps/java/security/SecureRandom.P .deps/java/security/Security.P \
|
.deps/java/security/SecureRandom.P .deps/java/security/Security.P \
|
||||||
.deps/java/security/Signature.P \
|
.deps/java/security/Signature.P \
|
||||||
.deps/java/security/SignatureException.P \
|
.deps/java/security/SignatureException.P .deps/java/security/cert/CRL.P \
|
||||||
|
.deps/java/security/cert/CRLException.P \
|
||||||
|
.deps/java/security/cert/Certificate.P \
|
||||||
|
.deps/java/security/cert/CertificateEncodingException.P \
|
||||||
|
.deps/java/security/cert/CertificateException.P \
|
||||||
|
.deps/java/security/cert/CertificateExpiredException.P \
|
||||||
|
.deps/java/security/cert/CertificateFactory.P \
|
||||||
|
.deps/java/security/cert/CertificateFactorySpi.P \
|
||||||
|
.deps/java/security/cert/CertificateNotYetValidException.P \
|
||||||
|
.deps/java/security/cert/CertificateParsingException.P \
|
||||||
|
.deps/java/security/cert/X509CRL.P \
|
||||||
|
.deps/java/security/cert/X509CRLEntry.P \
|
||||||
|
.deps/java/security/cert/X509Certificate.P \
|
||||||
|
.deps/java/security/cert/X509Extension.P \
|
||||||
.deps/java/security/interfaces/DSAKey.P \
|
.deps/java/security/interfaces/DSAKey.P \
|
||||||
.deps/java/security/interfaces/DSAParams.P \
|
.deps/java/security/interfaces/DSAParams.P \
|
||||||
.deps/java/security/interfaces/DSAPrivateKey.P \
|
.deps/java/security/interfaces/DSAPrivateKey.P \
|
||||||
|
@ -1392,9 +1428,10 @@ DEP_FILES = .deps/$(srcdir)/$(CONVERT_DIR)/gen-from-JIS.P \
|
||||||
.deps/java/text/RuleBasedCollator.P .deps/java/text/SimpleDateFormat.P \
|
.deps/java/text/RuleBasedCollator.P .deps/java/text/SimpleDateFormat.P \
|
||||||
.deps/java/text/StringCharacterIterator.P \
|
.deps/java/text/StringCharacterIterator.P \
|
||||||
.deps/java/util/AbstractCollection.P .deps/java/util/AbstractList.P \
|
.deps/java/util/AbstractCollection.P .deps/java/util/AbstractList.P \
|
||||||
.deps/java/util/Arrays.P .deps/java/util/BitSet.P \
|
.deps/java/util/AbstractSet.P .deps/java/util/Arrays.P \
|
||||||
.deps/java/util/Calendar.P .deps/java/util/Collection.P \
|
.deps/java/util/BasicMapEntry.P .deps/java/util/BitSet.P \
|
||||||
.deps/java/util/Comparator.P \
|
.deps/java/util/Bucket.P .deps/java/util/Calendar.P \
|
||||||
|
.deps/java/util/Collection.P .deps/java/util/Comparator.P \
|
||||||
.deps/java/util/ConcurrentModificationException.P \
|
.deps/java/util/ConcurrentModificationException.P \
|
||||||
.deps/java/util/Date.P .deps/java/util/Dictionary.P \
|
.deps/java/util/Date.P .deps/java/util/Dictionary.P \
|
||||||
.deps/java/util/EmptyStackException.P .deps/java/util/Enumeration.P \
|
.deps/java/util/EmptyStackException.P .deps/java/util/Enumeration.P \
|
||||||
|
@ -1402,15 +1439,19 @@ DEP_FILES = .deps/$(srcdir)/$(CONVERT_DIR)/gen-from-JIS.P \
|
||||||
.deps/java/util/GregorianCalendar.P .deps/java/util/Hashtable.P \
|
.deps/java/util/GregorianCalendar.P .deps/java/util/Hashtable.P \
|
||||||
.deps/java/util/Iterator.P .deps/java/util/List.P \
|
.deps/java/util/Iterator.P .deps/java/util/List.P \
|
||||||
.deps/java/util/ListIterator.P .deps/java/util/ListResourceBundle.P \
|
.deps/java/util/ListIterator.P .deps/java/util/ListResourceBundle.P \
|
||||||
.deps/java/util/Locale.P .deps/java/util/MissingResourceException.P \
|
.deps/java/util/Locale.P .deps/java/util/Map.P \
|
||||||
|
.deps/java/util/MissingResourceException.P \
|
||||||
.deps/java/util/NoSuchElementException.P .deps/java/util/Observable.P \
|
.deps/java/util/NoSuchElementException.P .deps/java/util/Observable.P \
|
||||||
.deps/java/util/Observer.P .deps/java/util/Properties.P \
|
.deps/java/util/Observer.P .deps/java/util/Properties.P \
|
||||||
.deps/java/util/PropertyResourceBundle.P .deps/java/util/Random.P \
|
.deps/java/util/PropertyResourceBundle.P .deps/java/util/Random.P \
|
||||||
.deps/java/util/ResourceBundle.P .deps/java/util/SimpleTimeZone.P \
|
.deps/java/util/ResourceBundle.P .deps/java/util/Set.P \
|
||||||
.deps/java/util/Stack.P .deps/java/util/StringTokenizer.P \
|
.deps/java/util/SimpleTimeZone.P .deps/java/util/Stack.P \
|
||||||
.deps/java/util/TimeZone.P .deps/java/util/TooManyListenersException.P \
|
.deps/java/util/StringTokenizer.P .deps/java/util/TimeZone.P \
|
||||||
.deps/java/util/Vector.P .deps/java/util/jar/JarEntry.P \
|
.deps/java/util/TooManyListenersException.P .deps/java/util/Vector.P \
|
||||||
.deps/java/util/jar/JarFile.P .deps/java/util/jar/JarInputStream.P \
|
.deps/java/util/jar/Attributes.P .deps/java/util/jar/JarEntry.P \
|
||||||
|
.deps/java/util/jar/JarException.P .deps/java/util/jar/JarFile.P \
|
||||||
|
.deps/java/util/jar/JarInputStream.P \
|
||||||
|
.deps/java/util/jar/JarOutputStream.P .deps/java/util/jar/Manifest.P \
|
||||||
.deps/java/util/zip/Adler32.P .deps/java/util/zip/CRC32.P \
|
.deps/java/util/zip/Adler32.P .deps/java/util/zip/CRC32.P \
|
||||||
.deps/java/util/zip/CheckedInputStream.P \
|
.deps/java/util/zip/CheckedInputStream.P \
|
||||||
.deps/java/util/zip/CheckedOutputStream.P \
|
.deps/java/util/zip/CheckedOutputStream.P \
|
||||||
|
|
|
@ -129,7 +129,7 @@ DIST_COMMON = Makefile.am Makefile.in
|
||||||
|
|
||||||
DISTFILES = $(DIST_COMMON) $(SOURCES) $(HEADERS) $(TEXINFOS) $(EXTRA_DIST)
|
DISTFILES = $(DIST_COMMON) $(SOURCES) $(HEADERS) $(TEXINFOS) $(EXTRA_DIST)
|
||||||
|
|
||||||
TAR = tar
|
TAR = gtar
|
||||||
GZIP_ENV = --best
|
GZIP_ENV = --best
|
||||||
all: all-redirect
|
all: all-redirect
|
||||||
.SUFFIXES:
|
.SUFFIXES:
|
||||||
|
@ -198,7 +198,7 @@ distdir: $(DISTFILES)
|
||||||
@for file in $(DISTFILES); do \
|
@for file in $(DISTFILES); do \
|
||||||
d=$(srcdir); \
|
d=$(srcdir); \
|
||||||
if test -d $$d/$$file; then \
|
if test -d $$d/$$file; then \
|
||||||
cp -pr $$/$$file $(distdir)/$$file; \
|
cp -pr $$d/$$file $(distdir)/$$file; \
|
||||||
else \
|
else \
|
||||||
test -f $(distdir)/$$file \
|
test -f $(distdir)/$$file \
|
||||||
|| ln $$d/$$file $(distdir)/$$file 2> /dev/null \
|
|| ln $$d/$$file $(distdir)/$$file 2> /dev/null \
|
||||||
|
|
|
@ -214,9 +214,13 @@ extern "Java"
|
||||||
class AbstractCollection;
|
class AbstractCollection;
|
||||||
class AbstractList;
|
class AbstractList;
|
||||||
class AbstractList$SubList;
|
class AbstractList$SubList;
|
||||||
|
class AbstractSet;
|
||||||
class Arrays;
|
class Arrays;
|
||||||
class Arrays$ListImpl;
|
class Arrays$ListImpl;
|
||||||
|
class BasicMapEntry;
|
||||||
class BitSet;
|
class BitSet;
|
||||||
|
class Bucket;
|
||||||
|
class Bucket$Node;
|
||||||
class Calendar;
|
class Calendar;
|
||||||
class Collection;
|
class Collection;
|
||||||
class Comparator;
|
class Comparator;
|
||||||
|
@ -229,13 +233,18 @@ extern "Java"
|
||||||
class EventObject;
|
class EventObject;
|
||||||
class GregorianCalendar;
|
class GregorianCalendar;
|
||||||
class Hashtable;
|
class Hashtable;
|
||||||
class HashtableEntry;
|
class Hashtable$HashtableCollection;
|
||||||
class HashtableEnumeration;
|
class Hashtable$HashtableEntry;
|
||||||
|
class Hashtable$HashtableEnumeration;
|
||||||
|
class Hashtable$HashtableIterator;
|
||||||
|
class Hashtable$HashtableSet;
|
||||||
class Iterator;
|
class Iterator;
|
||||||
class List;
|
class List;
|
||||||
class ListIterator;
|
class ListIterator;
|
||||||
class ListResourceBundle;
|
class ListResourceBundle;
|
||||||
class Locale;
|
class Locale;
|
||||||
|
class Map;
|
||||||
|
class Map$Entry;
|
||||||
class MissingResourceException;
|
class MissingResourceException;
|
||||||
class NoSuchElementException;
|
class NoSuchElementException;
|
||||||
class Observable;
|
class Observable;
|
||||||
|
@ -244,6 +253,7 @@ extern "Java"
|
||||||
class PropertyResourceBundle;
|
class PropertyResourceBundle;
|
||||||
class Random;
|
class Random;
|
||||||
class ResourceBundle;
|
class ResourceBundle;
|
||||||
|
class Set;
|
||||||
class SimpleTimeZone;
|
class SimpleTimeZone;
|
||||||
class Stack;
|
class Stack;
|
||||||
class StringTokenizer;
|
class StringTokenizer;
|
||||||
|
@ -253,9 +263,14 @@ extern "Java"
|
||||||
class VectorEnumeration;
|
class VectorEnumeration;
|
||||||
namespace jar
|
namespace jar
|
||||||
{
|
{
|
||||||
|
class Attributes;
|
||||||
class JarEntry;
|
class JarEntry;
|
||||||
|
class JarException;
|
||||||
class JarFile;
|
class JarFile;
|
||||||
|
class JarFile$JarEnumeration;
|
||||||
class JarInputStream;
|
class JarInputStream;
|
||||||
|
class JarOutputStream;
|
||||||
|
class Manifest;
|
||||||
};
|
};
|
||||||
|
|
||||||
namespace zip
|
namespace zip
|
||||||
|
@ -282,6 +297,92 @@ extern "Java"
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
namespace java
|
||||||
|
{
|
||||||
|
namespace io
|
||||||
|
{
|
||||||
|
class BlockDataException;
|
||||||
|
class BufferedInputStream;
|
||||||
|
class BufferedOutputStream;
|
||||||
|
class BufferedReader;
|
||||||
|
class BufferedWriter;
|
||||||
|
class ByteArrayInputStream;
|
||||||
|
class ByteArrayOutputStream;
|
||||||
|
class CharArrayReader;
|
||||||
|
class CharArrayWriter;
|
||||||
|
class CharConversionException;
|
||||||
|
class DataInput;
|
||||||
|
class DataInputStream;
|
||||||
|
class DataOutput;
|
||||||
|
class DataOutputStream;
|
||||||
|
class EOFException;
|
||||||
|
class Externalizable;
|
||||||
|
class File;
|
||||||
|
class FileDescriptor;
|
||||||
|
class FileInputStream;
|
||||||
|
class FileNotFoundException;
|
||||||
|
class FileOutputStream;
|
||||||
|
class FileReader;
|
||||||
|
class FileWriter;
|
||||||
|
class FilenameFilter;
|
||||||
|
class FilterInputStream;
|
||||||
|
class FilterOutputStream;
|
||||||
|
class FilterReader;
|
||||||
|
class FilterWriter;
|
||||||
|
class IOException;
|
||||||
|
class InputStream;
|
||||||
|
class InputStreamReader;
|
||||||
|
class InterfaceComparator;
|
||||||
|
class InterruptedIOException;
|
||||||
|
class InvalidClassException;
|
||||||
|
class InvalidObjectException;
|
||||||
|
class LineNumberInputStream;
|
||||||
|
class LineNumberReader;
|
||||||
|
class MemberComparator;
|
||||||
|
class NotActiveException;
|
||||||
|
class NotSerializableException;
|
||||||
|
class ObjectInput;
|
||||||
|
class ObjectInputStream;
|
||||||
|
class ObjectInputStream$GetField;
|
||||||
|
class ObjectInputValidation;
|
||||||
|
class ObjectOutput;
|
||||||
|
class ObjectOutputStream;
|
||||||
|
class ObjectOutputStream$PutField;
|
||||||
|
class ObjectStreamClass;
|
||||||
|
class ObjectStreamConstants;
|
||||||
|
class ObjectStreamException;
|
||||||
|
class ObjectStreamField;
|
||||||
|
class OptionalDataException;
|
||||||
|
class OutputStream;
|
||||||
|
class OutputStreamWriter;
|
||||||
|
class PipedInputStream;
|
||||||
|
class PipedOutputStream;
|
||||||
|
class PipedReader;
|
||||||
|
class PipedWriter;
|
||||||
|
class PrintStream;
|
||||||
|
class PrintWriter;
|
||||||
|
class PushbackInputStream;
|
||||||
|
class PushbackReader;
|
||||||
|
class RandomAccessFile;
|
||||||
|
class Reader;
|
||||||
|
class Replaceable;
|
||||||
|
class Resolvable;
|
||||||
|
class SequenceInputStream;
|
||||||
|
class Serializable;
|
||||||
|
class SerializablePermission;
|
||||||
|
class StreamCorruptedException;
|
||||||
|
class StreamTokenizer;
|
||||||
|
class StringBufferInputStream;
|
||||||
|
class StringReader;
|
||||||
|
class StringWriter;
|
||||||
|
class SyncFailedException;
|
||||||
|
class UTFDataFormatException;
|
||||||
|
class UnsupportedEncodingException;
|
||||||
|
class ValidatorAndPriority;
|
||||||
|
class WriteAbortedException;
|
||||||
|
class Writer;
|
||||||
|
};
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct java::lang::Object* jobject;
|
typedef struct java::lang::Object* jobject;
|
||||||
|
|
|
@ -128,7 +128,7 @@ DIST_COMMON = ./stamp-h.in Makefile.am Makefile.in config.h.in
|
||||||
|
|
||||||
DISTFILES = $(DIST_COMMON) $(SOURCES) $(HEADERS) $(TEXINFOS) $(EXTRA_DIST)
|
DISTFILES = $(DIST_COMMON) $(SOURCES) $(HEADERS) $(TEXINFOS) $(EXTRA_DIST)
|
||||||
|
|
||||||
TAR = tar
|
TAR = gtar
|
||||||
GZIP_ENV = --best
|
GZIP_ENV = --best
|
||||||
all: all-redirect
|
all: all-redirect
|
||||||
.SUFFIXES:
|
.SUFFIXES:
|
||||||
|
@ -225,7 +225,7 @@ distdir: $(DISTFILES)
|
||||||
@for file in $(DISTFILES); do \
|
@for file in $(DISTFILES); do \
|
||||||
d=$(srcdir); \
|
d=$(srcdir); \
|
||||||
if test -d $$d/$$file; then \
|
if test -d $$d/$$file; then \
|
||||||
cp -pr $$/$$file $(distdir)/$$file; \
|
cp -pr $$d/$$file $(distdir)/$$file; \
|
||||||
else \
|
else \
|
||||||
test -f $(distdir)/$$file \
|
test -f $(distdir)/$$file \
|
||||||
|| ln $$d/$$file $(distdir)/$$file 2> /dev/null \
|
|| ln $$d/$$file $(distdir)/$$file 2> /dev/null \
|
||||||
|
|
87
libjava/java/security/cert/CRL.java
Normal file
87
libjava/java/security/cert/CRL.java
Normal file
|
@ -0,0 +1,87 @@
|
||||||
|
/* CRL.java --- Certificate Revocation List
|
||||||
|
Copyright (C) 1999 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
|
||||||
|
package java.security.cert;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Certificate Revocation List class for managing CRLs that
|
||||||
|
have different formats but the same general use. They
|
||||||
|
all serve as lists of revoked certificates and can
|
||||||
|
be queried for a given certificate.
|
||||||
|
|
||||||
|
Specialized CRLs extend this class.
|
||||||
|
|
||||||
|
@author Mark Benvenuto
|
||||||
|
|
||||||
|
@since JDK 1.2
|
||||||
|
*/
|
||||||
|
public abstract class CRL
|
||||||
|
{
|
||||||
|
|
||||||
|
private String type;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Creates a new CRL for the specified type. An example
|
||||||
|
is "X.509".
|
||||||
|
|
||||||
|
@param type the standard name for the CRL type.
|
||||||
|
*/
|
||||||
|
protected CRL(String type)
|
||||||
|
{
|
||||||
|
this.type = type;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the CRL type.
|
||||||
|
|
||||||
|
@return a string representing the CRL type
|
||||||
|
*/
|
||||||
|
public final String getType()
|
||||||
|
{
|
||||||
|
return type;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns a string representing the CRL.
|
||||||
|
|
||||||
|
@return a string representing the CRL.
|
||||||
|
*/
|
||||||
|
public abstract String toString();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Determines whether or not the specified Certificate
|
||||||
|
is revoked.
|
||||||
|
|
||||||
|
@param cert A certificate to check if it is revoked
|
||||||
|
|
||||||
|
@return true if the certificate is revoked,
|
||||||
|
false otherwise.
|
||||||
|
*/
|
||||||
|
public abstract boolean isRevoked(Certificate cert);
|
||||||
|
|
||||||
|
|
||||||
|
}
|
59
libjava/java/security/cert/CRLException.java
Normal file
59
libjava/java/security/cert/CRLException.java
Normal file
|
@ -0,0 +1,59 @@
|
||||||
|
/* CRLException.java --- Certificate Revocation List Exception
|
||||||
|
Copyright (C) 1999 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
|
||||||
|
package java.security.cert;
|
||||||
|
import java.security.GeneralSecurityException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Exception for a Certificate Revocation List.
|
||||||
|
|
||||||
|
@since JDK 1.2
|
||||||
|
|
||||||
|
@author Mark Benvenuto
|
||||||
|
*/
|
||||||
|
public class CRLException extends GeneralSecurityException
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
Constructs an CRLExceptionwithout a message string.
|
||||||
|
*/
|
||||||
|
public CRLException()
|
||||||
|
{
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Constructs an CRLException with a message string.
|
||||||
|
|
||||||
|
@param msg A message to display with exception
|
||||||
|
*/
|
||||||
|
public CRLException(String msg)
|
||||||
|
{
|
||||||
|
super( msg );
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
237
libjava/java/security/cert/Certificate.java
Normal file
237
libjava/java/security/cert/Certificate.java
Normal file
|
@ -0,0 +1,237 @@
|
||||||
|
/* Certificate.java --- Certificate class
|
||||||
|
Copyright (C) 1999 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
|
||||||
|
package java.security.cert;
|
||||||
|
import java.security.PublicKey;
|
||||||
|
import java.security.NoSuchAlgorithmException;
|
||||||
|
import java.security.InvalidKeyException;
|
||||||
|
import java.security.NoSuchProviderException;
|
||||||
|
import java.security.SignatureException;
|
||||||
|
import java.io.ObjectInputStream;
|
||||||
|
import java.io.ByteArrayInputStream;
|
||||||
|
import java.io.ObjectStreamException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
The Certificate class is an abstract class used to manage
|
||||||
|
identity certificates. An identity certificate is a
|
||||||
|
combination of a principal and a public key which is
|
||||||
|
certified by another principal. This is the puprose of
|
||||||
|
Certificate Authorities (CA).
|
||||||
|
|
||||||
|
This class is used to manage different types of certificates
|
||||||
|
but have important common puposes. Different types of
|
||||||
|
certificates like X.509 and OpenPGP share general certificate
|
||||||
|
functions (like encoding and verifying) and information like
|
||||||
|
public keys.
|
||||||
|
|
||||||
|
X.509, OpenPGP, and SDSI can be implemented by subclassing this
|
||||||
|
class even though they differ in storage methods and information
|
||||||
|
stored.
|
||||||
|
|
||||||
|
@since JDK 1.2
|
||||||
|
|
||||||
|
@author Mark Benvenuto
|
||||||
|
*/
|
||||||
|
public abstract class Certificate
|
||||||
|
{
|
||||||
|
|
||||||
|
private String type;
|
||||||
|
/**
|
||||||
|
Constructs a new certificate of the specified type. An example
|
||||||
|
is "X.509".
|
||||||
|
|
||||||
|
@param type a valid standard name for a certificate.
|
||||||
|
*/
|
||||||
|
protected Certificate(String type)
|
||||||
|
{
|
||||||
|
this.type = type;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the Certificate type.
|
||||||
|
|
||||||
|
@return a string representing the Certificate type
|
||||||
|
*/
|
||||||
|
public final String getType()
|
||||||
|
{
|
||||||
|
return type;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Compares this Certificate to other. It checks if the
|
||||||
|
object if instanceOf Certificate and then checks if
|
||||||
|
the encoded form matches.
|
||||||
|
|
||||||
|
@param other An Object to test for equality
|
||||||
|
|
||||||
|
@return true if equal, false otherwise
|
||||||
|
*/
|
||||||
|
public boolean equals(Object other)
|
||||||
|
{
|
||||||
|
if( other instanceof Certificate ) {
|
||||||
|
try {
|
||||||
|
Certificate x = (Certificate) other;
|
||||||
|
if( getEncoded().length != x.getEncoded().length )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
byte b1[] = getEncoded();
|
||||||
|
byte b2[] = x.getEncoded();
|
||||||
|
|
||||||
|
for( int i = 0; i < b1.length; i++ )
|
||||||
|
if( b1[i] != b2[i] )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
} catch( CertificateEncodingException cee ) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns a hash code for this Certificate in its encoded
|
||||||
|
form.
|
||||||
|
|
||||||
|
@return A hash code of this class
|
||||||
|
*/
|
||||||
|
public int hashCode()
|
||||||
|
{
|
||||||
|
return super.hashCode();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Gets the DER ASN.1 encoded format for this Certificate.
|
||||||
|
It assumes each certificate has only one encoding format.
|
||||||
|
Ex: X.509 is encoded as ASN.1 DER
|
||||||
|
|
||||||
|
@return byte array containg encoded form
|
||||||
|
|
||||||
|
@throws CertificateEncodingException if an error occurs
|
||||||
|
*/
|
||||||
|
public abstract byte[] getEncoded() throws CertificateEncodingException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Verifies that this Certificate was properly signed with the
|
||||||
|
PublicKey that corresponds to its private key.
|
||||||
|
|
||||||
|
@param key PublicKey to verify with
|
||||||
|
|
||||||
|
@throws CertificateException encoding error
|
||||||
|
@throws NoSuchAlgorithmException unsupported algorithm
|
||||||
|
@throws InvalidKeyException incorrect key
|
||||||
|
@throws NoSuchProviderException no provider
|
||||||
|
@throws SignatureException signature error
|
||||||
|
*/
|
||||||
|
public abstract void verify(PublicKey key)
|
||||||
|
throws CertificateException,
|
||||||
|
NoSuchAlgorithmException,
|
||||||
|
InvalidKeyException,
|
||||||
|
NoSuchProviderException,
|
||||||
|
SignatureException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Verifies that this Certificate was properly signed with the
|
||||||
|
PublicKey that corresponds to its private key and uses
|
||||||
|
the signature engine provided by the provider.
|
||||||
|
|
||||||
|
@param key PublicKey to verify with
|
||||||
|
@param sigProvider Provider to use for signature algorithm
|
||||||
|
|
||||||
|
@throws CertificateException encoding error
|
||||||
|
@throws NoSuchAlgorithmException unsupported algorithm
|
||||||
|
@throws InvalidKeyException incorrect key
|
||||||
|
@throws NoSuchProviderException incorrect provider
|
||||||
|
@throws SignatureException signature error
|
||||||
|
*/
|
||||||
|
public abstract void verify(PublicKey key,
|
||||||
|
String sigProvider)
|
||||||
|
throws CertificateException,
|
||||||
|
NoSuchAlgorithmException,
|
||||||
|
InvalidKeyException,
|
||||||
|
NoSuchProviderException,
|
||||||
|
SignatureException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns a string representing the Certificate.
|
||||||
|
|
||||||
|
@return a string representing the Certificate.
|
||||||
|
*/
|
||||||
|
public abstract String toString();
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the public key stored in the Certificate.
|
||||||
|
|
||||||
|
@return The public key
|
||||||
|
*/
|
||||||
|
public abstract PublicKey getPublicKey();
|
||||||
|
|
||||||
|
|
||||||
|
/* INNER CLASS */
|
||||||
|
/**
|
||||||
|
Certificate.CertificateRep is an inner class used to provide an alternate
|
||||||
|
storage mechanism for serialized Certificates.
|
||||||
|
*/
|
||||||
|
protected static class CertificateRep implements java.io.Serializable
|
||||||
|
{
|
||||||
|
private String type;
|
||||||
|
private byte[] data;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Create an alternate Certificate class to store a serialized Certificate
|
||||||
|
|
||||||
|
@param type the name of certificate type
|
||||||
|
@param data the certificate data
|
||||||
|
*/
|
||||||
|
protected CertificateRep(String type,
|
||||||
|
byte[] data)
|
||||||
|
{
|
||||||
|
this.type = type;
|
||||||
|
this.data = data;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Return the stored Certificate
|
||||||
|
|
||||||
|
@return the stored certificate
|
||||||
|
|
||||||
|
@throws ObjectStreamException if certificate cannot be resolved
|
||||||
|
*/
|
||||||
|
protected Object readResolve()
|
||||||
|
throws ObjectStreamException
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
return new ObjectInputStream( new ByteArrayInputStream( data ) ).readObject();
|
||||||
|
} catch ( Exception e ) {
|
||||||
|
e.printStackTrace();
|
||||||
|
throw new RuntimeException ( e.toString() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
58
libjava/java/security/cert/CertificateEncodingException.java
Normal file
58
libjava/java/security/cert/CertificateEncodingException.java
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
/* CertificateEncodingException.java --- Certificate Encoding Exception
|
||||||
|
Copyright (C) 1999 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
|
||||||
|
package java.security.cert;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Exception for a Certificate Encoding.
|
||||||
|
|
||||||
|
@since JDK 1.2
|
||||||
|
|
||||||
|
@author Mark Benvenuto
|
||||||
|
*/
|
||||||
|
public class CertificateEncodingException extends CertificateException
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
Constructs an CertificateEncodingException without a message string.
|
||||||
|
*/
|
||||||
|
public CertificateEncodingException()
|
||||||
|
{
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Constructs an CertificateEncodingException with a message string.
|
||||||
|
|
||||||
|
@param msg A message to display with exception
|
||||||
|
*/
|
||||||
|
public CertificateEncodingException(String msg)
|
||||||
|
{
|
||||||
|
super( msg );
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
59
libjava/java/security/cert/CertificateException.java
Normal file
59
libjava/java/security/cert/CertificateException.java
Normal file
|
@ -0,0 +1,59 @@
|
||||||
|
/* CertificateException.java --- Certificate Exception
|
||||||
|
Copyright (C) 1999 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
|
||||||
|
package java.security.cert;
|
||||||
|
import java.security.GeneralSecurityException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Exception for a Certificate.
|
||||||
|
|
||||||
|
@since JDK 1.2
|
||||||
|
|
||||||
|
@author Mark Benvenuto
|
||||||
|
*/
|
||||||
|
public class CertificateException extends GeneralSecurityException
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
Constructs an CertificateException without a message string.
|
||||||
|
*/
|
||||||
|
public CertificateException()
|
||||||
|
{
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Constructs an CertificateException with a message string.
|
||||||
|
|
||||||
|
@param msg A message to display with exception
|
||||||
|
*/
|
||||||
|
public CertificateException(String msg)
|
||||||
|
{
|
||||||
|
super( msg );
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
58
libjava/java/security/cert/CertificateExpiredException.java
Normal file
58
libjava/java/security/cert/CertificateExpiredException.java
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
/* CertificateExpiredException.java --- Certificate Expired Exception
|
||||||
|
Copyright (C) 1999 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
|
||||||
|
package java.security.cert;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Exception for a Certificate Expiring.
|
||||||
|
|
||||||
|
@since JDK 1.2
|
||||||
|
|
||||||
|
@author Mark Benvenuto
|
||||||
|
*/
|
||||||
|
public class CertificateExpiredException extends CertificateException
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
Constructs an CertificateExpiredException without a message string.
|
||||||
|
*/
|
||||||
|
public CertificateExpiredException()
|
||||||
|
{
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Constructs an CertificateExpiredException with a message string.
|
||||||
|
|
||||||
|
@param msg A message to display with exception
|
||||||
|
*/
|
||||||
|
public CertificateExpiredException(String msg)
|
||||||
|
{
|
||||||
|
super( msg );
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
259
libjava/java/security/cert/CertificateFactory.java
Normal file
259
libjava/java/security/cert/CertificateFactory.java
Normal file
|
@ -0,0 +1,259 @@
|
||||||
|
/* CertificateFactory.java --- Certificate Factory Class
|
||||||
|
Copyright (C) 1999 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
|
||||||
|
package java.security.cert;
|
||||||
|
import java.security.NoSuchProviderException;
|
||||||
|
import java.security.Provider;
|
||||||
|
import java.security.Security;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.util.Collection;
|
||||||
|
|
||||||
|
/**
|
||||||
|
This class implments the CertificateFactory class interface
|
||||||
|
used to generate certificates and certificate revocation
|
||||||
|
list (CRL) objects from their encodings.
|
||||||
|
|
||||||
|
A certifcate factory for X.509 returns certificates of the
|
||||||
|
java.security.cert.X509Certificate class, and CRLs of the
|
||||||
|
java.security.cert.X509CRL class.
|
||||||
|
|
||||||
|
@since JDK 1.2
|
||||||
|
|
||||||
|
@author Mark Benvenuto
|
||||||
|
*/
|
||||||
|
public class CertificateFactory
|
||||||
|
{
|
||||||
|
|
||||||
|
private CertificateFactorySpi certFacSpi;
|
||||||
|
private Provider provider;
|
||||||
|
private String type;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Creates an instance of CertificateFactory
|
||||||
|
|
||||||
|
@param certFacSpi A CertificateFactory engine to use
|
||||||
|
@param provider A provider to use
|
||||||
|
@param type The type of Certificate
|
||||||
|
*/
|
||||||
|
protected CertificateFactory(CertificateFactorySpi certFacSpi, Provider provider, String type)
|
||||||
|
{
|
||||||
|
this.certFacSpi = certFacSpi;
|
||||||
|
this.provider = provider;
|
||||||
|
this.type = type;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
Gets an instance of the CertificateFactory class representing
|
||||||
|
the specified certificate factory. If the type is not
|
||||||
|
found then, it throws CertificateException.
|
||||||
|
|
||||||
|
@param type the type of certificate to choose
|
||||||
|
|
||||||
|
@return a CertificateFactory repesenting the desired type
|
||||||
|
|
||||||
|
@throws CertificateException if the type of certificate is not implemented by providers
|
||||||
|
*/
|
||||||
|
public static final CertificateFactory getInstance(String type) throws CertificateException
|
||||||
|
{
|
||||||
|
Provider[] p = Security.getProviders ();
|
||||||
|
|
||||||
|
for (int i = 0; i < p.length; i++)
|
||||||
|
{
|
||||||
|
String classname = p[i].getProperty ("CertificateFactory." + type);
|
||||||
|
if (classname != null)
|
||||||
|
return getInstance (classname, type, p[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
throw new CertificateException(type);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
Gets an instance of the CertificateFactory class representing
|
||||||
|
the specified certificate factory from the specified provider.
|
||||||
|
If the type is not found then, it throws CertificateException.
|
||||||
|
If the provider is not found, then it throws
|
||||||
|
NoSuchProviderException.
|
||||||
|
|
||||||
|
@param type the type of certificate to choose
|
||||||
|
|
||||||
|
@return a CertificateFactory repesenting the desired type
|
||||||
|
|
||||||
|
@throws CertificateException if the type of certificate is not implemented by providers
|
||||||
|
@throws NoSuchProviderException if the provider is not found
|
||||||
|
*/
|
||||||
|
public static final CertificateFactory getInstance(String type, String provider)
|
||||||
|
throws CertificateException, NoSuchProviderException
|
||||||
|
{
|
||||||
|
Provider p = Security.getProvider(provider);
|
||||||
|
if( p == null)
|
||||||
|
throw new NoSuchProviderException();
|
||||||
|
|
||||||
|
return getInstance (p.getProperty ("CertificateFactory." + type),
|
||||||
|
type, p);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static CertificateFactory getInstance (String classname,
|
||||||
|
String type,
|
||||||
|
Provider provider)
|
||||||
|
throws CertificateException
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
return new CertificateFactory( (CertificateFactorySpi)Class.forName( classname ).newInstance(), provider, type );
|
||||||
|
} catch( ClassNotFoundException cnfe) {
|
||||||
|
throw new CertificateException("Class not found");
|
||||||
|
} catch( InstantiationException ie) {
|
||||||
|
throw new CertificateException("Class instantiation failed");
|
||||||
|
} catch( IllegalAccessException iae) {
|
||||||
|
throw new CertificateException("Illegal Access");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
Gets the provider that the class is from.
|
||||||
|
|
||||||
|
@return the provider of this class
|
||||||
|
*/
|
||||||
|
public final Provider getProvider()
|
||||||
|
{
|
||||||
|
return provider;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the type of the certificate supported
|
||||||
|
|
||||||
|
@return A string with the type of certificate
|
||||||
|
*/
|
||||||
|
public final String getType()
|
||||||
|
{
|
||||||
|
return type;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Generates a Certificate based on the encoded data read
|
||||||
|
from the InputStream.
|
||||||
|
|
||||||
|
The input stream must contain only one certificate.
|
||||||
|
|
||||||
|
If there exists a specialized certificate class for the
|
||||||
|
certificate format handled by the certificate factory
|
||||||
|
then the return Ceritificate should be a typecast of it.
|
||||||
|
Ex: A X.509 CertificateFactory should return X509Certificate.
|
||||||
|
|
||||||
|
For X.509 certificates, the certificate in inStream must be
|
||||||
|
DER encoded and supplied in binary or printable (Base64)
|
||||||
|
encoding. If the certificate is in Base64 encoding, it must be
|
||||||
|
bounded by -----BEGINCERTIFICATE-----, and
|
||||||
|
-----END CERTIFICATE-----.
|
||||||
|
|
||||||
|
@param inStream an input stream containing the certificate data
|
||||||
|
|
||||||
|
@return a certificate initialized with InputStream data.
|
||||||
|
|
||||||
|
@throws CertificateException Certificate parsing error
|
||||||
|
*/
|
||||||
|
public final Certificate generateCertificate(InputStream inStream)
|
||||||
|
throws CertificateException
|
||||||
|
{
|
||||||
|
return certFacSpi.engineGenerateCertificate( inStream );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns a collection of certificates that were read from the
|
||||||
|
input stream. It may be empty, have only one, or have
|
||||||
|
multiple certificates.
|
||||||
|
|
||||||
|
For a X.509 certificate factory, the stream may contain a
|
||||||
|
single DER encoded certificate or a PKCS#7 certificate
|
||||||
|
chain. This is a PKCS#7 <I>SignedData</I> object with the
|
||||||
|
most significant field being <I>certificates</I>. If no
|
||||||
|
CRLs are present, then an empty collection is returned.
|
||||||
|
|
||||||
|
@param inStream an input stream containing the certificates
|
||||||
|
|
||||||
|
@return a collection of certificates initialized with
|
||||||
|
the InputStream data.
|
||||||
|
|
||||||
|
@throws CertificateException Certificate parsing error
|
||||||
|
*/
|
||||||
|
public final Collection generateCertificates(InputStream inStream)
|
||||||
|
throws CertificateException
|
||||||
|
{
|
||||||
|
return certFacSpi.engineGenerateCertificates( inStream );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Generates a CRL based on the encoded data read
|
||||||
|
from the InputStream.
|
||||||
|
|
||||||
|
The input stream must contain only one CRL.
|
||||||
|
|
||||||
|
If there exists a specialized CRL class for the
|
||||||
|
CRL format handled by the certificate factory
|
||||||
|
then the return CRL should be a typecast of it.
|
||||||
|
Ex: A X.509 CertificateFactory should return X509CRL.
|
||||||
|
|
||||||
|
@param inStream an input stream containing the CRL data
|
||||||
|
|
||||||
|
@return a CRL initialized with InputStream data.
|
||||||
|
|
||||||
|
@throws CRLException CRL parsing error
|
||||||
|
*/
|
||||||
|
public final CRL generateCRL(InputStream inStream)
|
||||||
|
throws CRLException
|
||||||
|
{
|
||||||
|
return certFacSpi.engineGenerateCRL( inStream );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
Generates CRLs based on the encoded data read
|
||||||
|
from the InputStream.
|
||||||
|
|
||||||
|
For a X.509 certificate factory, the stream may contain a
|
||||||
|
single DER encoded CRL or a PKCS#7 CRL set. This is a
|
||||||
|
PKCS#7 <I>SignedData</I> object with the most significant
|
||||||
|
field being <I>crls</I>. If no CRLs are present, then an
|
||||||
|
empty collection is returned.
|
||||||
|
|
||||||
|
@param inStream an input stream containing the CRLs
|
||||||
|
|
||||||
|
@return a collection of CRLs initialized with
|
||||||
|
the InputStream data.
|
||||||
|
|
||||||
|
@throws CRLException CRL parsing error
|
||||||
|
*/
|
||||||
|
public final Collection generateCRLs(InputStream inStream)
|
||||||
|
throws CRLException
|
||||||
|
{
|
||||||
|
return certFacSpi.engineGenerateCRLs( inStream );
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
142
libjava/java/security/cert/CertificateFactorySpi.java
Normal file
142
libjava/java/security/cert/CertificateFactorySpi.java
Normal file
|
@ -0,0 +1,142 @@
|
||||||
|
/* CertificateFactorySpi.java --- Certificate Factory Class
|
||||||
|
Copyright (C) 1999 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
|
||||||
|
package java.security.cert;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.util.Collection;
|
||||||
|
|
||||||
|
/**
|
||||||
|
CertificateFactorySpi is the abstract class Service Provider
|
||||||
|
Interface (SPI) for the CertificateFactory class. A provider
|
||||||
|
must implment all the abstract methods if they wish to
|
||||||
|
supply a certificate factory for a particular certificate
|
||||||
|
type. Ex: X.509
|
||||||
|
|
||||||
|
Certificate factories are used to generate certificates and
|
||||||
|
certificate revocation lists (CRL) from their encoding.
|
||||||
|
|
||||||
|
@since JDK 1.2
|
||||||
|
|
||||||
|
@author Mark Benvenuto
|
||||||
|
*/
|
||||||
|
public abstract class CertificateFactorySpi
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
Constructs a new CertificateFactorySpi
|
||||||
|
*/
|
||||||
|
public CertificateFactorySpi()
|
||||||
|
{}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Generates a Certificate based on the encoded data read
|
||||||
|
from the InputStream.
|
||||||
|
|
||||||
|
The input stream must contain only one certificate.
|
||||||
|
|
||||||
|
If there exists a specialized certificate class for the
|
||||||
|
certificate format handled by the certificate factory
|
||||||
|
then the return Ceritificate should be a typecast of it.
|
||||||
|
Ex: A X.509 CertificateFactory should return X509Certificate.
|
||||||
|
|
||||||
|
For X.509 certificates, the certificate in inStream must be
|
||||||
|
DER encoded and supplied in binary or printable (Base64)
|
||||||
|
encoding. If the certificate is in Base64 encoding, it must be
|
||||||
|
bounded by -----BEGINCERTIFICATE-----, and
|
||||||
|
-----END CERTIFICATE-----.
|
||||||
|
|
||||||
|
@param inStream an input stream containing the certificate data
|
||||||
|
|
||||||
|
@return a certificate initialized with InputStream data.
|
||||||
|
|
||||||
|
@throws CertificateException Certificate parsing error
|
||||||
|
*/
|
||||||
|
public abstract Certificate engineGenerateCertificate(InputStream inStream)
|
||||||
|
throws CertificateException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns a collection of certificates that were read from the
|
||||||
|
input stream. It may be empty, have only one, or have
|
||||||
|
multiple certificates.
|
||||||
|
|
||||||
|
For a X.509 certificate factory, the stream may contain a
|
||||||
|
single DER encoded certificate or a PKCS#7 certificate
|
||||||
|
chain. This is a PKCS#7 <I>SignedData</I> object with the
|
||||||
|
most significant field being <I>certificates</I>. If no
|
||||||
|
CRLs are present, then an empty collection is returned.
|
||||||
|
|
||||||
|
@param inStream an input stream containing the certificates
|
||||||
|
|
||||||
|
@return a collection of certificates initialized with
|
||||||
|
the InputStream data.
|
||||||
|
|
||||||
|
@throws CertificateException Certificate parsing error
|
||||||
|
*/
|
||||||
|
public abstract Collection engineGenerateCertificates(InputStream inStream)
|
||||||
|
throws CertificateException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Generates a CRL based on the encoded data read
|
||||||
|
from the InputStream.
|
||||||
|
|
||||||
|
The input stream must contain only one CRL.
|
||||||
|
|
||||||
|
If there exists a specialized CRL class for the
|
||||||
|
CRL format handled by the certificate factory
|
||||||
|
then the return CRL should be a typecast of it.
|
||||||
|
Ex: A X.509 CertificateFactory should return X509CRL.
|
||||||
|
|
||||||
|
@param inStream an input stream containing the CRL data
|
||||||
|
|
||||||
|
@return a CRL initialized with InputStream data.
|
||||||
|
|
||||||
|
@throws CRLException CRL parsing error
|
||||||
|
*/
|
||||||
|
public abstract CRL engineGenerateCRL(InputStream inStream)
|
||||||
|
throws CRLException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Generates CRLs based on the encoded data read
|
||||||
|
from the InputStream.
|
||||||
|
|
||||||
|
For a X.509 certificate factory, the stream may contain a
|
||||||
|
single DER encoded CRL or a PKCS#7 CRL set. This is a
|
||||||
|
PKCS#7 <I>SignedData</I> object with the most significant
|
||||||
|
field being <I>crls</I>. If no CRLs are present, then an
|
||||||
|
empty collection is returned.
|
||||||
|
|
||||||
|
@param inStream an input stream containing the CRLs
|
||||||
|
|
||||||
|
@return a collection of CRLs initialized with
|
||||||
|
the InputStream data.
|
||||||
|
|
||||||
|
@throws CRLException CRL parsing error
|
||||||
|
*/
|
||||||
|
public abstract Collection engineGenerateCRLs(InputStream inStream)
|
||||||
|
throws CRLException;
|
||||||
|
}
|
||||||
|
|
|
@ -0,0 +1,58 @@
|
||||||
|
/* CertificateNotYetValidException.java --- Certificate Not Yet Valid Exception
|
||||||
|
Copyright (C) 1999 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
|
||||||
|
package java.security.cert;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Exception for a Certificate being not yet valid.
|
||||||
|
|
||||||
|
@since JDK 1.2
|
||||||
|
|
||||||
|
@author Mark Benvenuto
|
||||||
|
*/
|
||||||
|
public class CertificateNotYetValidException extends CertificateException
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
Constructs an CertificateNotYetValidException without a message string.
|
||||||
|
*/
|
||||||
|
public CertificateNotYetValidException()
|
||||||
|
{
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Constructs an CertificateNotYetValidException with a message string.
|
||||||
|
|
||||||
|
@param msg A message to display with exception
|
||||||
|
*/
|
||||||
|
public CertificateNotYetValidException(String msg)
|
||||||
|
{
|
||||||
|
super( msg );
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
58
libjava/java/security/cert/CertificateParsingException.java
Normal file
58
libjava/java/security/cert/CertificateParsingException.java
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
/* CertificateParsingException.java --- Certificate Parsing Exception
|
||||||
|
Copyright (C) 1999 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
|
||||||
|
package java.security.cert;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Exception for a Certificate Parsing.
|
||||||
|
|
||||||
|
@since JDK 1.2
|
||||||
|
|
||||||
|
@author Mark Benvenuto
|
||||||
|
*/
|
||||||
|
public class CertificateParsingException extends CertificateException
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
Constructs an CertificateParsingException without a message string.
|
||||||
|
*/
|
||||||
|
public CertificateParsingException()
|
||||||
|
{
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Constructs an CertificateParsingException with a message string.
|
||||||
|
|
||||||
|
@param msg A message to display with exception
|
||||||
|
*/
|
||||||
|
public CertificateParsingException(String msg)
|
||||||
|
{
|
||||||
|
super( msg );
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
370
libjava/java/security/cert/X509CRL.java
Normal file
370
libjava/java/security/cert/X509CRL.java
Normal file
|
@ -0,0 +1,370 @@
|
||||||
|
/* X509CRL.java --- X.509 Certificate Revocation List
|
||||||
|
Copyright (C) 1999 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
|
||||||
|
package java.security.cert;
|
||||||
|
import java.math.BigInteger;
|
||||||
|
import java.security.Principal;
|
||||||
|
import java.security.PublicKey;
|
||||||
|
import java.security.NoSuchAlgorithmException;
|
||||||
|
import java.security.InvalidKeyException;
|
||||||
|
import java.security.NoSuchProviderException;
|
||||||
|
import java.security.SignatureException;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
/**
|
||||||
|
The X509CRL class is the abstract class used to manage
|
||||||
|
X.509 Certificate Revocation Lists. The CRL is a list of
|
||||||
|
time stamped entries which indicate which lists have been
|
||||||
|
revoked. The list is signed by a Certificate Authority (CA)
|
||||||
|
and made publically available in a repository.
|
||||||
|
|
||||||
|
Each revoked certificate in the CRL is identified by its
|
||||||
|
certificate serial number. When a piece of code uses a
|
||||||
|
certificate, the certificates validity is checked by
|
||||||
|
validating its signature and determing that it is not
|
||||||
|
only a recently acquired CRL. The recently aquired CRL
|
||||||
|
is depends on the local policy in affect. The CA issues
|
||||||
|
a new CRL periodically and entries are removed as the
|
||||||
|
certificate expiration date is reached
|
||||||
|
|
||||||
|
|
||||||
|
A description of the X.509 v2 CRL follows below from rfc2459.
|
||||||
|
|
||||||
|
"The X.509 v2 CRL syntax is as follows. For signature calculation,
|
||||||
|
the data that is to be signed is ASN.1 DER encoded. ASN.1 DER
|
||||||
|
encoding is a tag, length, value encoding system for each element.
|
||||||
|
|
||||||
|
CertificateList ::= SEQUENCE {
|
||||||
|
tbsCertList TBSCertList,
|
||||||
|
signatureAlgorithm AlgorithmIdentifier,
|
||||||
|
signatureValue BIT STRING }
|
||||||
|
|
||||||
|
TBSCertList ::= SEQUENCE {
|
||||||
|
version Version OPTIONAL,
|
||||||
|
-- if present, shall be v2
|
||||||
|
signature AlgorithmIdentifier,
|
||||||
|
issuer Name,
|
||||||
|
thisUpdate Time,
|
||||||
|
nextUpdate Time OPTIONAL,
|
||||||
|
revokedCertificates SEQUENCE OF SEQUENCE {
|
||||||
|
userCertificate CertificateSerialNumber,
|
||||||
|
revocationDate Time,
|
||||||
|
crlEntryExtensions Extensions OPTIONAL
|
||||||
|
-- if present, shall be v2
|
||||||
|
} OPTIONAL,
|
||||||
|
crlExtensions [0] EXPLICIT Extensions OPTIONAL
|
||||||
|
-- if present, shall be v2
|
||||||
|
}"
|
||||||
|
|
||||||
|
@author Mark Benvenuto
|
||||||
|
|
||||||
|
@since JDK 1.2
|
||||||
|
*/
|
||||||
|
public abstract class X509CRL extends CRL implements X509Extension
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
Constructs a new X509CRL.
|
||||||
|
*/
|
||||||
|
protected X509CRL()
|
||||||
|
{
|
||||||
|
super("X.509");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Compares this X509CRL to other. It checks if the
|
||||||
|
object if instanceOf X509CRL and then checks if
|
||||||
|
the encoded form matches.
|
||||||
|
|
||||||
|
@param other An Object to test for equality
|
||||||
|
|
||||||
|
@return true if equal, false otherwise
|
||||||
|
*/
|
||||||
|
public boolean equals(Object other)
|
||||||
|
{
|
||||||
|
if( other instanceof X509CRL ) {
|
||||||
|
try {
|
||||||
|
X509CRL x = (X509CRL) other;
|
||||||
|
if( getEncoded().length != x.getEncoded().length )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
byte b1[] = getEncoded();
|
||||||
|
byte b2[] = x.getEncoded();
|
||||||
|
|
||||||
|
for( int i = 0; i < b1.length; i++ )
|
||||||
|
if( b1[i] != b2[i] )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
} catch( CRLException crle ) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns a hash code for this X509CRL in its encoded
|
||||||
|
form.
|
||||||
|
|
||||||
|
@return A hash code of this class
|
||||||
|
*/
|
||||||
|
public int hashCode()
|
||||||
|
{
|
||||||
|
return super.hashCode();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Gets the DER ASN.1 encoded format for this X.509 CRL.
|
||||||
|
|
||||||
|
@return byte array containg encoded form
|
||||||
|
|
||||||
|
@throws CRLException if an error occurs
|
||||||
|
*/
|
||||||
|
public abstract byte[] getEncoded() throws CRLException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Verifies that this CRL was properly signed with the
|
||||||
|
PublicKey that corresponds to its private key.
|
||||||
|
|
||||||
|
@param key PublicKey to verify with
|
||||||
|
|
||||||
|
@throws CRLException encoding error
|
||||||
|
@throws NoSuchAlgorithmException unsupported algorithm
|
||||||
|
@throws InvalidKeyException incorrect key
|
||||||
|
@throws NoSuchProviderException no provider
|
||||||
|
@throws SignatureException signature error
|
||||||
|
*/
|
||||||
|
public abstract void verify(PublicKey key)
|
||||||
|
throws CRLException,
|
||||||
|
NoSuchAlgorithmException,
|
||||||
|
InvalidKeyException,
|
||||||
|
NoSuchProviderException,
|
||||||
|
SignatureException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Verifies that this CRL was properly signed with the
|
||||||
|
PublicKey that corresponds to its private key and uses
|
||||||
|
the signature engine provided by the provider.
|
||||||
|
|
||||||
|
@param key PublicKey to verify with
|
||||||
|
@param sigProvider Provider to use for signature algorithm
|
||||||
|
|
||||||
|
@throws CRLException encoding error
|
||||||
|
@throws NoSuchAlgorithmException unsupported algorithm
|
||||||
|
@throws InvalidKeyException incorrect key
|
||||||
|
@throws NoSuchProviderException incorrect provider
|
||||||
|
@throws SignatureException signature error
|
||||||
|
*/
|
||||||
|
public abstract void verify(PublicKey key,
|
||||||
|
String sigProvider)
|
||||||
|
throws CRLException,
|
||||||
|
NoSuchAlgorithmException,
|
||||||
|
InvalidKeyException,
|
||||||
|
NoSuchProviderException,
|
||||||
|
SignatureException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Gets the version of this CRL.
|
||||||
|
|
||||||
|
The ASN.1 encoding is:
|
||||||
|
|
||||||
|
version Version OPTIONAL,
|
||||||
|
-- if present, shall be v2
|
||||||
|
|
||||||
|
Version ::= INTEGER { v1(0), v2(1), v3(2) }
|
||||||
|
|
||||||
|
Consult rfc2459 for more information.
|
||||||
|
|
||||||
|
@return the version number, Ex: 1 or 2
|
||||||
|
*/
|
||||||
|
public abstract int getVersion();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the issuer (issuer distinguished name) of the CRL.
|
||||||
|
The issuer is the entity who signed and issued the
|
||||||
|
Certificate Revocation List.
|
||||||
|
|
||||||
|
The ASN.1 DER encoding is:
|
||||||
|
|
||||||
|
issuer Name,
|
||||||
|
|
||||||
|
Name ::= CHOICE {
|
||||||
|
RDNSequence }
|
||||||
|
|
||||||
|
RDNSequence ::= SEQUENCE OF RelativeDistinguishedName
|
||||||
|
|
||||||
|
RelativeDistinguishedName ::=
|
||||||
|
SET OF AttributeTypeAndValue
|
||||||
|
|
||||||
|
AttributeTypeAndValue ::= SEQUENCE {
|
||||||
|
type AttributeType,
|
||||||
|
value AttributeValue }
|
||||||
|
|
||||||
|
AttributeType ::= OBJECT IDENTIFIER
|
||||||
|
|
||||||
|
AttributeValue ::= ANY DEFINED BY AttributeType
|
||||||
|
|
||||||
|
DirectoryString ::= CHOICE {
|
||||||
|
teletexString TeletexString (SIZE (1..MAX)),
|
||||||
|
printableString PrintableString (SIZE (1..MAX)),
|
||||||
|
universalString UniversalString (SIZE (1..MAX)),
|
||||||
|
utf8String UTF8String (SIZE (1.. MAX)),
|
||||||
|
bmpString BMPString (SIZE (1..MAX)) }
|
||||||
|
|
||||||
|
Consult rfc2459 for more information.
|
||||||
|
|
||||||
|
@return the issuer in the Principal class
|
||||||
|
*/
|
||||||
|
public abstract Principal getIssuerDN();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the thisUpdate date of the CRL.
|
||||||
|
|
||||||
|
The ASN.1 DER encoding is:
|
||||||
|
|
||||||
|
thisUpdate Time,
|
||||||
|
|
||||||
|
Time ::= CHOICE {
|
||||||
|
utcTime UTCTime,
|
||||||
|
generalTime GeneralizedTime }
|
||||||
|
|
||||||
|
Consult rfc2459 for more information.
|
||||||
|
|
||||||
|
@return the thisUpdate date
|
||||||
|
*/
|
||||||
|
public abstract Date getThisUpdate();
|
||||||
|
|
||||||
|
/*
|
||||||
|
Gets the nextUpdate field
|
||||||
|
|
||||||
|
The ASN.1 DER encoding is:
|
||||||
|
|
||||||
|
nextUpdate Time OPTIONAL,
|
||||||
|
|
||||||
|
Time ::= CHOICE {
|
||||||
|
utcTime UTCTime,
|
||||||
|
generalTime GeneralizedTime }
|
||||||
|
|
||||||
|
Consult rfc2459 for more information.
|
||||||
|
|
||||||
|
@return the nextUpdate date
|
||||||
|
*/
|
||||||
|
public abstract Date getNextUpdate();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Gets the requeste dX509Entry for the specified
|
||||||
|
certificate serial number.
|
||||||
|
|
||||||
|
@return a X509CRLEntry representing the X.509 CRL entry
|
||||||
|
*/
|
||||||
|
public abstract X509CRLEntry getRevokedCertificate(BigInteger serialNumber);
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns a Set of revoked certificates.
|
||||||
|
|
||||||
|
@return a set of revoked certificates.
|
||||||
|
*/
|
||||||
|
public abstract Set getRevokedCertificates();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the DER ASN.1 encoded tbsCertList which is
|
||||||
|
the basic information of the list and associated certificates
|
||||||
|
in the encoded state. See top for more information.
|
||||||
|
|
||||||
|
The ASN.1 DER encoding is:
|
||||||
|
|
||||||
|
tbsCertList TBSCertList,
|
||||||
|
|
||||||
|
Consult rfc2459 for more information.
|
||||||
|
|
||||||
|
@return byte array representing tbsCertList
|
||||||
|
*/
|
||||||
|
public abstract byte[] getTBSCertList() throws CRLException;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the signature for the CRL.
|
||||||
|
|
||||||
|
The ASN.1 DER encoding is:
|
||||||
|
|
||||||
|
signatureValue BIT STRING
|
||||||
|
|
||||||
|
Consult rfc2459 for more information.
|
||||||
|
*/
|
||||||
|
public abstract byte[] getSignature();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the signature algorithm used to sign the CRL.
|
||||||
|
An examples is "SHA-1/DSA".
|
||||||
|
|
||||||
|
The ASN.1 DER encoding is:
|
||||||
|
|
||||||
|
signatureAlgorithm AlgorithmIdentifier,
|
||||||
|
|
||||||
|
AlgorithmIdentifier ::= SEQUENCE {
|
||||||
|
algorithm OBJECT IDENTIFIER,
|
||||||
|
parameters ANY DEFINED BY algorithm OPTIONAL }
|
||||||
|
|
||||||
|
Consult rfc2459 for more information.
|
||||||
|
|
||||||
|
The algorithm name is determined from the OID.
|
||||||
|
|
||||||
|
@return a string with the signature algorithm name
|
||||||
|
*/
|
||||||
|
public abstract String getSigAlgName();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the OID for the signature algorithm used.
|
||||||
|
Example "1.2.840.10040.4.3" is return for SHA-1 with DSA.\
|
||||||
|
|
||||||
|
The ASN.1 DER encoding for the example is:
|
||||||
|
|
||||||
|
id-dsa-with-sha1 ID ::= {
|
||||||
|
iso(1) member-body(2) us(840) x9-57 (10040)
|
||||||
|
x9cm(4) 3 }
|
||||||
|
|
||||||
|
Consult rfc2459 for more information.
|
||||||
|
|
||||||
|
@return a string containing the OID.
|
||||||
|
*/
|
||||||
|
public abstract String getSigAlgOID();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the AlgorithmParameters in the encoded form
|
||||||
|
for the signature algorithm used.
|
||||||
|
|
||||||
|
If access to the parameters is need, create an
|
||||||
|
instance of AlgorithmParameters.
|
||||||
|
|
||||||
|
@return byte array containing algorithm parameters, null
|
||||||
|
if no parameters are present in CRL
|
||||||
|
*/
|
||||||
|
public abstract byte[] getSigAlgParams();
|
||||||
|
|
||||||
|
}
|
157
libjava/java/security/cert/X509CRLEntry.java
Normal file
157
libjava/java/security/cert/X509CRLEntry.java
Normal file
|
@ -0,0 +1,157 @@
|
||||||
|
/* X509CRLEntry.java --- X.509 Certificate Revocation List Entry
|
||||||
|
Copyright (C) 1999 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
|
||||||
|
package java.security.cert;
|
||||||
|
import java.math.BigInteger;
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Abstract class for entries in the CRL (Certificate Revocation
|
||||||
|
List). The ASN.1 definition for <I>revokedCertificates</I> is
|
||||||
|
|
||||||
|
revokedCertificates SEQUENCE OF SEQUENCE {
|
||||||
|
userCertificate CertificateSerialNumber,
|
||||||
|
revocationDate Time,
|
||||||
|
crlEntryExtensions Extensions OPTIONAL
|
||||||
|
-- if present, shall be v2
|
||||||
|
} OPTIONAL,
|
||||||
|
|
||||||
|
CertificateSerialNumber ::= INTEGER
|
||||||
|
|
||||||
|
Time ::= CHOICE {
|
||||||
|
utcTime UTCTime,
|
||||||
|
generalTime GeneralizedTime }
|
||||||
|
|
||||||
|
Extensions ::= SEQUENCE SIZE (1..MAX) OF Extension
|
||||||
|
|
||||||
|
Extension ::= SEQUENCE {
|
||||||
|
extnID OBJECT IDENTIFIER,
|
||||||
|
critical BOOLEAN DEFAULT FALSE,
|
||||||
|
extnValue OCTET STRING }
|
||||||
|
|
||||||
|
For more information consult rfc2459.
|
||||||
|
|
||||||
|
@author Mark Benvenuto
|
||||||
|
|
||||||
|
@since JDK 1.2
|
||||||
|
*/
|
||||||
|
public abstract class X509CRLEntry implements X509Extension
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
Creates a new X509CRLEntry
|
||||||
|
*/
|
||||||
|
public X509CRLEntry()
|
||||||
|
{}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Compares this X509CRLEntry to other. It checks if the
|
||||||
|
object if instanceOf X509CRLEntry and then checks if
|
||||||
|
the encoded form( the inner SEQUENCE) matches.
|
||||||
|
|
||||||
|
@param other An Object to test for equality
|
||||||
|
|
||||||
|
@return true if equal, false otherwise
|
||||||
|
*/
|
||||||
|
public boolean equals(Object other)
|
||||||
|
{
|
||||||
|
if( other instanceof X509CRLEntry ) {
|
||||||
|
try {
|
||||||
|
X509CRLEntry xe = (X509CRLEntry) other;
|
||||||
|
if( getEncoded().length != xe.getEncoded().length )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
byte b1[] = getEncoded();
|
||||||
|
byte b2[] = xe.getEncoded();
|
||||||
|
|
||||||
|
for( int i = 0; i < b1.length; i++ )
|
||||||
|
if( b1[i] != b2[i] )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
} catch( CRLException crle ) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns a hash code for this X509CRLEntry in its encoded
|
||||||
|
form.
|
||||||
|
|
||||||
|
@return A hash code of this class
|
||||||
|
*/
|
||||||
|
public int hashCode()
|
||||||
|
{
|
||||||
|
return super.hashCode();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Gets the DER ASN.1 encoded format for this CRL Entry,
|
||||||
|
the inner SEQUENCE.
|
||||||
|
|
||||||
|
@return byte array containg encoded form
|
||||||
|
|
||||||
|
@throws CRLException if an error occurs
|
||||||
|
*/
|
||||||
|
public abstract byte[] getEncoded() throws CRLException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Gets the serial number for <I>userCertificate</I> in
|
||||||
|
this X509CRLEntry.
|
||||||
|
|
||||||
|
@return the serial number for this X509CRLEntry.
|
||||||
|
*/
|
||||||
|
public abstract BigInteger getSerialNumber();
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
Gets the revocation date in <I>revocationDate</I> for
|
||||||
|
this X509CRLEntry.
|
||||||
|
|
||||||
|
@return the revocation date for this X509CRLEntry.
|
||||||
|
*/
|
||||||
|
public abstract Date getRevocationDate();
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
Checks if this X509CRLEntry has extensions.
|
||||||
|
|
||||||
|
@return true if it has extensions, false otherwise
|
||||||
|
*/
|
||||||
|
public abstract boolean hasExtensions();
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns a string that represents this X509CRLEntry.
|
||||||
|
|
||||||
|
@return a string representing this X509CRLEntry.
|
||||||
|
*/
|
||||||
|
public abstract String toString();
|
||||||
|
|
||||||
|
}
|
444
libjava/java/security/cert/X509Certificate.java
Normal file
444
libjava/java/security/cert/X509Certificate.java
Normal file
|
@ -0,0 +1,444 @@
|
||||||
|
/* X509Certificate.java --- X.509 Certificate class
|
||||||
|
Copyright (C) 1999 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
|
||||||
|
package java.security.cert;
|
||||||
|
import java.math.BigInteger;
|
||||||
|
import java.security.Principal;
|
||||||
|
import java.security.PublicKey;
|
||||||
|
import java.security.NoSuchAlgorithmException;
|
||||||
|
import java.security.InvalidKeyException;
|
||||||
|
import java.security.NoSuchProviderException;
|
||||||
|
import java.security.SignatureException;
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
|
/**
|
||||||
|
X509Certificate is the abstract class for X.509 certificates.
|
||||||
|
This provides a stanard class interface for accessing all
|
||||||
|
the attributes of X.509 certificates.
|
||||||
|
|
||||||
|
In June 1996, the basic X.509 v3 format was finished by
|
||||||
|
ISO/IEC and ANSI X.9. The ASN.1 DER format is below:
|
||||||
|
|
||||||
|
Certificate ::= SEQUENCE {
|
||||||
|
tbsCertificate TBSCertificate,
|
||||||
|
signatureAlgorithm AlgorithmIdentifier,
|
||||||
|
signatureValue BIT STRING }
|
||||||
|
|
||||||
|
These certificates are widely used in various Internet
|
||||||
|
protocols to support authentication. It is used in
|
||||||
|
Privacy Enhanced Mail (PEM), Transport Layer Security (TLS),
|
||||||
|
Secure Sockets Layer (SSL), code signing for trusted software
|
||||||
|
distribution, and Secure Electronic Transactions (SET).
|
||||||
|
|
||||||
|
The certificates are managed and vouched for by
|
||||||
|
<I>Certificate Authorities</I> (CAs). CAs are companies or
|
||||||
|
groups that create certificates by placing the data in the
|
||||||
|
X.509 certificate format and signing it with their private
|
||||||
|
key. CAs serve as trusted third parties by certifying that
|
||||||
|
the person or group specified in the certificate is who
|
||||||
|
they say they are.
|
||||||
|
|
||||||
|
The ASN.1 defintion for <I>tbsCertificate</I> is
|
||||||
|
|
||||||
|
TBSCertificate ::= SEQUENCE {
|
||||||
|
version [0] EXPLICIT Version DEFAULT v1,
|
||||||
|
serialNumber CertificateSerialNumber,
|
||||||
|
signature AlgorithmIdentifier,
|
||||||
|
issuer Name,
|
||||||
|
validity Validity,
|
||||||
|
subject Name,
|
||||||
|
subjectPublicKeyInfo SubjectPublicKeyInfo,
|
||||||
|
issuerUniqueID [1] IMPLICIT UniqueIdentifier OPTIONAL,
|
||||||
|
-- If present, version shall be v2 or v3
|
||||||
|
subjectUniqueID [2] IMPLICIT UniqueIdentifier OPTIONAL,
|
||||||
|
-- If present, version shall be v2 or v3
|
||||||
|
extensions [3] EXPLICIT Extensions OPTIONAL
|
||||||
|
-- If present, version shall be v3
|
||||||
|
}
|
||||||
|
|
||||||
|
Version ::= INTEGER { v1(0), v2(1), v3(2) }
|
||||||
|
|
||||||
|
CertificateSerialNumber ::= INTEGER
|
||||||
|
|
||||||
|
Validity ::= SEQUENCE {
|
||||||
|
notBefore Time,
|
||||||
|
notAfter Time }
|
||||||
|
|
||||||
|
Time ::= CHOICE {
|
||||||
|
utcTime UTCTime,
|
||||||
|
generalTime GeneralizedTime }
|
||||||
|
|
||||||
|
UniqueIdentifier ::= BIT STRING
|
||||||
|
|
||||||
|
SubjectPublicKeyInfo ::= SEQUENCE {
|
||||||
|
algorithm AlgorithmIdentifier,
|
||||||
|
subjectPublicKey BIT STRING }
|
||||||
|
|
||||||
|
Extensions ::= SEQUENCE SIZE (1..MAX) OF Extension
|
||||||
|
|
||||||
|
Extension ::= SEQUENCE {
|
||||||
|
extnID OBJECT IDENTIFIER,
|
||||||
|
critical BOOLEAN DEFAULT FALSE,
|
||||||
|
extnValue OCTET STRING }
|
||||||
|
|
||||||
|
|
||||||
|
Certificates are created with the CertificateFactory.
|
||||||
|
For more information about X.509 certificates, consult
|
||||||
|
rfc2459.
|
||||||
|
|
||||||
|
@since JDK 1.2
|
||||||
|
|
||||||
|
@author Mark Benvenuto
|
||||||
|
*/
|
||||||
|
public abstract class X509Certificate extends Certificate implements X509Extension
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
Constructs a new certificate of the specified type.
|
||||||
|
*/
|
||||||
|
protected X509Certificate()
|
||||||
|
{
|
||||||
|
super( "X.509" );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Checks the validity of the X.509 certificate. It is valid
|
||||||
|
if the current date and time are within the period specified
|
||||||
|
by the certificate.
|
||||||
|
|
||||||
|
The ASN.1 DER encoding is:
|
||||||
|
|
||||||
|
validity Validity,
|
||||||
|
|
||||||
|
Validity ::= SEQUENCE {
|
||||||
|
notBefore Time,
|
||||||
|
notAfter Time }
|
||||||
|
|
||||||
|
Time ::= CHOICE {
|
||||||
|
utcTime UTCTime,
|
||||||
|
generalTime GeneralizedTime }
|
||||||
|
|
||||||
|
Consult rfc2459 for more information.
|
||||||
|
|
||||||
|
@throws CertificateExpiredException if the certificate expired
|
||||||
|
@throws CertificateNotYetValidException if the certificate is
|
||||||
|
not yet valid
|
||||||
|
*/
|
||||||
|
public abstract void checkValidity()
|
||||||
|
throws CertificateExpiredException,
|
||||||
|
CertificateNotYetValidException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Checks the validity of the X.509 certificate for the
|
||||||
|
specified time and date. It is valid if the specified
|
||||||
|
date and time are within the period specified by
|
||||||
|
the certificate.
|
||||||
|
|
||||||
|
@throws CertificateExpiredException if the certificate expired
|
||||||
|
based on the date
|
||||||
|
@throws CertificateNotYetValidException if the certificate is
|
||||||
|
not yet valid based on the date
|
||||||
|
*/
|
||||||
|
public abstract void checkValidity(Date date)
|
||||||
|
throws CertificateExpiredException,
|
||||||
|
CertificateNotYetValidException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the version of this certificate.
|
||||||
|
|
||||||
|
The ASN.1 DER encoding is:
|
||||||
|
|
||||||
|
version [0] EXPLICIT Version DEFAULT v1,
|
||||||
|
|
||||||
|
Version ::= INTEGER { v1(0), v2(1), v3(2) }
|
||||||
|
|
||||||
|
Consult rfc2459 for more information.
|
||||||
|
|
||||||
|
@return version number of certificate
|
||||||
|
*/
|
||||||
|
public abstract int getVersion();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Gets the serial number for serial Number in
|
||||||
|
this Certifcate. It must be a unique number
|
||||||
|
unique other serial numbers from the granting CA.
|
||||||
|
|
||||||
|
The ASN.1 DER encoding is:
|
||||||
|
|
||||||
|
serialNumber CertificateSerialNumber,
|
||||||
|
|
||||||
|
CertificateSerialNumber ::= INTEGER
|
||||||
|
|
||||||
|
Consult rfc2459 for more information.
|
||||||
|
|
||||||
|
@return the serial number for this X509CRLEntry.
|
||||||
|
*/
|
||||||
|
public abstract BigInteger getSerialNumber();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the issuer (issuer distinguished name) of the
|
||||||
|
Certificate. The issuer is the entity who signed
|
||||||
|
and issued the Certificate.
|
||||||
|
|
||||||
|
The ASN.1 DER encoding is:
|
||||||
|
|
||||||
|
issuer Name,
|
||||||
|
|
||||||
|
Name ::= CHOICE {
|
||||||
|
RDNSequence }
|
||||||
|
|
||||||
|
RDNSequence ::= SEQUENCE OF RelativeDistinguishedName
|
||||||
|
|
||||||
|
RelativeDistinguishedName ::=
|
||||||
|
SET OF AttributeTypeAndValue
|
||||||
|
|
||||||
|
AttributeTypeAndValue ::= SEQUENCE {
|
||||||
|
type AttributeType,
|
||||||
|
value AttributeValue }
|
||||||
|
|
||||||
|
AttributeType ::= OBJECT IDENTIFIER
|
||||||
|
|
||||||
|
AttributeValue ::= ANY DEFINED BY AttributeType
|
||||||
|
|
||||||
|
DirectoryString ::= CHOICE {
|
||||||
|
teletexString TeletexString (SIZE (1..MAX)),
|
||||||
|
printableString PrintableString (SIZE (1..MAX)),
|
||||||
|
universalString UniversalString (SIZE (1..MAX)),
|
||||||
|
utf8String UTF8String (SIZE (1.. MAX)),
|
||||||
|
bmpString BMPString (SIZE (1..MAX)) }
|
||||||
|
|
||||||
|
Consult rfc2459 for more information.
|
||||||
|
|
||||||
|
@return the issuer in the Principal class
|
||||||
|
*/
|
||||||
|
public abstract Principal getIssuerDN();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the subject (subject distinguished name) of the
|
||||||
|
Certificate. The subject is the entity who the Certificate
|
||||||
|
identifies.
|
||||||
|
|
||||||
|
The ASN.1 DER encoding is:
|
||||||
|
|
||||||
|
subject Name,
|
||||||
|
|
||||||
|
Consult rfc2459 for more information.
|
||||||
|
|
||||||
|
@return the issuer in the Principal class
|
||||||
|
*/
|
||||||
|
public abstract Principal getSubjectDN();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the date that this certificate is not to be used
|
||||||
|
before, <I>notBefore</I>.
|
||||||
|
|
||||||
|
The ASN.1 DER encoding is:
|
||||||
|
|
||||||
|
validity Validity,
|
||||||
|
|
||||||
|
Validity ::= SEQUENCE {
|
||||||
|
notBefore Time,
|
||||||
|
notAfter Time }
|
||||||
|
|
||||||
|
Time ::= CHOICE {
|
||||||
|
utcTime UTCTime,
|
||||||
|
generalTime GeneralizedTime }
|
||||||
|
|
||||||
|
Consult rfc2459 for more information.
|
||||||
|
|
||||||
|
@return the date <I>notBefore</I>
|
||||||
|
*/
|
||||||
|
public abstract Date getNotBefore();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the date that this certificate is not to be used
|
||||||
|
after, <I>notAfter</I>.
|
||||||
|
|
||||||
|
@return the date <I>notAfter</I>
|
||||||
|
*/
|
||||||
|
public abstract Date getNotAfter();
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the <I>tbsCertificate</I> from the certificate.
|
||||||
|
|
||||||
|
@return the DER encoded tbsCertificate
|
||||||
|
|
||||||
|
@throws CertificateEncodingException if encoding error occured
|
||||||
|
*/
|
||||||
|
public abstract byte[] getTBSCertificate() throws CertificateEncodingException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the signature in its raw DER encoded format.
|
||||||
|
|
||||||
|
The ASN.1 DER encoding is:
|
||||||
|
|
||||||
|
signatureValue BIT STRING
|
||||||
|
|
||||||
|
Consult rfc2459 for more information.
|
||||||
|
|
||||||
|
@return byte array representing signature
|
||||||
|
*/
|
||||||
|
public abstract byte[] getSignature();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the signature algorithm used to sign the CRL.
|
||||||
|
An examples is "SHA-1/DSA".
|
||||||
|
|
||||||
|
The ASN.1 DER encoding is:
|
||||||
|
|
||||||
|
signatureAlgorithm AlgorithmIdentifier,
|
||||||
|
|
||||||
|
AlgorithmIdentifier ::= SEQUENCE {
|
||||||
|
algorithm OBJECT IDENTIFIER,
|
||||||
|
parameters ANY DEFINED BY algorithm OPTIONAL }
|
||||||
|
|
||||||
|
Consult rfc2459 for more information.
|
||||||
|
|
||||||
|
The algorithm name is determined from the OID.
|
||||||
|
|
||||||
|
@return a string with the signature algorithm name
|
||||||
|
*/
|
||||||
|
public abstract String getSigAlgName();
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the OID for the signature algorithm used.
|
||||||
|
Example "1.2.840.10040.4.3" is return for SHA-1 with DSA.\
|
||||||
|
|
||||||
|
The ASN.1 DER encoding for the example is:
|
||||||
|
|
||||||
|
id-dsa-with-sha1 ID ::= {
|
||||||
|
iso(1) member-body(2) us(840) x9-57 (10040)
|
||||||
|
x9cm(4) 3 }
|
||||||
|
|
||||||
|
Consult rfc2459 for more information.
|
||||||
|
|
||||||
|
@return a string containing the OID.
|
||||||
|
*/
|
||||||
|
public abstract String getSigAlgOID();
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the AlgorithmParameters in the encoded form
|
||||||
|
for the signature algorithm used.
|
||||||
|
|
||||||
|
If access to the parameters is need, create an
|
||||||
|
instance of AlgorithmParameters.
|
||||||
|
|
||||||
|
@return byte array containing algorithm parameters, null
|
||||||
|
if no parameters are present in certificate
|
||||||
|
*/
|
||||||
|
public abstract byte[] getSigAlgParams();
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the issuer unique ID for this certificate.
|
||||||
|
|
||||||
|
The ASN.1 DER encoding is:
|
||||||
|
|
||||||
|
issuerUniqueID [1] IMPLICIT UniqueIdentifier OPTIONAL,
|
||||||
|
-- If present, version shall be v2 or v3
|
||||||
|
|
||||||
|
UniqueIdentifier ::= BIT STRING
|
||||||
|
|
||||||
|
Consult rfc2459 for more information.
|
||||||
|
|
||||||
|
@return bit representation of <I>issuerUniqueID</I>
|
||||||
|
*/
|
||||||
|
public abstract boolean[] getIssuerUniqueID();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the subject unique ID for this certificate.
|
||||||
|
|
||||||
|
The ASN.1 DER encoding is:
|
||||||
|
|
||||||
|
subjectUniqueID [2] IMPLICIT UniqueIdentifier OPTIONAL,
|
||||||
|
-- If present, version shall be v2 or v3
|
||||||
|
|
||||||
|
UniqueIdentifier ::= BIT STRING
|
||||||
|
|
||||||
|
Consult rfc2459 for more information.
|
||||||
|
|
||||||
|
@return bit representation of <I>subjectUniqueID</I>
|
||||||
|
*/
|
||||||
|
public abstract boolean[] getSubjectUniqueID();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns a boolean array representing the <I>KeyUsage</I>
|
||||||
|
extension for the certificate. The KeyUsage (OID = 2.5.29.15)
|
||||||
|
defines the purpose of the key in the certificate.
|
||||||
|
|
||||||
|
The ASN.1 DER encoding is:
|
||||||
|
|
||||||
|
id-ce-keyUsage OBJECT IDENTIFIER ::= { id-ce 15 }
|
||||||
|
|
||||||
|
KeyUsage ::= BIT STRING {
|
||||||
|
digitalSignature (0),
|
||||||
|
nonRepudiation (1),
|
||||||
|
keyEncipherment (2),
|
||||||
|
dataEncipherment (3),
|
||||||
|
keyAgreement (4),
|
||||||
|
keyCertSign (5),
|
||||||
|
cRLSign (6),
|
||||||
|
encipherOnly (7),
|
||||||
|
decipherOnly (8) }
|
||||||
|
|
||||||
|
Consult rfc2459 for more information.
|
||||||
|
|
||||||
|
@return bit representation of <I>KeyUsage</I>
|
||||||
|
*/
|
||||||
|
public abstract boolean[] getKeyUsage();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the certificate constraints path length from the
|
||||||
|
critical BasicConstraints extension, (OID = 2.5.29.19).
|
||||||
|
|
||||||
|
The basic constraints extensions is used to determine if
|
||||||
|
the subject of the certificate is a Certificate Authority (CA)
|
||||||
|
and how deep the certification path may exist. The
|
||||||
|
<I>pathLenConstraint</I> only takes affect if <I>cA</I>
|
||||||
|
is set to true. "A value of zero indicates that only an
|
||||||
|
end-entity certificate may follow in the path." (rfc2459)
|
||||||
|
|
||||||
|
The ASN.1 DER encoding is:
|
||||||
|
|
||||||
|
id-ce-basicConstraints OBJECT IDENTIFIER ::= { id-ce 19 }
|
||||||
|
|
||||||
|
BasicConstraints ::= SEQUENCE {
|
||||||
|
cA BOOLEAN DEFAULT FALSE,
|
||||||
|
pathLenConstraint INTEGER (0..MAX) OPTIONAL }
|
||||||
|
|
||||||
|
Consult rfc2459 for more information.
|
||||||
|
|
||||||
|
@return the length of the path constraint if BasicConstraints
|
||||||
|
is present and cA is TRUE. Otherwise returns -1.
|
||||||
|
*/
|
||||||
|
public abstract int getBasicConstraints();
|
||||||
|
|
||||||
|
|
||||||
|
}
|
102
libjava/java/security/cert/X509Extension.java
Normal file
102
libjava/java/security/cert/X509Extension.java
Normal file
|
@ -0,0 +1,102 @@
|
||||||
|
/* X509Extension.java --- X.509 Extension
|
||||||
|
Copyright (C) 1999 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
|
||||||
|
package java.security.cert;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Public abstract interface for the X.509 Extension.
|
||||||
|
|
||||||
|
This is used for X.509 v3 Certificates and CRL v2 (Certificate
|
||||||
|
Revocation Lists) for managing attributes assoicated with
|
||||||
|
Certificates, for managing the hierarchy of certificates,
|
||||||
|
and for managing the distribution of CRL. This extension
|
||||||
|
format is used to define private extensions.
|
||||||
|
|
||||||
|
Each extensions for a certificate or CRL must be marked
|
||||||
|
either critical or non-critical. If the certificate/CRL
|
||||||
|
system encounters a critical extension not recognized then
|
||||||
|
it must reject the certificate. A non-critical extension
|
||||||
|
may be just ignored if not recognized.
|
||||||
|
|
||||||
|
|
||||||
|
The ASN.1 definition for this class is:
|
||||||
|
|
||||||
|
Extensions ::= SEQUENCE SIZE (1..MAX) OF Extension
|
||||||
|
|
||||||
|
Extension ::= SEQUENCE {
|
||||||
|
extnId OBJECT IDENTIFIER,
|
||||||
|
critical BOOLEAN DEFAULT FALSE,
|
||||||
|
extnValue OCTET STRING
|
||||||
|
-- contains a DER encoding of a value
|
||||||
|
-- of the type registered for use with
|
||||||
|
-- the extnId object identifier value
|
||||||
|
}
|
||||||
|
|
||||||
|
@author Mark Benvenuto
|
||||||
|
|
||||||
|
@since JDK 1.2
|
||||||
|
*/
|
||||||
|
public abstract interface X509Extension
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns true if the certificate contains a critical extension
|
||||||
|
that is not supported.
|
||||||
|
|
||||||
|
@return true if has unsupported extension, false otherwise
|
||||||
|
*/
|
||||||
|
public boolean hasUnsupportedCriticalExtension();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns a set of the CRITICAL extension OIDs from the
|
||||||
|
certificate/CRL that the object implementing this interface
|
||||||
|
manages.
|
||||||
|
|
||||||
|
@return A Set containing the OIDs. If there are no CRITICAL
|
||||||
|
extensions or extensions at all this returns null.
|
||||||
|
*/
|
||||||
|
public Set getCriticalExtensionOIDs();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns a set of the NON-CRITICAL extension OIDs from the
|
||||||
|
certificate/CRL that the object implementing this interface
|
||||||
|
manages.
|
||||||
|
|
||||||
|
@return A Set containing the OIDs. If there are no NON-CRITICAL
|
||||||
|
extensions or extensions at all this returns null.
|
||||||
|
*/
|
||||||
|
public Set getNonCriticalExtensionOIDs();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the DER encoded OCTET string for the specified
|
||||||
|
extension value identified by a OID. The OID is a string
|
||||||
|
of number seperated by periods. Ex: 12.23.45.67
|
||||||
|
*/
|
||||||
|
public byte[] getExtensionValue(String oid);
|
||||||
|
|
||||||
|
}
|
83
libjava/java/util/AbstractSet.java
Normal file
83
libjava/java/util/AbstractSet.java
Normal file
|
@ -0,0 +1,83 @@
|
||||||
|
/* AbstractSet.java -- Abstract implementation of most of Set
|
||||||
|
Copyright (C) 1998 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
|
||||||
|
package java.util;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An abstract implementation of Set to make it easier to create your own
|
||||||
|
* implementations. In order to create a Set, subclass AbstractSet and
|
||||||
|
* implement the same methods that are required for AbstractCollection
|
||||||
|
* (although these methods must of course meet the requirements that Set puts
|
||||||
|
* on them - specifically, no element may be in the set more than once). This
|
||||||
|
* class simply provides implementations of equals() and hashCode() to fulfil
|
||||||
|
* the requirements placed on them by the Set interface.
|
||||||
|
*/
|
||||||
|
public abstract class AbstractSet extends AbstractCollection implements Set {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests whether the given object is equal to this Set. This implementation
|
||||||
|
* first checks whether this set <em>is</em> the given object, and returns
|
||||||
|
* true if so. Otherwise, if o is a Set and is the same size as this one, it
|
||||||
|
* returns the result of calling containsAll on the given Set. Otherwise, it
|
||||||
|
* returns false.
|
||||||
|
*
|
||||||
|
* @param o the Object to be tested for equality with this Set
|
||||||
|
* @return true if the given object is equal to this Set
|
||||||
|
*/
|
||||||
|
public boolean equals(Object o) {
|
||||||
|
if (o == this) {
|
||||||
|
return true;
|
||||||
|
} else if (o instanceof Set && ((Set)o).size() == size()) {
|
||||||
|
throw new Error ("FIXME: compiler error - AbstractSet.equals");
|
||||||
|
/* FIXME: this is the correct implementation, but a compiler
|
||||||
|
error prevents us from building it.
|
||||||
|
return containsAll((Collection)o); */
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a hash code for this Set. The hash code of a Set is the sum of the
|
||||||
|
* hash codes of all its elements, except that the hash code of null is
|
||||||
|
* defined to be zero. This implementation obtains an Iterator over the Set,
|
||||||
|
* and sums the results.
|
||||||
|
*
|
||||||
|
* @return a hash code for this Set
|
||||||
|
*/
|
||||||
|
public int hashCode() {
|
||||||
|
int hash = 0;
|
||||||
|
Iterator i = iterator();
|
||||||
|
while (i.hasNext()) {
|
||||||
|
try {
|
||||||
|
hash += i.next().hashCode();
|
||||||
|
} catch (NullPointerException e) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return hash;
|
||||||
|
}
|
||||||
|
}
|
135
libjava/java/util/BasicMapEntry.java
Normal file
135
libjava/java/util/BasicMapEntry.java
Normal file
|
@ -0,0 +1,135 @@
|
||||||
|
/* BasicMapEntry.java -- a class providing a plain-vanilla implementation of
|
||||||
|
the Map.Entry interface; could be used anywhere in java.util
|
||||||
|
Copyright (C) 1998 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
|
||||||
|
package java.util;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* a class which implements Map.Entry
|
||||||
|
*
|
||||||
|
* @author Jon Zeppieri
|
||||||
|
* @version $Revision: 1.3 $
|
||||||
|
* @modified $Id: BasicMapEntry.java,v 1.3 2000/03/15 21:59:07 rao Exp $
|
||||||
|
*/
|
||||||
|
class BasicMapEntry implements Map.Entry
|
||||||
|
{
|
||||||
|
/** the key */
|
||||||
|
Object key;
|
||||||
|
/** the value */
|
||||||
|
Object value;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* construct a new BasicMapEntry with the given key and value
|
||||||
|
*
|
||||||
|
* @param newKey the key of this Entry
|
||||||
|
* @param newValue the value of this Entry
|
||||||
|
*/
|
||||||
|
BasicMapEntry(Object newKey, Object newValue)
|
||||||
|
{
|
||||||
|
key = newKey;
|
||||||
|
value = newValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* returns true if <pre>o</pre> is a Map.Entry and
|
||||||
|
* <pre>
|
||||||
|
* (((o.getKey == null) ? (key == null) :
|
||||||
|
* o.getKey().equals(key)) &&
|
||||||
|
* ((o.getValue() == null) ? (value == null) :
|
||||||
|
* o.getValue().equals(value)))
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
|
* NOTE: the calls to getKey() and getValue() in this implementation
|
||||||
|
* are <i>NOT</i> superfluous and should not be removed. They insure
|
||||||
|
* that subclasses such as HashMapEntry work correctly
|
||||||
|
*
|
||||||
|
* @param o the Object being tested for equality
|
||||||
|
*/
|
||||||
|
public boolean equals(Object o)
|
||||||
|
{
|
||||||
|
Map.Entry tester;
|
||||||
|
Object oTestingKey, oTestingValue;
|
||||||
|
Object oKey, oValue;
|
||||||
|
if (o instanceof Map.Entry)
|
||||||
|
{
|
||||||
|
tester = (Map.Entry) o;
|
||||||
|
oKey = getKey();
|
||||||
|
oValue = getValue();
|
||||||
|
oTestingKey = tester.getKey();
|
||||||
|
oTestingValue = tester.getValue();
|
||||||
|
return (((oTestingKey == null) ? (oKey == null) :
|
||||||
|
oTestingKey.equals(oKey)) &&
|
||||||
|
((oTestingValue == null) ? (oValue == null) :
|
||||||
|
oTestingValue.equals(oValue)));
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** returns the key */
|
||||||
|
public Object getKey()
|
||||||
|
{
|
||||||
|
return key;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** returns the value */
|
||||||
|
public Object getValue()
|
||||||
|
{
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** the hashCode() for a Map.Entry is
|
||||||
|
* <pre>
|
||||||
|
* ((getKey() == null) ? 0 : getKey().hashCode()) ^
|
||||||
|
* ((getValue() == null) ? 0 : getValue().hashCode());
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
|
* NOTE: the calls to getKey() and getValue() in this implementation
|
||||||
|
* are <i>NOT</i> superfluous and should not be removed. They insure
|
||||||
|
* that subclasses such as HashMapEntry work correctly
|
||||||
|
*/
|
||||||
|
public int hashCode()
|
||||||
|
{
|
||||||
|
Object oKey = getKey();
|
||||||
|
Object oValue = getValue();
|
||||||
|
return ((oKey == null) ? 0 : oKey.hashCode()) ^
|
||||||
|
((oValue == null) ? 0 : oValue.hashCode());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* sets the value of this Map.Entry
|
||||||
|
*
|
||||||
|
* @param newValue the new value of this Map.Entry
|
||||||
|
*/
|
||||||
|
public Object setValue(Object newValue)
|
||||||
|
throws java.lang.UnsupportedOperationException, ClassCastException,
|
||||||
|
IllegalArgumentException, NullPointerException
|
||||||
|
{
|
||||||
|
Object oVal = value;
|
||||||
|
value = newValue;
|
||||||
|
return oVal;
|
||||||
|
}
|
||||||
|
}
|
199
libjava/java/util/Bucket.java
Normal file
199
libjava/java/util/Bucket.java
Normal file
|
@ -0,0 +1,199 @@
|
||||||
|
/* Bucket.java -- a class providing a hash-bucket data structure
|
||||||
|
(a lightweight linked list)
|
||||||
|
Copyright (C) 1998, 2000 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
|
||||||
|
package java.util;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* a class representing a simple, lightweight linked-list, using Node
|
||||||
|
* objects as its linked nodes; this is used by Hashtable and HashMap
|
||||||
|
*
|
||||||
|
* @author Jon Zeppieri
|
||||||
|
* @version $Revision: 1.3 $
|
||||||
|
* @modified $Id: Bucket.java,v 1.3 2000/03/15 21:59:08 rao Exp $
|
||||||
|
*/
|
||||||
|
class Bucket
|
||||||
|
{
|
||||||
|
/** the first node of the lined list, originally null */
|
||||||
|
Node first;
|
||||||
|
|
||||||
|
/** trivial constructor for a Bucket */
|
||||||
|
Bucket()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
/** add this key / value pair to the list
|
||||||
|
*
|
||||||
|
* @param newNode a Node object to be added to this list
|
||||||
|
* @return the old value mapped to the key if there was one,
|
||||||
|
* otherwise null.
|
||||||
|
*/
|
||||||
|
Object add(Node newNode)
|
||||||
|
{
|
||||||
|
Object oKey;
|
||||||
|
Object oTestKey = newNode.getKey();
|
||||||
|
Node it = first;
|
||||||
|
Node prev = null;
|
||||||
|
if (it == null) // if the list is empty (the ideal case), we make a new single-node list
|
||||||
|
{
|
||||||
|
first = newNode;
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
else // otherwise try to find where this key already exists in the list,
|
||||||
|
{// and if it does, replace the value with the new one (and return the old one)
|
||||||
|
while (it != null)
|
||||||
|
{
|
||||||
|
oKey = it.getKey();
|
||||||
|
if ((oKey == null) ? (oTestKey == null) :
|
||||||
|
oKey.equals(oTestKey))
|
||||||
|
{
|
||||||
|
Object oldValue = it.value;
|
||||||
|
it.value = newNode.getValue();
|
||||||
|
return oldValue;
|
||||||
|
}
|
||||||
|
prev = it;
|
||||||
|
it = it.next;
|
||||||
|
}
|
||||||
|
prev.next = newNode; // otherwise, just stick this at the
|
||||||
|
return null; // end of the list
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* remove a Map.Entry in this list with the supplied key and return its value,
|
||||||
|
* if it exists, else return null
|
||||||
|
*
|
||||||
|
* @param key the key we are looking for in this list
|
||||||
|
*/
|
||||||
|
Object removeByKey(Object key)
|
||||||
|
{
|
||||||
|
Object oEntryKey;
|
||||||
|
Node prev = null;
|
||||||
|
Node it = first;
|
||||||
|
while (it != null)
|
||||||
|
{
|
||||||
|
oEntryKey = it.getKey();
|
||||||
|
if ((oEntryKey == null) ? (key == null) : oEntryKey.equals(key))
|
||||||
|
{
|
||||||
|
if (prev == null) // we are removing the first element
|
||||||
|
first = it.next;
|
||||||
|
else
|
||||||
|
prev.next = it.next;
|
||||||
|
return it.getValue();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
prev = it;
|
||||||
|
it = it.next;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* return the value which the supplied key maps to, if it maps to anything in this list,
|
||||||
|
* otherwise, return null
|
||||||
|
*
|
||||||
|
* @param key the key mapping to a value that we are looking for
|
||||||
|
*/
|
||||||
|
Object getValueByKey(Object key)
|
||||||
|
{
|
||||||
|
Node entry = getEntryByKey(key);
|
||||||
|
return (entry == null) ? null : entry.getValue();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* return the Map.Entry which the supplied key is a part of, if such a Map.Entry exists,
|
||||||
|
* null otherwise
|
||||||
|
*
|
||||||
|
* this method is important for HashMap, which can hold null values and the null key
|
||||||
|
*
|
||||||
|
* @param key the key for which we are finding the corresponding Map.Entry
|
||||||
|
*/
|
||||||
|
Node getEntryByKey(Object key)
|
||||||
|
{
|
||||||
|
Object oEntryKey;
|
||||||
|
Node it = first;
|
||||||
|
while (it != null)
|
||||||
|
{
|
||||||
|
oEntryKey = it.getKey();
|
||||||
|
if ((oEntryKey == null) ? (key == null) : oEntryKey.equals(key))
|
||||||
|
return it;
|
||||||
|
it = it.next;
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* return true if this list has a Map.Entry whose value equals() the supplied value
|
||||||
|
*
|
||||||
|
* @param value the value we are looking to match in this list
|
||||||
|
*/
|
||||||
|
boolean containsValue(Object value)
|
||||||
|
{
|
||||||
|
Object oEntryValue;
|
||||||
|
Node it = first;
|
||||||
|
while (it != null)
|
||||||
|
{
|
||||||
|
oEntryValue = it.getValue();
|
||||||
|
if ((oEntryValue == null) ? (value == null) : oEntryValue.equals(value))
|
||||||
|
return true;
|
||||||
|
it = it.next;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// INNSER CLASSES ----------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* a class represnting a node in our lightweight linked-list
|
||||||
|
* that we use for hash buckets; a Node object contains a Map.Entry as its
|
||||||
|
* <pre>value</pre> property and a reference (possibly, even hopefully, null)
|
||||||
|
* to another Node as its <pre>next</pre> property.
|
||||||
|
*
|
||||||
|
* There <i>is</i> a reason for not using a highly generic "LinkedNode" type
|
||||||
|
* class: we want to eliminate runtime typechecks.
|
||||||
|
*
|
||||||
|
* @author Jon Zeppieri
|
||||||
|
* @version $Revision: 1.3 $
|
||||||
|
* @modified $Id: Bucket.java,v 1.3 2000/03/15 21:59:08 rao Exp $
|
||||||
|
*/
|
||||||
|
static class Node extends BasicMapEntry implements Map.Entry
|
||||||
|
{
|
||||||
|
/** a reference to the next node in the linked list */
|
||||||
|
Node next;
|
||||||
|
|
||||||
|
/** non-trivial contructor -- sets the <pre>value</pre> of the Bucket upon instantiation */
|
||||||
|
Node(Object key, Object value)
|
||||||
|
{
|
||||||
|
super(key, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
// EOF ------------------------------------------------------------------------
|
||||||
|
}
|
File diff suppressed because it is too large
Load diff
57
libjava/java/util/Map.java
Normal file
57
libjava/java/util/Map.java
Normal file
|
@ -0,0 +1,57 @@
|
||||||
|
/* Map.java -- An object that maps keys to values
|
||||||
|
Copyright (C) 1998 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
|
||||||
|
// TO DO:
|
||||||
|
// ~ Doc comments for everything.
|
||||||
|
|
||||||
|
package java.util;
|
||||||
|
|
||||||
|
public interface Map
|
||||||
|
{
|
||||||
|
public void clear();
|
||||||
|
public boolean containsKey(Object key);
|
||||||
|
public boolean containsValue(Object value);
|
||||||
|
public Set entrySet();
|
||||||
|
public boolean equals(Object o);
|
||||||
|
public Object get(Object key);
|
||||||
|
public Object put(Object key, Object value);
|
||||||
|
public int hashCode();
|
||||||
|
public boolean isEmpty();
|
||||||
|
public Set keySet();
|
||||||
|
public void putAll(Map m);
|
||||||
|
public Object remove(Object o);
|
||||||
|
public int size();
|
||||||
|
public Collection values();
|
||||||
|
|
||||||
|
public static interface Entry {
|
||||||
|
public Object getKey();
|
||||||
|
public Object getValue();
|
||||||
|
public Object setValue(Object value);
|
||||||
|
public int hashCode();
|
||||||
|
public boolean equals(Object o);
|
||||||
|
}
|
||||||
|
}
|
48
libjava/java/util/Set.java
Normal file
48
libjava/java/util/Set.java
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
/* Set.java -- A collection that prohibits duplicates
|
||||||
|
Copyright (C) 1998 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
|
||||||
|
// TO DO:
|
||||||
|
// ~ Doc comments for everything.
|
||||||
|
|
||||||
|
package java.util;
|
||||||
|
|
||||||
|
public interface Set extends Collection {
|
||||||
|
boolean add(Object o);
|
||||||
|
boolean addAll(Collection c);
|
||||||
|
void clear();
|
||||||
|
boolean contains(Object o);
|
||||||
|
boolean containsAll(Collection c);
|
||||||
|
boolean equals(Object o);
|
||||||
|
int hashCode();
|
||||||
|
boolean isEmpty();
|
||||||
|
Iterator iterator();
|
||||||
|
boolean remove(Object o);
|
||||||
|
boolean removeAll(Collection c);
|
||||||
|
boolean retainAll(Collection c);
|
||||||
|
int size();
|
||||||
|
Object[] toArray();
|
||||||
|
}
|
586
libjava/java/util/jar/Attributes.java
Normal file
586
libjava/java/util/jar/Attributes.java
Normal file
|
@ -0,0 +1,586 @@
|
||||||
|
/* Attributes.java -- Represents attribute name/value pairs from a Manifest
|
||||||
|
Copyright (C) 2000 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
package java.util.jar;
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Hashtable;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Represents attribute name/value pairs from a Manifest as a Map.
|
||||||
|
* The names of an attribute are represented by the
|
||||||
|
* <code>Attributes.Name</code> class and should confirm to the restrictions
|
||||||
|
* described in that class. Note that the Map interface that Attributes
|
||||||
|
* implements allows you to put names and values into the attribute that don't
|
||||||
|
* follow these restriction (and are not really Atrribute.Names, but if you do
|
||||||
|
* that it might cause undefined behaviour later).
|
||||||
|
* <p>
|
||||||
|
* If you use the constants defined in the inner class Name then you can be
|
||||||
|
* sure that you always access the right attribute names. This makes
|
||||||
|
* manipulating the Attributes more or less type safe.
|
||||||
|
* <p>
|
||||||
|
* Most of the methods are wrappers to implement the Map interface. The really
|
||||||
|
* usefull and often used methods are <code>getValue(Name)</code> and
|
||||||
|
* <code>getValue(String)</code>. If you actually want to set attributes you
|
||||||
|
* may want to use the <code>putValue(String, String)</code> method
|
||||||
|
* (sorry there is no public type safe <code>putValue(Name, String)</code>
|
||||||
|
* method).
|
||||||
|
*
|
||||||
|
* @see java.util.jar.Attributes.Name
|
||||||
|
* @author Mark Wielaard (mark@klomp.org)
|
||||||
|
*/
|
||||||
|
public class Attributes implements Cloneable, Map {
|
||||||
|
|
||||||
|
// Fields
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The map that holds all the attribute name/value pairs. In this
|
||||||
|
* implementation it is actually a Hashtable, but that can be different in
|
||||||
|
* other implementations.
|
||||||
|
*/
|
||||||
|
protected Map map;
|
||||||
|
|
||||||
|
// Inner class
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Represents a name of a Manifest Attribute. Defines a couple of well
|
||||||
|
* know names for the general main attributes, stand alone application
|
||||||
|
* attributes, applet attributes, extension identification attributes,
|
||||||
|
* package versioning and sealing attributes, file contents attributes,
|
||||||
|
* bean objects attribute and signing attributes. See the
|
||||||
|
* <p>
|
||||||
|
* The characters of a Name must obey the following restrictions:
|
||||||
|
* <ul>
|
||||||
|
* <li> Must contain at least one character
|
||||||
|
* <li> The first character must be alphanumeric (a-z, A-Z, 0-9)
|
||||||
|
* <li> All other characters must be alphanumeric, a '-' or a '_'
|
||||||
|
* </ul>
|
||||||
|
* <p>
|
||||||
|
* When comparing Names (with <code>equals</code>) all characters are
|
||||||
|
* converted to lowercase. But you can get the original case sensitive
|
||||||
|
* string with the <code>toString()</code> method.
|
||||||
|
*
|
||||||
|
* @since 1.2
|
||||||
|
* @author Mark Wielaard (mark@klomp.org)
|
||||||
|
*/
|
||||||
|
public static class Name {
|
||||||
|
|
||||||
|
// Fields
|
||||||
|
|
||||||
|
// General Main Attributes
|
||||||
|
|
||||||
|
/**
|
||||||
|
* General main attribute -
|
||||||
|
* the version of this Manifest file.
|
||||||
|
*/
|
||||||
|
public static final Name MANIFEST_VERSION
|
||||||
|
= new Name("Manifest-Version");
|
||||||
|
/**
|
||||||
|
* General main attribute -
|
||||||
|
* tool and version that created this Manifest file.
|
||||||
|
*/
|
||||||
|
public static final Name CREATED_BY
|
||||||
|
= new Name("Created-By");
|
||||||
|
/**
|
||||||
|
* General main attribute -
|
||||||
|
* the version of the jar file signature.
|
||||||
|
*/
|
||||||
|
public static final Name SIGNATURE_VERSION
|
||||||
|
= new Name("Signature-Version");
|
||||||
|
/**
|
||||||
|
* General main attribute -
|
||||||
|
* (relative) URLs of the libraries/classpaths that the Classes in
|
||||||
|
* this jar file depend on.
|
||||||
|
*/
|
||||||
|
public static final Name CLASS_PATH
|
||||||
|
= new Name("Class-Path");
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Stand alone application attribute -
|
||||||
|
* the entry (without the .class ending) that is the main
|
||||||
|
* class of this jar file.
|
||||||
|
*/
|
||||||
|
public static final Name MAIN_CLASS
|
||||||
|
= new Name("Main-Class");
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Applet attribute -
|
||||||
|
* a list of extension libraries that the applet in this
|
||||||
|
* jar file depends on.
|
||||||
|
* For every named extension there should be some Attributes in the
|
||||||
|
* Manifest manifest file with the following Names:
|
||||||
|
* <ul>
|
||||||
|
* <li> <extension>-Extension-Name:
|
||||||
|
* unique name of the extension
|
||||||
|
* <li> <extension>-Specification-Version:
|
||||||
|
* minimum specification version
|
||||||
|
* <li> <extension>-Implementation-Version:
|
||||||
|
* minimum implementation version
|
||||||
|
* <li> <extension>-Implementation-Vendor-Id:
|
||||||
|
* unique id of implementation vendor
|
||||||
|
* <li> <extension>-Implementation-URL:
|
||||||
|
* where the latest version of the extension library can be found
|
||||||
|
* </ul>
|
||||||
|
*/
|
||||||
|
public static final Name EXTENSION_LIST
|
||||||
|
= new Name("Extension-List");
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Extension identification attribute -
|
||||||
|
* the name if the extension library contained in the jar.
|
||||||
|
*/
|
||||||
|
public static final Name EXTENSION_NAME
|
||||||
|
= new Name("Extension-Name");
|
||||||
|
/**
|
||||||
|
* Extension identification attribute -
|
||||||
|
* synonym for <code>EXTENSTION_NAME</code>.
|
||||||
|
*/
|
||||||
|
public static final Name EXTENSION_INSTALLATION
|
||||||
|
= EXTENSION_NAME;
|
||||||
|
|
||||||
|
// Package versioning and sealing attributes
|
||||||
|
/**
|
||||||
|
* Package versioning -
|
||||||
|
* name of extension library contained in this jar.
|
||||||
|
*/
|
||||||
|
public static final Name IMPLEMENTATION_TITLE
|
||||||
|
= new Name("Implementation-Title");
|
||||||
|
/**
|
||||||
|
* Package versioning -
|
||||||
|
* version of the extension library contained in this jar.
|
||||||
|
*/
|
||||||
|
public static final Name IMPLEMENTATION_VERSION
|
||||||
|
= new Name("Implementation-Version");
|
||||||
|
/**
|
||||||
|
* Package versioning -
|
||||||
|
* name of extension library creator contained in this jar.
|
||||||
|
*/
|
||||||
|
public static final Name IMPLEMENTATION_VENDOR
|
||||||
|
= new Name("Implementation-Vendor");
|
||||||
|
/**
|
||||||
|
* Package versioning -
|
||||||
|
* unique id of extension library creator.
|
||||||
|
*/
|
||||||
|
public static final Name IMPLEMENTATION_VENDOR_ID
|
||||||
|
= new Name("Implementation-Vendor-Id");
|
||||||
|
/**
|
||||||
|
* Package versioning -
|
||||||
|
* location where this implementation can be downloaded.
|
||||||
|
*/
|
||||||
|
public static final Name IMPLEMENTATION_URL
|
||||||
|
= new Name("Implementation-URL");
|
||||||
|
/**
|
||||||
|
* Package versioning -
|
||||||
|
* title of the specification contained in this jar.
|
||||||
|
*/
|
||||||
|
public static final Name SPECIFICATION_TITLE
|
||||||
|
= new Name("Specification-Title");
|
||||||
|
/**
|
||||||
|
* Package versioning -
|
||||||
|
* version of the specification contained in this jar.
|
||||||
|
*/
|
||||||
|
public static final Name SPECIFICATION_VERSION
|
||||||
|
= new Name("Specification-Version");
|
||||||
|
/**
|
||||||
|
* Package versioning -
|
||||||
|
* organisation that maintains the specification contains in this
|
||||||
|
* jar.
|
||||||
|
*/
|
||||||
|
public static final Name SPECIFICATION_VENDOR
|
||||||
|
= new Name("Specification-Vendor");
|
||||||
|
/**
|
||||||
|
* Package sealing -
|
||||||
|
* whether (all) package(s) is(/are) sealed. Value is either "true"
|
||||||
|
* or "false".
|
||||||
|
*/
|
||||||
|
public static final Name SEALED
|
||||||
|
= new Name("Sealed");
|
||||||
|
|
||||||
|
/**
|
||||||
|
* File contents attribute -
|
||||||
|
* Mime type and subtype for the jar entry.
|
||||||
|
*/
|
||||||
|
public static final Name CONTENT_TYPE
|
||||||
|
= new Name("Content-Type");
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Bean objects attribute -
|
||||||
|
* whether the entry is a Java Bean. Value is either "true" or "false".
|
||||||
|
*/
|
||||||
|
public static final Name JAVA_BEAN
|
||||||
|
= new Name("Java-Bean");
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Signing attribute -
|
||||||
|
* application specific signing attribute. Must be understood by
|
||||||
|
* the manifest parser when present to validate the jar (entry).
|
||||||
|
*/
|
||||||
|
public static final Name MAGIC
|
||||||
|
= new Name("Magic");
|
||||||
|
|
||||||
|
/** The (lowercase) String representation of this Name */
|
||||||
|
private final String name;
|
||||||
|
/** The original String given to the constructor */
|
||||||
|
private final String origName;
|
||||||
|
|
||||||
|
// Constructor
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new Name from the given String.
|
||||||
|
* Throws an IllegalArgumentException if the given String is empty or
|
||||||
|
* contains any illegal Name characters.
|
||||||
|
*
|
||||||
|
* @param name the name of the new Name
|
||||||
|
* @exception IllegalArgumentException if name isn't a valid String
|
||||||
|
* representation of a Name
|
||||||
|
* @exception NullPointerException if name is null
|
||||||
|
*/
|
||||||
|
public Name(String name) throws IllegalArgumentException,
|
||||||
|
NullPointerException {
|
||||||
|
// name must not be null
|
||||||
|
// this will throw a NullPointerException if it is
|
||||||
|
char chars[] = name.toCharArray();
|
||||||
|
|
||||||
|
// there must be at least one character
|
||||||
|
if (chars.length == 0)
|
||||||
|
throw new IllegalArgumentException(
|
||||||
|
"There must be at least one character in a name");
|
||||||
|
|
||||||
|
// first character must be alphanum
|
||||||
|
char c = chars[0];
|
||||||
|
if (!((c >= 'a' && c <= 'z') ||
|
||||||
|
(c >= 'A' && c <= 'Z') ||
|
||||||
|
(c >= '0' && c <= '9')))
|
||||||
|
throw new IllegalArgumentException(
|
||||||
|
"First character must be alphanum");
|
||||||
|
|
||||||
|
// all other characters must be alphanums, '-' or '_'
|
||||||
|
for (int i = 1; i < chars.length; i++) {
|
||||||
|
if (!((c >= 'a' && c <= 'z') ||
|
||||||
|
(c >= 'A' && c <= 'Z') ||
|
||||||
|
(c >= '0' && c <= '9') ||
|
||||||
|
(c == '-') || (c == '_')))
|
||||||
|
throw new IllegalArgumentException(
|
||||||
|
"Characters must be alphanums, '-' or '_'");
|
||||||
|
}
|
||||||
|
|
||||||
|
// Still here? Then convert to lower case and be done.
|
||||||
|
// Store the original name for toString();
|
||||||
|
this.origName = name;
|
||||||
|
this.name = name.toLowerCase();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the hash code of the (lowercase) String representation of
|
||||||
|
* this Name.
|
||||||
|
*/
|
||||||
|
public int hashCode() {
|
||||||
|
return name.hashCode();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks if another object is equal to this Name object.
|
||||||
|
* Another object is equal to this Name object if it is an instance of
|
||||||
|
* Name and the (lowercase) string representation of the name is equal.
|
||||||
|
*/
|
||||||
|
public boolean equals(Object o) {
|
||||||
|
// Quick and dirty check
|
||||||
|
if (name == o)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
try {
|
||||||
|
// Note that the constructor already converts the strings to
|
||||||
|
// lowercase.
|
||||||
|
String otherName = ((Name)o).name;
|
||||||
|
return name.equals(otherName);
|
||||||
|
} catch (ClassCastException cce) {
|
||||||
|
return false;
|
||||||
|
} catch (NullPointerException npe) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the string representation of this Name as given to the
|
||||||
|
* constructor (not neccesarily the lower case representation).
|
||||||
|
*/
|
||||||
|
public String toString() {
|
||||||
|
return origName;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Constructors
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an empty Attributes map.
|
||||||
|
*/
|
||||||
|
public Attributes() {
|
||||||
|
map = new Hashtable();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an empty Attributes map with the given initial size.
|
||||||
|
* @param size the initial size of the underlying map
|
||||||
|
*/
|
||||||
|
public Attributes(int size) {
|
||||||
|
map = new Hashtable(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an Attributes map with the initial values taken from another
|
||||||
|
* Attributes map.
|
||||||
|
* @param attr Attributes map to take the initial values from
|
||||||
|
*/
|
||||||
|
public Attributes(Attributes attr) {
|
||||||
|
map = new Hashtable(attr.map);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Methods
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the value of an attribute name given as a String.
|
||||||
|
*
|
||||||
|
* @param name a String describing the Name to look for
|
||||||
|
* @return the value gotten from the map of null when not found
|
||||||
|
*/
|
||||||
|
public String getValue(String name) {
|
||||||
|
return (String)get(new Name(name));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the value of the given attribute name.
|
||||||
|
*
|
||||||
|
* @param name the Name to look for
|
||||||
|
* @return the value gotten from the map of null when not found
|
||||||
|
*/
|
||||||
|
public String getValue(Name name) {
|
||||||
|
return (String)get(name);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Stores an attribute name (represented by a String) and value in this
|
||||||
|
* Attributes map.
|
||||||
|
* When the (case insensitive string) name already exists the value is
|
||||||
|
* replaced and the old value is returned.
|
||||||
|
*
|
||||||
|
* @param name a (case insensitive) String representation of the attribite
|
||||||
|
* name to add/replace
|
||||||
|
* @param value the (new) value of the attribute name
|
||||||
|
* @returns the old value of the attribute name or null if it didn't exist
|
||||||
|
* yet
|
||||||
|
*/
|
||||||
|
public String putValue(String name, String value)
|
||||||
|
{
|
||||||
|
return putValue(new Name(name), value);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Stores an attribute name (represented by a String) and value in this
|
||||||
|
* Attributes map.
|
||||||
|
* When the name already exists the value is replaced and the old value
|
||||||
|
* is returned.
|
||||||
|
* <p>
|
||||||
|
* I don't know why there is no public method with this signature. I think
|
||||||
|
* there should be one.
|
||||||
|
*
|
||||||
|
* @param name the attribite name to add/replace
|
||||||
|
* @param value the (new) value of the attribute name
|
||||||
|
* @returns the old value of the attribute name or null if it didn't exist
|
||||||
|
* yet
|
||||||
|
*/
|
||||||
|
private String putValue(Name name, String value)
|
||||||
|
{
|
||||||
|
return (String)put(name, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Methods from Cloneable interface
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return a clone of this attribute map.
|
||||||
|
*/
|
||||||
|
public Object clone() {
|
||||||
|
return new Attributes(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Methods from Map interface
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Removes all attributes.
|
||||||
|
*/
|
||||||
|
public void clear() {
|
||||||
|
map.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks to see if there is an attribute with the specified name.
|
||||||
|
* XXX - what if the object is a String?
|
||||||
|
*
|
||||||
|
* @param attrName the name of the attribute to check
|
||||||
|
* @return true if there is an attribute with the specified name, false
|
||||||
|
* otherwise
|
||||||
|
*/
|
||||||
|
public boolean containsKey(Object attrName) {
|
||||||
|
return map.containsKey(attrName);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks to see if there is an attribute name with the specified value.
|
||||||
|
*
|
||||||
|
* @param attrValue the value of a attribute to check
|
||||||
|
* @return true if there is an attribute name with the specified value,
|
||||||
|
* false otherwise
|
||||||
|
*/
|
||||||
|
public boolean containsValue(Object attrValue) {
|
||||||
|
return map.containsValue(attrValue);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gives a Set of atrribute name and values pairs as MapEntries.
|
||||||
|
* @see java.util.Map.Entry
|
||||||
|
* @see java.util.Map#entrySet()
|
||||||
|
*
|
||||||
|
* @return a set of attribute name value pairs
|
||||||
|
*/
|
||||||
|
public Set entrySet() {
|
||||||
|
return map.entrySet();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks to see if two Attributes are equal. The supplied object must be
|
||||||
|
* a real instance of Attributes and contain the same attribute name/value
|
||||||
|
* pairs.
|
||||||
|
*
|
||||||
|
* @param o another Attribute object which should be checked for equality
|
||||||
|
* @return true if the object is an instance of Attributes and contains the
|
||||||
|
* same name/value pairs, false otherwise
|
||||||
|
*/
|
||||||
|
public boolean equals(Object o) {
|
||||||
|
// quick and dirty check
|
||||||
|
if (this == o)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
try {
|
||||||
|
return map.equals(((Attributes)o).map);
|
||||||
|
} catch (ClassCastException cce) {
|
||||||
|
return false;
|
||||||
|
} catch (NullPointerException npe) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the value of a specified attribute name.
|
||||||
|
* XXX - what if the object is a String?
|
||||||
|
*
|
||||||
|
* @param attrName the name of the attribute we want the value of
|
||||||
|
* @return the value of the specified attribute name or null when there is
|
||||||
|
* no such attribute name
|
||||||
|
*/
|
||||||
|
public Object get(Object attrName) {
|
||||||
|
return map.get(attrName);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the hashcode of the attribute name/value map.
|
||||||
|
*/
|
||||||
|
public int hashCode() {
|
||||||
|
return map.hashCode();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns true if there are no attributes set, false otherwise.
|
||||||
|
*/
|
||||||
|
public boolean isEmpty() {
|
||||||
|
return map.isEmpty();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gives a Set of all the values of defined attribute names.
|
||||||
|
*/
|
||||||
|
public Set keySet() {
|
||||||
|
return map.keySet();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds or replaces a attribute name/value pair.
|
||||||
|
* XXX - What if the name is a string? What if the name is neither a Name
|
||||||
|
* nor a String? What if the value is not a string?
|
||||||
|
*
|
||||||
|
* @param name the name of the attribute
|
||||||
|
* @param value the (new) value of the attribute
|
||||||
|
* @return the old value of the attribute or null when there was no old
|
||||||
|
* attribute with this name
|
||||||
|
*/
|
||||||
|
public Object put(Object name, Object value) {
|
||||||
|
return map.put(name, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds or replaces all attribute name/value pairs from another
|
||||||
|
* Attributes object to this one. The supplied Map must be an instance of
|
||||||
|
* Attributes.
|
||||||
|
*
|
||||||
|
* @param attr the Attributes object to merge with this one
|
||||||
|
* @exception ClassCastException if the supplied map is not an instance of
|
||||||
|
* Attributes
|
||||||
|
*/
|
||||||
|
public void putAll(Map attr) {
|
||||||
|
if (!(attr instanceof Attributes)) {
|
||||||
|
throw new ClassCastException(
|
||||||
|
"Supplied Map is not an instance of Attributes");
|
||||||
|
}
|
||||||
|
map.putAll(attr);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove a attribute name/value pair.
|
||||||
|
* XXX - What if the name is a String?
|
||||||
|
*
|
||||||
|
* @param name the name of the attribute name/value pair to remove
|
||||||
|
* @return the old value of the attribute or null if the attribute didn't
|
||||||
|
* exist
|
||||||
|
*/
|
||||||
|
public Object remove(Object name) {
|
||||||
|
return map.remove(name);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the number of defined attribute name/value pairs.
|
||||||
|
*/
|
||||||
|
public int size() {
|
||||||
|
return map.size();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns all the values of the defined attribute name/value pairs as a
|
||||||
|
* Collection.
|
||||||
|
*/
|
||||||
|
public Collection values() {
|
||||||
|
return map.values();
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,39 +1,139 @@
|
||||||
/* Copyright (C) 1999 Free Software Foundation
|
/* JarEntry.java - Represents an entry in a jar file
|
||||||
|
Copyright (C) 2000 Free Software Foundation, Inc.
|
||||||
|
|
||||||
This file is part of libgcj.
|
This file is part of GNU Classpath.
|
||||||
|
|
||||||
This software is copyrighted work licensed under the terms of the
|
GNU Classpath is free software; you can redistribute it and/or modify
|
||||||
Libgcj License. Please consult the file "LIBGCJ_LICENSE" for
|
it under the terms of the GNU General Public License as published by
|
||||||
details. */
|
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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
package java.util.jar;
|
package java.util.jar;
|
||||||
|
|
||||||
import java.util.zip.*;
|
import java.io.IOException;
|
||||||
|
import java.security.cert.Certificate;
|
||||||
|
import java.util.zip.ZipEntry;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Does not implement the security and manifest methods.
|
* Extension to a ZipEntry that contains manifest attributes and certificates.
|
||||||
|
* Both the Atrributes and the Certificates can be null when not set.
|
||||||
|
* Note that the <code>getCertificates()</code> method only returns a
|
||||||
|
* valid value after all of the data of the entry has been read.
|
||||||
|
* <p>
|
||||||
|
* There are no public methods to set the attributes or certificate of an
|
||||||
|
* Entru. Only JarEntries created by the classes in <code>java.util.jar</code>
|
||||||
|
* will have these properties set.
|
||||||
*
|
*
|
||||||
* @author Kresten Krab Thorup <krab@gnu.org>
|
* @since 1.2
|
||||||
* @date August 10, 1999.
|
* @author Mark Wielaard (mark@klomp.org)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
public class JarEntry extends ZipEntry {
|
||||||
|
|
||||||
public class JarEntry extends ZipEntry
|
// (Packge local) fields
|
||||||
{
|
|
||||||
ZipEntry zip;
|
|
||||||
|
|
||||||
public JarEntry (ZipEntry ent)
|
Attributes attr;
|
||||||
{
|
Certificate certs[];
|
||||||
super (ent);
|
|
||||||
}
|
|
||||||
|
|
||||||
public JarEntry (JarEntry ent)
|
// Constructors
|
||||||
{
|
|
||||||
super (ent);
|
|
||||||
}
|
|
||||||
|
|
||||||
public JarEntry (String name)
|
/**
|
||||||
{
|
* Creates a new JarEntry with the specified name and no attributes or
|
||||||
super (name);
|
* or certificates. Calls <code>super(name)</code> so all other (zip)entry
|
||||||
}
|
* fields are null or -1.
|
||||||
|
*
|
||||||
|
* @param name the name of the new jar entry
|
||||||
|
* @exception NullPointerException when the supplied name is null
|
||||||
|
* @exception IllegalArgumentException when the supplied name is longer
|
||||||
|
* than 65535 bytes
|
||||||
|
*/
|
||||||
|
public JarEntry(String name) throws NullPointerException,
|
||||||
|
IllegalArgumentException {
|
||||||
|
super(name);
|
||||||
|
attr = null;
|
||||||
|
certs = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new JarEntry with the specified ZipEntry as template for
|
||||||
|
* all properties of the entry. Both attributes and certificates will be
|
||||||
|
* null.
|
||||||
|
*
|
||||||
|
* @param entry the ZipEntry whose fields should be copied
|
||||||
|
*/
|
||||||
|
public JarEntry(ZipEntry entry) {
|
||||||
|
super(entry);
|
||||||
|
attr = null;
|
||||||
|
certs = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new JarEntry with the specified JarEntry as template for
|
||||||
|
* all properties of the entry.
|
||||||
|
*
|
||||||
|
* @param entry the jarEntry whose fields should be copied
|
||||||
|
*/
|
||||||
|
public JarEntry(JarEntry entry) {
|
||||||
|
super(entry);
|
||||||
|
try {
|
||||||
|
attr = entry.getAttributes();
|
||||||
|
} catch(IOException _) {}
|
||||||
|
certs = entry.getCertificates();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Methods
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a copy of the Attributes set for this entry.
|
||||||
|
* When no Attributes are set in the manifest null is returned.
|
||||||
|
*
|
||||||
|
* @return a copy of the Attributes set for this entry
|
||||||
|
* @exception IOException This will never be thrown. It is here for
|
||||||
|
* binary compatibility.
|
||||||
|
*/
|
||||||
|
public Attributes getAttributes() throws IOException {
|
||||||
|
if (attr != null) {
|
||||||
|
return (Attributes) attr.clone();
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a copy of the certificates set for this entry.
|
||||||
|
* When no certificates are set or when not all data of this entry has
|
||||||
|
* been read null is returned.
|
||||||
|
* <p>
|
||||||
|
* To make sure that this call returns a valid value you must read all
|
||||||
|
* data from the JarInputStream for this entry.
|
||||||
|
* When you don't need the data for an entry but want to know the
|
||||||
|
* certificates that are set for the entry then you can skip all data by
|
||||||
|
* calling <code>skip(entry.getSize())</code> on the JarInputStream for
|
||||||
|
* the entry.
|
||||||
|
*
|
||||||
|
* @return a copy of the certificates set for this entry
|
||||||
|
*/
|
||||||
|
public Certificate[] getCertificates() {
|
||||||
|
if (certs != null) {
|
||||||
|
return (Certificate []) certs.clone();
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
65
libjava/java/util/jar/JarException.java
Normal file
65
libjava/java/util/jar/JarException.java
Normal file
|
@ -0,0 +1,65 @@
|
||||||
|
/* Attributes.java -- exception thrown to indicate an problem with a jar file
|
||||||
|
Copyright (C) 2000 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
package java.util.jar;
|
||||||
|
|
||||||
|
import java.util.zip.ZipException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This exception is thrown to indicate an problem with a jar file.
|
||||||
|
* It can be constructed with or without a descriptive message of the problem.
|
||||||
|
* <p>
|
||||||
|
* Note that none of the methods in the java.util.jar package actually declare
|
||||||
|
* to throw this exception, most just declare that they throw an IOException
|
||||||
|
* which is super class of JarException.
|
||||||
|
*
|
||||||
|
* @since 1.2
|
||||||
|
* @author Mark Wielaard (mark@klomp.org)
|
||||||
|
*/
|
||||||
|
|
||||||
|
public class JarException extends ZipException {
|
||||||
|
|
||||||
|
// Constructors
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new JarException without a descriptive error message.
|
||||||
|
*/
|
||||||
|
public JarException() {
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new JarException with a descriptive error message indicating
|
||||||
|
* what went wrong. This message can later be retrieved by calling the
|
||||||
|
* <code>getMessage()</code> method.
|
||||||
|
* @see java.lang.Throwable@getMessage()
|
||||||
|
*
|
||||||
|
* @param message The descriptive error message
|
||||||
|
*/
|
||||||
|
public JarException(String message) {
|
||||||
|
super(message);
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,56 +1,277 @@
|
||||||
/* Copyright (C) 1999 Free Software Foundation
|
/* JarFile.java - Representation of a jar file
|
||||||
|
Copyright (C) 2000 Free Software Foundation, Inc.
|
||||||
|
|
||||||
This file is part of libgcj.
|
This file is part of GNU Classpath.
|
||||||
|
|
||||||
This software is copyrighted work licensed under the terms of the
|
GNU Classpath is free software; you can redistribute it and/or modify
|
||||||
Libgcj License. Please consult the file "LIBGCJ_LICENSE" for
|
it under the terms of the GNU General Public License as published by
|
||||||
details. */
|
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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
package java.util.jar;
|
package java.util.jar;
|
||||||
|
|
||||||
import java.util.zip.*;
|
import java.util.zip.ZipEntry;
|
||||||
|
import java.util.zip.ZipException;
|
||||||
|
import java.util.zip.ZipFile;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
import java.io.FileNotFoundException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.Enumeration;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Does not implement any of the security. Just a place holder, so
|
* Representation of a jar file.
|
||||||
* that I can implement URLClassLoader.
|
* <p>
|
||||||
|
* Note that this class is not a subclass of java.io.File but a subclass of
|
||||||
|
* java.util.zip.ZipFile and you can only read JarFiles with it (although
|
||||||
|
* there are constructors that take a File object).
|
||||||
|
* <p>
|
||||||
|
* XXX - verification of Manifest signatures is not yet implemented.
|
||||||
*
|
*
|
||||||
* @author Kresten Krab Thorup <krab@gnu.org>
|
* @since 1.2
|
||||||
* @date August 10, 1999.
|
* @author Mark Wielaard (mark@klomp.org)
|
||||||
*/
|
*/
|
||||||
|
public class JarFile extends ZipFile {
|
||||||
|
|
||||||
public class JarFile extends ZipFile
|
// Fields
|
||||||
{
|
|
||||||
private boolean verify;
|
|
||||||
|
|
||||||
public JarFile (String file) throws java.io.IOException
|
/** The name of the manifest entry: META-INF/MANIFEST.MF */
|
||||||
{
|
public static final String MANIFEST_NAME = "META-INF/MANIFEST.MF";
|
||||||
super (file);
|
|
||||||
}
|
|
||||||
|
|
||||||
public JarFile (File file) throws java.io.IOException
|
|
||||||
{
|
|
||||||
super (file);
|
|
||||||
}
|
|
||||||
|
|
||||||
public JarFile (String file, boolean verify) throws java.io.IOException
|
/**
|
||||||
{
|
* The manifest of this file, if any, otherwise null.
|
||||||
super (file);
|
* Read by the constructor.
|
||||||
this.verify = verify;
|
*/
|
||||||
}
|
private final Manifest manifest;
|
||||||
|
|
||||||
public JarFile (File file, boolean verify) throws java.io.IOException
|
|
||||||
{
|
|
||||||
super (file);
|
|
||||||
this.verify = verify;
|
|
||||||
}
|
|
||||||
|
|
||||||
public JarEntry getJarEntry (String name)
|
/** Wether to verify the manifest and all entries */
|
||||||
{
|
private boolean verify;
|
||||||
ZipEntry ent = getEntry(name);
|
|
||||||
if (ent == null)
|
// Constructors
|
||||||
return null;
|
|
||||||
else
|
/**
|
||||||
return new JarEntry(ent);
|
* Creates a new JarFile, tries to read the manifest and if the manifest
|
||||||
}
|
* exists verifies it.
|
||||||
|
*
|
||||||
|
* @param fileName the name of the file to open
|
||||||
|
* @exception FileNotFoundException if the fileName cannot be found
|
||||||
|
* @exception IOException if another IO exception occurs while reading
|
||||||
|
*/
|
||||||
|
public JarFile(String fileName) throws FileNotFoundException,
|
||||||
|
IOException {
|
||||||
|
this (fileName, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new JarFile, tries to read the manifest and if the manifest
|
||||||
|
* exists and verify is true verfies it.
|
||||||
|
*
|
||||||
|
* @param fileName the name of the file to open
|
||||||
|
* @param verify checks manifest and entries when true and a manifest
|
||||||
|
* exists, when false no checks are made
|
||||||
|
* @exception FileNotFoundException if the fileName cannot be found
|
||||||
|
* @exception IOException if another IO exception occurs while reading
|
||||||
|
*/
|
||||||
|
public JarFile(String fileName, boolean verify) throws
|
||||||
|
FileNotFoundException,
|
||||||
|
IOException {
|
||||||
|
super(fileName);
|
||||||
|
manifest = readManifest();
|
||||||
|
if (verify)
|
||||||
|
verify();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new JarFile, tries to read the manifest and if the manifest
|
||||||
|
* exists verifies it.
|
||||||
|
*
|
||||||
|
* @param file the file to open as a jar file
|
||||||
|
* @exception FileNotFoundException if the file does not exits
|
||||||
|
* @exception IOException if another IO exception occurs while reading
|
||||||
|
*/
|
||||||
|
public JarFile(File file) throws FileNotFoundException,
|
||||||
|
IOException {
|
||||||
|
this (file, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new JarFile, tries to read the manifest and if the manifest
|
||||||
|
* exists and verify is true verfies it.
|
||||||
|
*
|
||||||
|
* @param file the file to open to open as a jar file
|
||||||
|
* @param verify checks manifest and entries when true and a manifest
|
||||||
|
* exists, when false no checks are made
|
||||||
|
* @exception FileNotFoundException if file does not exist
|
||||||
|
* @exception IOException if another IO exception occurs while reading
|
||||||
|
*/
|
||||||
|
public JarFile(File file, boolean verify) throws FileNotFoundException,
|
||||||
|
IOException {
|
||||||
|
super(file);
|
||||||
|
manifest = readManifest();
|
||||||
|
if (verify)
|
||||||
|
verify();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* XXX - not yet implemented in java.util.zip.ZipFile
|
||||||
|
*
|
||||||
|
* @param file the file to open to open as a jar file
|
||||||
|
* @param verify checks manifest and entries when true and a manifest
|
||||||
|
* exists, when false no checks are made
|
||||||
|
* @param mode XXX - see ZipFile
|
||||||
|
* @exception FileNotFoundException XXX
|
||||||
|
* @exception IOException XXX
|
||||||
|
* @exception IllegalArgumentException XXX
|
||||||
|
*
|
||||||
|
* @since 1.3
|
||||||
|
*/
|
||||||
|
public JarFile(File file, boolean verify, int mode) throws
|
||||||
|
FileNotFoundException,
|
||||||
|
IOException,
|
||||||
|
IllegalArgumentException {
|
||||||
|
// XXX - For now don't use super(file, mode)
|
||||||
|
this(file, verify);
|
||||||
|
/* super(file, mode);
|
||||||
|
manifest = readManifest();
|
||||||
|
if (verify)
|
||||||
|
verify(); */
|
||||||
|
}
|
||||||
|
|
||||||
|
// Methods
|
||||||
|
|
||||||
|
/**
|
||||||
|
* XXX - should verify the manifest file
|
||||||
|
*/
|
||||||
|
private void verify() {
|
||||||
|
// only check if manifest is not null
|
||||||
|
if (manifest == null) {
|
||||||
|
verify = false;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
verify = true;
|
||||||
|
// XXX - verify manifest
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parses and returns the manifest if it exists, otherwise returns null.
|
||||||
|
*/
|
||||||
|
private Manifest readManifest() {
|
||||||
|
try {
|
||||||
|
ZipEntry manEntry = super.getEntry(MANIFEST_NAME);
|
||||||
|
if (manEntry != null) {
|
||||||
|
InputStream in = super.getInputStream(manEntry);
|
||||||
|
return new Manifest(in);
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
} catch (IOException ioe) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a enumeration of all the entries in the JarFile.
|
||||||
|
* Note that also the Jar META-INF entries are returned.
|
||||||
|
*
|
||||||
|
* @exception IllegalStateException when the JarFile is already closed
|
||||||
|
*/
|
||||||
|
public Enumeration entries() throws IllegalStateException {
|
||||||
|
return new JarEnumeration(super.entries());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Wraps a given Zip Entries Enumeration. For every zip entry a
|
||||||
|
* JarEntry is created and the corresponding Attributes are looked up.
|
||||||
|
* XXX - Should also look up the certificates.
|
||||||
|
*/
|
||||||
|
private class JarEnumeration implements Enumeration {
|
||||||
|
|
||||||
|
private final Enumeration entries;
|
||||||
|
|
||||||
|
JarEnumeration(Enumeration e) {
|
||||||
|
entries = e;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean hasMoreElements() {
|
||||||
|
return entries.hasMoreElements();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Object nextElement() {
|
||||||
|
ZipEntry zip = (ZipEntry) entries.nextElement();
|
||||||
|
JarEntry jar = new JarEntry(zip);
|
||||||
|
if (manifest != null) {
|
||||||
|
jar.attr = manifest.getAttributes(jar.getName());
|
||||||
|
}
|
||||||
|
// XXX jar.certs
|
||||||
|
return jar;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* XXX
|
||||||
|
* It actually returns a JarEntry not a zipEntry
|
||||||
|
* @param name XXX
|
||||||
|
*/
|
||||||
|
public ZipEntry getEntry(String name) {
|
||||||
|
ZipEntry entry = super.getEntry(name);
|
||||||
|
if (entry != null) {
|
||||||
|
JarEntry jarEntry = new JarEntry(getEntry(name));
|
||||||
|
if (manifest != null) {
|
||||||
|
jarEntry.attr = manifest.getAttributes(name);
|
||||||
|
// XXX jarEntry.certs
|
||||||
|
}
|
||||||
|
return jarEntry;
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* XXX should verify the inputstream
|
||||||
|
* @param entry XXX
|
||||||
|
* @exception ZipException XXX
|
||||||
|
* @exception IOException XXX
|
||||||
|
*/
|
||||||
|
public synchronized InputStream getInputStream(ZipEntry entry) throws
|
||||||
|
ZipException,
|
||||||
|
IOException {
|
||||||
|
return super.getInputStream(entry); // XXX verify
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the JarEntry that belongs to the name if such an entry
|
||||||
|
* exists in the JarFile. Returns null otherwise
|
||||||
|
* Convenience method that just casts the result from <code>getEntry</code>
|
||||||
|
* to a JarEntry.
|
||||||
|
*
|
||||||
|
* @param name the jar entry name to look up
|
||||||
|
* @return the JarEntry if it exists, null otherwise
|
||||||
|
*/
|
||||||
|
public JarEntry getJarEntry(String name) {
|
||||||
|
return (JarEntry)getEntry(name);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the manifest for this JarFile or null when the JarFile does not
|
||||||
|
* contain a manifest file.
|
||||||
|
*/
|
||||||
|
public Manifest getManifest() {
|
||||||
|
return manifest;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,32 +1,175 @@
|
||||||
/* Copyright (C) 1999 Free Software Foundation
|
/* JarInputStream.java - InputStream for reading jar files
|
||||||
|
Copyright (C) 2000 Free Software Foundation, Inc.
|
||||||
|
|
||||||
This file is part of libgcj.
|
This file is part of GNU Classpath.
|
||||||
|
|
||||||
This software is copyrighted work licensed under the terms of the
|
GNU Classpath is free software; you can redistribute it and/or modify
|
||||||
Libgcj License. Please consult the file "LIBGCJ_LICENSE" for
|
it under the terms of the GNU General Public License as published by
|
||||||
details. */
|
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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
package java.util.jar;
|
package java.util.jar;
|
||||||
|
|
||||||
import java.util.zip.*;
|
import java.io.InputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.zip.ZipEntry;
|
||||||
|
import java.util.zip.ZipInputStream;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Does not implement any of the security. Just a place holder, so
|
* InputStream for reading jar files.
|
||||||
* that I can implement URLClassLoader.
|
* XXX - verification of the signatures in the Manifest file is not yet
|
||||||
|
* implemented.
|
||||||
*
|
*
|
||||||
* @author Kresten Krab Thorup <krab@gnu.org>
|
* @since 1.2
|
||||||
* @date August 10, 1999.
|
* @author Mark Wielaard (mark@klomp.org)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
public class JarInputStream extends ZipInputStream {
|
||||||
|
|
||||||
public class JarInputStream extends ZipInputStream
|
// Fields
|
||||||
{
|
|
||||||
public JarEntry getNextJarEntry () throws java.io.IOException
|
/** The manifest for this file or null when there was no manifest. */
|
||||||
{
|
private Manifest manifest;
|
||||||
return new JarEntry (getNextEntry ());
|
|
||||||
|
/** The first real JarEntry for this file. Used by readManifest() to store
|
||||||
|
an entry that isn't the manifest but that should be returned by
|
||||||
|
getNextEntry next time it is called. Null when no firstEntry was read
|
||||||
|
while searching for the manifest entry, or when it has already been
|
||||||
|
returned by getNextEntry(). */
|
||||||
|
private JarEntry firstEntry;
|
||||||
|
|
||||||
|
// Constructors
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new JarInputStream and tries to read the manifest.
|
||||||
|
* If such a manifest is present the JarInputStream tries to verify all
|
||||||
|
* the entry signatures while reading.
|
||||||
|
*
|
||||||
|
* @param in InputStream to read the jar from
|
||||||
|
* @exception IOException when an error occurs when opening or reading
|
||||||
|
*/
|
||||||
|
public JarInputStream(InputStream in) throws IOException {
|
||||||
|
this(in, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
public JarInputStream (java.io.InputStream is)
|
/**
|
||||||
{
|
* Creates a new JarInputStream and tries to read the manifest.
|
||||||
super(is);
|
* If such a manifest is present and verify is true, the JarInputStream
|
||||||
}
|
* tries to verify all the entry signatures while reading.
|
||||||
|
*
|
||||||
|
* @param in InputStream to read the jar from
|
||||||
|
* @param verify wheter or not to verify the manifest entries
|
||||||
|
* @exception IOException when an error occurs when opening or reading
|
||||||
|
*/
|
||||||
|
public JarInputStream(InputStream in, boolean verify) throws IOException {
|
||||||
|
super(in);
|
||||||
|
readManifest(verify);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Methods
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the manifest if found. Skips all entries that start with "META-INF/"
|
||||||
|
*
|
||||||
|
* @param verify when true (and a Manifest is found) checks the Manifest,
|
||||||
|
* when false no check is performed
|
||||||
|
* @exception IOException if an error occurs while reading
|
||||||
|
*/
|
||||||
|
private void readManifest(boolean verify) throws IOException {
|
||||||
|
firstEntry = (JarEntry) super.getNextEntry();
|
||||||
|
while ((firstEntry != null) &&
|
||||||
|
firstEntry.getName().startsWith("META-INF/")) {
|
||||||
|
if(firstEntry.getName().equals(JarFile.MANIFEST_NAME)) {
|
||||||
|
manifest = new Manifest(this);
|
||||||
|
}
|
||||||
|
firstEntry = (JarEntry) super.getNextEntry();
|
||||||
|
}
|
||||||
|
closeEntry();
|
||||||
|
|
||||||
|
if (verify) {
|
||||||
|
// XXX
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a JarEntry for a particular name and consults the manifest
|
||||||
|
* for the Attributes of the entry.
|
||||||
|
* Used by <code>ZipEntry.getNextEntry()</code>
|
||||||
|
*
|
||||||
|
* @param name the name of the new entry
|
||||||
|
*/
|
||||||
|
protected ZipEntry createZipEntry(String name) {
|
||||||
|
ZipEntry zipEntry = super.createZipEntry(name);
|
||||||
|
JarEntry jarEntry = new JarEntry(zipEntry);
|
||||||
|
if (manifest != null) {
|
||||||
|
jarEntry.attr = manifest.getAttributes(name);
|
||||||
|
}
|
||||||
|
return jarEntry;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the Manifest for the jar file or null if there was no Manifest.
|
||||||
|
*/
|
||||||
|
public Manifest getManifest() {
|
||||||
|
return manifest;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the next entry or null when there are no more entries.
|
||||||
|
* Does actually return a JarEntry, if you don't want to cast it yourself
|
||||||
|
* use <code>getNextJarEntry()</code>. Does not return any entries found
|
||||||
|
* at the beginning of the ZipFile that are special
|
||||||
|
* (those that start with "META-INF/").
|
||||||
|
*
|
||||||
|
* @exception IOException if an IO error occurs when reading the entry
|
||||||
|
*/
|
||||||
|
public ZipEntry getNextEntry() throws IOException {
|
||||||
|
ZipEntry entry;
|
||||||
|
if (firstEntry != null) {
|
||||||
|
entry = firstEntry;
|
||||||
|
firstEntry = null;
|
||||||
|
} else {
|
||||||
|
entry = super.getNextEntry();
|
||||||
|
}
|
||||||
|
return entry;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the next jar entry or null when there are no more entries.
|
||||||
|
*
|
||||||
|
* @exception IOException if an IO error occurs when reading the entry
|
||||||
|
*/
|
||||||
|
public JarEntry getNextJarEntry() throws IOException {
|
||||||
|
return (JarEntry)getNextEntry();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* XXX
|
||||||
|
*
|
||||||
|
* @param buf XXX
|
||||||
|
* @param off XXX
|
||||||
|
* @param len XXX
|
||||||
|
* @return XXX
|
||||||
|
* @exception IOException XXX
|
||||||
|
*/
|
||||||
|
public int read(byte[] buf, int off, int len) throws IOException {
|
||||||
|
// XXX if (verify) {}
|
||||||
|
return super.read(buf, off, len);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
98
libjava/java/util/jar/JarOutputStream.java
Normal file
98
libjava/java/util/jar/JarOutputStream.java
Normal file
|
@ -0,0 +1,98 @@
|
||||||
|
/* JarOutputStream.java - OutputStream for writing jar files
|
||||||
|
Copyright (C) 2000 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
package java.util.jar;
|
||||||
|
|
||||||
|
import java.io.OutputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.zip.ZipEntry;
|
||||||
|
import java.util.zip.ZipOutputStream;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* OutputStream for writing jar files.
|
||||||
|
* A special ZipOutputStream that can take JarEntries and can have a optional
|
||||||
|
* Manifest as first entry.
|
||||||
|
*
|
||||||
|
* @author Mark Wielaard (mark@klomp.org)
|
||||||
|
*/
|
||||||
|
|
||||||
|
public class JarOutputStream extends ZipOutputStream {
|
||||||
|
|
||||||
|
// Constructors
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new JarOutputStream without a manifest entry.
|
||||||
|
*
|
||||||
|
* @param out the stream to create the new jar on
|
||||||
|
* @exception IOException if something unexpected happend
|
||||||
|
*/
|
||||||
|
public JarOutputStream(OutputStream out) throws IOException {
|
||||||
|
this(out, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new JarOutputStream with a manifest entry.
|
||||||
|
* The manifest will be the first entry in the jar.
|
||||||
|
*
|
||||||
|
* @param out the stream to create the new jar on
|
||||||
|
* @param man the manifest that should be put in the jar file or null
|
||||||
|
* for no manifest entry
|
||||||
|
* @exception IOException if something unexpected happend
|
||||||
|
*/
|
||||||
|
public JarOutputStream(OutputStream out, Manifest man) throws IOException {
|
||||||
|
super(out);
|
||||||
|
if (man != null)
|
||||||
|
writeManifest(man);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Methods
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Writes the manifest to a new JarEntry in this JarOutputStream with as
|
||||||
|
* name JarFile.MANIFEST_NAME.
|
||||||
|
*
|
||||||
|
* @param manifest the non null manifest to be written
|
||||||
|
* @exception IOException if something unexpected happend
|
||||||
|
*/
|
||||||
|
private void writeManifest(Manifest manifest) throws IOException {
|
||||||
|
// Create a new Jar Entry for the Manifest
|
||||||
|
JarEntry entry = new JarEntry(JarFile.MANIFEST_NAME);
|
||||||
|
putNextEntry(entry);
|
||||||
|
manifest.write(this);
|
||||||
|
closeEntry();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Prepares the JarOutputStream for writing the next entry.
|
||||||
|
* This implementation just calls <code>super.putNextEntre()</code>.
|
||||||
|
*
|
||||||
|
* @param entry The information for the next entry
|
||||||
|
* @exception IOException when some unexpected I/O exception occured
|
||||||
|
*/
|
||||||
|
public void putNextEntry(ZipEntry entry) throws IOException {
|
||||||
|
super.putNextEntry(entry); // XXX
|
||||||
|
}
|
||||||
|
}
|
406
libjava/java/util/jar/Manifest.java
Normal file
406
libjava/java/util/jar/Manifest.java
Normal file
|
@ -0,0 +1,406 @@
|
||||||
|
/* Attributes.java -- Reads, writes and manipulaties jar manifest files
|
||||||
|
Copyright (C) 2000 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., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
02111-1307 USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with other files to
|
||||||
|
produce an executable, this library does not by itself cause the
|
||||||
|
resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why the
|
||||||
|
executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
package java.util.jar;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.io.InputStreamReader;
|
||||||
|
import java.io.OutputStream;
|
||||||
|
import java.io.OutputStreamWriter;
|
||||||
|
import java.io.PrintWriter;
|
||||||
|
import java.io.Reader;
|
||||||
|
import java.io.Writer;
|
||||||
|
import java.util.Hashtable;
|
||||||
|
import java.util.Iterator;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reads, writes and manipulaties jar manifest files.
|
||||||
|
* XXX
|
||||||
|
*
|
||||||
|
* @since 1.2
|
||||||
|
* @author Mark Wielaard (mark@klomp.org)
|
||||||
|
*/
|
||||||
|
public class Manifest implements Cloneable {
|
||||||
|
|
||||||
|
// Fields
|
||||||
|
|
||||||
|
/** The main attributes of the manifest (jar file). */
|
||||||
|
private final Attributes mainAttr;
|
||||||
|
|
||||||
|
/** A map of atrributes for all entries described in this Manifest. */
|
||||||
|
private final Map entries;
|
||||||
|
|
||||||
|
// Constructors
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new empty Manifest.
|
||||||
|
*/
|
||||||
|
public Manifest() {
|
||||||
|
mainAttr = new Attributes();
|
||||||
|
entries = new Hashtable();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a Manifest from the supplied input stream.
|
||||||
|
*
|
||||||
|
* @see read(Inputstream)
|
||||||
|
* @see write(OutputStream)
|
||||||
|
*
|
||||||
|
* @param InputStream the input stream to read the manifest from
|
||||||
|
* @exception IOException when an i/o exception occurs or the input stream
|
||||||
|
* does not describe a valid manifest
|
||||||
|
*/
|
||||||
|
public Manifest(InputStream in) throws IOException {
|
||||||
|
this();
|
||||||
|
read(in);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a Manifest from another Manifest.
|
||||||
|
* Makes a deep copy of the main attributes, but a shallow copy of
|
||||||
|
* the other entries. This means that you can freely add, change or remove
|
||||||
|
* the main attributes or the entries of the new manifest without effecting
|
||||||
|
* the original manifest, but adding, changing or removing attributes from
|
||||||
|
* a particular entry also changes the attributes of that entry in the
|
||||||
|
* original manifest.
|
||||||
|
*
|
||||||
|
* @see clone()
|
||||||
|
* @param man the Manifest to copy from
|
||||||
|
*/
|
||||||
|
public Manifest (Manifest man) {
|
||||||
|
mainAttr = new Attributes(man.getMainAttributes());
|
||||||
|
entries = new Hashtable(man.getEntries());
|
||||||
|
}
|
||||||
|
|
||||||
|
// Methods
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the main attributes of this Manifest.
|
||||||
|
*/
|
||||||
|
public Attributes getMainAttributes() {
|
||||||
|
return mainAttr;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets a map of entry Strings to Attributes for all the entries described
|
||||||
|
* in this manifest. Adding, changing or removing from this entries map
|
||||||
|
* changes the entries of this manifest.
|
||||||
|
*/
|
||||||
|
public Map getEntries() {
|
||||||
|
return entries;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the Attributes associated with the Entry.
|
||||||
|
* <p>
|
||||||
|
* Implemented as:
|
||||||
|
* <code>return (Attributes)getEntries().get(entryName)</code>
|
||||||
|
*
|
||||||
|
* @param entryName the name of the entry to look up
|
||||||
|
* @return the attributes associated with the entry or null when none
|
||||||
|
*/
|
||||||
|
public Attributes getAttributes(String entryName) {
|
||||||
|
return (Attributes)getEntries().get(entryName);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Clears the main attributes and removes all the entries from the
|
||||||
|
* manifest.
|
||||||
|
*/
|
||||||
|
public void clear() {
|
||||||
|
mainAttr.clear();
|
||||||
|
entries.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* XXX
|
||||||
|
*/
|
||||||
|
public void read(InputStream in) throws IOException {
|
||||||
|
BufferedReader br = new BufferedReader(
|
||||||
|
new InputStreamReader(in, "8859_1"));
|
||||||
|
read_main_section(getMainAttributes(), br);
|
||||||
|
read_individual_sections(getEntries(), br);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Private Static methods for reading the Manifest file from BufferedReader
|
||||||
|
|
||||||
|
private static void read_main_section(Attributes attr,
|
||||||
|
BufferedReader br) throws
|
||||||
|
IOException {
|
||||||
|
read_version_info(attr, br);
|
||||||
|
read_attributes(attr, br);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void read_version_info(Attributes attr,
|
||||||
|
BufferedReader br) throws
|
||||||
|
IOException {
|
||||||
|
String version_header = Attributes.Name.MANIFEST_VERSION.toString();
|
||||||
|
try {
|
||||||
|
String value = expect_header(version_header, br);
|
||||||
|
attr.putValue(version_header, value);
|
||||||
|
} catch (IOException ioe) {
|
||||||
|
throw new JarException(
|
||||||
|
"Manifest should start with a " + version_header
|
||||||
|
+ ": " + ioe.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static String expect_header(String header, BufferedReader br)
|
||||||
|
throws IOException {
|
||||||
|
|
||||||
|
String s = br.readLine();
|
||||||
|
if (s == null) {
|
||||||
|
throw new JarException("unexpected end of file");
|
||||||
|
}
|
||||||
|
return expect_header(header, br, s);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static String expect_header(String header, BufferedReader br,
|
||||||
|
String s) throws IOException {
|
||||||
|
try {
|
||||||
|
String name = s.substring(0, header.length() + 1);
|
||||||
|
if (name.equalsIgnoreCase(header + ":")) {
|
||||||
|
String value_start = s.substring(header.length() + 2);
|
||||||
|
return read_header_value(value_start, br);
|
||||||
|
}
|
||||||
|
} catch (IndexOutOfBoundsException iobe) {}
|
||||||
|
// If we arrive here, something went wrong
|
||||||
|
throw new JarException("unexpected '" + s + "'");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static String read_header_value(String s, BufferedReader br)
|
||||||
|
throws IOException {
|
||||||
|
boolean try_next = true;
|
||||||
|
while (try_next) {
|
||||||
|
// Lets see if there is something on the next line
|
||||||
|
br.mark(1);
|
||||||
|
if (br.read() == ' ') {
|
||||||
|
s += br.readLine();
|
||||||
|
} else {
|
||||||
|
br.reset();
|
||||||
|
try_next = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void read_attributes(Attributes attr,
|
||||||
|
BufferedReader br) throws
|
||||||
|
IOException {
|
||||||
|
String s = br.readLine();
|
||||||
|
while (s != null && (!s.equals(""))) {
|
||||||
|
read_attribute(attr, s, br);
|
||||||
|
s = br.readLine();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void read_attribute(Attributes attr, String s,
|
||||||
|
BufferedReader br) throws IOException {
|
||||||
|
try {
|
||||||
|
int colon = s.indexOf(": ");
|
||||||
|
String name = s.substring(0, colon);
|
||||||
|
String value_start = s.substring(colon+2);
|
||||||
|
String value = read_header_value(value_start, br);
|
||||||
|
attr.putValue(name, value);
|
||||||
|
} catch (IndexOutOfBoundsException iobe) {
|
||||||
|
throw new JarException(
|
||||||
|
"Manifest contains a bad header: " + s);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void read_individual_sections(Map entries,
|
||||||
|
BufferedReader br) throws
|
||||||
|
IOException {
|
||||||
|
String s = br.readLine();
|
||||||
|
while (s != null && (!s.equals(""))) {
|
||||||
|
Attributes attr = read_section_name(s, br, entries);
|
||||||
|
read_attributes(attr, br);
|
||||||
|
s = br.readLine();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Attributes read_section_name(String s, BufferedReader br,
|
||||||
|
Map entries) throws
|
||||||
|
JarException {
|
||||||
|
try {
|
||||||
|
String name = expect_header("Name", br, s);
|
||||||
|
Attributes attr = new Attributes();
|
||||||
|
entries.put(name, attr);
|
||||||
|
return attr;
|
||||||
|
} catch(IOException ioe) {
|
||||||
|
throw new JarException
|
||||||
|
("Section should start with a Name header: "
|
||||||
|
+ ioe.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* XXX
|
||||||
|
*/
|
||||||
|
public void write(OutputStream out) throws IOException {
|
||||||
|
PrintWriter pw = new PrintWriter(
|
||||||
|
new BufferedWriter(
|
||||||
|
new OutputStreamWriter(out, "8859_1")));
|
||||||
|
write_main_section(getMainAttributes(), pw);
|
||||||
|
pw.println();
|
||||||
|
write_individual_sections(getEntries(), pw);
|
||||||
|
if (pw.checkError()) {
|
||||||
|
throw new JarException("Error while writing manifest");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Private Static functions for writing the Manifest file to a PrintWriter
|
||||||
|
|
||||||
|
private static void write_main_section(Attributes attr,
|
||||||
|
PrintWriter pw)
|
||||||
|
throws JarException {
|
||||||
|
|
||||||
|
write_version_info(attr, pw);
|
||||||
|
write_main_attributes(attr, pw);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void write_version_info(Attributes attr, PrintWriter pw) {
|
||||||
|
// First check if there is already a version attribute set
|
||||||
|
String version = attr.getValue(Attributes.Name.MANIFEST_VERSION);
|
||||||
|
if (version == null) {
|
||||||
|
version = "1.0";
|
||||||
|
}
|
||||||
|
write_header(Attributes.Name.MANIFEST_VERSION.toString(), version, pw);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void write_header(String name, String value,
|
||||||
|
PrintWriter pw) {
|
||||||
|
pw.print(name + ": ");
|
||||||
|
|
||||||
|
int last = 68 - name.length();
|
||||||
|
if (last > value.length()) {
|
||||||
|
pw.println(value);
|
||||||
|
} else {
|
||||||
|
pw.println(value.substring(0, last));
|
||||||
|
}
|
||||||
|
while (last < value.length()) {
|
||||||
|
pw.print(" ");
|
||||||
|
int end = (last + 69);
|
||||||
|
if (end > value.length()) {
|
||||||
|
pw.println(value.substring(last));
|
||||||
|
} else {
|
||||||
|
pw.println(value.substring(last, end));
|
||||||
|
}
|
||||||
|
last = end;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void write_main_attributes(Attributes attr,
|
||||||
|
PrintWriter pw) throws
|
||||||
|
JarException {
|
||||||
|
Iterator it = attr.entrySet().iterator();
|
||||||
|
while(it.hasNext()) {
|
||||||
|
Map.Entry entry = (Map.Entry)it.next();
|
||||||
|
// Don't print the manifest version again
|
||||||
|
if (!Attributes.Name.MANIFEST_VERSION.equals(entry.getKey())) {
|
||||||
|
write_attribute_entry(entry, pw);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void write_attribute_entry(Map.Entry entry,
|
||||||
|
PrintWriter pw) throws
|
||||||
|
JarException {
|
||||||
|
String name = entry.getKey().toString();
|
||||||
|
String value = entry.getValue().toString();
|
||||||
|
|
||||||
|
if (name.equalsIgnoreCase("Name")) {
|
||||||
|
throw new JarException("Attributes cannot be called 'Name'");
|
||||||
|
}
|
||||||
|
if (name.startsWith("From")) {
|
||||||
|
throw new JarException(
|
||||||
|
"Header cannot start with the four letters 'From'"
|
||||||
|
+ name);
|
||||||
|
}
|
||||||
|
write_header(name, value, pw);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void write_individual_sections(Map entries,
|
||||||
|
PrintWriter pw)
|
||||||
|
throws JarException {
|
||||||
|
|
||||||
|
Iterator it = entries.entrySet().iterator();
|
||||||
|
while (it.hasNext()) {
|
||||||
|
Map.Entry entry = (Map.Entry)it.next();
|
||||||
|
write_header("Name", entry.getKey().toString(), pw);
|
||||||
|
write_entry_attributes((Attributes)entry.getValue(), pw);
|
||||||
|
pw.println();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void write_entry_attributes(Attributes attr,
|
||||||
|
PrintWriter pw) throws
|
||||||
|
JarException {
|
||||||
|
Iterator it = attr.entrySet().iterator();
|
||||||
|
while(it.hasNext()) {
|
||||||
|
Map.Entry entry = (Map.Entry)it.next();
|
||||||
|
write_attribute_entry(entry, pw);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Makes a deep copy of the main attributes, but a shallow copy of
|
||||||
|
* the other entries. This means that you can freely add, change or remove
|
||||||
|
* the main attributes or the entries of the new manifest without effecting
|
||||||
|
* the original manifest, but adding, changing or removing attributes from
|
||||||
|
* a particular entry also changes the attributes of that entry in the
|
||||||
|
* original manifest. Calls <CODE>new Manifest(this)</CODE>.
|
||||||
|
*/
|
||||||
|
public Object clone() {
|
||||||
|
return new Manifest(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks if another object is equal to this Manifest object.
|
||||||
|
* Another Object is equal to this Manifest object if it is an instance of
|
||||||
|
* Manifest and the main attributes and the entries of the other manifest
|
||||||
|
* are equal to this one.
|
||||||
|
*/
|
||||||
|
public boolean equals(Object o) {
|
||||||
|
return (o instanceof Manifest) &&
|
||||||
|
(mainAttr.equals(((Manifest)o).mainAttr)) &&
|
||||||
|
(entries.equals(((Manifest)o).entries));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Calculates the hash code of the manifest. Implemented by a xor of the
|
||||||
|
* hash code of the main attributes with the hash code of the entries map.
|
||||||
|
*/
|
||||||
|
public int hashCode() {
|
||||||
|
return mainAttr.hashCode() ^ entries.hashCode();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -123,6 +123,12 @@ public class ZipInputStream extends InflaterInputStream implements ZipConstants
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected ZipEntry createZipEntry (String name)
|
||||||
|
{
|
||||||
|
// FIXME - must figure out what this is supposed to do.
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
public int read (byte[] b, int off, int len) throws IOException
|
public int read (byte[] b, int off, int len) throws IOException
|
||||||
{
|
{
|
||||||
if (len > avail)
|
if (len > avail)
|
||||||
|
|
|
@ -137,7 +137,7 @@ DIST_COMMON = ChangeLog Makefile.am Makefile.in
|
||||||
|
|
||||||
DISTFILES = $(DIST_COMMON) $(SOURCES) $(HEADERS) $(TEXINFOS) $(EXTRA_DIST)
|
DISTFILES = $(DIST_COMMON) $(SOURCES) $(HEADERS) $(TEXINFOS) $(EXTRA_DIST)
|
||||||
|
|
||||||
TAR = tar
|
TAR = gtar
|
||||||
GZIP_ENV = --best
|
GZIP_ENV = --best
|
||||||
all: all-redirect
|
all: all-redirect
|
||||||
.SUFFIXES:
|
.SUFFIXES:
|
||||||
|
@ -165,7 +165,7 @@ distdir: $(DISTFILES)
|
||||||
@for file in $(DISTFILES); do \
|
@for file in $(DISTFILES); do \
|
||||||
d=$(srcdir); \
|
d=$(srcdir); \
|
||||||
if test -d $$d/$$file; then \
|
if test -d $$d/$$file; then \
|
||||||
cp -pr $$/$$file $(distdir)/$$file; \
|
cp -pr $$d/$$file $(distdir)/$$file; \
|
||||||
else \
|
else \
|
||||||
test -f $(distdir)/$$file \
|
test -f $(distdir)/$$file \
|
||||||
|| ln $$d/$$file $(distdir)/$$file 2> /dev/null \
|
|| ln $$d/$$file $(distdir)/$$file 2> /dev/null \
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue