1
0
mirror of https://github.com/octoleo/plantuml.git synced 2024-11-16 18:25:11 +00:00
plantuml/src/smetana/core/CStarStar.java

106 lines
2.6 KiB
Java
Raw Normal View History

2016-03-06 16:47:34 +00:00
/* ========================================================================
* PlantUML : a free UML diagram generator
* ========================================================================
*
* Project Info: http://plantuml.com
*
2017-03-15 19:13:31 +00:00
* 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
*
2016-03-06 16:47:34 +00:00
* 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
2016-03-06 16:47:34 +00:00
*
* This translation is distributed under the same Licence as the original C program.
*
* 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 smetana.core;
import java.util.ArrayList;
import java.util.List;
2020-11-21 17:33:24 +00:00
public class CStarStar<O> extends UnsupportedC {
2016-03-06 16:47:34 +00:00
2020-11-21 17:33:24 +00:00
private final List<O> data;
private final int offset;
2016-03-06 16:47:34 +00:00
2020-11-21 17:33:24 +00:00
private CStarStar(List<O> data, int offset) {
this.data = data;
this.offset = offset;
}
public static <O> CStarStar<O> ALLOC(int size, Class cl) {
final CStarStar<O> result = new CStarStar<O>(new ArrayList<O>(), 0);
result.realloc(size);
return result;
}
2016-03-06 16:47:34 +00:00
2020-11-21 17:33:24 +00:00
public static <O> CStarStar<O> REALLOC(int size, CStarStar<O> old, Class<O> cl) {
if (old==null) {
return ALLOC(size, cl);
}
old.realloc(size);
return old;
}
2016-03-06 16:47:34 +00:00
2020-11-21 17:33:24 +00:00
public int comparePointer_(CStarStar<O> other) {
if (this.data != other.data) {
throw new IllegalArgumentException();
}
return this.offset - other.offset;
2016-03-06 16:47:34 +00:00
}
2020-11-21 17:33:24 +00:00
public O get_(int i) {
return data.get(i + offset);
2016-03-06 16:47:34 +00:00
}
2020-11-21 17:33:24 +00:00
public void set_(int i, O value) {
data.set(i + offset, value);
}
public void realloc(int size) {
if (offset != 0) {
throw new IllegalStateException();
}
2016-03-06 16:47:34 +00:00
for (int i = 0; i < size; i++) {
2020-11-21 17:33:24 +00:00
data.add(null);
2016-03-06 16:47:34 +00:00
}
}
2020-11-21 17:33:24 +00:00
public CStarStar<O> plus_(int delta) {
return new CStarStar<O>(data, offset + delta);
}
2016-03-06 16:47:34 +00:00
2020-11-21 17:33:24 +00:00
public void _swap(int i, int j) {
if (offset != 0) {
throw new IllegalStateException();
}
final O e1 = data.get(i);
final O e2 = data.get(j);
data.set(i, e2);
data.set(j, e1);
2016-03-06 16:47:34 +00:00
}
2020-11-21 17:33:24 +00:00
2016-03-06 16:47:34 +00:00
}