Friday, July 04, 2008
A problem of layout?
Monday, June 23, 2008
Looking for the Wood not the Trees
Diversity
So why the excitement? Well I don't think its the bling, its the fact that there is a faster more versatile version of the platform that I use for so many things. You see it used to be that I used to have a range of strategies for editing and dealing with the heterogeneous data and programming languages that I use.
Can we say nedit, Komodo, IntelliJ IDEA, wing etc. Most of them were open source thought I must admit I used IntelliJ IDEA (and damn good it was too [eclipse still isn't as polished but is more versatile and open]). However, now I have one tool suite that allows me to deal with most of these at the same time within the same editing environment, so I have less things to remember less windows to find on my desktop and more support for what I am doing there's more...
Community & Open Source
I have found the eclipse community (and especially the emf mailing list http://www.eclipse.org/newsportal/thread.php?group=eclipse.tools.emf and especially Ed Merks) to be quite wonderful. Dealing with a newbie, who makes quite few mistakes and still being friendly helpful and authoritative all at the same time is a wonderful skill.
Having an open source platform has also been a vital asset so on the project I have been working on. For example how do I replace <%packageA.packageB.Class%> with the correct declaration in a custom jet template? Go look at the source code ;-) (though it would be even nicer if I could go and look at the javadoc!) (see the getBody function). So another one of my answers is its the whole, not the trees.
In conclusion Where else could I have work flow that goes python->model-> java all in the same environment, with such ease?
Sunday, March 23, 2008
How do ccpn data models get written
- you call python makeJavaApi.py from the command line which lives in ccpn/python/memops/scripts_v2
- This then uses XmlModelIo.readModel() to read the pure ccpn metamodel which returns the root meta-package as its result
- a thing called the ModelPortal gets constructed from the meta-model. (This seems to provide functions that access the meta-model in particular ways, examples include for example leafPackagesByImport - leaf packages sorted by import (imported before importing), dataTypesByInheritance - data types sorted by inheritance (supertype before subtype), dataObjTypesAlphabetic - data types sorted alphabetically by name etc...)
- JavaFileModelAdapt.processModel(modelPortal) processes the model-portal (and its owned meta-model) to adapt it to the idiosyncrasies of the requirements of the java language
- the class method JavaFileApiGen.writeApi gets called with the model-portal as its first parameter and information in the other parameters about where to store the model the version.
- finally inside JavaFileApiGen.writeApi we do some more setup create a JavaFileApiGen object and then call processModel() on it this then calls a general meta-model traverser which is in the class ModelTraverse.processModel
- now comes the interesting bit! This then causes a series of callbacks on the JavaFileApiGen class to be called. Using the following hack I think I can work out most of them...
grep def ../metamodel/ModelTraverse_py_2_1.py | tr '(' ' ' | awk '{print $2}' - this then visits the following list of apparently interesting methods
- processBranchPackage
- initLeafPackage
- processLeafPackage
- endLeafPackage
- processDataType
- processConstant
- processException
- initClass
- processClass
- endClass
- initDataObjType
- processDataObjType
- endDataObjType
- processAttribute
- processRole
- initOperation
- processOperation
- endOperation
- processParameter
Don't invite eclipse euorpa to the feast!
Why Europa isn't my quartermaster!
- If you have the wrong platform bundles installed ie x86 rather than x86_64 specifically
- org.eclipse.core.filesystem.linux.x86_64_1.0.100.v20070510.jar
- org.eclipse.equinox.launcher.gtk.linux.x86_64_1.0.2.R331_v20071019
- org.eclipse.platform.source.linux.gtk.x86_64_3.3.2.R33x_v20071022-_19UEksF-G8Yc6bUv3Dz
- org.eclipse.rcp.source.linux.gtk.x86_64_3.3.2.R33x_r20071022-8y8eE9CEV3FspP8HJrY1M2dS
- org.eclipse.swt.gtk.linux.x86_64_3.3.2.v3347.jar
the error message you get on startup is very obtuse
exit code code=13 is about as friendly as my favourite error message 'an unknown error occurred at an unknown location' - I can't see where it says i have the wrong platform modules here... isn't this something the launcher should check for?
I tried to swap the x86 bundles for the X86_64 versions I had lying around and then got this...
now if you understand what you have just done this is OK. However, it's still not the most useful message! What should a launchers companion library be called (Yhe Charlotte Bartlett.dll)
So how did you get me in this mess Stanley?
Now the way I got into this mess wasn't so obvious either....
I decided I wanted to play with emf and use the Soyatec eUML2 free editor. This all seems well and fine so I did what they asked and added the Soyatec website to my update site list and tried to install the eUML2 component. Thats when the hell started as I tried to get the right set of dependencies for the soyatec product to work with the other plugins on the Europa Discovery Site and failed over and over on dependencies on gmf and ocl so for example I would get
eUML2 (*.*.*.*) requires feature ***.***.gmf (x.x..xxxx) or compatible.
where x.x..xxxx was a lower version number than the one I already hadinstalled....
More heartache
So having got into dependany hell where did I go next. I remembered that Yoxos/Inoopract has this damn neat Yoxos on demand service and stuff me it does what it says on the jar:
- it sorted my dependencies like a treat
- it made me my own custom eclipse which I can go back to
- it was free
- Yoxos has its own provisioning which is available inside eclipse and works again like a dream. It resolves dependencies and just making it all work (in actual fact this plug-in appears to be very much related to the online experience which appears to be a RAP version of the Yoxos provisioning plug-in)
Yep I am Linux_x86_64 whereas the button here is effectively Linux_86. I guess this is something Innoopract/Yoxos need to solve or at least they do need to flag that they don't support x86_64 linux.
Wrapup
So what can we conclude from this trip round the houses?
- getting the right versions of eclipse plug-ins can still be a hassle even with the update manager and the newest dependency management tools
- If you have a system which doesn't exactly match the rest of the world (though i might say come on x86_64 isn't that rare ;-) you can easily end up in trouble
- the best laid plans of mice and men fail especially when you plan to 'just quickly' install a piece of software (alway a bad move)
- I suceeded in the end by doing the off-line Soyatec installation which included all the required dependencies at the right version. Heres the picture to prove it:
- Why is the update manager in the help menu??? It always seemed strange to me; File maybe Window maybe but help no way!!
- Why doesn't the eclipse Updates window have a maximize button some of the package names are long enough....
- why don't I blog more often (no don't ask me to answer that one)