📄 pop3folder.java
字号:
/* * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. * * Copyright 1997-2007 Sun Microsystems, Inc. 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://glassfish.dev.java.net/public/CDDL+GPL.html * or glassfish/bootstrap/legal/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 glassfish/bootstrap/legal/LICENSE.txt. * Sun designates this particular file as subject to the "Classpath" exception * as provided by Sun in the GPL Version 2 section of the License file that * accompanied this code. If applicable, add the following below the License * Header, with the fields enclosed by brackets [] replaced by your own * identifying information: "Portions Copyrighted [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. *//* * @(#)POP3Folder.java 1.34 07/05/04 */package com.sun.mail.pop3;import javax.mail.*;import javax.mail.internet.*;import javax.mail.event.*;import java.io.InputStream;import java.io.BufferedInputStream;import java.io.ByteArrayInputStream;import java.io.IOException;import java.io.EOFException;import java.util.Vector;import java.util.StringTokenizer;import java.lang.reflect.Constructor;import com.sun.mail.util.LineInputStream;/** * A POP3 Folder (can only be "INBOX"). * * See the <a href="package-summary.html">com.sun.mail.pop3</a> package * documentation for further information on the POP3 protocol provider. <p> * * @author Bill Shannon * @author John Mani (ported to the javax.mail APIs) */public class POP3Folder extends Folder { private String name; private Protocol port; private int total; private int size; private boolean exists = false; private boolean opened = false; private Vector message_cache; private boolean doneUidl = false; POP3Folder(POP3Store store, String name) { super(store); this.name = name; if (name.equalsIgnoreCase("INBOX")) exists = true; } public String getName() { return name; } public String getFullName() { return name; } public Folder getParent() { return new DefaultFolder((POP3Store)store); } /** * Always true for the folder "INBOX", always false for * any other name. * * @return true for INBOX, false otherwise */ public boolean exists() { return exists; } /** * Always throws <code>MessagingException</code> because no POP3 folders * can contain subfolders. * * @exception MessagingException always */ public Folder[] list(String pattern) throws MessagingException { throw new MessagingException("not a directory"); } /** * Always returns a NUL character because POP3 doesn't support a hierarchy. * * @return NUL */ public char getSeparator() { return '\0'; } /** * Always returns Folder.HOLDS_MESSAGES. * * @return Folder.HOLDS_MESSAGES */ public int getType() { return HOLDS_MESSAGES; } /** * Always returns <code>false</code>; the POP3 protocol doesn't * support creating folders. * * @return false */ public boolean create(int type) throws MessagingException { return false; } /** * Always returns <code>false</code>; the POP3 protocol provides * no way to determine when a new message arrives. * * @return false */ public boolean hasNewMessages() throws MessagingException { return false; // no way to know } /** * Always throws <code>MessagingException</code> because no POP3 folders * can contain subfolders. * * @exception MessagingException always */ public Folder getFolder(String name) throws MessagingException { throw new MessagingException("not a directory"); } /** * Always throws <code>MethodNotSupportedException</code> * because the POP3 protocol doesn't allow the INBOX to * be deleted. * * @exception MethodNotSupportedException always */ public boolean delete(boolean recurse) throws MessagingException { throw new MethodNotSupportedException("delete"); } /** * Always throws <code>MethodNotSupportedException</code> * because the POP3 protocol doesn't support multiple folders. * * @exception MethodNotSupportedException always */ public boolean renameTo(Folder f) throws MessagingException { throw new MethodNotSupportedException("renameTo"); } /** * Throws <code>FolderNotFoundException</code> unless this * folder is named "INBOX". * * @exception FolderNotFoundException if not INBOX * @exception AuthenticationException authentication failures * @exception MessagingException other open failures */ public synchronized void open(int mode) throws MessagingException { checkClosed(); if (!exists) throw new FolderNotFoundException(this, "folder is not INBOX"); try { port = ((POP3Store)store).getPort(this); Status s = port.stat(); total = s.total; size = s.size; this.mode = mode; opened = true; } catch (IOException ioex) { try { if (port != null) port.quit(); } catch (IOException ioex2) { // ignore } finally { port = null; ((POP3Store)store).closePort(this); } throw new MessagingException("Open failed", ioex); } // Create the message cache vector of appropriate size message_cache = new Vector(total); message_cache.setSize(total); doneUidl = false; notifyConnectionListeners(ConnectionEvent.OPENED); } public synchronized void close(boolean expunge) throws MessagingException { checkOpen(); try { /* * Some POP3 servers will mark messages for deletion when * they're read. To prevent such messages from being * deleted before the client deletes them, you can set * the mail.pop3.rsetbeforequit property to true. This * causes us to issue a POP3 RSET command to clear all * the "marked for deletion" flags. We can then explicitly * delete messages as desired. */ if (((POP3Store)store).rsetBeforeQuit) port.rset(); if (expunge && mode == READ_WRITE) { // find all messages marked deleted and issue DELE commands POP3Message m; for (int i = 0; i < message_cache.size(); i++) { if ((m = (POP3Message)message_cache.elementAt(i)) != null) { if (m.isSet(Flags.Flag.DELETED)) try { port.dele(i + 1); } catch (IOException ioex) { throw new MessagingException( "Exception deleting messages during close", ioex); } } } } port.quit(); } catch (IOException ex) { // do nothing } finally { port = null; ((POP3Store)store).closePort(this); message_cache = null; opened = false; notifyConnectionListeners(ConnectionEvent.CLOSED); } } public boolean isOpen() { if (!opened) return false; if (store.isConnected()) return true; try {
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -