mirror of https://github.com/apache/openjpa.git
OPENJPA-401 making temporary classloader optional for MappingTool ant task
git-svn-id: https://svn.apache.org/repos/asf/openjpa/branches/1.0.x@618744 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
3b790c8bf3
commit
304117261f
|
@ -49,6 +49,7 @@ import org.apache.openjpa.util.MultiLoaderClassResolver;
|
|||
* <li><code>file</code></li>
|
||||
* <li><code>schemaFile</code></li>
|
||||
* <li><code>sqlFile</code></li>
|
||||
* <li><code>tmpClassLoader</code></li>
|
||||
* </ul> Of these arguments, only <code>action</code> is required.
|
||||
*/
|
||||
public class MappingToolTask
|
||||
|
@ -61,6 +62,7 @@ public class MappingToolTask
|
|||
protected String file = null;
|
||||
protected String schemaFile = null;
|
||||
protected String sqlFile = null;
|
||||
protected boolean tmpClassLoader = true;
|
||||
|
||||
/**
|
||||
* Set the enumerated MappingTool action type.
|
||||
|
@ -175,22 +177,28 @@ public class MappingToolTask
|
|||
throws Exception {
|
||||
if (MappingTool.ACTION_IMPORT.equals(flags.action))
|
||||
assertFiles(files);
|
||||
ClassLoader toolLoader = (ClassLoader) AccessController
|
||||
.doPrivileged(J2DoPrivHelper
|
||||
.getClassLoaderAction(MappingTool.class));
|
||||
ClassLoader loader = toolLoader;
|
||||
MultiLoaderClassResolver resolver = new MultiLoaderClassResolver();
|
||||
|
||||
if (tmpClassLoader) {
|
||||
loader = (ClassLoader) AccessController.doPrivileged(J2DoPrivHelper
|
||||
|
||||
.newTemporaryClassLoaderAction(getClassLoader()));
|
||||
resolver.addClassLoader(loader);
|
||||
}
|
||||
resolver.addClassLoader(toolLoader);
|
||||
|
||||
ClassLoader loader =
|
||||
(ClassLoader) AccessController.doPrivileged(J2DoPrivHelper
|
||||
.newTemporaryClassLoaderAction(getClassLoader()));
|
||||
|
||||
if (flags.meta && MappingTool.ACTION_ADD.equals(flags.action))
|
||||
flags.metaDataFile = Files.getFile(file, loader);
|
||||
else
|
||||
flags.mappingWriter = Files.getWriter(file, loader);
|
||||
|
||||
flags.schemaWriter = Files.getWriter(schemaFile, loader);
|
||||
flags.sqlWriter = Files.getWriter(sqlFile, loader);
|
||||
|
||||
MultiLoaderClassResolver resolver = new MultiLoaderClassResolver();
|
||||
resolver.addClassLoader((ClassLoader) AccessController.doPrivileged(
|
||||
J2DoPrivHelper.getClassLoaderAction(MappingTool.class)));
|
||||
resolver.addClassLoader(loader);
|
||||
JDBCConfiguration conf = (JDBCConfiguration) getConfiguration();
|
||||
conf.setClassResolver(resolver);
|
||||
|
||||
|
@ -218,5 +226,18 @@ public class MappingToolTask
|
|||
return actions;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* <P>
|
||||
* Set whether a temporary ClassLoader should be used by the MappingTool.
|
||||
* The default value is true
|
||||
* </P>
|
||||
*
|
||||
* @param tmpClassLoader
|
||||
* Whether the temporary ClassLoader should be used.
|
||||
*/
|
||||
public void setTmpClassLoader(boolean tmpClassLoader) {
|
||||
this.tmpClassLoader = tmpClassLoader;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue