summaryrefslogtreecommitdiff
path: root/ext
diff options
context:
space:
mode:
authorSam Ruby <rubys@php.net>2000-05-12 09:51:16 +0000
committerSam Ruby <rubys@php.net>2000-05-12 09:51:16 +0000
commit33ceae28094b0c800fe39fa9d66313b3d687b21e (patch)
tree7b2f992485f2b9bd1fc91e5413dd4931601c171f /ext
parentafedd22f19f59055d2574875db29f098004a1d67 (diff)
downloadphp-git-33ceae28094b0c800fe39fa9d66313b3d687b21e.tar.gz
i18n, part I
Diffstat (limited to 'ext')
-rw-r--r--ext/java/java.c14
-rw-r--r--ext/java/reflect.java11
-rw-r--r--ext/rpc/java/java.c14
-rw-r--r--ext/rpc/java/reflect.java11
4 files changed, 32 insertions, 18 deletions
diff --git a/ext/java/java.c b/ext/java/java.c
index b7c2a4dc06..2da4ac849c 100644
--- a/ext/java/java.c
+++ b/ext/java/java.c
@@ -263,7 +263,9 @@ static jobjectArray _java_makeArray(int argc, pval** argv) {
for (i=0; i<argc; i++) {
switch (argv[i]->type) {
case IS_STRING:
- arg=(*jenv)->NewStringUTF(jenv,argv[i]->value.str.val);
+ arg=(*jenv)->NewByteArray(jenv,argv[i]->value.str.len);
+ (*jenv)->SetByteArrayRegion(jenv,(jbyteArray)arg,0,
+ argv[i]->value.str.len, argv[i]->value.str.val);
break;
case IS_OBJECT:
@@ -498,16 +500,16 @@ ZEND_GET_MODULE(java)
/***************************************************************************/
JNIEXPORT void JNICALL Java_net_php_reflect_setResultFromString
- (JNIEnv *jenv, jclass self, jlong result, jstring value)
+ (JNIEnv *jenv, jclass self, jlong result, jbyteArray jvalue)
{
jboolean isCopy;
- const char *valueAsUTF = (*jenv)->GetStringUTFChars(jenv, value, &isCopy);
+ jbyte *value = (*jenv)->GetByteArrayElements(jenv, jvalue, &isCopy);
pval *presult = (pval*)(long)result;
presult->type=IS_STRING;
- presult->value.str.len=strlen(valueAsUTF);
+ presult->value.str.len=(*jenv)->GetArrayLength(jenv, jvalue);
presult->value.str.val=emalloc(presult->value.str.len+1);
- strcpy(presult->value.str.val, valueAsUTF);
- if (isCopy) (*jenv)->ReleaseStringUTFChars(jenv, value, valueAsUTF);
+ strcpy(presult->value.str.val, value);
+ if (isCopy) (*jenv)->ReleaseByteArrayElements(jenv, jvalue, value, 0);
}
JNIEXPORT void JNICALL Java_net_php_reflect_setResultFromLong
diff --git a/ext/java/reflect.java b/ext/java/reflect.java
index b7693e907c..f2bc02a2f6 100644
--- a/ext/java/reflect.java
+++ b/ext/java/reflect.java
@@ -38,7 +38,7 @@ class reflect {
//
// Native methods
//
- private static native void setResultFromString(long result, String value);
+ private static native void setResultFromString(long result, byte value[]);
private static native void setResultFromLong(long result, long value);
private static native void setResultFromDouble(long result, double value);
private static native void setResultFromBoolean(long result, boolean value);
@@ -56,7 +56,7 @@ class reflect {
if (value instanceof java.lang.String) {
- setResultFromString(result, (String)value);
+ setResultFromString(result, ((String)value).getBytes());
} else if (value instanceof java.lang.Number) {
@@ -155,6 +155,9 @@ class reflect {
if (!c.isInstance(args[i])) break;
weight++;
}
+ } else if (parms[i].isInstance("")) {
+ if (!(args[i] instanceof byte[]))
+ weight+=9999;
} else if (parms[i].isPrimitive()) {
Class c=parms[i];
if (args[i] instanceof Number) {
@@ -199,7 +202,9 @@ class reflect {
Object result[] = args;
for (int i=0; i<args.length; i++) {
if (parms[i].isInstance(args[i])) continue;
- if (args[i] instanceof Number && parms[i].isPrimitive()) {
+ if (args[i] instanceof byte[] && parms[i].isInstance("")) {
+ result[i] = new String((byte[])args[i]);
+ } else if (args[i] instanceof Number && parms[i].isPrimitive()) {
if (result==args) result=(Object[])result.clone();
Class c = parms[i];
Number n = (Number)args[i];
diff --git a/ext/rpc/java/java.c b/ext/rpc/java/java.c
index b7c2a4dc06..2da4ac849c 100644
--- a/ext/rpc/java/java.c
+++ b/ext/rpc/java/java.c
@@ -263,7 +263,9 @@ static jobjectArray _java_makeArray(int argc, pval** argv) {
for (i=0; i<argc; i++) {
switch (argv[i]->type) {
case IS_STRING:
- arg=(*jenv)->NewStringUTF(jenv,argv[i]->value.str.val);
+ arg=(*jenv)->NewByteArray(jenv,argv[i]->value.str.len);
+ (*jenv)->SetByteArrayRegion(jenv,(jbyteArray)arg,0,
+ argv[i]->value.str.len, argv[i]->value.str.val);
break;
case IS_OBJECT:
@@ -498,16 +500,16 @@ ZEND_GET_MODULE(java)
/***************************************************************************/
JNIEXPORT void JNICALL Java_net_php_reflect_setResultFromString
- (JNIEnv *jenv, jclass self, jlong result, jstring value)
+ (JNIEnv *jenv, jclass self, jlong result, jbyteArray jvalue)
{
jboolean isCopy;
- const char *valueAsUTF = (*jenv)->GetStringUTFChars(jenv, value, &isCopy);
+ jbyte *value = (*jenv)->GetByteArrayElements(jenv, jvalue, &isCopy);
pval *presult = (pval*)(long)result;
presult->type=IS_STRING;
- presult->value.str.len=strlen(valueAsUTF);
+ presult->value.str.len=(*jenv)->GetArrayLength(jenv, jvalue);
presult->value.str.val=emalloc(presult->value.str.len+1);
- strcpy(presult->value.str.val, valueAsUTF);
- if (isCopy) (*jenv)->ReleaseStringUTFChars(jenv, value, valueAsUTF);
+ strcpy(presult->value.str.val, value);
+ if (isCopy) (*jenv)->ReleaseByteArrayElements(jenv, jvalue, value, 0);
}
JNIEXPORT void JNICALL Java_net_php_reflect_setResultFromLong
diff --git a/ext/rpc/java/reflect.java b/ext/rpc/java/reflect.java
index b7693e907c..f2bc02a2f6 100644
--- a/ext/rpc/java/reflect.java
+++ b/ext/rpc/java/reflect.java
@@ -38,7 +38,7 @@ class reflect {
//
// Native methods
//
- private static native void setResultFromString(long result, String value);
+ private static native void setResultFromString(long result, byte value[]);
private static native void setResultFromLong(long result, long value);
private static native void setResultFromDouble(long result, double value);
private static native void setResultFromBoolean(long result, boolean value);
@@ -56,7 +56,7 @@ class reflect {
if (value instanceof java.lang.String) {
- setResultFromString(result, (String)value);
+ setResultFromString(result, ((String)value).getBytes());
} else if (value instanceof java.lang.Number) {
@@ -155,6 +155,9 @@ class reflect {
if (!c.isInstance(args[i])) break;
weight++;
}
+ } else if (parms[i].isInstance("")) {
+ if (!(args[i] instanceof byte[]))
+ weight+=9999;
} else if (parms[i].isPrimitive()) {
Class c=parms[i];
if (args[i] instanceof Number) {
@@ -199,7 +202,9 @@ class reflect {
Object result[] = args;
for (int i=0; i<args.length; i++) {
if (parms[i].isInstance(args[i])) continue;
- if (args[i] instanceof Number && parms[i].isPrimitive()) {
+ if (args[i] instanceof byte[] && parms[i].isInstance("")) {
+ result[i] = new String((byte[])args[i]);
+ } else if (args[i] instanceof Number && parms[i].isPrimitive()) {
if (result==args) result=(Object[])result.clone();
Class c = parms[i];
Number n = (Number)args[i];