1
0
mirror of https://github.com/octoleo/plantuml.git synced 2024-12-23 19:39:10 +00:00
plantuml/src/h/ST_Agraph_s.java

341 lines
8.3 KiB
Java
Raw Normal View History

2017-09-03 16:59:24 +00:00
/* ========================================================================
* 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-2017, 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.UnsupportedSize_t;
import smetana.core.UnsupportedStarStruct;
import smetana.core.UnsupportedStructAndPtr;
import smetana.core.__ptr__;
import smetana.core.__struct__;
import smetana.core.size_t;
import smetana.core.amiga.StarArrayOfPtr;
import smetana.core.amiga.StarStruct;
public class ST_Agraph_s extends UnsupportedStructAndPtr {
public final ST_Agobj_s base = new ST_Agobj_s(this);
public final ST_Agdesc_s desc = new ST_Agdesc_s(this);
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 */
// Agraph_t *parent, *root; /* subgraphs - ancestors */
public ST_Agraph_s root; /* subgraphs - ancestors */
public ST_Agclos_s clos; /* shared resources */
private final StarStruct _parent;
public ST_Agraph_s() {
this(null);
}
public ST_Agraph_s(StarStruct parent) {
this._parent = parent;
}
public StarStruct getParent() {
return _parent;
}
@Override
public __struct__ getStruct() {
return this;
}
@Override
public void setStruct(String fieldName, __struct__ newData) {
if (fieldName.equals("desc")) {
desc.copyDataFrom(newData);
return;
}
super.setStruct(fieldName, newData);
}
@Override
public StarStruct amp() {
return new Amp(this);
}
public class Amp extends UnsupportedStarStruct {
private final ST_Agraph_s me;
public Amp(ST_Agraph_s me) {
this.me = me;
}
@Override
public __ptr__ getPtr(String fieldName) {
return ST_Agraph_s.this.getPtr(fieldName);
}
@Override
public __struct__ getStruct() {
return ST_Agraph_s.this.getStruct();
}
@Override
public __struct__ getStruct(String fieldName) {
return ST_Agraph_s.this.getStruct(fieldName);
}
@Override
public boolean isSameThan(StarStruct other) {
if (other instanceof Amp) {
Amp other2 = (Amp) other;
return this.me == other2.me;
}
if (other instanceof ST_Agraph_s) {
ST_Agraph_s other2 = (ST_Agraph_s) other;
return this.me == other2;
}
return super.isSameThan(other);
}
@Override
public __ptr__ castTo(Class dest) {
if (dest == Agobj_s.class) {
return base.amp();
}
if (dest == Agraph_s.class) {
return ST_Agraph_s.this;
}
return super.castTo(dest);
}
@Override
public Object addVirtualBytes(int virtualBytes) {
if (virtualBytes == 0) {
return this;
}
OFFSET offset = OFFSET.fromInt(virtualBytes);
// if (offset.toString().equals("h.Agedge_s::seq_link")) {
// return seq_link;
// }
if (offset.toString().equals("h.Agraph_s::link")) {
return link;
}
System.err.println("offset176=" + offset);
return super.addVirtualBytes(virtualBytes);
}
public ST_Agraph_s getObject() {
return me;
}
}
@Override
public Object addVirtualBytes(int virtualBytes) {
if (virtualBytes == 0) {
return this;
}
OFFSET offset = OFFSET.fromInt(virtualBytes);
// if (offset.toString().equals("h.Agedge_s::seq_link")) {
// return seq_link;
// }
if (offset.toString().equals("h.Agraph_s::link")) {
return link;
}
System.err.println("offset156=" + offset);
return super.addVirtualBytes(virtualBytes);
}
@Override
public __struct__ getStruct(String fieldName) {
if (fieldName.equals("desc")) {
return desc;
}
return super.getStruct(fieldName);
}
@Override
public __ptr__ setPtr(String fieldName, __ptr__ newData) {
if (fieldName.equals("clos")) {
this.clos = (ST_Agclos_s) newData;
return clos;
}
if (fieldName.equals("root")) {
this.root = (ST_Agraph_s) newData;
return root;
}
if (fieldName.equals("n_seq")) {
this.n_seq = (ST_dt_s) newData;
return n_seq;
}
if (fieldName.equals("n_id")) {
this.n_id = (ST_dt_s) newData;
return n_id;
}
if (fieldName.equals("e_seq")) {
this.e_seq = (ST_dt_s) newData;
return e_seq;
}
if (fieldName.equals("e_id")) {
this.e_id = (ST_dt_s) newData;
return e_id;
}
if (fieldName.equals("g_dict")) {
this.g_dict = (ST_dt_s) newData;
return g_dict;
}
if (fieldName.equals("parent")) {
this.parent = (ST_Agraph_s) newData;
return parent;
}
return super.setPtr(fieldName, newData);
}
@Override
public __ptr__ getPtr(String fieldName) {
if (fieldName.equals("clos")) {
return clos;
}
if (fieldName.equals("root")) {
return root;
}
if (fieldName.equals("parent")) {
return parent;
}
if (fieldName.equals("n_id")) {
return n_id;
}
if (fieldName.equals("n_seq")) {
return n_seq;
}
if (fieldName.equals("e_id")) {
return e_id;
}
if (fieldName.equals("e_seq")) {
return e_seq;
}
if (fieldName.equals("g_dict")) {
return g_dict;
}
return super.getPtr(fieldName);
}
@Override
public __ptr__ castTo(Class dest) {
if (dest == Agobj_s.class) {
return base;
}
if (dest == Agraph_s.class) {
return this;
}
return super.castTo(dest);
}
@Override
public boolean isSameThan(StarStruct other) {
ST_Agraph_s other2 = (ST_Agraph_s) other;
return this == other2;
}
public StarStruct from_link(ST_dtlink_s from) {
if (from == link) {
return amp();
}
throw new IllegalArgumentException();
}
public static size_t sizeof(final int nb) {
return new UnsupportedSize_t(nb) {
@Override
public Object malloc() {
return new StarArrayOfPtr(new STArray<ST_Agraph_s>(nb, 0, ST_Agraph_s.class));
}
@Override
public int getInternalNb() {
return nb;
}
@Override
public Object realloc(Object old) {
StarArrayOfPtr old2 = (StarArrayOfPtr) old;
old2.realloc(nb);
return old2;
}
};
}
//
// public interface ST_Agraph_s extends __ptr__ {
// public static List<String> DEFINITION = Arrays.asList(
// "struct Agraph_s",
// "{",
// "Agobj_t base",
// "Agdesc_t desc",
// "Dtlink_t link",
// "Dict_t *n_seq",
// "Dict_t *n_id",
// "Dict_t *e_seq, *e_id",
// "Dict_t *g_dict",
// "Agraph_t *parent, *root",
// "Agclos_t *clos",
// "}");
}
// 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 */
// };