OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-dev/] [or1k-gcc/] [libjava/] [classpath/] [org/] [omg/] [CosNaming/] [_BindingIteratorImplBase.java] - Blame information for rev 775

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 775 jeremybenn
/* _BindingIteratorImplBase.java --
2
   Copyright (C) 2005 Free Software Foundation, Inc.
3
 
4
This file is part of GNU Classpath.
5
 
6
GNU Classpath is free software; you can redistribute it and/or modify
7
it under the terms of the GNU General Public License as published by
8
the Free Software Foundation; either version 2, or (at your option)
9
any later version.
10
 
11
GNU Classpath is distributed in the hope that it will be useful, but
12
WITHOUT ANY WARRANTY; without even the implied warranty of
13
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14
General Public License for more details.
15
 
16
You should have received a copy of the GNU General Public License
17
along with GNU Classpath; see the file COPYING.  If not, write to the
18
Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
19
02110-1301 USA.
20
 
21
Linking this library statically or dynamically with other modules is
22
making a combined work based on this library.  Thus, the terms and
23
conditions of the GNU General Public License cover the whole
24
combination.
25
 
26
As a special exception, the copyright holders of this library give you
27
permission to link this library with independent modules to produce an
28
executable, regardless of the license terms of these independent
29
modules, and to copy and distribute the resulting executable under
30
terms of your choice, provided that you also meet, for each linked
31
independent module, the terms and conditions of the license of that
32
module.  An independent module is a module which is not derived from
33
or based on this library.  If you modify this library, you may extend
34
this exception to your version of the library, but you are not
35
obligated to do so.  If you do not wish to do so, delete this
36
exception statement from your version. */
37
 
38
 
39
package org.omg.CosNaming;
40
 
41
import gnu.CORBA.Minor;
42
 
43
import org.omg.CORBA.BAD_OPERATION;
44
import org.omg.CORBA.BooleanHolder;
45
import org.omg.CORBA.CompletionStatus;
46
import org.omg.CORBA.DynamicImplementation;
47
import org.omg.CORBA.ServerRequest;
48
import org.omg.CORBA.portable.InputStream;
49
import org.omg.CORBA.portable.InvokeHandler;
50
import org.omg.CORBA.portable.OutputStream;
51
import org.omg.CORBA.portable.ResponseHandler;
52
import org.omg.CORBA.portable.Streamable;
53
 
54
/**
55
 * The binding iterator implementation base.
56
 *
57
 * @author Audrius Meskauskas, Lithuania (AudriusA@Bioinformatics.org)
58
 */
59
public abstract class _BindingIteratorImplBase
60
  extends DynamicImplementation
61
  implements BindingIterator, InvokeHandler
62
{
63
  /**
64
   * Use serialVersionUID (v1.4) for interoperability.
65
   */
66
  private static final long serialVersionUID = 3472591176635005503L;
67
 
68
  /**
69
   * The binding interator repository id.
70
   */
71
  private static String[] ids = { BindingIteratorHelper.id() };
72
 
73
  /**
74
   * Return the list of repository ids.
75
   */
76
  public String[] _ids()
77
  {
78
    return ids;
79
  }
80
 
81
  /**
82
   * Call the required method.
83
   */
84
  public OutputStream _invoke(String method, InputStream in, ResponseHandler rh)
85
  {
86
    OutputStream out = null;
87
 
88
    // We suppose that the next_n should be the most popular.
89
    if (method.equals("next_n"))
90
      {
91
        // The next_n has been invoked.
92
        int amount = in.read_ulong();
93
        BindingListHolder a_list = new BindingListHolder();
94
 
95
        boolean result = next_n(amount, a_list);
96
 
97
        out = rh.createReply();
98
        out.write_boolean(result);
99
        BindingListHelper.write(out, a_list.value);
100
      }
101
    else if (method.equals("next_one"))
102
      {
103
        // The next_one has been invoked.
104
        BindingHolder a_binding = new BindingHolder();
105
 
106
        boolean result = next_one(a_binding);
107
 
108
        out = rh.createReply();
109
        out.write_boolean(result);
110
        BindingHelper.write(out, a_binding.value);
111
      }
112
    else if (method.equals("destroy"))
113
      {
114
        // The destroy has been invoked.
115
        destroy();
116
        out = rh.createReply();
117
      }
118
    else
119
      throw new BAD_OPERATION(method, Minor.Method,
120
        CompletionStatus.COMPLETED_MAYBE);
121
 
122
    return out;
123
  }
124
 
125
  /**
126
   * The obsolete invocation using server request. Implemented for
127
   * compatibility reasons, but is it more effectinve to use
128
   * {@link #_invoke}.
129
   *
130
   * @param request a server request.
131
   */
132
  public void invoke(ServerRequest request)
133
  {
134
    // "destroy" has a void return type, the two other methods - boolean.
135
    Streamable result =
136
      request.operation().equals("destroy") ? null : new BooleanHolder();
137
    gnu.CORBA.ServiceRequestAdapter.invoke(request, this, result);
138
  }
139
}

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.