Choosing Between MEL and CTL2 for DataMapper Scripting
DataMapper will continue to be fully supported in all current and future versions of Mule ESB 3.x, however it will be removed in Mule 4.0 in favour of the Transform Message component (based on DataWeave code). We recommend that if you wish to take advantage of the new capabilities of DataWeave or if you start new projects, upgrade now. A migration tool is now included in Studio, which assists in converting a DataMapper map to DataWeave. Right click on a DataMapper, select Migrate to DataWeave, and follow the instructions. If you don’t see DataMapper on your palette, you can enable it by going to Preferences → Anypoint Studio → Palette Profiles and ticking the checkbox Show deprecated Mule Components and Attributes. |
The transformation code for Anypoint DataMapper element mappings can be generated in one of two languages: Mule Expression Language (MEL) or CTL2 (Clover Transformation Language).
As of Mule 3.4, MEL is the default language. MEL offers a number of technical advantages over CTL2:
-
MEL can call out to any Java library. For example, you have the usual Java string and mathematical functions available, as well as any Java library you include in your project.
-
MEL is used throughout the rest of Mule as the primary expression language, so using it in DataMapper makes for an experience more consistent with the rest of Mule ESB.
-
MEL is being actively developed with new capabilities to continue to expose Mule features.
Mule recommends that you use MEL rather than CTL2 for future DataMapper development.
CTL2 was licensed from a third party for use in past versions of DataMapper, and is still fully supported for reasons of backward compatibility, but it offers no functional advantages over MEL. Note, when using MEL in DataMapper, the Mule message object is not available for use.
The images below illustrate DataMapper’s Script view displaying the same mapping, in CTL2 (below, at top) and MEL (below, at bottom.
Setting the DataMapper Scripting Language Preference
By default, Studio uses MEL as DataMapper’s scripting engine. However, you can change this setting if you wish to use CTL2 as the default.
-
In Studio, navigate to Preferences > Anypoint Studio > DataMapper.
-
Use the drop-down for the Default Script Type field to select
CTL
. -
Click OK to save your changes.
See Also
-
For complete information on MEL, see Mule Expression Language.
-
For complete information on CTL syntax and capabilities, including a language and functions reference, download the Mule Datamapper CTL2 Reference