- Update to upstream SVN r700; drop all now upstreamed patches
This commit is contained in:
parent
8e879d7f94
commit
85c51a9364
@ -1 +0,0 @@
|
|||||||
jna-3.0.4.svn630.tar.bz2
|
|
@ -1,66 +0,0 @@
|
|||||||
diff -ur jna-3.0.4-svn630/src/com/sun/jna/CallbackReference.java jna-3.0.4-svn630.orig/src/com/sun/jna/CallbackReference.java
|
|
||||||
--- jna-3.0.4-svn630/src/com/sun/jna/CallbackReference.java 2008-07-31 13:44:21.000000000 -0400
|
|
||||||
+++ jna-3.0.4-svn630.orig/src/com/sun/jna/CallbackReference.java 2008-09-03 09:04:35.000000000 -0400
|
|
||||||
@@ -16,6 +16,7 @@
|
|
||||||
import java.lang.reflect.InvocationHandler;
|
|
||||||
import java.lang.reflect.InvocationTargetException;
|
|
||||||
import java.lang.reflect.Method;
|
|
||||||
+import java.lang.reflect.Field;
|
|
||||||
import java.lang.reflect.Proxy;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.Iterator;
|
|
||||||
@@ -150,22 +151,45 @@
|
|
||||||
}
|
|
||||||
return cls;
|
|
||||||
}
|
|
||||||
+
|
|
||||||
+ private static Method checkMethod(Method m) {
|
|
||||||
+ if (m.getParameterTypes().length > Function.MAX_NARGS) {
|
|
||||||
+ String msg = "Method signature exceeds the maximum "
|
|
||||||
+ + "parameter count: " + m;
|
|
||||||
+ throw new IllegalArgumentException(msg);
|
|
||||||
+ }
|
|
||||||
+ return m;
|
|
||||||
+ }
|
|
||||||
|
|
||||||
private static Method getCallbackMethod(Callback callback) {
|
|
||||||
- Method[] mlist = callback.getClass().getMethods();
|
|
||||||
+ Class klass = callback.getClass();
|
|
||||||
+ Method[] mlist = klass.getDeclaredMethods();
|
|
||||||
+
|
|
||||||
+ /* If there's only one method, just try it. */
|
|
||||||
+ if (mlist.length == 1)
|
|
||||||
+ return checkMethod(mlist[0]);
|
|
||||||
+
|
|
||||||
+ /* Now try looking for a field named "METHOD_NAME" which
|
|
||||||
+ * tells us which method to use.
|
|
||||||
+ */
|
|
||||||
+ String methName = Callback.METHOD_NAME;
|
|
||||||
+ try {
|
|
||||||
+ Field methNameField = klass.getField("METHOD_NAME");
|
|
||||||
+ methName = (String) methNameField.get(null);
|
|
||||||
+ } catch (NoSuchFieldException e) {
|
|
||||||
+ } catch (Exception e) {
|
|
||||||
+ String msg = "Callback METHOD_NAME field is invalid";
|
|
||||||
+ throw new IllegalArgumentException(msg);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
for (int mi=0;mi < mlist.length;mi++) {
|
|
||||||
Method m = mlist[mi];
|
|
||||||
- if (Callback.METHOD_NAME.equals(m.getName())) {
|
|
||||||
- if (m.getParameterTypes().length > Function.MAX_NARGS) {
|
|
||||||
- String msg = "Method signature exceeds the maximum "
|
|
||||||
- + "parameter count: " + m;
|
|
||||||
- throw new IllegalArgumentException(msg);
|
|
||||||
- }
|
|
||||||
- return m;
|
|
||||||
+ if (methName.equals(m.getName())) {
|
|
||||||
+ return checkMethod(m);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
String msg = "Callback must implement method named '"
|
|
||||||
- + Callback.METHOD_NAME + "'";
|
|
||||||
+ + methName + "'";
|
|
||||||
throw new IllegalArgumentException(msg);
|
|
||||||
}
|
|
||||||
|
|
@ -1,81 +0,0 @@
|
|||||||
Only in jna-3.0.4-svn630.orig/: build-d64
|
|
||||||
Only in jna-3.0.4-svn630.orig/: build.number
|
|
||||||
Only in jna-3.0.4-svn630.orig/: debugfiles.list
|
|
||||||
Only in jna-3.0.4-svn630.orig/: debuglinks.list
|
|
||||||
Only in jna-3.0.4-svn630.orig/: debugsources.list
|
|
||||||
Only in jna-3.0.4-svn630.orig/doc: javadoc
|
|
||||||
diff -ur jna-3.0.4-svn630/src/com/sun/jna/Native.java jna-3.0.4-svn630.orig/src/com/sun/jna/Native.java
|
|
||||||
--- jna-3.0.4-svn630/src/com/sun/jna/Native.java 2008-09-01 12:12:50.000000000 -0400
|
|
||||||
+++ jna-3.0.4-svn630.orig/src/com/sun/jna/Native.java 2008-09-01 12:12:27.000000000 -0400
|
|
||||||
@@ -51,7 +51,9 @@
|
|
||||||
* which would require every {@link Structure} which requires custom mapping
|
|
||||||
* or alignment to define a constructor and pass parameters to the superclass.
|
|
||||||
* To avoid lots of boilerplate, the base {@link Structure} constructor
|
|
||||||
- * figures out these properties based on its enclosing interface.<p>
|
|
||||||
+ * figures out these properties based on its enclosing interface. Alternatively,
|
|
||||||
+ * A field named TYPE_MAPPER may be declared.
|
|
||||||
+ * <p>
|
|
||||||
* <a name=library_loading></a>
|
|
||||||
* <h2>Library Loading</h2>
|
|
||||||
* When JNA classes are loaded, the native shared library (jnidispatch) is
|
|
||||||
@@ -350,32 +352,44 @@
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
+ private static final TypeMapper getClassTypeMapper(Class cls) {
|
|
||||||
+ try {
|
|
||||||
+ Field field = cls.getField("TYPE_MAPPER");
|
|
||||||
+ return (TypeMapper) field.get(null);
|
|
||||||
+ }
|
|
||||||
+ catch (NoSuchFieldException e) {
|
|
||||||
+ return null;
|
|
||||||
+ }
|
|
||||||
+ catch (Exception e) {
|
|
||||||
+ throw new IllegalArgumentException("TYPE_MAPPER must be a public field of type "
|
|
||||||
+ + TypeMapper.class.getName() + " ("
|
|
||||||
+ + e + "): " + cls);
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
/** Return the preferred {@link TypeMapper} for the given native interface.
|
|
||||||
* See {@link com.sun.jna.Library#OPTION_TYPE_MAPPER}.
|
|
||||||
*/
|
|
||||||
public static TypeMapper getTypeMapper(Class cls) {
|
|
||||||
+ if (Callback.class.isAssignableFrom(cls)) {
|
|
||||||
+ return getClassTypeMapper(cls);
|
|
||||||
+ }
|
|
||||||
synchronized(libraries) {
|
|
||||||
Class interfaceClass = findLibraryClass(cls);
|
|
||||||
if (interfaceClass == null)
|
|
||||||
return null;
|
|
||||||
+ TypeMapper mapper = getClassTypeMapper(interfaceClass);
|
|
||||||
+ if (mapper != null) {
|
|
||||||
+ typeMappers.put(interfaceClass, mapper);
|
|
||||||
+ } else {
|
|
||||||
+ Map options = getLibraryOptions(cls);
|
|
||||||
+ if (options != null
|
|
||||||
+ && options.containsKey(Library.OPTION_TYPE_MAPPER)) {
|
|
||||||
+ typeMappers.put(interfaceClass, options.get(Library.OPTION_TYPE_MAPPER));
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
if (!loadInstance(interfaceClass)
|
|
||||||
|| !typeMappers.containsKey(interfaceClass)) {
|
|
||||||
- try {
|
|
||||||
- Field field = interfaceClass.getField("TYPE_MAPPER");
|
|
||||||
- typeMappers.put(interfaceClass, field.get(null));
|
|
||||||
- }
|
|
||||||
- catch (NoSuchFieldException e) {
|
|
||||||
- Map options = getLibraryOptions(cls);
|
|
||||||
- if (options != null
|
|
||||||
- && options.containsKey(Library.OPTION_TYPE_MAPPER)) {
|
|
||||||
- typeMappers.put(interfaceClass, options.get(Library.OPTION_TYPE_MAPPER));
|
|
||||||
- }
|
|
||||||
- }
|
|
||||||
- catch (Exception e) {
|
|
||||||
- throw new IllegalArgumentException("TYPE_MAPPER must be a public field of type "
|
|
||||||
- + TypeMapper.class.getName() + " ("
|
|
||||||
- + e + "): " + interfaceClass);
|
|
||||||
- }
|
|
||||||
}
|
|
||||||
return (TypeMapper)typeMappers.get(interfaceClass);
|
|
||||||
}
|
|
@ -1,43 +0,0 @@
|
|||||||
diff -ur jna-3.0.4.orig/build.xml jna-3.0.4-svn630/build.xml
|
|
||||||
--- jna-3.0.4.orig/build.xml 2008-07-31 13:44:34.000000000 -0400
|
|
||||||
+++ jna-3.0.4-svn630/build.xml 2008-07-31 14:08:58.000000000 -0400
|
|
||||||
@@ -348,17 +348,7 @@
|
|
||||||
<arg value="VERSION=${jni.version}"/>
|
|
||||||
<arg value="CHECKSUM=${jni.md5}"/>
|
|
||||||
</exec>
|
|
||||||
- <mkdir dir="${classes}/com/sun/jna/${os.prefix}"/>
|
|
||||||
- <copy todir="${classes}/com/sun/jna/${os.prefix}">
|
|
||||||
- <fileset dir="${build.native}"
|
|
||||||
- includes="jnidispatch.dll,libjnidispatch.*"/>
|
|
||||||
- </copy>
|
|
||||||
- <mkdir dir="${eclipse.classes}/com/sun/jna/${os.prefix}"/>
|
|
||||||
- <copy todir="${eclipse.classes}/com/sun/jna/${os.prefix}"
|
|
||||||
- failonerror="false">
|
|
||||||
- <fileset dir="${build.native}"
|
|
||||||
- includes="jnidispatch.dll,libjnidispatch.*"/>
|
|
||||||
- </copy>
|
|
||||||
+ <antcall target="copy-native"/>
|
|
||||||
<!-- For web start, native libraries may be provided in the root of -->
|
|
||||||
<!-- an included jar file -->
|
|
||||||
<jar jarfile="${build}/${native.jar}">
|
|
||||||
@@ -369,6 +359,20 @@
|
|
||||||
</manifest>
|
|
||||||
</jar>
|
|
||||||
</target>
|
|
||||||
+
|
|
||||||
+ <target name="copy-native" unless="nomixedjar.native">
|
|
||||||
+ <mkdir dir="${classes}/com/sun/jna/${os.prefix}" unless="nomixedjar.native"/>
|
|
||||||
+ <copy todir="${classes}/com/sun/jna/${os.prefix}" unless="nomixedjar.native">
|
|
||||||
+ <fileset dir="${build.native}"
|
|
||||||
+ includes="jnidispatch.dll,libjnidispatch.*"/>
|
|
||||||
+ </copy>
|
|
||||||
+ <mkdir dir="${eclipse.classes}/com/sun/jna/${os.prefix}"/>
|
|
||||||
+ <copy todir="${eclipse.classes}/com/sun/jna/${os.prefix}"
|
|
||||||
+ failonerror="false">
|
|
||||||
+ <fileset dir="${build.native}"
|
|
||||||
+ includes="jnidispatch.dll,libjnidispatch.*"/>
|
|
||||||
+ </copy>
|
|
||||||
+ </target>
|
|
||||||
|
|
||||||
<target name="compile-tests" depends="compile,native"
|
|
||||||
description="Compile all test code">
|
|
@ -1,40 +0,0 @@
|
|||||||
diff -ur jna-3.0.4-svn630/src/com/sun/jna/Structure.java jna-3.0.4-svn630.orig/src/com/sun/jna/Structure.java
|
|
||||||
--- jna-3.0.4-svn630/src/com/sun/jna/Structure.java 2008-09-05 21:49:16.000000000 -0400
|
|
||||||
+++ jna-3.0.4-svn630.orig/src/com/sun/jna/Structure.java 2008-09-06 17:43:34.000000000 -0400
|
|
||||||
@@ -612,28 +612,28 @@
|
|
||||||
|
|
||||||
// Set the value at the offset according to its type
|
|
||||||
if (nativeType == boolean.class || nativeType == Boolean.class) {
|
|
||||||
- memory.setInt(offset, Boolean.TRUE.equals(value) ? -1 : 0);
|
|
||||||
+ memory.setInt(offset, (value != null && Boolean.TRUE.equals(value)) ? -1 : 0);
|
|
||||||
}
|
|
||||||
else if (nativeType == byte.class || nativeType == Byte.class) {
|
|
||||||
- memory.setByte(offset, ((Byte)value).byteValue());
|
|
||||||
+ memory.setByte(offset, value != null ? ((Byte)value).byteValue() : 0);
|
|
||||||
}
|
|
||||||
else if (nativeType == short.class || nativeType == Short.class) {
|
|
||||||
- memory.setShort(offset, ((Short)value).shortValue());
|
|
||||||
+ memory.setShort(offset, value != null ? ((Short)value).shortValue() : 0);
|
|
||||||
}
|
|
||||||
else if (nativeType == char.class || nativeType == Character.class) {
|
|
||||||
- memory.setChar(offset, ((Character)value).charValue());
|
|
||||||
+ memory.setChar(offset, value != null ? ((Character)value).charValue() : '\0');
|
|
||||||
}
|
|
||||||
else if (nativeType == int.class || nativeType == Integer.class) {
|
|
||||||
- memory.setInt(offset, ((Integer)value).intValue());
|
|
||||||
+ memory.setInt(offset, value != null ? ((Integer)value).intValue() : 0);
|
|
||||||
}
|
|
||||||
else if (nativeType == long.class || nativeType == Long.class) {
|
|
||||||
- memory.setLong(offset, ((Long)value).longValue());
|
|
||||||
+ memory.setLong(offset, value != null ? ((Long)value).longValue() : 0);
|
|
||||||
}
|
|
||||||
else if (nativeType == float.class || nativeType == Float.class) {
|
|
||||||
- memory.setFloat(offset, ((Float)value).floatValue());
|
|
||||||
+ memory.setFloat(offset, value != null ? ((Float)value).floatValue() : 0.0f);
|
|
||||||
}
|
|
||||||
else if (nativeType == double.class || nativeType == Double.class) {
|
|
||||||
- memory.setDouble(offset, ((Double)value).doubleValue());
|
|
||||||
+ memory.setDouble(offset, value != null ? ((Double)value).doubleValue() : 0.0);
|
|
||||||
}
|
|
||||||
else if (nativeType == Pointer.class) {
|
|
||||||
memory.setPointer(offset, (Pointer)value);
|
|
@ -1,46 +0,0 @@
|
|||||||
diff -ur jna-3.0.4-svn630/src/com/sun/jna/Structure.java jna-3.0.4-svn630.orig/src/com/sun/jna/Structure.java
|
|
||||||
--- jna-3.0.4-svn630/src/com/sun/jna/Structure.java 2008-07-31 13:44:21.000000000 -0400
|
|
||||||
+++ jna-3.0.4-svn630.orig/src/com/sun/jna/Structure.java 2008-09-05 21:47:51.000000000 -0400
|
|
||||||
@@ -126,8 +126,16 @@
|
|
||||||
}
|
|
||||||
|
|
||||||
protected Structure(int size, int alignment) {
|
|
||||||
+ this(size, alignment, null);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ protected Structure(TypeMapper mapper) {
|
|
||||||
+ this(CALCULATE_SIZE, ALIGN_DEFAULT, mapper);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ protected Structure(int size, int alignment, TypeMapper mapper) {
|
|
||||||
setAlignType(alignment);
|
|
||||||
- setTypeMapper(null);
|
|
||||||
+ setTypeMapper(mapper);
|
|
||||||
allocateMemory(size);
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -974,7 +982,8 @@
|
|
||||||
}
|
|
||||||
catch(IllegalArgumentException e) {
|
|
||||||
throw new IllegalArgumentException("The type \"" + type.getName()
|
|
||||||
- + "\" is not supported as a structure field");
|
|
||||||
+ + "\" is not supported as a structure field: "
|
|
||||||
+ + e.getMessage());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
diff -ur jna-3.0.4-svn630/src/com/sun/jna/Union.java jna-3.0.4-svn630.orig/src/com/sun/jna/Union.java
|
|
||||||
--- jna-3.0.4-svn630/src/com/sun/jna/Union.java 2008-07-31 13:44:21.000000000 -0400
|
|
||||||
+++ jna-3.0.4-svn630.orig/src/com/sun/jna/Union.java 2008-09-05 21:47:18.000000000 -0400
|
|
||||||
@@ -39,6 +39,11 @@
|
|
||||||
protected Union(int size, int alignType) {
|
|
||||||
super(size, alignType);
|
|
||||||
}
|
|
||||||
+
|
|
||||||
+ protected Union(TypeMapper mapper) {
|
|
||||||
+ super(mapper);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
/** Indicates which field will be used to write to native memory.
|
|
||||||
* @throws IllegalArgumentException if the type does not correspond to
|
|
||||||
* any declared union field.
|
|
24
jna.spec
24
jna.spec
@ -1,6 +1,6 @@
|
|||||||
Name: jna
|
Name: jna
|
||||||
Version: 3.0.4
|
Version: 3.0.4
|
||||||
Release: 3.svn630%{?dist}
|
Release: 4.svn700%{?dist}
|
||||||
Summary: Pure Java access to native libraries
|
Summary: Pure Java access to native libraries
|
||||||
|
|
||||||
Group: Development/Libraries
|
Group: Development/Libraries
|
||||||
@ -10,20 +10,10 @@ URL: https://jna.dev.java.net/
|
|||||||
# following commands to generate the tarball:
|
# following commands to generate the tarball:
|
||||||
# svn export https://jna.dev.java.net/svn/jna/tags/%{version}/jnalib/ --username guest jna-%{version}
|
# svn export https://jna.dev.java.net/svn/jna/tags/%{version}/jnalib/ --username guest jna-%{version}
|
||||||
# tar -cjf jna-%{version}.tar.bz2 jna-%{version}
|
# tar -cjf jna-%{version}.tar.bz2 jna-%{version}
|
||||||
Source0: %{name}-%{version}.svn630.tar.bz2
|
Source0: %{name}-%{version}.svn700.tar.bz2
|
||||||
# This patch is Fedora-specific for now until we get the huge
|
# This patch is Fedora-specific for now until we get the huge
|
||||||
# JNI library location mess sorted upstream
|
# JNI library location mess sorted upstream
|
||||||
Patch1: jna-3.0.2-loadlibrary.patch
|
Patch1: jna-3.0.2-loadlibrary.patch
|
||||||
# Will send upstream...
|
|
||||||
Patch2: jna-3.0.4-nomixedjar.patch
|
|
||||||
# https://jna.dev.java.net/issues/show_bug.cgi?id=84
|
|
||||||
Patch3: jna-3.0.4-callbacks-typemappers.patch
|
|
||||||
# https://jna.dev.java.net/issues/show_bug.cgi?id=85
|
|
||||||
Patch4: jna-3.0.4-callbacks-methodname.patch
|
|
||||||
# https://jna.dev.java.net/issues/show_bug.cgi?id=86
|
|
||||||
Patch5: jna-3.0.4-structure-reason.patch
|
|
||||||
# https://jna.dev.java.net/issues/show_bug.cgi?id=87
|
|
||||||
Patch6: jna-3.0.4-structure-handle-null.patch
|
|
||||||
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
|
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
|
||||||
|
|
||||||
BuildRequires: java-devel >= 1.6 ant jpackage-utils ant-nodeps
|
BuildRequires: java-devel >= 1.6 ant jpackage-utils ant-nodeps
|
||||||
@ -52,13 +42,8 @@ This package contains the javadocs for %{name}.
|
|||||||
|
|
||||||
|
|
||||||
%prep
|
%prep
|
||||||
%setup -q -n %{name}-%{version}-svn630
|
%setup -q -n %{name}-%{version}-svn700
|
||||||
sed -e 's|@JNIPATH@|%{_libdir}/%{name}|' %{PATCH1} | patch -p1
|
sed -e 's|@JNIPATH@|%{_libdir}/%{name}|' %{PATCH1} | patch -p1
|
||||||
%patch2 -p1
|
|
||||||
%patch3 -p1
|
|
||||||
%patch4 -p1
|
|
||||||
%patch5 -p1
|
|
||||||
%patch6 -p1
|
|
||||||
|
|
||||||
# all java binaries must be removed from the sources
|
# all java binaries must be removed from the sources
|
||||||
find . -name '*.jar' -exec rm -f '{}' \;
|
find . -name '*.jar' -exec rm -f '{}' \;
|
||||||
@ -115,6 +100,9 @@ rm -rf %{buildroot}
|
|||||||
|
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Tue Sep 09 2008 Colin Walters <walters@redhat.com> - 3.0.4-4.svn700
|
||||||
|
- Update to upstream SVN r700; drop all now upstreamed patches
|
||||||
|
|
||||||
* Sat Sep 06 2008 Colin Walters <walters@redhat.com> - 3.0.4-3.svn630
|
* Sat Sep 06 2008 Colin Walters <walters@redhat.com> - 3.0.4-3.svn630
|
||||||
- A few more patches for JGIR
|
- A few more patches for JGIR
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user