-
Notifications
You must be signed in to change notification settings - Fork 165
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
ClassInfo.addIndexes() doesn't use MetaDataClassLoader.loadClass() instead of Class.forName() #314
Comments
gauravdingolia
changed the title
addIndexes() doesn't use MetaDataClassLoader.loadClass() instead of Class.forName()
ClassInfo.addIndexes() doesn't use MetaDataClassLoader.loadClass() instead of Class.forName()
Dec 30, 2016
@gauravdingolia : Could you provide more detail? Versions, stack traces, sample code etc. |
private Map<String, FieldInfo> addIndexes() {
Map<String, FieldInfo> indexes = new HashMap<>();
// No way to get declared fields from current byte code impl. Using reflection instead.
Field[] declaredFields;
try {
declaredFields = Class.forName(className).getDeclaredFields();
} catch (ClassNotFoundException e) {
throw new RuntimeException("Could not reflectively read declared fields", e);
}
final String indexAnnotation = Index.class.getCanonicalName();
for (FieldInfo fieldInfo : fieldsInfo().fields()) {
if (isDeclaredField(declaredFields, fieldInfo.getName()) && fieldInfo.hasAnnotation(indexAnnotation)) {
indexes.put(fieldInfo.property(), fieldInfo);
}
}
return indexes;
} Source from ClassInfo.java 2.1.0 When using neo4j ogm with play 2.5, there is a problem while instantiating SessionFactory.
When I dig down to the source, turns out that ClassInfo.addIndex() is still using Class.forName instead of MetaDataClassLoader.loadClass(). Please correct me if I am missing something. |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
No description provided.
The text was updated successfully, but these errors were encountered: