"Additional operators XML in Linux does not work"
jingram
New Altair Community Member
I believe that you cannot load additional operators XML files in linux: the following code works in windows:
Thanks,
Jon
String myOperatorsPath = MyInit.class.getResource("/com/mycompany/rapidminer/MyOperators.xml").getPath();But it does not work in Linux because it appears that the operators path is split by RapidMiner's OperaterService according the the Linux file separator ":" and as such the file path above results in two files ("file" and "/home/user/my.jar!/com/mycompany/rapidminer/MyOperators.xml") which are clearly not files
logger.info("Attempting to load additional RapidMiner Operators at path {}.", myOperatorsPath); // This will be something like "file:/home/user/my.jar!/com/mycompany/rapidminer/MyOperators.xml"
OperatorService.setAdditionalOperatorDescriptors(myOperatorsPath);
logger.info("Initialising RapidMiner OperatorService.");
// Note: only need to initialise RapidMiner Operations for this app
OperatorService.init();
I wonder if you could confirm this is a bug and either way provide a solution for loading additional operators from XML file located WITHIN a jar file. Just a reminder that the code does work on Windows, but not linux.
OperatorService.init:
String[] additionalOperatorFileNames = additionalOperators.split(File.pathSeparator); // this is ":" on Linux, and ";" on Windows.
for (int i = 0; i < additionalOperatorFileNames.length; i++) {
...
}
Thanks,
Jon
Tagged:
0
Answers
-
Hi,
I can confirm that your code will not work. However, it is a miracle that it works on Windows. The method signature OperatorService.setAdditionalOperatorDescriptors() asks for file names, not URLs, so passing "file:/home/user/my.jar!/com/mycompany/rapidminer/MyOperators.xml" would not work either. Anyway, why do you assume getResource(...).getPath() returns anything that is usable without the rest of the URL? Maybe in your Windows version the class files were not in a Jar but in a file system, so the getPath() actually returned valid file names and it worked by chance.
I agree that there is no escaping in the mathod you are calling, but adding the escaping would not help either due to the reasons mentioned above. Why don't you just make it an extension, that's much cleaner anyway. Actually I don't remember why the OperatorService.setAdditionalOperatorDescriptors() exists anyway :-)
Best,
Simon0 -
You're probably right - they are in the file system within my packages, so perhaps through Eclipse they were loaded as files, not from the Jar.
I'm sure an extension would be cleaner. However, the "additional operators" feature seems very quick and easy. The only steps need are:- Write my custom operator (can be in my package as long as it extends Operator).
- Create my Operators.xml and OperatorsDescription.xml - I actually believe the operator description requirement should be relaxed for quick development and plugin of operators. In this case, I only need to do step 1.
- Tell RapidMiner where to find my xml files.
Thanks for the response, Jon.
0 -
Hi,
ok, so the only thing you need to do is to use a file rather than a URL.
In your case, you seem to have a JAR already, so making it an extension, is basically step 3: Tell RapidMiner where to find your xml files. That goes into the manifest.
Best,
Simon0