¿Cómo puedo iterar a través de mi modelo fem de un editor de GMF sin analizar el archivo XML de modelo?

StackOverflow https://stackoverflow.com/questions/4398541

Pregunta

He creado con éxito un editor de GMF que atrae a los modelos basados ??en mi EMF model.What lo que quería hacer es iterar a través de mi modelo eclasses .Can lograrse esto en tiempo de ejecución a través de mi código del plugin sin tener que leer el archivo XML que crea el editor de GMF? ¿existe una API de EMF?

¿Fue útil?

Solución

Cuando se genera el código de prueba a partir del archivo genmodel entonces dentro de la XYZ.test complemento no es tal tipo de código que yo era poligonales searching.It a través del archivo XMI de su modelo

// Create a resource set to hold the resources.
    //
    ResourceSet resourceSet = new ResourceSetImpl();

    // Register the appropriate resource factory to handle all file extensions.
    //
    resourceSet.getResourceFactoryRegistry().getExtensionToFactoryMap().put
        (Resource.Factory.Registry.DEFAULT_EXTENSION, 
         new XMIResourceFactoryImpl());

    // Register the package to ensure it is available during loading.
    //
    resourceSet.getPackageRegistry().put
        (XYZmetamodelPackage.eNS_URI, 
         XYZmetamodelPackage.eINSTANCE);

    // If there are no arguments, emit an appropriate usage message.
    //
    if (args.length == 0) {
        System.out.println("Enter a list of file paths or URIs that have content like this:");
        try {
            Resource resource = resourceSet.createResource(URI.createURI("http:///My.metamodel"));
            ModelObject root = atagmetamodelFactory.eINSTANCE.createModelObject();
            resource.getContents().add(root);
            resource.save(System.out, null);
        }
        catch (IOException exception) {
            exception.printStackTrace();
        }
    }
    else {
        // Iterate over all the arguments.
        //
        for (int i = 0; i < args.length; ++i) {
            // Construct the URI for the instance file.
            // The argument is treated as a file path only if it denotes an existing file.
            // Otherwise, it's directly treated as a URL.
            //
            File file = new File(args[i]);
            URI uri = file.isFile() ? URI.createFileURI(file.getAbsolutePath()): URI.createURI(args[i]);

            try {
                // Demand load resource for this file.
                //
                Resource resource = resourceSet.getResource(uri, true);
                System.out.println("Loaded " + uri);

                // Validate the contents of the loaded resource.
                //
                for (EObject eObject : resource.getContents()) {
                    Diagnostic diagnostic = Diagnostician.INSTANCE.validate(eObject);
                    if (diagnostic.getSeverity() != Diagnostic.OK) {
                        printDiagnostic(diagnostic, "");
                    }
                }
            }
            catch (RuntimeException exception) {
                System.out.println("Problem loading " + uri);
                exception.printStackTrace();
            }
        }
    }
}
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top