1
0
mirror of https://github.com/octoleo/plantuml.git synced 2024-12-22 02:49:06 +00:00
plantuml/src/h/ST_object_t.java

209 lines
5.2 KiB
Java
Raw Normal View History

2017-10-07 09:46:53 +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.
*
2019-01-16 18:34:41 +00:00
* (C) Copyright 2009-2020, Arnaud Roques
2017-10-07 09:46:53 +00:00
*
* 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;
2018-10-21 19:44:14 +00:00
import java.util.ArrayList;
2017-10-07 09:46:53 +00:00
import java.util.List;
2018-10-21 19:44:14 +00:00
import smetana.core.UnsupportedArrayOfStruct2;
2017-10-07 09:46:53 +00:00
import smetana.core.UnsupportedStructAndPtr;
2018-10-21 19:44:14 +00:00
import smetana.core.__array_of_ptr__;
2017-10-07 09:46:53 +00:00
import smetana.core.__ptr__;
import smetana.core.__struct__;
import smetana.core.size_t;
import smetana.core.amiga.StarStruct;
2018-11-26 18:46:22 +00:00
public class ST_object_t extends UnsupportedStructAndPtr implements ST_Node_t___or_object_t {
2017-10-07 09:46:53 +00:00
private final StarStruct parent;
public ST_object_t() {
this(null);
}
public ST_object_t(StarStruct parent) {
this.parent = parent;
}
// "typedef struct",
// "{",
2018-10-21 19:44:14 +00:00
public final ST_pointf pos = new ST_pointf(this);
public final ST_pointf sz = new ST_pointf(this);
2017-10-07 09:46:53 +00:00
// "xlabel_t *lbl",
2018-10-21 19:44:14 +00:00
public ST_xlabel_t.Array lbl;
2017-10-07 09:46:53 +00:00
// "}",
// "object_t");
@Override
2018-10-21 19:44:14 +00:00
public ST_object_t getStruct() {
return this;
2017-10-07 09:46:53 +00:00
}
2018-10-21 19:44:14 +00:00
@Override
public ST_object_t getPtr() {
return this;
}
@Override
public boolean isSameThan(StarStruct other) {
ST_object_t other2 = (ST_object_t) other;
return this == other2;
}
public static class Array extends UnsupportedArrayOfStruct2 implements __ptr__, __array_of_ptr__ {
private final List<ST_object_t> data;
private final int pos;
@Override
public Array asPtr() {
return this;
}
@Override
public ST_object_t getStruct() {
return get(0);
}
@Override
public __ptr__ setPtr(String fieldName, __ptr__ data) {
return get(0).setPtr(fieldName, data);
}
@Override
public void setStruct(String fieldName, __struct__ data) {
get(0).setStruct(fieldName, data);
}
public Array(int size) {
this.data = new ArrayList<ST_object_t>();
this.pos = 0;
for (int i = 0; i < size; i++) {
data.add(new ST_object_t());
}
}
public Array reallocJ(int newsize) {
while (data.size() < newsize) {
data.add(new ST_object_t());
}
return this;
}
public Array plus(int delta) {
return plusJ(delta);
}
private Array(List<ST_object_t> data, int pos) {
this.data = data;
this.pos = pos;
}
public ST_object_t get(int i) {
return this.data.get(pos + i);
}
public Array plusJ(int i) {
return new Array(data, pos + i);
}
public int minus(Array other) {
if (this.data != other.data) {
throw new IllegalArgumentException();
}
return this.pos - other.pos;
}
public Array move(int delta) {
throw new UnsupportedOperationException(getClass().toString());
}
public void realloc(size_t nb) {
throw new UnsupportedOperationException(getClass().toString());
}
public int comparePointerInternal(__array_of_ptr__ other) {
throw new UnsupportedOperationException(getClass().toString());
}
2017-10-07 09:46:53 +00:00
}
@Override
public __ptr__ setPtr(String fieldName, __ptr__ newData) {
if (fieldName.equals("pos")) {
this.pos.copyDataFrom(newData);
return newData;
}
if (fieldName.equals("lbl")) {
2018-10-21 19:44:14 +00:00
this.lbl = (ST_xlabel_t.Array) newData;
2017-10-07 09:46:53 +00:00
return this.lbl;
}
return super.setPtr(fieldName, newData);
}
@Override
public void setStruct(String fieldName, __struct__ newData) {
if (fieldName.equals("pos")) {
this.pos.copyDataFrom(newData);
return;
}
if (fieldName.equals("sz")) {
this.sz.copyDataFrom(newData);
return;
}
super.setStruct(fieldName, newData);
}
}
// typedef struct {
// pointf pos; /* Position of lower-left corner of object */
// pointf sz; /* Size of object; may be zero for a point */
// xlabel_t *lbl; /* Label attached to object, or NULL */
// } object_t;