Break circular dependency in DevTools without using field injection

This commit is contained in:
Andy Wilkinson 2018-05-02 13:43:19 +01:00
parent 06cf698387
commit d0f329caa4
1 changed files with 14 additions and 13 deletions

View File

@ -62,24 +62,12 @@ public class LocalDevToolsAutoConfiguration {
@ConditionalOnProperty(prefix = "spring.devtools.livereload", name = "enabled", matchIfMissing = true)
static class LiveReloadConfiguration {
private DevToolsProperties properties;
private LiveReloadServer liveReloadServer;
LiveReloadConfiguration(DevToolsProperties properties,
ObjectProvider<LiveReloadServer> liveReloadServer) {
this.properties = properties;
LiveReloadConfiguration(ObjectProvider<LiveReloadServer> liveReloadServer) {
this.liveReloadServer = liveReloadServer.getIfAvailable();
}
@Bean
@RestartScope
@ConditionalOnMissingBean
public LiveReloadServer liveReloadServer() {
return new LiveReloadServer(this.properties.getLivereload().getPort(),
Restarter.getInstance().getThreadFactory());
}
@EventListener
public void onContextRefreshed(ContextRefreshedEvent event) {
optionalLiveReloadServer().triggerReload();
@ -97,6 +85,19 @@ public class LocalDevToolsAutoConfiguration {
return new OptionalLiveReloadServer(this.liveReloadServer);
}
@Configuration
static class LiveReloadServerConfiguration {
@Bean
@RestartScope
@ConditionalOnMissingBean
public LiveReloadServer liveReloadServer(DevToolsProperties properties) {
return new LiveReloadServer(properties.getLivereload().getPort(),
Restarter.getInstance().getThreadFactory());
}
}
}
/**