use of meghanada.reflect.MemberDescriptor in project meghanada-server by mopemope.
the class DeclarationSearcher method searchMethodCall.
private static Optional<Declaration> searchMethodCall(final Source source, final Integer line, final Integer col, final String symbol) {
final EntryMessage entryMessage = log.traceEntry("line={} col={} symbol={}", line, col, symbol);
final Optional<MethodCall> methodCall = source.getMethodCall(line, col, true);
final Optional<Declaration> result = methodCall.map(mc -> {
final String methodName = mc.name;
final List<String> arguments = mc.getArguments();
final String declaringClass = mc.declaringClass;
if (declaringClass == null) {
return null;
}
final CachedASMReflector reflector = CachedASMReflector.getInstance();
final MemberDescriptor method = searchMethod(declaringClass, methodName, arguments).orElseGet(() -> searchConstructor(declaringClass, arguments).orElse(null));
String declaration;
if (method != null) {
declaration = method.getDeclaration();
} else {
final String args = Joiner.on(", ").join(arguments);
declaration = mc.returnType + ' ' + methodName + '(' + args + ')';
}
String scope = mc.scope;
if (scope != null && !scope.isEmpty()) {
scope = scope + '.' + symbol;
} else {
scope = symbol;
}
return new Declaration(scope.trim(), declaration, Declaration.Type.METHOD, mc.argumentIndex);
});
log.traceExit(entryMessage);
return result;
}
use of meghanada.reflect.MemberDescriptor in project meghanada-server by mopemope.
the class MemberCacheLoader method loadFromReflector.
private List<MemberDescriptor> loadFromReflector(String fqcn) {
final String initName = ClassNameUtils.getSimpleName(fqcn);
final ASMReflector asmReflector = ASMReflector.getInstance();
Map<String, ClassIndex> index = CachedASMReflector.getInstance().getGlobalClassIndex();
final InheritanceInfo info = asmReflector.getReflectInfo(index, fqcn);
final List<MemberDescriptor> result = asmReflector.reflectAll(info);
return result.stream().filter(md -> {
if (md.matchType(CandidateUnit.MemberType.CONSTRUCTOR)) {
final String name = ClassNameUtils.getSimpleName(md.getName());
return name.equals(initName);
}
return true;
}).collect(Collectors.toList());
}
use of meghanada.reflect.MemberDescriptor in project meghanada-server by mopemope.
the class JavaCompletion method completionSymbols.
private static Collection<? extends CandidateUnit> completionSymbols(Source source, int line, String prefix) {
Set<CandidateUnit> result = new HashSet<>(32);
// prefix search
log.debug("Search variables prefix:{} line:{}", prefix, line);
Optional<TypeScope> typeScope = source.getTypeScope(line);
if (!typeScope.isPresent()) {
return result;
}
String fqcn = typeScope.get().getFQCN();
// add this member
for (MemberDescriptor c : JavaCompletion.reflectSelf(fqcn, true, prefix)) {
if (c.getName().startsWith(prefix)) {
result.add(c);
}
}
if (fqcn.contains(ClassNameUtils.INNER_MARK)) {
// add parent
String parentClass = fqcn;
while (true) {
int i = parentClass.lastIndexOf('$');
if (i < 0) {
break;
}
parentClass = parentClass.substring(0, i);
for (MemberDescriptor c : JavaCompletion.reflectSelf(parentClass, true, prefix)) {
if (c.getName().startsWith(prefix)) {
result.add(c);
}
}
}
}
log.debug("self fqcn:{}", fqcn);
Map<String, Variable> symbols = source.getDeclaratorMap(line);
log.debug("search variables size:{} result:{}", symbols.size(), symbols);
for (Map.Entry<String, Variable> e : symbols.entrySet()) {
String k = e.getKey();
Variable v = e.getValue();
log.debug("check variable name:{}", k);
if (k.startsWith(prefix)) {
log.debug("match variable name:{}", k);
if (!v.isField) {
result.add(v.toCandidateUnit());
}
}
}
// import
for (Map.Entry<String, String> e : source.getImportedClassMap().entrySet()) {
String k = e.getKey();
String v = e.getValue();
if (k.startsWith(prefix)) {
result.add(ClassIndex.createClass(v));
}
}
// static import
for (Map.Entry<String, String> e : source.staticImportClass.entrySet()) {
String methodName = e.getKey();
String clazz = e.getValue();
for (MemberDescriptor md : JavaCompletion.reflectWithFQCN(clazz, methodName)) {
if (md.getName().equals(methodName)) {
result.add(md);
}
}
}
// Add class
if (Character.isUpperCase(prefix.charAt(0))) {
// completion
CachedASMReflector reflector = CachedASMReflector.getInstance();
boolean fuzzySearch = Config.load().useClassFuzzySearch();
if (fuzzySearch) {
result.addAll(reflector.fuzzySearchClasses(prefix.toLowerCase()));
} else {
result.addAll(reflector.searchClasses(prefix.toLowerCase()));
}
}
List<CandidateUnit> list = new ArrayList<>(result);
list.sort(comparing(source, prefix));
return list;
}
use of meghanada.reflect.MemberDescriptor in project meghanada-server by mopemope.
the class JavaCompletion method completionFieldsOrMethods.
private static Collection<? extends CandidateUnit> completionFieldsOrMethods(final Source source, final int line, final String var, final String target) {
// completionAt methods or fields
if (var.equals("this")) {
return JavaCompletion.completionThis(source, line, target);
}
if (var.equals("super")) {
return JavaCompletion.completionSuper(source, line, target);
}
log.debug("search '{}' field or method", var);
String ownPackage = source.getPackageName();
final Set<CandidateUnit> res = new HashSet<>(32);
{
// completion static method
String fqcn = source.getImportedClassFQCN(var, null);
if (nonNull(fqcn)) {
if (!fqcn.contains(".") && !ownPackage.isEmpty()) {
fqcn = ownPackage + '.' + fqcn;
}
final Collection<? extends CandidateUnit> result = JavaCompletion.reflect(ownPackage, fqcn, true, false, target);
res.addAll(result);
// add inner class
final Collection<? extends CandidateUnit> inners = CachedASMReflector.getInstance().searchInnerClasses(fqcn);
res.addAll(inners);
if (!res.isEmpty()) {
return res;
}
}
}
{
final Map<String, Variable> symbols = source.getDeclaratorMap(line);
final Variable variable = symbols.get(var);
if (nonNull(variable)) {
// get data from reflector
String fqcn = variable.fqcn;
if (!fqcn.contains(".")) {
fqcn = ownPackage + '.' + fqcn;
}
final Collection<? extends CandidateUnit> reflect = JavaCompletion.reflect(ownPackage, fqcn, target);
res.addAll(reflect);
}
}
{
for (final ClassScope cs : source.getClassScopes()) {
final String fqcn = cs.getFQCN();
final Optional<MemberDescriptor> fieldResult = JavaCompletion.reflectSelf(fqcn, true, target).stream().filter(c -> c instanceof FieldDescriptor && c.getName().equals(var)).findFirst();
if (fieldResult.isPresent()) {
final MemberDescriptor memberDescriptor = fieldResult.orElse(null);
final String returnType = memberDescriptor.getRawReturnType();
final Collection<? extends CandidateUnit> reflect = reflect(ownPackage, returnType, target);
res.addAll(reflect);
}
}
}
{
// java.lang
final String fqcn = "java.lang." + var;
final Collection<? extends CandidateUnit> result = JavaCompletion.reflect(ownPackage, fqcn, true, false, target);
res.addAll(result);
}
{
String fqcn = var;
if (!ownPackage.isEmpty()) {
fqcn = ownPackage + '.' + var;
}
final Collection<? extends CandidateUnit> reflectResults = JavaCompletion.reflect(ownPackage, fqcn, true, false, target);
res.addAll(reflectResults);
final CachedASMReflector reflector = CachedASMReflector.getInstance();
if (reflector.containsFQCN(fqcn)) {
final Collection<? extends CandidateUnit> inners = reflector.searchInnerClasses(fqcn);
res.addAll(inners);
}
}
if (line > 0 && res.isEmpty()) {
List<MethodCall> calls = source.getMethodCall(line - 1);
long lastCol = 0;
String lastFQCN = null;
for (MethodCall call : calls) {
long col = call.nameRange.begin.column;
String name = ClassNameUtils.getSimpleName(call.name);
if (name.equals(var) && col > lastCol) {
lastFQCN = call.returnType;
lastCol = col;
}
}
if (nonNull(lastFQCN)) {
res.addAll(reflectWithFQCN(lastFQCN, ""));
}
}
return res;
}
use of meghanada.reflect.MemberDescriptor in project meghanada-server by mopemope.
the class ASMReflector method getMembersFromClassFile.
private List<MemberDescriptor> getMembersFromClassFile(final File parent, final File file, String fqcn, boolean includeSuper) throws IOException {
try (final InputStream in = new FileInputStream(file)) {
final ClassReader classReader = new ClassReader(in);
final String className = ClassNameUtils.replaceSlash(classReader.getClassName());
if (className.equals(fqcn)) {
final ClassAnalyzeVisitor cv = new ClassAnalyzeVisitor(className, className, false, true);
classReader.accept(cv, 0);
final List<MemberDescriptor> members = cv.getMembers();
if (includeSuper) {
readSuperMembers(parent, cv, members);
}
return members;
}
}
return null;
}
Aggregations