+ if (log.isDebugEnabled())
+ log.info("Argeo Suite App " + appPid + " started");
+
+ Objects.requireNonNull(contentRepository, "Content repository must be provided");
+ Objects.requireNonNull(appUserState, "App user state must be provided");
+
+ long janitorPeriod = 12 * 60 * 60 * 1000;// 12h
+ janitorTimer.schedule(new TimerTask() {
+
+ @Override
+ public void run() {
+ refs: for (WeakReference<SwtAppUi> uiRef : managedUis.values()) {
+ SwtAppUi ui = uiRef.get();
+ if (ui == null)
+ continue refs;
+ ui.disposeIfTimedout();
+ }
+ if (log.isDebugEnabled())
+ log.debug(managedUis.size() + " UIs being managed by app " + appPid);
+ }
+ }, janitorPeriod, janitorPeriod);