當前位置: 首頁>>代碼示例>>Java>>正文


Java TracerFactory類代碼示例

本文整理匯總了Java中net.ssehub.easy.instantiation.core.model.execution.TracerFactory的典型用法代碼示例。如果您正苦於以下問題:Java TracerFactory類的具體用法?Java TracerFactory怎麽用?Java TracerFactory使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


TracerFactory類屬於net.ssehub.easy.instantiation.core.model.execution包,在下文中一共展示了TracerFactory類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: initialize

import net.ssehub.easy.instantiation.core.model.execution.TracerFactory; //導入依賴的package包/類
/**
 * Initializes the repository connector. This is done automatically on first access, but shall be done during
 * layer startup.
 */
public static void initialize() {
    if (null == loader) {
        // start up EASy 
        try {
            QmLogging.setLogLevel(Level.INFO);
            QmLogging.disableUnwantedLogging();
            //QmLogging.setLogLevel("org.eclipse.xtext.service.BindModule", Level.INFO);
            loader = new ListLoader();
            loader.setVerbose(false);
            loader.startup();
        } catch (IOException e) {
            getLogger().error(e.getMessage());
        }
        
        if (readModels()) {
            // set tracing 
            TracerFactory.setDefaultInstance(TracerFactory.DEFAULT);
        }
    }
}
 
開發者ID:QualiMaster,項目名稱:Infrastructure,代碼行數:25,代碼來源:RepositoryConnector.java

示例2: executeScript

import net.ssehub.easy.instantiation.core.model.execution.TracerFactory; //導入依賴的package包/類
/**
     * Creates a VIL executor for the contained PLP.
     * 
     * @param artifactsFolder the name of the folder in testdata
     * @param script the script
     * @param targetFile the target directory
     * 
     * @throws ModelManagementException 
     * @throws VilException 
     */
    private void executeScript(String artifactsFolder, File script, File targetFile) throws
        ModelManagementException, 
        VilException {
//        final File base = new File(getArtifactsFolder(), artifactsFolder);
//        final File script = new File(getArtifactsFolder(), script);
        // execute
        //System.out.println(script.getAbsolutePath());
        String scriptName = script.getName().replaceAll(".vil", "");
        ProjectDescriptor source = new ProjectDescriptor(script.getAbsolutePath(), scriptName);
        ProjectDescriptor target = new ProjectDescriptor(source, targetFile);
        TracerFactory.setDefaultInstance(ConsoleTracerFactory.INSTANCE);
        Executor executor = new Executor(source.getMainVilScript()).addSource(source).addTarget(target)
                .addConfiguration(ProjectDescriptor.getConfiguration(scriptName));
        executor.execute();
    }
 
開發者ID:SSEHUB,項目名稱:EASyProducer,代碼行數:26,代碼來源:ProjectExecutionTest.java

示例3: visitValueAssignmentExpression

import net.ssehub.easy.instantiation.core.model.execution.TracerFactory; //導入依賴的package包/類
@Override
public Object visitValueAssignmentExpression(ValueAssignmentExpression ex) throws VilException {
    Object result;
    VariableDeclaration var = ex.getVarDecl();
    FieldDescriptor field = ex.getField();
    Object val = ex.getValueExpression().accept(this);
    if (null != val) {
        try {
            if (null != field) {
                field.setValue(environment.getValue(var), val);
            } else {
                environment.setValue(var, val);
            }
            notifyValueDefined(var, field, val);
            result = Boolean.TRUE;
        } catch (VilException e) {
            result = null;
            TracerFactory.createInstantiatorTracer().traceError(e.getMessage());
        }
    } else {
        result = null; // undefined
    }
    return result;
}
 
開發者ID:SSEHUB,項目名稱:EASyProducer,代碼行數:25,代碼來源:EvaluationVisitor.java

示例4: visitFieldAccessExpression

import net.ssehub.easy.instantiation.core.model.execution.TracerFactory; //導入依賴的package包/類
@Override
public Object visitFieldAccessExpression(FieldAccessExpression ex) throws VilException {
    Object result = null;
    try {
        Object ownerValue;
        if (null != ex.getVariable()) {
            ownerValue = environment.getValue(ex.getVariable()); 
        } else {
            if (null == ex.getNested()) { // static -> variable == null
                ownerValue = null; 
            } else {
                ownerValue = ex.getNested().accept(this);
            }
        }
        if (ex.isMetaAccess()) {
            result = ex.getField().getMetaValue(ownerValue);
        } else {
            result = ex.getField().getValue(ownerValue);
        }
    } catch (VilException e) {
        // -> undefined
        TracerFactory.createInstantiatorTracer().traceError(e.getMessage());
    }
    return result;
}
 
開發者ID:SSEHUB,項目名稱:EASyProducer,代碼行數:26,代碼來源:EvaluationVisitor.java

示例5: visitRule

import net.ssehub.easy.instantiation.core.model.execution.TracerFactory; //導入依賴的package包/類
@Override
public Object visitRule(VtlRule rule) throws VilException {
    net.ssehub.easy.instantiation.core.model.templateModel.ITracer tracer 
        = TracerFactory.createTemplateLanguageTracer();
    TracerFactory.registerTemplateLanguageTracer(tracer);
    Writer writer = new NullWriter(); // not for reuse
    Map<String, Object> localParam = new HashMap<String, Object>(); // by default
    localParam.put(PARAM_CONFIG, environment.getTopLevelConfiguration());
    localParam.put(PARAM_TARGET, null); // for now
    TemplateLangExecution exec = new TemplateLangExecution(tracer, writer, localParam);
    Def def = rule.getDef();
    Template template = (Template) def.getParent();
    exec.getRuntimeEnvironment().switchContext(template);
    exec.visitModelHeader(template);
    Object result = def.accept(exec);
    TracerFactory.unregisterTemplateLanguageTracer(tracer);
    return result;
}
 
開發者ID:SSEHUB,項目名稱:EASyProducer,代碼行數:19,代碼來源:BuildlangExecution.java

示例6: handleMessages

import net.ssehub.easy.instantiation.core.model.execution.TracerFactory; //導入依賴的package包/類
/**
 * Handles AspectJ messages.
 * 
 * @param handler the message handler
 * @throws VilException in case that abort of processing is needed
 */
private static void handleMessages(MessageHandler handler) throws VilException {
    IInstantiatorTracer tracer = TracerFactory.createInstantiatorTracer();
    for (IMessage msg : handler.getUnmodifiableListView()) {
        if (msg.isDebug() || msg.isInfo() || msg.isWarning()) {
            tracer.traceMessage(msg.getMessage());
        } else {
            tracer.traceError(msg.getMessage());
        }
    }
    if (handler.getErrors().length > 0) {
        StringBuilder tmp = new StringBuilder();
        for (IMessage message : handler.getMessages(null, true)) {
            tmp.append(message.toString());
            tmp.append("\r\n");
        }
        throw new VilException(tmp.toString(), VilException.ID_RUNTIME_EXECUTION);
    }
}
 
開發者ID:SSEHUB,項目名稱:EASyProducer,代碼行數:25,代碼來源:AspectJ.java

示例7: testJavaDebug

import net.ssehub.easy.instantiation.core.model.execution.TracerFactory; //導入依賴的package包/類
/**
 * For developing modified Java templates.
 * 
 * @throws IOException shall not occur
 */
//@Ignore("just for development/debugging")
@Test
public void testJavaDebug() throws IOException {
    TracerFactory.setInstance(new ConsoleTracerFactory(true));

    String[] names = new String[3];
    names[0] = "javaExperiments";
    names[1] = "javaExperiments";
    names[2] = "javaExperimentsDebug";

    // no reasoning: we just need specific structures/values
    File tmp = executeCase(names, null, "", null, false); 
    File expected = new File(tmp, "PriorityPip_DataManagementElement0DataManagementElement.java");
    TextTestUtils.assertFileEquality(new File(tmp, "PrioPip_DME.java"), expected);
    TextTestUtils.assertFileEquality(new File(tmp, "PrioPip_DME0.java"), expected);
    TextTestUtils.assertFileEquality(new File(tmp, "PrioPip_DME1.java"), expected);
}
 
開發者ID:SSEHUB,項目名稱:EASyProducer,代碼行數:23,代碼來源:LocalExperimentsTests.java

示例8: setTracerFactory

import net.ssehub.easy.instantiation.core.model.execution.TracerFactory; //導入依賴的package包/類
/**
 * Sets the tracer factory.
 * 
 * @return <code>true</code> if logging/tracing is enabled, <code>false</code> else
 */
private static boolean setTracerFactory() {
    boolean log = AdaptationConfiguration.enableAdaptationRtVilLogging();
    if (log) {
        if (!setConfiguredTracerFactory()) {
            TracerFactory.setInstance(ConsoleTracerFactory.INSTANCE); // thread-based setting
        }
    } else {
        setConfiguredTracerFactory();
    }
    return log;
}
 
開發者ID:QualiMaster,項目名稱:Infrastructure,代碼行數:17,代碼來源:AdaptationEventQueue.java

示例9: createProfilePipeline

import net.ssehub.easy.instantiation.core.model.execution.TracerFactory; //導入依賴的package包/類
/**
 * Profiles the given algorithm. Create a specific pipeline with data source, specific family holding
 * only the test algorithm. Stores data and control file into <code>source</code>.
 * 
 * @param config the configuration to be used as basis for creating a profiling pipeline
 * @param pipelineName the name of the pipeline to be created (must be a valid Java identifier)
 * @param familyName the name of the family to test
 * @param algorithmName the name of the algorithm within <code>family</code> to test
 * @param source the source project descriptor, also to be used as target folder for instantiation (the folder may 
 *     be empty)
 * @return pipeline information
 * @throws VilException in case of model query problems, model management problems, CST errors, unmatching IVML 
 *     values or VIL execution errors
 */
@QMInternal
public static ProfileData createProfilePipeline(net.ssehub.easy.varModel.confModel.Configuration config, 
    String pipelineName, String familyName, String algorithmName, IProjectDescriptor source) throws VilException {
    ProfileData result = null;
    if (null == config.getProject()) {
        throw new VilException("no project available - syntax/parsing error?", VilException.ID_INVALID);
    }
    try {
        Project qm = createNewRoot(config, pipelineName, familyName, algorithmName);
        Configuration cfg = new Configuration(qm);
        
        TracerFactory.setInstance(ConsoleTracerFactory.INSTANCE); // clear thread specific instance
        StandaloneProjectDescriptor target = new StandaloneProjectDescriptor(source, source.getBase());
        Executor executor = new Executor(source.getMainVilScript())
            .addSource(source).addTarget(target)
            .addConfiguration(cfg)
            .addCustomArgument("pipelineName", pipelineName)
            .addStartRuleName("pipeline");
        executor.execute();
        TracerFactory.setInstance(null); // clear thread specific instance

        File base = source.getBase();
        Compound familyType = findCompound(qm, TYPE_FAMILY);
        IDecisionVariable testFamily = findNamedVariable(config, familyType, familyName);
        IDecisionVariable testAlgorithm = Configuration.dereference(findAlgorithm(testFamily, algorithmName, true));
        String algArtifact = VariableHelper.getString(testAlgorithm, SLOT_ALGORITHM_ARTIFACT);
        extractProfilingArtifact(algArtifact, algorithmName, base);
        File pipFile = new File(base, "pipelines/eu/qualimaster/" + pipelineName + "/target/" + pipelineName 
            + "-" + PIP_VERSION + "-jar-with-dependencies.jar");
        File dataFile = getDataFile(base);
        File controlFile = getControlFile(base);
        result = new ProfileData(pipelineName, pipFile, dataFile, controlFile);
    } catch (ModelQueryException | ModelManagementException | ValueDoesNotMatchTypeException 
        | CSTSemanticException e) {
        throw new VilException(e.getMessage(), VilException.ID_RUNTIME);
    }
    return result;
}
 
開發者ID:QualiMaster,項目名稱:QM-EASyProducer,代碼行數:53,代碼來源:AlgorithmProfileHelper.java

示例10: enableTracing

import net.ssehub.easy.instantiation.core.model.execution.TracerFactory; //導入依賴的package包/類
/**
 * Enables or disables tracing on registered tracers for this thread.
 * 
 * @param enable enable or disable
 */
public static void enableTracing(boolean enable) {
    net.ssehub.easy.instantiation.core.model.buildlangModel.ITracer bTracer 
        = TracerFactory.getRegisteredBuildLanguageTracer();
    if (null != bTracer) {
        bTracer.enable(enable);
    }
    
    net.ssehub.easy.instantiation.core.model.templateModel.ITracer tTracer 
        = TracerFactory.getRegisteredTemplateLanguageTracer();
    if (null != tTracer) {
        tTracer.enable(enable);
    }
}
 
開發者ID:SSEHUB,項目名稱:EASyProducer,代碼行數:19,代碼來源:Tracing.java

示例11: getCurrentTracer

import net.ssehub.easy.instantiation.core.model.execution.TracerFactory; //導入依賴的package包/類
/**
 * Returns the current tracer for this thread.
 * 
 * @return the current tracer (may be <b>null</b>)
 */
public static ITracer getCurrentTracer() {
    // more specific one / nested one goes first
    ITracer tracer = TracerFactory.getRegisteredTemplateLanguageTracer();
    if (null == tracer) {
        tracer = TracerFactory.getRegisteredBuildLanguageTracer();
    }
    return tracer;
}
 
開發者ID:SSEHUB,項目名稱:EASyProducer,代碼行數:14,代碼來源:ExecutionLocal.java

示例12: run

import net.ssehub.easy.instantiation.core.model.execution.TracerFactory; //導入依賴的package包/類
@Override
public void run() {
    TracerFactory.setInstance(tracers); // set thread-based
    IInstantiatorTracer tracer = TracerFactory.createInstantiatorTracer();
    try {
        InputStreamReader isr = new InputStreamReader(is);
        BufferedReader br = new BufferedReader(isr);
        String line = null;
        while ((line = br.readLine()) != null) {
            if (null != manipulator) {
                line = manipulator.manipulate(line);
            }
            if (null != line) {
                if (isErrorStream) {
                    tracer.traceError(line);
                } else {
                    tracer.traceMessage(line);
                }
            }
        }
    } catch (EOFException eof) {
        // ok, terminate
    } catch (IOException ioe) {
        EASyLoggerFactory.INSTANCE.getLogger(StreamGobbler.class, Bundle.ID).exception(ioe);
    } finally {
        TracerFactory.setInstance(null); // reset thread-based
    }
}
 
開發者ID:SSEHUB,項目名稱:EASyProducer,代碼行數:29,代碼來源:StreamGobbler.java

示例13: earlyStartup

import net.ssehub.easy.instantiation.core.model.execution.TracerFactory; //導入依賴的package包/類
@Override
public void earlyStartup() {
    IWorkbench workbench = PlatformUI.getWorkbench();
    workbench.getDisplay().syncExec(new Runnable() {
        public void run() {
            // I would expect the following line to be part of the startup of EASy core
            EASyLogger logger = EASyLoggerFactory.INSTANCE.getLogger(Startup.class,
                "de.uni_hildesheim.sse.easy.ui");
            logger.info("EASy-Producer 2.0 is up and running...");
            ResourcesMgmt.INSTANCE.findPLProjects();
        }
    });
    // Register the observer for sending messages to the console of the running Eclipse-instance.
    TracerFactory.setDefaultInstance(GuiTracerFactory.INSTANCE);
}
 
開發者ID:SSEHUB,項目名稱:EASyProducer,代碼行數:16,代碼來源:Startup.java

示例14: TimeMeasurementTracerFactory

import net.ssehub.easy.instantiation.core.model.execution.TracerFactory; //導入依賴的package包/類
/**
 * Default constructor for on-demand class loading with no tracing.
 */
public TimeMeasurementTracerFactory() {
    this(TracerFactory.DEFAULT);
}
 
開發者ID:QualiMaster,項目名稱:Infrastructure,代碼行數:7,代碼來源:TimeMeasurementTracerFactory.java

示例15: createTestTracerFactory

import net.ssehub.easy.instantiation.core.model.execution.TracerFactory; //導入依賴的package包/類
@Override
public TracerFactory createTestTracerFactory(Writer trace, String[] baseFolders) {
    return new TestTracerFactory(trace, baseFolders);
}
 
開發者ID:SSEHUB,項目名稱:EASyProducer,代碼行數:5,代碼來源:BuildLangTestConfigurer.java


注:本文中的net.ssehub.easy.instantiation.core.model.execution.TracerFactory類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。