1 package org.simantics.scl.osgi;
3 import java.util.ArrayList;
5 import org.simantics.scl.compiler.errors.DoesNotExist;
6 import org.simantics.scl.compiler.errors.Failable;
7 import org.simantics.scl.compiler.module.Module;
8 import org.simantics.scl.compiler.module.options.ModuleCompilationOptions;
9 import org.simantics.scl.compiler.module.options.ModuleCompilationOptionsAdvisor;
10 import org.simantics.scl.compiler.module.repository.ModuleRepository;
11 import org.simantics.scl.compiler.source.repository.ModuleSourceRepository;
12 import org.simantics.scl.compiler.testing.repository.TestRepository;
13 import org.simantics.scl.osgi.internal.Activator;
14 import org.simantics.scl.osgi.internal.ServiceBasedModuleSourceRepository;
15 import org.simantics.scl.osgi.internal.ServiceBasedTestRepository;
16 import org.slf4j.Logger;
17 import org.slf4j.LoggerFactory;
19 import gnu.trove.procedure.TObjectProcedure;
22 public class SCLOsgi {
24 private static final Logger LOGGER = LoggerFactory.getLogger(SCLOsgi.class);
28 public static ModuleSourceRepository SOURCE_REPOSITORY = new ServiceBasedModuleSourceRepository(Activator.getContext());
29 public static ModuleRepository MODULE_REPOSITORY = new ModuleRepository(SOURCE_REPOSITORY);
30 public static TestRepository TEST_REPOSITORY = new ServiceBasedTestRepository(Activator.getContext());
33 MODULE_REPOSITORY.setAdvisor(new ModuleCompilationOptionsAdvisor() {
34 ModuleCompilationOptions options = null;
36 public ModuleCompilationOptions getOptions(String moduleName) {
38 options = new ModuleCompilationOptions(false);
39 options.collectDebugInfo = Activator.getContext().getProperty("osgi.dev") != null; //$NON-NLS-1$
46 public static String compileAllModules() {
47 ArrayList<String> modulesWithErrors = new ArrayList<String>();
48 SCLOsgi.SOURCE_REPOSITORY.forAllModules(new TObjectProcedure<String>() {
50 public boolean execute(String moduleName) {
51 Failable<Module> module = SCLOsgi.MODULE_REPOSITORY.getModule(moduleName);
52 if(module.didSucceed())
53 LOGGER.trace("{} - {}", moduleName, "succeeded");
54 else if(module == DoesNotExist.INSTANCE)
55 LOGGER.trace("{} - {}", moduleName, "does not exist"); // should not happen
57 LOGGER.trace("{} - {}", moduleName, "error");
58 modulesWithErrors.add(moduleName);
63 if(!modulesWithErrors.isEmpty()) {
64 StringBuilder b = new StringBuilder();
65 b.append("Some SCL modules failed to compile:");
66 for(String module : modulesWithErrors)
67 b.append(' ').append(module);