Extension methods
In Visual Objects, you could define methods to classes where you had no sources and that are defined in other libraries.
In the .NET Framework this is not possible, but since this is a very powerful language feature, you can use the Extension methods
to attach methods to another class where you have no sources. This works even with system classes and base datatypes (Everything is an object).
Please look at this code:
local cString as string local cResult as string cString := "Hello world!" cResult := cString:Left( 5 )
But the System.String
class has no Left()
method!
The solution is this one:
static class StringExtensions static method Left( self cString as string, nLen as int ) as string local cReturn as string if nLen >= cString:Length cReturn := cString else cReturn := cString:Substring( 0, nLen ) endif return cReturn
The secret stays in the first parameter: self cString as string
If you have defined this extension method in an assembly with a different namespace, this namespace of course must be included by a using
statement.
And if you look at the sample code, you will see that the length of the string is checked before the SubString()
method is called to be sure no exception is created if the string is shorter than indicated in the parameter. For more details see the Exceptions topic.