Casting Ruby from .NET Framework DLL
This article provides an introduction to cross-technology handling of casting mechanism. Casting is necessary in statically-typed languages like C, C++, Java, and C#, where the data type of a variable is known at compile time. In these languages, if you want to assign a value of one type to a variable of another type, you need to perform a cast.
For example, if you have an integer and you want to use it as a float, you would need to cast it to a float. This is done because different data types may be represented differently in memory, and casting ensures that the data is interpreted correctly.
In contrast, dynamically-typed languages like Python or JavaScript perform most of the casting automatically, and explicit casting is less common.
Javonet allows you to reference and use modules or packages written in (Java/Kotlin/Groovy/Clojure, C#/VB.NET, Ruby, Perl, Python, JavaScript/TypeScript) like they were created in your technology. If have not yet created your first project check Javonet overview and quick start guides for your technology.
With Javonet you can interact with objects and methods from .NET Framework DLL like they were available in Ruby but invocation must be performed through Javonet SDK API.
Custom Ruby showing .NET Framework DLL casting
With Javonet it is possible to reference any custom .NET Framework DLL and interact with its methods declared on types defined within that module almost the same as with any other Ruby library.
Snippet below represents the sample code from .NET Framework DLL which contains a few methods with the same name but different parameter type. Each of these methods can perform different logic so it is necessary to invoke intended method.
public static string CastSampleMethod(System.UInt32 value)
{
return "CastSampleMethod with System.UInt32 called";
}
public static string CastSampleMethod(System.Single value)
{
return "CastSampleMethod with System.Single called";
}
public static string CastSampleMethod(System.Double[] value)
{
return "CastSampleMethod with System.Double[] called";
}
It is possible to invoke each of these methods by casting the value from ruby to proper type specified in .NET Framework DLL.
# use activate only once in your app
Javonet.activate('your-license-key')
# create called runtime context
called_runtime = Javonet.in_memory.clr
# set up variables
library_path = "#{resources_directory}/TestClass.dll"
class_name = 'TestClass.TestClass'
# load custom library
called_runtime.load_library(library_path)
# get type from the runtime
called_runtime_type = called_runtime.get_type(class_name).execute
# get type for casting
target_type = called_runtime.get_type('System.UInt32')
# invoke type's static method
response = called_runtime_type
.invoke_static_method('CastSampleMethod', called_runtime.cast(target_type, 5.2))
.execute
# get value from response
result = response.get_value
# write result to console
puts result
In the snippet above, user intended to invoke CastSampleMethod with argument of specific type. Value from ruby has been casted to proper type and passed to CastSampleMethod. Second example shows the same steps but for different parameter type.
# use activate only once in your app
Javonet.activate('your-license-key')
# create called runtime context
called_runtime = Javonet.in_memory.clr
# set up variables
library_path = "#{resources_directory}/TestClass.dll"
class_name = 'TestClass.TestClass'
# load custom library
called_runtime.load_library(library_path)
# get type from the runtime
called_runtime_type = called_runtime.get_type(class_name).execute
# get type for casting
target_type = called_runtime.get_type('System.Single')
# invoke type's static method
response = called_runtime_type
.invoke_static_method('CastSampleMethod',
called_runtime.cast(target_type, 5))
.execute
# get value from response
result = response.get_value
# write result to console
puts result
In the snippet above, user intended to invoke CastSampleMethod with argument of specific type. Value from ruby has been casted to proper type and passed to CastSampleMethod.
The same operation can be performed remotely by just changing the new Runtime Context invocation from in memory to tcp that will create and interact with your .NET Framework DLL objects on any remote node, container or service that hosts Javonet Code Gateway. This way you can preserve the same logic in your application and instantly switch between monolithic and microservices architecture without the need to implement the integration layer based on web services or other remote invocation methods.
Read more about use cases and software architecture scenarios where Javonet runtime bridging technology can support your development process.
Was this article helpful?