diff options
author | Martin Sustrik <sustrik@fastmq.com> | 2009-09-08 13:55:13 +0200 |
---|---|---|
committer | Martin Sustrik <sustrik@fastmq.com> | 2009-09-08 13:55:13 +0200 |
commit | 3069b6bd54486346f7bfcce58d6a5e34d129965c (patch) | |
tree | cdef109605b657baa1abc28cada66425dda438c5 | |
parent | ec6822a477b89ac77afc90425bf36c4829dbef3d (diff) |
win port of java binding + java perf tests
-rw-r--r-- | java/Context.cpp | 7 | ||||
-rw-r--r-- | java/Message.cpp | 138 | ||||
-rw-r--r-- | java/Socket.cpp | 7 | ||||
-rw-r--r-- | java/org/zmq/Socket.java | 2 | ||||
-rw-r--r-- | msvc/j_local_lat/j_local_lat.vcproj | 78 | ||||
-rw-r--r-- | msvc/j_local_thr/j_local_thr.vcproj | 78 | ||||
-rw-r--r-- | msvc/j_remote_lat/j_remote_lat.vcproj | 78 | ||||
-rw-r--r-- | msvc/j_remote_thr/j_remote_thr.vcproj | 78 | ||||
-rw-r--r-- | msvc/msvc.sln | 45 | ||||
-rw-r--r-- | perf/c/local_thr.c | 3 |
10 files changed, 374 insertions, 140 deletions
diff --git a/java/Context.cpp b/java/Context.cpp index 3fc66bd..67094e8 100644 --- a/java/Context.cpp +++ b/java/Context.cpp @@ -34,7 +34,14 @@ static void raise_exception (JNIEnv *env, int err) assert (exception_class); // Get text description of the exception. +#if defined _MSC_VER +#pragma warning (push) +#pragma warning (disable:4996) +#endif const char *err_msg = strerror (err); +#if defined _MSC_VER +#pragma warning (pop) +#endif // Raise the exception. int rc = env->ThrowNew (exception_class, err_msg); diff --git a/java/Message.cpp b/java/Message.cpp deleted file mode 100644 index 2105216..0000000 --- a/java/Message.cpp +++ /dev/null @@ -1,138 +0,0 @@ -/* - Copyright (c) 2007-2009 FastMQ Inc. - - This file is part of 0MQ. - - 0MQ is free software; you can redistribute it and/or modify it under - the terms of the Lesser GNU General Public License as published by - the Free Software Foundation; either version 3 of the License, or - (at your option) any later version. - - 0MQ is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - Lesser GNU General Public License for more details. - - You should have received a copy of the Lesser GNU General Public License - along with this program. If not, see <http://www.gnu.org/licenses/>. -*/ - -#include <stdlib.h> -#include <string.h> -#include <assert.h> -#include <errno.h> - -#include "zmq.h" -#include "org_zmq_Message.h" - -static jfieldID msg_handle_fid = NULL; - -static void -raise_exception (JNIEnv *env, int err) -{ - // Get exception class. - jclass exception_class = env->FindClass ("java/lang/Exception"); - assert (exception_class); - - // Get text description of the exception. - const char *err_msg = strerror (err); - - // Raise the exception. - int rc = env->ThrowNew (exception_class, err_msg); - assert (rc == 0); - - // Free the local ref. - env->DeleteLocalRef (exception_class); -} - -JNIEXPORT void JNICALL -Java_org_zmq_Message_construct (JNIEnv *env, jobject obj) -{ - if (msg_handle_fid == NULL) { - jclass cls = env->GetObjectClass (obj); - assert (cls != NULL); - msg_handle_fid = env->GetFieldID (cls, "msgHandle", "J"); - assert (msg_handle_fid != NULL); - env->DeleteLocalRef (cls); - } - - zmq_msg_t *msg = (zmq_msg_t*) malloc (sizeof (zmq_msg_t)); - if (msg == NULL) { - raise_exception (env, ENOMEM); - return; - } - - int rc = zmq_msg_init (msg); - assert (rc == 0); - env->SetLongField (obj, msg_handle_fid, (jlong) msg); -} - -JNIEXPORT void JNICALL -Java_org_zmq_Message_constructWithData (JNIEnv *env, jobject obj, - jbyteArray payload) -{ - if (msg_handle_fid == NULL) { - jclass cls = env->GetObjectClass (obj); - assert (cls != NULL); - msg_handle_fid = env->GetFieldID (cls, "msgHandle", "J"); - assert (msg_handle_fid != NULL); - env->DeleteLocalRef (cls); - } - - zmq_msg_t *msg = (zmq_msg_t*) malloc (sizeof (zmq_msg_t)); - if (msg == NULL) { - raise_exception (env, ENOMEM); - return; - } - - jsize array_size = env->GetArrayLength (payload); - jbyte *array_data = env->GetByteArrayElements (payload, NULL); - - int rc = zmq_msg_init_size (msg, array_size); - assert (rc == 0); - - memcpy (zmq_msg_data (msg), array_data, array_size); - env->ReleaseByteArrayElements (payload, array_data, JNI_ABORT); - - env->SetLongField (obj, msg_handle_fid, (jlong) msg); -} - -JNIEXPORT void JNICALL -Java_org_zmq_Message_finalize (JNIEnv *env, jobject obj) -{ - zmq_msg_t *msg = (zmq_msg_t*) env->GetLongField (obj, msg_handle_fid); - assert (msg); - - int rc = zmq_msg_close (msg); - assert (rc == 0); - - free (msg); -} - -JNIEXPORT jbyteArray JNICALL -Java_org_zmq_Message_getMsgPayload (JNIEnv *env, jobject obj) -{ - zmq_msg_t *msg = (zmq_msg_t*) env->GetLongField (obj, msg_handle_fid); - assert (msg); - - jsize msg_size = zmq_msg_size (msg); - jbyte *msg_data = (jbyte*) zmq_msg_data (msg); - - jbyteArray payload = env->NewByteArray (msg_size); - if (payload == NULL) - return NULL; - - env->SetByteArrayRegion (payload, 0, msg_size, msg_data); - assert (!env->ExceptionCheck ()); - - return payload; -} - -JNIEXPORT jint JNICALL -Java_org_zmq_Message_getMsgType (JNIEnv *env, jobject obj) -{ - zmq_msg_t *msg = (zmq_msg_t*) env->GetLongField (obj, msg_handle_fid); - assert (msg); - - return (jint) zmq_msg_type (msg); -} diff --git a/java/Socket.cpp b/java/Socket.cpp index f87c298..51ee816 100644 --- a/java/Socket.cpp +++ b/java/Socket.cpp @@ -35,7 +35,14 @@ static void raise_exception (JNIEnv *env, int err) assert (exception_class); // Get text description of the exception. +#if defined _MSC_VER +#pragma warning (push) +#pragma warning (disable:4996) +#endif const char *err_msg = strerror (err); +#if defined _MSC_VER +#pragma warning (pop) +#endif // Raise the exception. int rc = env->ThrowNew (exception_class, err_msg); diff --git a/java/org/zmq/Socket.java b/java/org/zmq/Socket.java index 832467f..4c6a3d3 100644 --- a/java/org/zmq/Socket.java +++ b/java/org/zmq/Socket.java @@ -1,4 +1,4 @@ -/* + /* Copyright (c) 2007-2009 FastMQ Inc. This file is part of 0MQ. diff --git a/msvc/j_local_lat/j_local_lat.vcproj b/msvc/j_local_lat/j_local_lat.vcproj new file mode 100644 index 0000000..be8da5f --- /dev/null +++ b/msvc/j_local_lat/j_local_lat.vcproj @@ -0,0 +1,78 @@ +<?xml version="1.0" encoding="windows-1250"?> +<VisualStudioProject + ProjectType="Visual C++" + Version="9.00" + Name="j_local_lat" + ProjectGUID="{F4D93BC6-9D70-4113-94A8-817A52B49290}" + RootNamespace="j_local_lat" + TargetFrameworkVersion="196613" + > + <Platforms> + <Platform + Name="Win32" + /> + </Platforms> + <ToolFiles> + </ToolFiles> + <Configurations> + <Configuration + Name="Debug|Win32" + OutputDirectory="$(SolutionDir)$(ConfigurationName)" + IntermediateDirectory="$(ConfigurationName)" + ConfigurationType="10" + CharacterSet="2" + > + <Tool + Name="VCPreBuildEventTool" + Description="Compiling Java classes" + CommandLine="javac -classpath ..\..\java ..\..\perf\java\local_lat.java" + /> + <Tool + Name="VCCustomBuildTool" + /> + <Tool + Name="VCMIDLTool" + /> + <Tool + Name="VCPostBuildEventTool" + /> + </Configuration> + <Configuration + Name="Release|Win32" + OutputDirectory="$(SolutionDir)$(ConfigurationName)" + IntermediateDirectory="$(ConfigurationName)" + ConfigurationType="10" + CharacterSet="2" + WholeProgramOptimization="1" + > + <Tool + Name="VCPreBuildEventTool" + Description="Compiling Java classes" + CommandLine="javac -classpath ..\..\java ..\..\perf\java\local_lat.java" + /> + <Tool + Name="VCCustomBuildTool" + /> + <Tool + Name="VCMIDLTool" + /> + <Tool + Name="VCPostBuildEventTool" + /> + </Configuration> + </Configurations> + <References> + </References> + <Files> + <Filter + Name="Java Files" + > + <File + RelativePath="..\..\perf\java\local_lat.java" + > + </File> + </Filter> + </Files> + <Globals> + </Globals> +</VisualStudioProject> diff --git a/msvc/j_local_thr/j_local_thr.vcproj b/msvc/j_local_thr/j_local_thr.vcproj new file mode 100644 index 0000000..465b859 --- /dev/null +++ b/msvc/j_local_thr/j_local_thr.vcproj @@ -0,0 +1,78 @@ +<?xml version="1.0" encoding="windows-1250"?> +<VisualStudioProject + ProjectType="Visual C++" + Version="9.00" + Name="j_local_thr" + ProjectGUID="{95E6161D-418B-4ABF-85E2-F07797742156}" + RootNamespace="j_local_thr" + TargetFrameworkVersion="196613" + > + <Platforms> + <Platform + Name="Win32" + /> + </Platforms> + <ToolFiles> + </ToolFiles> + <Configurations> + <Configuration + Name="Debug|Win32" + OutputDirectory="$(SolutionDir)$(ConfigurationName)" + IntermediateDirectory="$(ConfigurationName)" + ConfigurationType="10" + CharacterSet="2" + > + <Tool + Name="VCPreBuildEventTool" + Description="Compiling Java classes" + CommandLine="javac -classpath ..\..\java ..\..\perf\java\local_thr.java" + /> + <Tool + Name="VCCustomBuildTool" + /> + <Tool + Name="VCMIDLTool" + /> + <Tool + Name="VCPostBuildEventTool" + /> + </Configuration> + <Configuration + Name="Release|Win32" + OutputDirectory="$(SolutionDir)$(ConfigurationName)" + IntermediateDirectory="$(ConfigurationName)" + ConfigurationType="10" + CharacterSet="2" + WholeProgramOptimization="1" + > + <Tool + Name="VCPreBuildEventTool" + Description="Compiling Java classes" + CommandLine="javac -classpath ..\..\java ..\..\perf\java\local_thr.java" + /> + <Tool + Name="VCCustomBuildTool" + /> + <Tool + Name="VCMIDLTool" + /> + <Tool + Name="VCPostBuildEventTool" + /> + </Configuration> + </Configurations> + <References> + </References> + <Files> + <Filter + Name="Java Files" + > + <File + RelativePath="..\..\perf\java\local_thr.java" + > + </File> + </Filter> + </Files> + <Globals> + </Globals> +</VisualStudioProject> diff --git a/msvc/j_remote_lat/j_remote_lat.vcproj b/msvc/j_remote_lat/j_remote_lat.vcproj new file mode 100644 index 0000000..9b62d34 --- /dev/null +++ b/msvc/j_remote_lat/j_remote_lat.vcproj @@ -0,0 +1,78 @@ +<?xml version="1.0" encoding="windows-1250"?> +<VisualStudioProject + ProjectType="Visual C++" + Version="9.00" + Name="j_remote_lat" + ProjectGUID="{15C832D0-2E68-484A-9DCE-BC872FE1C7EF}" + RootNamespace="j_remote_lat" + TargetFrameworkVersion="196613" + > + <Platforms> + <Platform + Name="Win32" + /> + </Platforms> + <ToolFiles> + </ToolFiles> + <Configurations> + <Configuration + Name="Debug|Win32" + OutputDirectory="$(SolutionDir)$(ConfigurationName)" + IntermediateDirectory="$(ConfigurationName)" + ConfigurationType="10" + CharacterSet="2" + > + <Tool + Name="VCPreBuildEventTool" + Description="Compiling Java classes" + CommandLine="javac -classpath ..\..\java ..\..\perf\java\remote_lat.java" + /> + <Tool + Name="VCCustomBuildTool" + /> + <Tool + Name="VCMIDLTool" + /> + <Tool + Name="VCPostBuildEventTool" + /> + </Configuration> + <Configuration + Name="Release|Win32" + OutputDirectory="$(SolutionDir)$(ConfigurationName)" + IntermediateDirectory="$(ConfigurationName)" + ConfigurationType="10" + CharacterSet="2" + WholeProgramOptimization="1" + > + <Tool + Name="VCPreBuildEventTool" + Description="Compiling Java classes" + CommandLine="javac -classpath ..\..\java ..\..\perf\java\remote_lat.java" + /> + <Tool + Name="VCCustomBuildTool" + /> + <Tool + Name="VCMIDLTool" + /> + <Tool + Name="VCPostBuildEventTool" + /> + </Configuration> + </Configurations> + <References> + </References> + <Files> + <Filter + Name="Java Files" + > + <File + RelativePath="..\..\perf\java\remote_lat.java" + > + </File> + </Filter> + </Files> + <Globals> + </Globals> +</VisualStudioProject> diff --git a/msvc/j_remote_thr/j_remote_thr.vcproj b/msvc/j_remote_thr/j_remote_thr.vcproj new file mode 100644 index 0000000..5993087 --- /dev/null +++ b/msvc/j_remote_thr/j_remote_thr.vcproj @@ -0,0 +1,78 @@ +<?xml version="1.0" encoding="windows-1250"?> +<VisualStudioProject + ProjectType="Visual C++" + Version="9.00" + Name="j_remote_thr" + ProjectGUID="{00A421BA-3B6B-45BD-B91F-DED953472622}" + RootNamespace="j_remote_thr" + TargetFrameworkVersion="196613" + > + <Platforms> + <Platform + Name="Win32" + /> + </Platforms> + <ToolFiles> + </ToolFiles> + <Configurations> + <Configuration + Name="Debug|Win32" + OutputDirectory="$(SolutionDir)$(ConfigurationName)" + IntermediateDirectory="$(ConfigurationName)" + ConfigurationType="10" + CharacterSet="2" + > + <Tool + Name="VCPreBuildEventTool" + Description="Compiling Java classes" + CommandLine="javac -classpath ..\..\java ..\..\perf\java\remote_thr.java" + /> + <Tool + Name="VCCustomBuildTool" + /> + <Tool + Name="VCMIDLTool" + /> + <Tool + Name="VCPostBuildEventTool" + /> + </Configuration> + <Configuration + Name="Release|Win32" + OutputDirectory="$(SolutionDir)$(ConfigurationName)" + IntermediateDirectory="$(ConfigurationName)" + ConfigurationType="10" + CharacterSet="2" + WholeProgramOptimization="1" + > + <Tool + Name="VCPreBuildEventTool" + Description="Compiling Java classes" + CommandLine="javac -classpath ..\..\java ..\..\perf\java\remote_thr.java" + /> + <Tool + Name="VCCustomBuildTool" + /> + <Tool + Name="VCMIDLTool" + /> + <Tool + Name="VCPostBuildEventTool" + /> + </Configuration> + </Configurations> + <References> + </References> + <Files> + <Filter + Name="Java Files" + > + <File + RelativePath="..\..\perf\java\remote_thr.java" + > + </File> + </Filter> + </Files> + <Globals> + </Globals> +</VisualStudioProject> diff --git a/msvc/msvc.sln b/msvc/msvc.sln index b9efc82..0cc5eb4 100644 --- a/msvc/msvc.sln +++ b/msvc/msvc.sln @@ -43,6 +43,31 @@ Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "cpp_remote_thr", "cpp_remot {641C5F36-32EE-4323-B740-992B651CF9D6} = {641C5F36-32EE-4323-B740-992B651CF9D6} EndProjectSection EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "java", "java\java.vcproj", "{66C40C34-7E05-4B03-8027-F40850C01364}" + ProjectSection(ProjectDependencies) = postProject + {641C5F36-32EE-4323-B740-992B651CF9D6} = {641C5F36-32EE-4323-B740-992B651CF9D6} + EndProjectSection +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "j_local_lat", "j_local_lat\j_local_lat.vcproj", "{F4D93BC6-9D70-4113-94A8-817A52B49290}" + ProjectSection(ProjectDependencies) = postProject + {66C40C34-7E05-4B03-8027-F40850C01364} = {66C40C34-7E05-4B03-8027-F40850C01364} + EndProjectSection +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "j_remote_lat", "j_remote_lat\j_remote_lat.vcproj", "{15C832D0-2E68-484A-9DCE-BC872FE1C7EF}" + ProjectSection(ProjectDependencies) = postProject + {66C40C34-7E05-4B03-8027-F40850C01364} = {66C40C34-7E05-4B03-8027-F40850C01364} + EndProjectSection +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "j_local_thr", "j_local_thr\j_local_thr.vcproj", "{95E6161D-418B-4ABF-85E2-F07797742156}" + ProjectSection(ProjectDependencies) = postProject + {66C40C34-7E05-4B03-8027-F40850C01364} = {66C40C34-7E05-4B03-8027-F40850C01364} + EndProjectSection +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "j_remote_thr", "j_remote_thr\j_remote_thr.vcproj", "{00A421BA-3B6B-45BD-B91F-DED953472622}" + ProjectSection(ProjectDependencies) = postProject + {66C40C34-7E05-4B03-8027-F40850C01364} = {66C40C34-7E05-4B03-8027-F40850C01364} + EndProjectSection +EndProject Global GlobalSection(SolutionConfigurationPlatforms) = preSolution Debug|Win32 = Debug|Win32 @@ -85,6 +110,26 @@ Global {EB051624-35C2-4B51-B5DD-8734372617A7}.Debug|Win32.Build.0 = Debug|Win32 {EB051624-35C2-4B51-B5DD-8734372617A7}.Release|Win32.ActiveCfg = Release|Win32 {EB051624-35C2-4B51-B5DD-8734372617A7}.Release|Win32.Build.0 = Release|Win32 + {66C40C34-7E05-4B03-8027-F40850C01364}.Debug|Win32.ActiveCfg = Debug|Win32 + {66C40C34-7E05-4B03-8027-F40850C01364}.Debug|Win32.Build.0 = Debug|Win32 + {66C40C34-7E05-4B03-8027-F40850C01364}.Release|Win32.ActiveCfg = Release|Win32 + {66C40C34-7E05-4B03-8027-F40850C01364}.Release|Win32.Build.0 = Release|Win32 + {F4D93BC6-9D70-4113-94A8-817A52B49290}.Debug|Win32.ActiveCfg = Debug|Win32 + {F4D93BC6-9D70-4113-94A8-817A52B49290}.Debug|Win32.Build.0 = Debug|Win32 + {F4D93BC6-9D70-4113-94A8-817A52B49290}.Release|Win32.ActiveCfg = Release|Win32 + {F4D93BC6-9D70-4113-94A8-817A52B49290}.Release|Win32.Build.0 = Release|Win32 + {15C832D0-2E68-484A-9DCE-BC872FE1C7EF}.Debug|Win32.ActiveCfg = Debug|Win32 + {15C832D0-2E68-484A-9DCE-BC872FE1C7EF}.Debug|Win32.Build.0 = Debug|Win32 + {15C832D0-2E68-484A-9DCE-BC872FE1C7EF}.Release|Win32.ActiveCfg = Release|Win32 + {15C832D0-2E68-484A-9DCE-BC872FE1C7EF}.Release|Win32.Build.0 = Release|Win32 + {95E6161D-418B-4ABF-85E2-F07797742156}.Debug|Win32.ActiveCfg = Debug|Win32 + {95E6161D-418B-4ABF-85E2-F07797742156}.Debug|Win32.Build.0 = Debug|Win32 + {95E6161D-418B-4ABF-85E2-F07797742156}.Release|Win32.ActiveCfg = Release|Win32 + {95E6161D-418B-4ABF-85E2-F07797742156}.Release|Win32.Build.0 = Release|Win32 + {00A421BA-3B6B-45BD-B91F-DED953472622}.Debug|Win32.ActiveCfg = Debug|Win32 + {00A421BA-3B6B-45BD-B91F-DED953472622}.Debug|Win32.Build.0 = Debug|Win32 + {00A421BA-3B6B-45BD-B91F-DED953472622}.Release|Win32.ActiveCfg = Release|Win32 + {00A421BA-3B6B-45BD-B91F-DED953472622}.Release|Win32.Build.0 = Release|Win32 EndGlobalSection GlobalSection(SolutionProperties) = preSolution HideSolutionNode = FALSE diff --git a/perf/c/local_thr.c b/perf/c/local_thr.c index 83ebee1..68d9ec6 100644 --- a/perf/c/local_thr.c +++ b/perf/c/local_thr.c @@ -73,7 +73,8 @@ int main (int argc, char *argv []) if (elapsed == 0) elapsed = 1; - throughput = (double) message_count / (double) elapsed * 1000000; + throughput = (unsigned long) + ((double) message_count / (double) elapsed * 1000000); megabits = (double) (throughput * message_size * 8) / 1000000; printf ("message size: %d [B]\n", (int) message_size); |