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
|
|
|
}
|