![JAR search and dependency download from the Maven repository](/logo.png)
org.apache.maven.plugins.dependency.tree.GraphmlDependencyNodeVisitor Maven / Gradle / Ivy
package org.apache.maven.plugins.dependency.tree;
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
import java.io.Writer;
import org.apache.maven.shared.dependency.graph.DependencyNode;
import org.apache.maven.shared.dependency.graph.traversal.DependencyNodeVisitor;
/**
* A dependency node visitor that serializes visited nodes to a writer using the
* graphml format.
*
* @author Jerome Creignou
* @since 2.1
*/
public class GraphmlDependencyNodeVisitor
extends AbstractSerializingVisitor
implements DependencyNodeVisitor
{
/**
* Graphml xml file header. Define Schema and root element. We also define 2 key as meta data.
*/
private static final String GRAPHML_HEADER = " "
+ "\n"
+ " \n"
+ " \n"
+ "\n";
/**
* Graphml xml file footer.
*/
private static final String GRAPHML_FOOTER = " ";
/**
* Constructor.
*
* @param writer the writer to write to.
*/
public GraphmlDependencyNodeVisitor( Writer writer )
{
super( writer );
}
/**
* {@inheritDoc}
*/
@Override
public boolean endVisit( DependencyNode node )
{
if ( node.getParent() == null || node.getParent() == node )
{
writer.write( GRAPHML_FOOTER );
}
else
{
DependencyNode p = node.getParent();
writer.print( "" );
if ( node.getArtifact().getScope() != null )
{
// add Edge label
writer.print( "" + node.getArtifact().getScope()
+ " " );
}
writer.println( " " );
}
return true;
}
/**
* {@inheritDoc}
*/
@Override
public boolean visit( DependencyNode node )
{
if ( node.getParent() == null || node.getParent() == node )
{
writer.write( GRAPHML_HEADER );
}
// write node
writer.print( "" );
// add node label
writer.print( "" + node.toNodeString()
+ " " );
writer.println( " " );
return true;
}
/**
* Generate a unique id from a DependencyNode.
*
* Current implementation is rather simple and uses hashcode.
*
*
* @param node the DependencyNode to use.
* @return the unique id.
*/
private static String generateId( DependencyNode node )
{
return String.valueOf( node.hashCode() );
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy