[jbosstools-dev] a problem of classpath too long
feng.qian
fqian at redhat.com
Fri Mar 6 04:14:44 EST 2009
Hi all,
Up to now, I resolved the problem. Write the mail is just for
introducing my method.
I have tested some methods:
1 call jboss ws runtime other class:
org.jboss.wsf.spi.tools.ant.WSProvideTask
This method can't fix this issue because the WSProvideTask class call
the command line too at last and can't avoid the issue.
2 call org.jboss.wsf.spi.tools.cmd.WSProvide directly.
Thi methos has two way to realize:
One is using classloader and the other is using eclipse launch
configuration(as Rob said)
These two ways both need to load some jars according to the
wsprovider.sh. I do not know if these sh are same from different
verion of jboss AS or WS. So I tested them and know they can
resolved the issue. But I do not use it.
3 use ProcessBuilder
ProcessBuilder builder = new ProcessBuilder(command);
builder.directory(new File(commandLocation));
Process proc = builder.start();
command is a list that contain my command segments
This method can't fix this issue.
4 create a temp.jar and add all of the jars into the temp.jar's menifest
file. Then use this jar instead of all of the jars to the class path
Now I use this method to resolve this issue.
5 maybe have another way from a runtime guy: change the .sh file and
add all of the jars into the command line classpath, then run
the command as: wsprovider.sh -w -k ............. thejavaclass
The wsprovider.sh call org.jboss.wsf.spi.tools.cmd.WSProvide. I have
study the codes of the class, it create a classloader to run and
the classloader will extend parent's classpath. So we can use the
method to resolve this issue.
But we need to get the wsprovider.sh and modify it, then run.
I do not test it.
At the end, I think jboss ws team should offer a class to handle this
issue because in command line, the issue occurs too.
Grid
> Hi all,
>
> There is a problem about classpath.
> Up to now, the jboss ws module of our tools use two commands --
> 'wsprovider.sh' and 'wsconsumer.bat' -- to generate codes
> in both scenes: bottow-up(from a java class) and top-down(from a wsdl
> file).
> When we call wsprovider.bat to generate codes, we may create a command
> to run in our eclipse console like this:
> wsprovider -c 'a.jar:b.jar:c.jar.............xxx.jar' -w -k
> ............. thejavaclass
> My codes run this command like this in my plugins:
> Runtime rt = Runtime.getRuntime();
> rt.exec(command.toString(), null, new File(commandLocation));
> On linux, this is ok. But on windows, a error occurs: the command is
> too long. This is caused by the classpath parameter is
> too long because we add very many jars to '-c'
> I think, in enterprise scenes, we will often meet this problem -- need
> to add many jars to classpath.
> So I want to ask if we have a way to set a container or a jars folder
> for these jars.
>
> Thanks
> Grid
>
>
> _______________________________________________
> jbosstools-dev mailing list
> jbosstools-dev at lists.jboss.org
> https://lists.jboss.org/mailman/listinfo/jbosstools-dev
More information about the jbosstools-dev
mailing list