All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.ow2.mind.adl.annotations.DumpASTAnnotationProcessor Maven / Gradle / Ivy

The newest version!
/**
 * Copyright (C) 2010 France Telecom
 *
 * This file is part of "Mind Compiler" is free software: you can redistribute 
 * it and/or modify it under the terms of the GNU Lesser General Public License 
 * as published by the Free Software Foundation, either version 3 of the 
 * License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT 
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 * FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public License for more
 * details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this program.  If not, see .
 *
 * Contact: [email protected]
 *
 * Authors: Matthieu ANNE
 * Contributors:
 */

package org.ow2.mind.adl.annotations;

import java.util.Map;

import org.objectweb.fractal.adl.ADLException;
import org.objectweb.fractal.adl.Definition;
import org.objectweb.fractal.adl.Node;
import org.objectweb.fractal.adl.interfaces.Interface;
import org.objectweb.fractal.adl.interfaces.InterfaceContainer;
import org.ow2.mind.adl.annotation.ADLLoaderPhase;
import org.ow2.mind.adl.annotation.AbstractADLLoaderAnnotationProcessor;
import org.ow2.mind.adl.ast.ASTHelper;
import org.ow2.mind.adl.ast.Binding;
import org.ow2.mind.adl.ast.BindingContainer;
import org.ow2.mind.adl.ast.Component;
import org.ow2.mind.adl.ast.ComponentContainer;
import org.ow2.mind.adl.ast.MindInterface;
import org.ow2.mind.annotation.Annotation;

/**
 * @author Matthieu ANNE
 */
public class DumpASTAnnotationProcessor extends
	AbstractADLLoaderAnnotationProcessor {

    private static void showComponents(final Definition definition,
	    final int depth) {
	String prf = "  ";

	for (int i = 0; i < depth; i++)
	    prf = prf + "   ";

	System.out.println(prf + "Definition source: "
		+ definition.astGetSource());

	final Interface[] interfaces = ((InterfaceContainer) definition)
		.getInterfaces();
	if (interfaces.length == 0) {
	    System.out.println(prf + "No interface");
	} else {
	    System.out
		    .println(prf + "Interface quantity: " + interfaces.length);
	}
	for (int i = 0; i < interfaces.length; i++) {
	    final MindInterface itf = (MindInterface) interfaces[i];
	    System.out.print(prf + "Interface[" + i + "] is " + itf.getName()
		    + " with role " + itf.getRole() + ", signature: "
		    + itf.getSignature());
	    if (itf.getCardinality() != null) {
		System.out.print(", cardinality: " + itf.getCardinality());
	    }
	    if (itf.getContingency() != null) {
		System.out.print(", contingency: " + itf.getContingency());
	    }
	    if (itf.getNumberOfElement() != null) {
		System.out.print(", number of element: "
			+ itf.getNumberOfElement());
	    }
	    System.out.println();
	}

	if (ASTHelper.isComposite(definition)) {
	    final Component[] subComponents = ((ComponentContainer) definition)
		    .getComponents();
	    System.out.print(prf + "Subcomponent quantity: "
		    + subComponents.length + " (" + subComponents[0].getName());
	    for (int i = 1; i < subComponents.length; i++) {
		System.out.print(", " + subComponents[i].getName());
	    }
	    System.out.println(")");

	    final Binding[] bindings = ((BindingContainer) definition)
		    .getBindings();
	    if (bindings.length == 0) {
		System.out.println(prf + "No binding");
	    } else {
		System.out
			.println(prf + "Binding quantity: " + bindings.length);
	    }
	    for (int i = 0; i < bindings.length; i++) {
		final Binding binding = bindings[i];
		System.out.print(prf + "Binding #" + i + " is from "
			+ binding.getFromComponent() + "."
			+ binding.getFromInterface());
		if (binding.getFromInterfaceNumber() != null) {
		    System.out.print("[" + binding.getFromInterfaceNumber()
			    + "]");
		}
		System.out.print(" to " + binding.getToComponent() + "."
			+ binding.getToInterface());
		if (binding.getToInterfaceNumber() != null) {
		    System.out
			    .print("[" + binding.getToInterfaceNumber() + "]");
		}
		System.out.println();
	    }

	    for (int i = 0; i < subComponents.length; i++) {
		final Component subComponent = subComponents[i];
		try {
		    System.out.println(prf
			    + "Component #"
			    + i
			    + ": "
			    + subComponent.getName()
			    + " ("
			    + ASTHelper.getResolvedComponentDefinition(
				    subComponent, null, null).getName() + ")");
		} catch (final ADLException e1) {
		    // TODO Auto-generated catch block
		    e1.printStackTrace();
		}
		try {
		    showComponents(ASTHelper.getResolvedDefinition(subComponent
			    .getDefinitionReference(), null, null), depth + 1);
		} catch (final ADLException e) {
		    // TODO Auto-generated catch block
		    e.printStackTrace();
		}
	    }

	} else if (ASTHelper.isPrimitive(definition)) {

	}
    }

    private static void showDefinitionContent(final Definition definition) {
	System.out.println("Showing content of current definition: "
		+ definition.getName() + ";\n");
	showComponents(definition, 0);

	System.out
		.println("\n\n---------------------------------------------------------------\n\n");

    }

    /*
     * (non-Javadoc)
     * 
     * @see
     * org.ow2.mind.adl.annotation.ADLLoaderAnnotationProcessor#processAnnotation
     * (org.ow2.mind.annotation.Annotation, org.objectweb.fractal.adl.Node,
     * org.objectweb.fractal.adl.Definition,
     * org.ow2.mind.adl.annotation.ADLLoaderPhase, java.util.Map)
     */
    public Definition processAnnotation(final Annotation annotation,
	    final Node node, final Definition definition,
	    final ADLLoaderPhase phase, final Map context)
	    throws ADLException {
	assert annotation instanceof DumpAST;
	showDefinitionContent(definition);
	return null;
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy