Skip to content

Commit 78ffdcc

Browse files
committed
feat: config current thread classloader and support fing mybatis configuaration by psimethod
1 parent 6b26919 commit 78ffdcc

File tree

2 files changed

+44
-1
lines changed

2 files changed

+44
-1
lines changed

src/main/java/io/github/linyimin/plugin/utils/MapperDomUtils.java

Lines changed: 37 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -188,13 +188,49 @@ public static MybatisConfiguration findConfiguration(Project project, PsiMethod
188188

189189
List<DomFileElement<MybatisConfiguration>> elements = DomService.getInstance().getFileElements(MybatisConfiguration.class, project, scope);
190190

191-
return elements.stream()
191+
MybatisConfiguration mybatisConfiguration = elements.stream()
192192
.filter(configuration -> {
193193
assert module != null;
194194
assert configuration.getModule() != null;
195195
return StringUtils.equals(module.getName(), configuration.getModule().getName());
196196
})
197197
.map(DomFileElement::getRootElement)
198198
.findFirst().orElse(null);
199+
200+
if (Objects.nonNull(mybatisConfiguration)) {
201+
return mybatisConfiguration;
202+
}
203+
204+
205+
return findConfigurationByPsiMethod(project, elements, psiMethod);
206+
207+
}
208+
209+
private static MybatisConfiguration findConfigurationByPsiMethod(Project project, List<DomFileElement<MybatisConfiguration>> elements, PsiMethod psiMethod) {
210+
211+
if (Objects.isNull(psiMethod.getContainingClass())) {
212+
return null;
213+
}
214+
215+
List<Mapper> mappers = MapperDomUtils.findMappersByNamespace(project, psiMethod.getContainingClass().getQualifiedName());
216+
217+
if (CollectionUtils.isEmpty(mappers)) {
218+
return null;
219+
}
220+
221+
XmlTag xmlTag = mappers.get(0).getXmlTag();
222+
if (Objects.isNull(xmlTag) || Objects.isNull(xmlTag.getContainingFile())) {
223+
return null;
224+
}
225+
226+
String mapperFileName = xmlTag.getContainingFile().getName();
227+
228+
229+
return elements.stream()
230+
.map(DomFileElement::getRootElement)
231+
.filter(configuration -> {
232+
XmlTag tag = configuration.getXmlTag();
233+
return Objects.nonNull(tag) && StringUtils.contains(tag.getText(), mapperFileName);
234+
}).findFirst().orElse(null);
199235
}
200236
}

src/main/java/io/github/linyimin/plugin/utils/MybatisSqlUtils.java

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -32,7 +32,12 @@ public class MybatisSqlUtils {
3232

3333
public static String getSql(String mybatisConfiguration, String qualifiedMethod, String params, boolean isCheck) {
3434

35+
ClassLoader currentClassLoader = Thread.currentThread().getContextClassLoader();
36+
3537
try {
38+
39+
Thread.currentThread().setContextClassLoader(MybatisPojoCompile.classLoader);
40+
3641
InputStream in = IOUtils.toInputStream(mybatisConfiguration, Charset.defaultCharset());
3742
Resources.setDefaultClassLoader(MybatisPojoCompile.classLoader);
3843

@@ -47,6 +52,8 @@ public static String getSql(String mybatisConfiguration, String qualifiedMethod,
4752
Messages.showInfoMessage(e.getMessage(), Constant.APPLICATION_NAME);
4853
}
4954
throw e;
55+
} finally {
56+
Thread.currentThread().setContextClassLoader(currentClassLoader);
5057
}
5158
}
5259

0 commit comments

Comments
 (0)