Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/jdk17u
Path: blob/master/src/java.base/unix/classes/jdk/internal/loader/ClassLoaderHelper.java
67794 views
1
/*
2
* Copyright (c) 2012, 2021, Oracle and/or its affiliates. All rights reserved.
3
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4
*
5
* This code is free software; you can redistribute it and/or modify it
6
* under the terms of the GNU General Public License version 2 only, as
7
* published by the Free Software Foundation. Oracle designates this
8
* particular file as subject to the "Classpath" exception as provided
9
* by Oracle in the LICENSE file that accompanied this code.
10
*
11
* This code is distributed in the hope that it will be useful, but WITHOUT
12
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14
* version 2 for more details (a copy is included in the LICENSE file that
15
* accompanied this code).
16
*
17
* You should have received a copy of the GNU General Public License version
18
* 2 along with this work; if not, write to the Free Software Foundation,
19
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
20
*
21
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
22
* or visit www.oracle.com if you need additional information or have any
23
* questions.
24
*/
25
26
package jdk.internal.loader;
27
28
import java.io.File;
29
import java.util.ArrayList;
30
31
class ClassLoaderHelper {
32
33
private ClassLoaderHelper() {}
34
35
/**
36
* Returns true if loading a native library only if
37
* it's present on the file system.
38
*/
39
static boolean loadLibraryOnlyIfPresent() {
40
return true;
41
}
42
43
/**
44
* Returns an alternate path name for the given file
45
* such that if the original pathname did not exist, then the
46
* file may be located at the alternate location.
47
* For most platforms, this behavior is not supported and returns null.
48
*/
49
static File mapAlternativeName(File lib) {
50
return null;
51
}
52
53
/**
54
* Parse a PATH env variable.
55
*
56
* Empty elements will be replaced by dot.
57
*/
58
static String[] parsePath(String ldPath) {
59
char ps = File.pathSeparatorChar;
60
ArrayList<String> paths = new ArrayList<>();
61
int pathStart = 0;
62
int pathEnd;
63
while ((pathEnd = ldPath.indexOf(ps, pathStart)) >= 0) {
64
paths.add((pathStart < pathEnd) ?
65
ldPath.substring(pathStart, pathEnd) : ".");
66
pathStart = pathEnd + 1;
67
}
68
int ldLen = ldPath.length();
69
paths.add((pathStart < ldLen) ?
70
ldPath.substring(pathStart, ldLen) : ".");
71
return paths.toArray(new String[paths.size()]);
72
}
73
}
74
75