Home » Newcomers » Newcomers » User Libraries(Exporting does not bring in User Library - Worked on Jan 1, not now)
User Libraries [message #1864620] |
Fri, 29 March 2024 01:12 |
Linus 12 Messages: 1 Registered: March 2024 |
Junior Member |
|
|
I have been working with the Eclipse IDE for a number of years, mostly basic stuff, seemingly able to get things to work just fine. However I recently had to update a project that I hadn't modified in 3 months and now something has changed and I can't figure out where the problem is occurring to fix it.
My apologies if the nomenclature I am using is incorrect, but I'm hoping you can help me figure out what is going on.
Environment:
Eclipse
Eclipse Java EE IDE for Web Developers.
Version: Neon.3 Release (4.6.3)
Build id: 20170314-1500
Windows
Windows 10 Pro
Version 22H2
OS Build 19045.4170
Project Information
Working on an Java Workspace, with 6 "Java Projects" that 'compile' into a single 'program'
Some, but not all, of the "Java Projects" use specific and unique Jar files for classes provided either via GitHub or other repositories. In each of the projects that use them, I have added them into the project via the "Referenced Library" via the Build Path -> Configure Build Path... -> Java Build Path dialog box.
Again, some, but not all, of the "Java Projects" use a set of Jar files with "common classes" that I have written. Mostly utilities to perform some action or hold data that is common across all of my projects. (My toolbox, if you will.)
Initially I also added these to each project's "Referenced Library". The problem I ran into was that if I modified the 'common classes' I then had to update every project's "Referenced Library" with the new Jar File, Source file, and Java doc file.
The solution to that was to place these jar files with the 'common classes' into a User Library. I then added the User Library to those projects that that used these 'common classes'. When there was a change to one of those, simply updating the User Library changed the jar for ALL of the java projects that referenced that User Library. Great Stuff!!!
Now fast forward 3 months....
Due to a pending computer upgrade, I moved all of my source files from my local machine to server I set up. I access the files through a drive letter on my windows machine.
Eclipse had a problem when I tried to "modify" the "Workspace" to point to the new locations, so I started fresh and created new workspaces and pulled in the packages one by one and set up the libraries connections, etc. I did NOT reinstall Eclipse or move it.
Making changes to the workspace projects works well, testing via the IDE also works.....
Problem with Exporting
All of my programs are run via command files on my machines, This allows me to schedule them at different times and frequencies, as will as run them mostly unattended. I do this by exporting the workspace to a Runnable JAR File, and then invoking them via the command files.
I use the "Export,,, -> Runnable JAR File... -> Runnable JAR File Export" dialog box. I specify the Launch Configuration, the Destination File, and "Extract required libraries into the generated JAR" option. and press Finish.
The JAR file is created with no errors and no warnings.
However the JAR file is actually smaller than than the ones created before moving the source files, despite the fact that I have added additional packages inside a number of the Java Projects.
Running the programs via the command line results in the error:
Exception in thread "main" java.lang.NoClassDefFoundError: jutils/Errs
(Yes, I do have a "main" and everything worked fine before.)
Sure enough, the jutils/Errs is one of those classes in the JAR files contained in the "User Library"!
No amount of removing, re-adding, deleting the and recreating the "User Library", cleaning, closing, reopening, the projects, seems to solve this problem. I can open the resulting JAR files (using WINRAR) and can clearly see the classes in the "old" JAR file, but they are missing from the new JAR files.
The only solution I have at this point is to add all the "Common Classes" back into the "Referenced Library" of each of the projects. This of course causes a maintenance issue when one of those are changed (which was originally solved by going to the User Library!)
This does work, but the exported JAR file is now almost 1.5 times as big as before!
Question
I know I must be missing something, a pointer to the files or file link. But I just can't see the forest for the trees right now. Could I get some insight from someone on this? i hoping the fix is something stupid I just over looked. ( I have no problem saying "Duhhhh" after finding a simple solution while looking for a complex one!)
Thanks
|
|
|
Re: User Libraries [message #1866345 is a reply to message #1864620] |
Tue, 28 May 2024 03:49 |
sob adiet Messages: 3 Registered: May 2024 |
Junior Member |
|
|
Eclipse Ecores is a project I'm currently working on in Eclipse Neon 2. I'll be providing the ecores and the project will produce the adapter, reader, writer, source model, and target model. At the moment, I have to manually update the classpath every time I want to use Eclipse. I do this by going into the plugin tools, selecting update classpath, and then clicking okk once I've selected all the folders or projects in my workspace. However, is it possible to eliminate this procedure? My ideal scenario would be for the system to immediately update the classpath whenever there is a change to the workspace, as soon as my projects are added to it.
Can it be done?
phrazle
[Updated on: Tue, 28 May 2024 03:50] Report message to a moderator
|
|
|
Re: User Libraries [message #1866354 is a reply to message #1866345] |
Tue, 28 May 2024 06:07 |
Ed Merks Messages: 33209 Registered: July 2009 |
Senior Member |
|
|
Via the view menu (Package or Project Explore) you can using Filters... to unfilter .* resources. You'll see there is a .classpath file. This is what's being updated and it generally looks like this:<classpath>
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-11"/>
<classpathentry kind="con" path="org.eclipse.pde.core.requiredPlugins"/>
<classpathentry kind="src" path="src"/>
<classpathentry kind="output" path="bin"/>
</classpath>
There's not much here that ever needs to change, except JavaSE-11 value, but it won't change to some other value all by itself, so I'm sure why you would need to keep updating the classpath. I have many, many projects with Ecore models and I never need to do this.
Ed Merks
Professional Support: https://www.macromodeling.com/
|
|
|
Goto Forum:
Current Time: Sun Sep 08 00:12:55 GMT 2024
Powered by FUDForum. Page generated in 0.09776 seconds
|