h.ST_Agraph_s Maven / Gradle / Ivy
/* ========================================================================
* PlantUML : a free UML diagram generator
* ========================================================================
*
* Project Info: http://plantuml.com
*
* If you like this project or if you find it useful, you can support us at:
*
* http://plantuml.com/patreon (only 1$ per month!)
* http://plantuml.com/paypal
*
* This file is part of Smetana.
* Smetana is a partial translation of Graphviz/Dot sources from C to Java.
*
* (C) Copyright 2009-2022, Arnaud Roques
*
* This translation is distributed under the same Licence as the original C program:
*
*************************************************************************
* Copyright (c) 2011 AT&T Intellectual Property
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors: See CVS logs. Details at http://www.graphviz.org/
*************************************************************************
*
* THE ACCOMPANYING PROGRAM IS PROVIDED UNDER THE TERMS OF THIS ECLIPSE PUBLIC
* LICENSE ("AGREEMENT"). [Eclipse Public License - v 1.0]
*
* ANY USE, REPRODUCTION OR DISTRIBUTION OF THE PROGRAM CONSTITUTES
* RECIPIENT'S ACCEPTANCE OF THIS AGREEMENT.
*
* You may obtain a copy of the License at
*
* http://www.eclipse.org/legal/epl-v10.html
*
* 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.
*
*/
package h;
import smetana.core.OFFSET;
import smetana.core.__ptr__;
import smetana.core.__struct__;
import smetana.core.debug.SmetanaDebug;
final public class ST_Agraph_s extends ST_Agobj_s {
public final ST_Agobj_s base = this;
public final ST_Agdesc_s desc = new ST_Agdesc_s();
public final ST_dtlink_s link = new ST_dtlink_s(this);
public ST_dt_s n_seq; /* the node set in sequence */
public ST_dt_s n_id; /* the node set indexed by ID */
public ST_dt_s e_seq; /* holders for edge sets */
public ST_dt_s e_id; /* holders for edge sets */
public ST_dt_s g_dict; /* subgraphs - descendants */
public ST_Agraph_s parent; /* subgraphs - ancestors */
public ST_Agraph_s root; /* subgraphs - ancestors */
public ST_Agclos_s clos; /* shared resources */
public String NAME;
private static int CPT = 0;
@Override
public String toString() {
return super.toString() + " " + NAME;
}
public ST_Agraph_s() {
this.NAME = "G" + CPT;
CPT++;
SmetanaDebug.LOG("creation " + this);
}
@Override
public Object getTheField(OFFSET offset) {
if (offset == null || offset.getSign()==0) {
return this;
}
if (offset.getField().equals("link")) {
return link;
}
throw new UnsupportedOperationException();
}
@Override
public void ___(__struct__ arg) {
throw new UnsupportedOperationException();
}
@Override
public boolean isSameThan(__ptr__ other) {
ST_Agraph_s other2 = (ST_Agraph_s) other;
return this == other2;
}
}
// struct Agraph_s {
// Agobj_t base;
// Agdesc_t desc;
// Dtlink_t link;
// Dict_t *n_seq; /* the node set in sequence */
// Dict_t *n_id; /* the node set indexed by ID */
// Dict_t *e_seq, *e_id; /* holders for edge sets */
// Dict_t *g_dict; /* subgraphs - descendants */
// Agraph_t *parent, *root; /* subgraphs - ancestors */
// Agclos_t *clos; /* shared resources */
// };