xref: /aoo4110/main/jvmaccess/source/classpath.cxx (revision b1cdbd2c)
1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski #include "sal/config.h"
25*b1cdbd2cSJim Jagielski 
26*b1cdbd2cSJim Jagielski #include "jvmaccess/classpath.hxx"
27*b1cdbd2cSJim Jagielski 
28*b1cdbd2cSJim Jagielski #include <vector>
29*b1cdbd2cSJim Jagielski 
30*b1cdbd2cSJim Jagielski #include "com/sun/star/lang/IllegalArgumentException.hpp"
31*b1cdbd2cSJim Jagielski #include "com/sun/star/uno/Any.hxx"
32*b1cdbd2cSJim Jagielski #include "com/sun/star/uno/Reference.hxx"
33*b1cdbd2cSJim Jagielski #include "com/sun/star/uno/RuntimeException.hpp"
34*b1cdbd2cSJim Jagielski #include "com/sun/star/uno/XComponentContext.hpp"
35*b1cdbd2cSJim Jagielski #include "com/sun/star/uno/XInterface.hpp"
36*b1cdbd2cSJim Jagielski #include "com/sun/star/uri/UriReferenceFactory.hpp"
37*b1cdbd2cSJim Jagielski #include "com/sun/star/uri/XVndSunStarExpandUrlReference.hpp"
38*b1cdbd2cSJim Jagielski #include "com/sun/star/util/XMacroExpander.hpp"
39*b1cdbd2cSJim Jagielski #include "osl/diagnose.h"
40*b1cdbd2cSJim Jagielski #include "rtl/ustring.hxx"
41*b1cdbd2cSJim Jagielski #include "sal/types.h"
42*b1cdbd2cSJim Jagielski 
43*b1cdbd2cSJim Jagielski #if defined SOLAR_JAVA
44*b1cdbd2cSJim Jagielski #include "jni.h"
45*b1cdbd2cSJim Jagielski #endif
46*b1cdbd2cSJim Jagielski 
47*b1cdbd2cSJim Jagielski namespace {
48*b1cdbd2cSJim Jagielski 
49*b1cdbd2cSJim Jagielski namespace css = ::com::sun::star;
50*b1cdbd2cSJim Jagielski 
51*b1cdbd2cSJim Jagielski }
52*b1cdbd2cSJim Jagielski 
doTranslateToUrls(css::uno::Reference<css::uno::XComponentContext> const & context,void * environment,::rtl::OUString const & classPath)53*b1cdbd2cSJim Jagielski void * ::jvmaccess::ClassPath::doTranslateToUrls(
54*b1cdbd2cSJim Jagielski     css::uno::Reference< css::uno::XComponentContext > const & context,
55*b1cdbd2cSJim Jagielski     void * environment, ::rtl::OUString const & classPath)
56*b1cdbd2cSJim Jagielski {
57*b1cdbd2cSJim Jagielski     OSL_ASSERT(context.is() && environment != 0);
58*b1cdbd2cSJim Jagielski #if defined SOLAR_JAVA
59*b1cdbd2cSJim Jagielski     ::JNIEnv * const env = static_cast< ::JNIEnv * >(environment);
60*b1cdbd2cSJim Jagielski     jclass classUrl(env->FindClass("java/net/URL"));
61*b1cdbd2cSJim Jagielski     if (classUrl == 0) {
62*b1cdbd2cSJim Jagielski         return 0;
63*b1cdbd2cSJim Jagielski     }
64*b1cdbd2cSJim Jagielski     jmethodID ctorUrl(
65*b1cdbd2cSJim Jagielski         env->GetMethodID(classUrl, "<init>", "(Ljava/lang/String;)V"));
66*b1cdbd2cSJim Jagielski     if (ctorUrl == 0) {
67*b1cdbd2cSJim Jagielski         return 0;
68*b1cdbd2cSJim Jagielski     }
69*b1cdbd2cSJim Jagielski     ::std::vector< jobject > urls;
70*b1cdbd2cSJim Jagielski     for (::sal_Int32 i = 0; i != -1;) {
71*b1cdbd2cSJim Jagielski         ::rtl::OUString url(classPath.getToken(0, ' ', i));
72*b1cdbd2cSJim Jagielski         if (url.getLength() != 0) {
73*b1cdbd2cSJim Jagielski             css::uno::Reference< css::uri::XVndSunStarExpandUrlReference >
74*b1cdbd2cSJim Jagielski                 expUrl(
75*b1cdbd2cSJim Jagielski                     css::uri::UriReferenceFactory::create(context)->parse(url),
76*b1cdbd2cSJim Jagielski                     css::uno::UNO_QUERY);
77*b1cdbd2cSJim Jagielski             if (expUrl.is()) {
78*b1cdbd2cSJim Jagielski                 css::uno::Reference< css::util::XMacroExpander > expander(
79*b1cdbd2cSJim Jagielski                     context->getValueByName(
80*b1cdbd2cSJim Jagielski                         ::rtl::OUString(
81*b1cdbd2cSJim Jagielski                             RTL_CONSTASCII_USTRINGPARAM(
82*b1cdbd2cSJim Jagielski                                 "/singletons/"
83*b1cdbd2cSJim Jagielski                                 "com.sun.star.util.theMacroExpander"))),
84*b1cdbd2cSJim Jagielski                     css::uno::UNO_QUERY_THROW);
85*b1cdbd2cSJim Jagielski                 try {
86*b1cdbd2cSJim Jagielski                     url = expUrl->expand(expander);
87*b1cdbd2cSJim Jagielski                 } catch (css::lang::IllegalArgumentException & e) {
88*b1cdbd2cSJim Jagielski                     throw css::uno::RuntimeException(
89*b1cdbd2cSJim Jagielski                         (::rtl::OUString(
90*b1cdbd2cSJim Jagielski                             RTL_CONSTASCII_USTRINGPARAM(
91*b1cdbd2cSJim Jagielski                                 "com.sun.star.lang.IllegalArgumentException: "))
92*b1cdbd2cSJim Jagielski                          + e.Message),
93*b1cdbd2cSJim Jagielski                         css::uno::Reference< css::uno::XInterface >());
94*b1cdbd2cSJim Jagielski                 }
95*b1cdbd2cSJim Jagielski             }
96*b1cdbd2cSJim Jagielski             jvalue arg;
97*b1cdbd2cSJim Jagielski             arg.l = env->NewString(
98*b1cdbd2cSJim Jagielski                 static_cast< jchar const * >(url.getStr()),
99*b1cdbd2cSJim Jagielski                 static_cast< jsize >(url.getLength()));
100*b1cdbd2cSJim Jagielski             if (arg.l == 0) {
101*b1cdbd2cSJim Jagielski                 return 0;
102*b1cdbd2cSJim Jagielski             }
103*b1cdbd2cSJim Jagielski             jobject o(env->NewObjectA(classUrl, ctorUrl, &arg));
104*b1cdbd2cSJim Jagielski             if (o == 0) {
105*b1cdbd2cSJim Jagielski                 return 0;
106*b1cdbd2cSJim Jagielski             }
107*b1cdbd2cSJim Jagielski             urls.push_back(o);
108*b1cdbd2cSJim Jagielski         }
109*b1cdbd2cSJim Jagielski     }
110*b1cdbd2cSJim Jagielski     jobjectArray result = env->NewObjectArray(
111*b1cdbd2cSJim Jagielski         static_cast< jsize >(urls.size()), classUrl, 0);
112*b1cdbd2cSJim Jagielski         // static_cast is ok, as each element of urls occupied at least one
113*b1cdbd2cSJim Jagielski         // character of the ::rtl::OUString classPath
114*b1cdbd2cSJim Jagielski     if (result == 0) {
115*b1cdbd2cSJim Jagielski         return 0;
116*b1cdbd2cSJim Jagielski     }
117*b1cdbd2cSJim Jagielski     jsize idx = 0;
118*b1cdbd2cSJim Jagielski     for (std::vector< jobject >::iterator i(urls.begin()); i != urls.end(); ++i)
119*b1cdbd2cSJim Jagielski     {
120*b1cdbd2cSJim Jagielski         env->SetObjectArrayElement(result, idx++, *i);
121*b1cdbd2cSJim Jagielski     }
122*b1cdbd2cSJim Jagielski     return result;
123*b1cdbd2cSJim Jagielski #else
124*b1cdbd2cSJim Jagielski     return 0;
125*b1cdbd2cSJim Jagielski #endif
126*b1cdbd2cSJim Jagielski }
127*b1cdbd2cSJim Jagielski 
doLoadClass(css::uno::Reference<css::uno::XComponentContext> const & context,void * environment,::rtl::OUString const & classPath,::rtl::OUString const & name)128*b1cdbd2cSJim Jagielski void * ::jvmaccess::ClassPath::doLoadClass(
129*b1cdbd2cSJim Jagielski     css::uno::Reference< css::uno::XComponentContext > const & context,
130*b1cdbd2cSJim Jagielski     void * environment, ::rtl::OUString const & classPath,
131*b1cdbd2cSJim Jagielski     ::rtl::OUString const & name)
132*b1cdbd2cSJim Jagielski {
133*b1cdbd2cSJim Jagielski     OSL_ASSERT(context.is() && environment != 0);
134*b1cdbd2cSJim Jagielski #if defined SOLAR_JAVA
135*b1cdbd2cSJim Jagielski     ::JNIEnv * const env = static_cast< ::JNIEnv * >(environment);
136*b1cdbd2cSJim Jagielski     jclass classLoader(env->FindClass("java/net/URLClassLoader"));
137*b1cdbd2cSJim Jagielski     if (classLoader == 0) {
138*b1cdbd2cSJim Jagielski         return 0;
139*b1cdbd2cSJim Jagielski     }
140*b1cdbd2cSJim Jagielski     jmethodID ctorLoader(
141*b1cdbd2cSJim Jagielski         env->GetMethodID(classLoader, "<init>", "([Ljava/net/URL;)V"));
142*b1cdbd2cSJim Jagielski     if (ctorLoader == 0) {
143*b1cdbd2cSJim Jagielski         return 0;
144*b1cdbd2cSJim Jagielski     }
145*b1cdbd2cSJim Jagielski     jvalue arg;
146*b1cdbd2cSJim Jagielski     arg.l = translateToUrls(context, env, classPath);
147*b1cdbd2cSJim Jagielski     if (arg.l == 0) {
148*b1cdbd2cSJim Jagielski         return 0;
149*b1cdbd2cSJim Jagielski     }
150*b1cdbd2cSJim Jagielski     jobject cl = env->NewObjectA(classLoader, ctorLoader, &arg);
151*b1cdbd2cSJim Jagielski     if (cl == 0) {
152*b1cdbd2cSJim Jagielski         return 0;
153*b1cdbd2cSJim Jagielski     }
154*b1cdbd2cSJim Jagielski     jmethodID methLoadClass(
155*b1cdbd2cSJim Jagielski         env->GetMethodID(
156*b1cdbd2cSJim Jagielski             classLoader, "loadClass", "(Ljava/lang/String;)Ljava/lang/Class;"));
157*b1cdbd2cSJim Jagielski     if (methLoadClass == 0) {
158*b1cdbd2cSJim Jagielski         return 0;
159*b1cdbd2cSJim Jagielski     }
160*b1cdbd2cSJim Jagielski     arg.l = env->NewString(
161*b1cdbd2cSJim Jagielski         static_cast< jchar const * >(name.getStr()),
162*b1cdbd2cSJim Jagielski         static_cast< jsize >(name.getLength()));
163*b1cdbd2cSJim Jagielski     if (arg.l == 0) {
164*b1cdbd2cSJim Jagielski         return 0;
165*b1cdbd2cSJim Jagielski     }
166*b1cdbd2cSJim Jagielski     return env->CallObjectMethodA(cl, methLoadClass, &arg);
167*b1cdbd2cSJim Jagielski #else
168*b1cdbd2cSJim Jagielski     return 0;
169*b1cdbd2cSJim Jagielski #endif
170*b1cdbd2cSJim Jagielski }
171