0N/A/*
0N/A * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
0N/A *
292N/A * Copyright (c) 1997-2010 Oracle and/or its affiliates. All rights reserved.
0N/A *
0N/A * The contents of this file are subject to the terms of either the GNU
0N/A * General Public License Version 2 only ("GPL") or the Common Development
0N/A * and Distribution License("CDDL") (collectively, the "License"). You
292N/A * may not use this file except in compliance with the License. You can
292N/A * obtain a copy of the License at
292N/A * https://glassfish.dev.java.net/public/CDDL+GPL_1_1.html
292N/A * or packager/legal/LICENSE.txt. See the License for the specific
0N/A * language governing permissions and limitations under the License.
0N/A *
0N/A * When distributing the software, include this License Header Notice in each
292N/A * file and include the License file at packager/legal/LICENSE.txt.
292N/A *
292N/A * GPL Classpath Exception:
292N/A * Oracle designates this particular file as subject to the "Classpath"
292N/A * exception as provided by Oracle in the GPL Version 2 section of the License
292N/A * file that accompanied this code.
292N/A *
292N/A * Modifications:
292N/A * If applicable, add the following below the License Header, with the fields
292N/A * enclosed by brackets [] replaced by your own identifying information:
292N/A * "Portions Copyright [year] [name of copyright owner]"
0N/A *
0N/A * Contributor(s):
0N/A * If you wish your version of this file to be governed by only the CDDL or
0N/A * only the GPL Version 2, indicate your decision by adding "[Contributor]
0N/A * elects to include this software in this distribution under the [CDDL or GPL
0N/A * Version 2] license." If you don't indicate a single choice of license, a
0N/A * recipient has the option to distribute your version of this file under
0N/A * either the CDDL, the GPL Version 2 or to extend the choice of license to
0N/A * its licensees as provided above. However, if you add GPL Version 2 code
0N/A * and therefore, elected the GPL Version 2 license, then the option applies
0N/A * only if the new code is made subject to such option by the copyright
0N/A * holder.
0N/A */
0N/A
0N/Apackage com.sun.mail.remote;
0N/A
0N/Aimport javax.mail.*;
0N/Aimport com.sun.mail.mbox.*;
0N/A
0N/A/**
0N/A * A remote Inbox folder. The data is actually managed by our subclass
0N/A * (<code>MboxFolder</code>). We fetch data from the remote Inbox and
0N/A * add it to the local Inbox.
0N/A *
0N/A * @author Bill Shannon
0N/A */
0N/A
0N/Apublic class RemoteInbox extends MboxFolder {
0N/A
0N/A private RemoteStore mstore;
0N/A
0N/A protected RemoteInbox(RemoteStore store, String name) {
0N/A super(store, name);
0N/A this.mstore = store;
0N/A }
0N/A
0N/A /**
0N/A * Poll the remote store for any new messages.
0N/A */
0N/A public synchronized boolean hasNewMessages() {
0N/A try {
0N/A mstore.updateInbox();
0N/A } catch (MessagingException ex) {
0N/A // ignore it
0N/A }
0N/A return super.hasNewMessages();
0N/A }
0N/A
0N/A /**
0N/A * Open the folder in the specified mode.
0N/A * Poll the remote store for any new messages first.
0N/A */
0N/A public synchronized void open(int mode) throws MessagingException {
0N/A mstore.updateInbox();
0N/A super.open(mode);
0N/A }
0N/A
0N/A /**
0N/A * Return the number of messages in this folder.
0N/A * Poll the remote store for any new messages first.
0N/A */
0N/A public synchronized int getMessageCount() throws MessagingException {
0N/A mstore.updateInbox();
0N/A return super.getMessageCount();
0N/A }
0N/A}