/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
// common infrastructure for SunPKCS11 tests
public abstract class PKCS11Test {
// directory of the test source
private final static String REL_CLOSED = "../../../../closed/sun/security/pkcs11".replace('/', SEP);
// directory corresponding to BASE in the /closed hierarchy
static {
// hack
if (k < 0) k = 0;
}
}
main(p);
System.out.println("Completed test with provider " + p.getName() + " (" + (stop - start) + " ms).");
}
try {
} finally {
// Do not restore providers if nothing changed. This is especailly
boolean found = false;
if (oldProviders[i] != newProviders[i]) {
found = true;
break;
}
}
if (!found) return;
}
for (Provider p: newProviders) {
}
for (Provider p: oldProviders) {
Security.addProvider(p);
}
}
}
return;
}
}
// run test for default configured PKCS11 providers (if any)
return;
}
}
}
}
if (PKCS11_BASE != null) {
return PKCS11_BASE;
}
while (true) {
break;
}
throw new Exception("Test root directory not found");
}
}
return PKCS11_BASE;
}
osName = "Windows";
NSPR_PREFIX = "lib";
}
return null;
// throw new Exception("Unsupported OS " + osid);
}
return null;
}
return libdir;
}
try {
} catch (UnsatisfiedLinkError e) {
return;
}
}
}
// load NSS softoken dependencies in advance to avoid resolver issues
return true;
}
return;
}
return;
}
// NSS always wants forward slashes for the config path
}
static {
}
if (b == null) {
return "(null)";
}
for (int i = 0; i < b.length; i++) {
int k = b[i] & 0xff;
if (i != 0) {
}
}
}
if (s.equals("(null)")) {
return null;
}
try {
int n = s.length();
StringReader r = new StringReader(s);
while (true) {
int b1 = nextNibble(r);
if (b1 < 0) {
break;
}
int b2 = nextNibble(r);
if (b2 < 0) {
throw new RuntimeException("Invalid string " + s);
}
}
return out.toByteArray();
} catch (IOException e) {
throw new RuntimeException(e);
}
}
while (true) {
if (ch == -1) {
return -1;
return ch - '0';
}
}
}
<T> T[] concat(T[] a, T[] b) {
return a;
}
T[] r = (T[])java.lang.reflect.Array.newInstance(a.getClass().getComponentType(), a.length + b.length);
return r;
}
}