Installation uses Matlab Packages which are not available during the installation process
qlahcim opened this issue · 7 comments
When I try to install MEP on Linux Mint 18.3 with Matlab R2018b, I always get the following error message:
Long stack trace
kva@lr17:~/Documents/MATLAB$ java -jar MEP_1.34.jar
Exception in thread "AWT-EventQueue-0" java.lang.NoClassDefFoundError: com/mathworks/services/settings/SettingNotFoundException
at at.mep.installer.JPanelInstall.copyFiles(JPanelInstall.java:378)
at at.mep.installer.JPanelInstall.doInstall(JPanelInstall.java:295)
at at.mep.installer.JPanelInstall.access$700(JPanelInstall.java:14)
at at.mep.installer.JPanelInstall$4.actionPerformed(JPanelInstall.java:238)
at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:2022)
at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2348)
at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:402)
at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:259)
at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:252)
at java.awt.Component.processMouseEvent(Component.java:6539)
at javax.swing.JComponent.processMouseEvent(JComponent.java:3324)
at java.awt.Component.processEvent(Component.java:6304)
at java.awt.Container.processEvent(Container.java:2239)
at java.awt.Component.dispatchEventImpl(Component.java:4889)
at java.awt.Container.dispatchEventImpl(Container.java:2297)
at java.awt.Component.dispatchEvent(Component.java:4711)
at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4904)
at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4535)
at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4476)
at java.awt.Container.dispatchEventImpl(Container.java:2283)
at java.awt.Window.dispatchEventImpl(Window.java:2746)
at java.awt.Component.dispatchEvent(Component.java:4711)
at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:760)
at java.awt.EventQueue.access$500(EventQueue.java:97)
at java.awt.EventQueue$3.run(EventQueue.java:709)
at java.awt.EventQueue$3.run(EventQueue.java:703)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(ProtectionDomain.java:74)
at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(ProtectionDomain.java:84)
at java.awt.EventQueue$4.run(EventQueue.java:733)
at java.awt.EventQueue$4.run(EventQueue.java:731)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(ProtectionDomain.java:74)
at java.awt.EventQueue.dispatchEvent(EventQueue.java:730)
at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:205)
at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:116)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:105)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:101)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:93)
at java.awt.EventDispatchThread.run(EventDispatchThread.java:82)
Caused by: java.lang.ClassNotFoundException: com.mathworks.services.settings.SettingNotFoundException
at java.net.URLClassLoader.findClass(URLClassLoader.java:382)
at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:349)
at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
... 40 more
I would like to avoid manual installation, because I plan to install MEP on many desktop PCs with linux.
Any help???
could you try this version?
MEP_1.35.jar.zip
I could also add the possibility to define the 3 paths with command line arguments.
e.g.: java -jar mep... "jarpath" "javaclasspath" "installdir"
OK ... thanks for help. After command:
java -jar MEP_1.35.jar
was automatically created a directory MEP at ~/Documents/MATLAB with the following content:
kva@lr17:~/Documents/MATLAB/MEP$ tree -a
.
├── CustomProps.properties
├── DefaultProps.properties
├── matconsolectl-4.5.0.jar
├── MEP_1.35.jar
└── Replacements
├── MEPR_Rev.m
├── MEPR_SC.m
├── MEPR_THIS.m
└── Variables
├── MEPV_AUTHORLONG.m
├── MEPV_DATE.m
├── MEPV_REV.m
└── MEPV_THIS.m
2 directories, 11 files
After that I had javaclasspath.txt with the following content:
/home/kva/Documents/MATLAB/MEP/MEP_1.35.jar
/home/kva/Documents/MATLAB/MEP/matconsolectl-4.5.0.jar
and I was created two additional files:
startup.m with the following content:
at.mep.Start.start('/home/kva/Documents/MATLAB/MEP/CustomProps.properties', ...
'/home/kva/Documents/MATLAB/MEP/DefaultProps.properties');
import at.mep.util.*;
import at.mep.editor.*;
ctrl = true;
shift = true;
alt = true;
ks_MyKeyReleaseFunction = KeyStrokeUtil.getKeyStroke(java.awt.event.KeyEvent.VK_INSERT, ~ctrl, ~shift, alt, false);
EditorApp.addMatlabCallback('MyKeyReleaseFunction', ks_MyKeyReleaseFunction , 'MyKeyReleaseFunction');
and MyKeyReleaseFunction.m with the following content:
function out = MyKeyReleaseFunction(actionEvent)
if nargin == 0; out = []; return; end
% this is necessary, the first thing happen is trying find out whether
% the passed function is a valid matlab function or not
% assignin('base','actionEvent',actionEvent)
fprintf('ALT + INSERT\n')
out = 1;
according your suggestions on wiki. But after all that, when I start MATLAB I always get open editor, see attached screenshot.
Is that normal behavior? Is possible to suppress opening editor window with
MEP: Sorry!
text ???
Will be possible to create automatically the javaclasspath.txt file in a case when it does not exist at default MATLAB directory /home/kva/Documents/MATLAB and add some generic content to startup.m file at the same directory (+ in a case of no startup.m file)?
It would be really very useful, if the installer solve all installation steps fully interactively and automatically.
MEP needs at least one editor open. If none is open it will create one editor tab. It's annoying, yes.
I could do that, it's definitely something the installer should do. but i cannot validate that the folder of javaclasspath.txt and startup.m is a valid matlab folder.
I think the validation of startup.m file is possible to perform by check
>> which startup
and javaclasspath could be checked by output parsing of javaclasspath
command.
Moreover, other MEP-like files, the "MyKeyReleaseFunction.m" for example, should be located at MEP directory, too. And MEP installer should add this directory to the PATH automatically.
And, what do you think about any "uninstall" and/or "plugin on/off" switcher MATLAB function?
So finally, I think that your plugin is really very good (!!!), but I strongly propose to finalize MEP installer to be more comprehensive and "fully" automatic.
I cannot use matlab libraries and/or functions in the install environment, therefore i cannot use the which
method, the javaclasspath
method and change the PATH entry.
Plugin on/off: yes, this should possible... maybe.
Uninstall: is tricky. but should be possible too.
I cannot use matlab libraries and/or functions in the install environment, therefore i cannot use the
which
method, thejavaclasspath
method and change the PATH entry.
Yes of course, you are right! Installer is entirely based on java. But, what about two-step installation process, when 2nd step is realized in Matlab by proper "MEP_configure" script, which will be best place for MEP "on/off" switching, too. Or, what about fully MATLAB based install script ???
Please, understand my position, your plugin has very good functionality, but the installation process is really a tricky part for anybody, who is not familiar with MATLAB.
Plugin on/off: yes, this should possible... maybe.
Uninstall: is tricky. but should be possible too.
OK ... I will be happy for these modifications in future releases. But, anyway, thanks for your plugin, it is really very helpful.
FYI: you don't have to create MyKeyReleaseFunction
, this is just an example on how to create custom keybindings, and is not necessary to run MEP.