001    /*
002     * Copyright (c) 2001-2004 Caucho Technology, Inc.  All rights reserved.
003     *
004     * The Apache Software License, Version 1.1
005     *
006     * Redistribution and use in source and binary forms, with or without
007     * modification, are permitted provided that the following conditions
008     * are met:
009     *
010     * 1. Redistributions of source code must retain the above copyright
011     *    notice, this list of conditions and the following disclaimer.
012     *
013     * 2. Redistributions in binary form must reproduce the above copyright
014     *    notice, this list of conditions and the following disclaimer in
015     *    the documentation and/or other materials provided with the
016     *    distribution.
017     *
018     * 3. The end-user documentation included with the redistribution, if
019     *    any, must include the following acknowlegement:
020     *       "This product includes software developed by the
021     *        Caucho Technology (http://www.caucho.com/)."
022     *    Alternately, this acknowlegement may appear in the software itself,
023     *    if and wherever such third-party acknowlegements normally appear.
024     *
025     * 4. The names "Hessian", "Resin", and "Caucho" must not be used to
026     *    endorse or promote products derived from this software without prior
027     *    written permission. For written permission, please contact
028     *    info@caucho.com.
029     *
030     * 5. Products derived from this software may not be called "Resin"
031     *    nor may "Resin" appear in their names without prior written
032     *    permission of Caucho Technology.
033     *
034     * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
035     * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
036     * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
037     * DISCLAIMED.  IN NO EVENT SHALL CAUCHO TECHNOLOGY OR ITS CONTRIBUTORS
038     * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
039     * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
040     * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
041     * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
042     * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
043     * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
044     * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
045     *
046     * @author Scott Ferguson
047     */
048    
049    package com.caucho.burlap.io;
050    
051    /**
052     * Encapsulates a remote address when no stub is available, e.g. for
053     * Java MicroEdition.
054     */
055    public class BurlapRemote {
056      private String type;
057      private String url;
058    
059      /**
060       * Creates a new Burlap remote object.
061       *
062       * @param type the remote stub interface
063       * @param url the remote url
064       */
065      public BurlapRemote(String type, String url)
066      {
067        this.type = type;
068        this.url = url;
069      }
070    
071      /**
072       * Creates an uninitialized Burlap remote.
073       */
074      public BurlapRemote()
075      {
076      }
077    
078      /**
079       * Returns the remote api class name.
080       */
081      public String getType()
082      {
083        return this.type;
084      }
085    
086      /**
087       * Returns the remote URL.
088       */
089      public String getURL()
090      {
091        return this.url;
092      }
093    
094      /**
095       * Sets the remote URL.
096       */
097      public void setURL(String url)
098      {
099        this.url = url;
100      }
101    
102      /**
103       * Defines the hashcode.
104       */
105      public int hashCode()
106      {
107        return this.url.hashCode();
108      }
109    
110      /**
111       * Defines equality
112       */
113      public boolean equals(Object obj)
114      {
115        if (! (obj instanceof BurlapRemote))
116          return false;
117    
118        BurlapRemote remote = (BurlapRemote) obj;
119    
120        return this.url.equals(remote.url);
121      }
122    
123      /**
124       * Readable version of the remote.
125       */
126      public String toString()
127      {
128        return "[BurlapRemote " + this.url + "]";
129      }
130    }