Categories:
Audio (13)
Biotech (29)
Bytecode (36)
Database (77)
Framework (7)
Game (7)
General (507)
Graphics (53)
I/O (35)
IDE (2)
JAR Tools (102)
JavaBeans (21)
JDBC (121)
JDK (426)
JSP (20)
Logging (108)
Mail (58)
Messaging (8)
Network (84)
PDF (97)
Report (7)
Scripting (84)
Security (32)
Server (121)
Servlet (26)
SOAP (24)
Testing (54)
Web (15)
XML (322)
Collections:
Other Resources:
JavaMail 1.6.2 Source Code Files
JavaMail Source Code Files are provided in the source package file, httpcomponents-client-5.2-src.zip.
You can browse JavaMail Source Code files below:
✍: FYIcenter.com
⏎ com/sun/mail/util/UUEncoderStream.java
/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
*
* Copyright (c) 1997-2017 Oracle and/or its affiliates. All rights reserved.
*
* The contents of this file are subject to the terms of either the GNU
* General Public License Version 2 only ("GPL") or the Common Development
* and Distribution License("CDDL") (collectively, the "License"). You
* may not use this file except in compliance with the License. You can
* obtain a copy of the License at
* https://oss.oracle.com/licenses/CDDL+GPL-1.1
* or LICENSE.txt. See the License for the specific
* language governing permissions and limitations under the License.
*
* When distributing the software, include this License Header Notice in each
* file and include the License file at LICENSE.txt.
*
* GPL Classpath Exception:
* Oracle designates this particular file as subject to the "Classpath"
* exception as provided by Oracle in the GPL Version 2 section of the License
* file that accompanied this code.
*
* Modifications:
* If applicable, add the following below the License Header, with the fields
* enclosed by brackets [] replaced by your own identifying information:
* "Portions Copyright [year] [name of copyright owner]"
*
* Contributor(s):
* If you wish your version of this file to be governed by only the CDDL or
* only the GPL Version 2, indicate your decision by adding "[Contributor]
* elects to include this software in this distribution under the [CDDL or GPL
* Version 2] license." If you don't indicate a single choice of license, a
* recipient has the option to distribute your version of this file under
* either the CDDL, the GPL Version 2 or to extend the choice of license to
* its licensees as provided above. However, if you add GPL Version 2 code
* and therefore, elected the GPL Version 2 license, then the option applies
* only if the new code is made subject to such option by the copyright
* holder.
*/
package com.sun.mail.util;
import java.io.*;
/**
* This class implements a UUEncoder. It is implemented as
* a FilterOutputStream, so one can just wrap this class around
* any output stream and write bytes into this filter. The Encoding
* is done as the bytes are written out.
*
* @author John Mani
*/
public class UUEncoderStream extends FilterOutputStream {
private byte[] buffer; // cache of bytes that are yet to be encoded
private int bufsize = 0; // size of the cache
private boolean wrotePrefix = false;
private boolean wroteSuffix = false;
private String name; // name of file
private int mode; // permissions mode
/**
* Create a UUencoder that encodes the specified input stream
* @param out the output stream
*/
public UUEncoderStream(OutputStream out) {
this(out, "encoder.buf", 0644);
}
/**
* Create a UUencoder that encodes the specified input stream
* @param out the output stream
* @param name Specifies a name for the encoded buffer
*/
public UUEncoderStream(OutputStream out, String name) {
this(out, name, 0644);
}
/**
* Create a UUencoder that encodes the specified input stream
* @param out the output stream
* @param name Specifies a name for the encoded buffer
* @param mode Specifies permission mode for the encoded buffer
*/
public UUEncoderStream(OutputStream out, String name, int mode) {
super(out);
this.name = name;
this.mode = mode;
buffer = new byte[45];
}
/**
* Set up the buffer name and permission mode.
* This method has any effect only if it is invoked before
* you start writing into the output stream
*
* @param name the buffer name
* @param mode the permission mode
*/
public void setNameMode(String name, int mode) {
this.name = name;
this.mode = mode;
}
@Override
public void write(byte[] b, int off, int len) throws IOException {
for (int i = 0; i < len; i++)
write(b[off + i]);
}
@Override
public void write(byte[] data) throws IOException {
write(data, 0, data.length);
}
@Override
public void write(int c) throws IOException {
/* buffer up characters till we get a line's worth, then encode
* and write them out. Max number of characters allowed per
* line is 45.
*/
buffer[bufsize++] = (byte)c;
if (bufsize == 45) {
writePrefix();
encode();
bufsize = 0;
}
}
@Override
public void flush() throws IOException {
if (bufsize > 0) { // If there's unencoded characters in the buffer
writePrefix();
encode(); // .. encode them
bufsize = 0;
}
writeSuffix();
out.flush();
}
@Override
public void close() throws IOException {
flush();
out.close();
}
/**
* Write out the prefix: "begin <mode> <name>"
*/
private void writePrefix() throws IOException {
if (!wrotePrefix) {
// name should be ASCII, but who knows...
PrintStream ps = new PrintStream(out, false, "utf-8");
ps.format("begin %o %s%n", mode, name);
ps.flush();
wrotePrefix = true;
}
}
/**
* Write a single line containing space and the suffix line
* containing the single word "end" (terminated by a newline)
*/
private void writeSuffix() throws IOException {
if (!wroteSuffix) {
PrintStream ps = new PrintStream(out, false, "us-ascii");
ps.println(" \nend");
ps.flush();
wroteSuffix = true;
}
}
/**
* Encode a line.
* Start off with the character count, followed by the encoded atoms
* and terminate with LF. (or is it CRLF or the local line-terminator ?)
* Take three bytes and encodes them into 4 characters
* If bufsize if not a multiple of 3, the remaining bytes are filled
* with '1'. This insures that the last line won't end in spaces
* and potentiallly be truncated.
*/
private void encode() throws IOException {
byte a, b, c;
int c1, c2, c3, c4;
int i = 0;
// Start off with the count of characters in the line
out.write((bufsize & 0x3f) + ' ');
while (i < bufsize) {
a = buffer[i++];
if (i < bufsize) {
b = buffer[i++];
if (i < bufsize)
c = buffer[i++];
else // default c to 1
c = 1;
}
else { // default b & c to 1
b = 1;
c = 1;
}
c1 = (a >>> 2) & 0x3f;
c2 = ((a << 4) & 0x30) | ((b >>> 4) & 0xf);
c3 = ((b << 2) & 0x3c) | ((c >>> 6) & 0x3);
c4 = c & 0x3f;
out.write(c1 + ' ');
out.write(c2 + ' ');
out.write(c3 + ' ');
out.write(c4 + ' ');
}
// Terminate with LF. (should it be CRLF or local line-terminator ?)
out.write('\n');
}
/**** begin TEST program *****
public static void main(String argv[]) throws Exception {
FileInputStream infile = new FileInputStream(argv[0]);
UUEncoderStream encoder = new UUEncoderStream(System.out);
int c;
while ((c = infile.read()) != -1)
encoder.write(c);
encoder.close();
}
**** end TEST program *****/
}
⏎ com/sun/mail/util/UUEncoderStream.java
Or download all of them as a single archive file:
File name: javax.mail-1.6.2-sources.jar File size: 851487 bytes Release date: 2018-08-29 Download
⇒ Download and Install javax.mail-1.5.4.jar
⇐ Download and Install javax.mail-1.6.2.jar
2016-01-07, ≈70🔥, 0💬
Popular Posts:
Apache ZooKeeper is an open-source server which enables highly reliable distributed coordination. Ap...
JBrowser Source Code Files are provided in the source package file. You can download JBrowser source...
JDK 17 jdk.javadoc.jmod is the JMOD file for JDK 17 Java Document tool, which can be invoked by the ...
How to display XML element type information with the jaxp\TypeInfoWriter.java provided in the Apache...
JDK 11 jdk.internal.JVM Stat.jmod is the JMOD file for JDK 11 Internal Jvmstat module. JDK 11 Intern...