1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126
|
/*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include <jni.h>
#include "JCCEnv.h"
#include "java/lang/Object.h"
#include "java/lang/Class.h"
#include "java/util/Iterator.h"
namespace java {
namespace util {
enum {
mid_hasNext,
mid_next,
max_mid
};
Class *Iterator::class$ = NULL;
jmethodID *Iterator::mids$ = NULL;
jclass Iterator::initializeClass(bool getOnly)
{
if (getOnly)
return (jclass) (class$ == NULL ? NULL : class$->this$);
if (!class$)
{
jclass cls = env->findClass("java/util/Iterator");
mids$ = new jmethodID[max_mid];
mids$[mid_hasNext] = env->getMethodID(cls, "hasNext",
"()Z");
mids$[mid_next] = env->getMethodID(cls, "next",
"()Ljava/lang/Object;");
class$ = (Class *) new JObject(cls);
}
return (jclass) class$->this$;
}
jboolean Iterator::hasNext() const
{
return env->callBooleanMethod(this$, mids$[mid_hasNext]);
}
Object Iterator::next() const
{
return Object(env->callObjectMethod(this$, mids$[mid_next]));
}
}
}
#include "structmember.h"
#include "functions.h"
#include "macros.h"
namespace java {
namespace util {
static PyObject *t_Iterator_hasNext(t_Iterator *self);
static PyObject *t_Iterator_next(t_Iterator *self);
static PyMethodDef t_Iterator__methods_[] = {
DECLARE_METHOD(t_Iterator, hasNext, METH_NOARGS),
DECLARE_METHOD(t_Iterator, next, METH_NOARGS),
{ NULL, NULL, 0, NULL }
};
DECLARE_TYPE(Iterator, t_Iterator, JObject, java::util::Iterator,
abstract_init, 0, 0, 0, 0, 0);
#ifdef _java_generics
PyObject *t_Iterator::wrap_Object(const Iterator& object,
PyTypeObject *T)
{
PyObject *obj = t_Iterator::wrap_Object(object);
if (obj != Py_None)
{
t_Iterator *self = (t_Iterator *) obj;
self->parameters[0] = T;
}
return obj;
}
PyObject *t_Iterator::wrap_jobject(const jobject& object,
PyTypeObject *T)
{
PyObject *obj = t_Iterator::wrap_jobject(object);
if (obj != Py_None)
{
t_Iterator *self = (t_Iterator *) obj;
self->parameters[0] = T;
}
return obj;
}
#endif
static PyObject *t_Iterator_hasNext(t_Iterator *self)
{
jboolean b;
OBJ_CALL(b = self->object.hasNext());
Py_RETURN_BOOL(b);
}
static PyObject *t_Iterator_next(t_Iterator *self)
{
Object next((jobject) NULL);
OBJ_CALL(next = self->object.next());
return t_Object::wrap_Object(next);
}
}
}
|