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 javax.mail.search;
0N/A
0N/Aimport javax.mail.Message;
0N/Aimport javax.mail.Address;
0N/Aimport javax.mail.internet.InternetAddress;
0N/A
0N/A/**
0N/A * This abstract class implements string comparisons for Message
0N/A * addresses. <p>
0N/A *
0N/A * Note that this class differs from the <code>AddressTerm</code> class
0N/A * in that this class does comparisons on address strings rather than
0N/A * Address objects.
0N/A *
0N/A * @since JavaMail 1.1
0N/A */
0N/A
0N/Apublic abstract class AddressStringTerm extends StringTerm {
0N/A
0N/A private static final long serialVersionUID = 3086821234204980368L;
0N/A
0N/A /**
0N/A * Constructor.
0N/A *
0N/A * @param pattern the address pattern to be compared.
0N/A */
0N/A protected AddressStringTerm(String pattern) {
0N/A super(pattern, true); // we need case-insensitive comparison.
0N/A }
0N/A
0N/A /**
0N/A * Check whether the address pattern specified in the constructor is
0N/A * a substring of the string representation of the given Address
0N/A * object. <p>
0N/A *
0N/A * Note that if the string representation of the given Address object
0N/A * contains charset or transfer encodings, the encodings must be
0N/A * accounted for, during the match process. <p>
0N/A *
0N/A * @param a The comparison is applied to this Address object.
0N/A * @return true if the match succeeds, otherwise false.
0N/A */
0N/A protected boolean match(Address a) {
0N/A if (a instanceof InternetAddress) {
0N/A InternetAddress ia = (InternetAddress)a;
0N/A // We dont use toString() to get "a"'s String representation,
0N/A // because InternetAddress.toString() returns a RFC 2047
0N/A // encoded string, which isn't what we need here.
0N/A
0N/A return super.match(ia.toUnicodeString());
0N/A } else
0N/A return super.match(a.toString());
0N/A }
0N/A
0N/A /**
0N/A * Equality comparison.
0N/A */
0N/A public boolean equals(Object obj) {
0N/A if (!(obj instanceof AddressStringTerm))
0N/A return false;
0N/A return super.equals(obj);
0N/A }
0N/A}