Not logged in.  Login/Logout/Register | List snippets | | Create snippet | Upload image | Upload data

126
LINES

< > BotCompany Repo | #1028793 // IntBuffer

JavaX fragment (include) [tags: use-pretranspiled]

Libraryless. Click here for Pure Java version (10901L/60K).

1  
sclass IntBuffer implements Iterable<Int> {
2  
  int[] data;
3  
  int size;
4  
  
5  
  *() {}
6  
  *(int size) { if (size != 0) data = new int[size]; }
7  
  *(Iterable<Int> l) {
8  
    if (l cast Cl) allocate(l.size());
9  
    addAll(l);
10  
  }
11  
  
12  
  void add(int i) {
13  
    if (size >= lIntArray(data)) {
14  
      data = resizeIntArray(data, Math.max(1, toInt(Math.min(maximumSafeArraySize(), lIntArray(data)*2L))));
15  
      if (size >= data.length) fail("IntBuffer too large: " + size);
16  
    }
17  
    data[size++] = i;
18  
  }
19  
  
20  
  void allocate(int n) {
21  
    data = resizeIntArray(data, max(n, size()));
22  
  }
23  
  
24  
  void setSize(int n) {
25  
    data = resizeIntArray(data, n);
26  
    size = min(l(data), size);
27  
  }
28  
  
29  
  void addAll(Iterable<Int> l) {
30  
    if (l != null) for (int i : l) add(i);
31  
  }
32  
  
33  
  void addAll(int... l) {
34  
    if (l != null) for (int i : l) add(i);
35  
  }
36  
  
37  
  // Note: may return the internal array
38  
  int[] toArray aka toIntArray() {
39  
    ret size == 0 ? null : resizeIntArray(data, size);
40  
  }
41  
  
42  
  int[] subArray(int from, int to) {
43  
    ret subIntArray(data, from, min(to, size));
44  
  }
45  
  
46  
  int[] toArrayNonNull() {
47  
    ret unnull(toArray());
48  
  }
49  
  
50  
  // abandoned version
51  
  /*L<Int> toList() {
52  
    ret intArrayToList(data, 0, size);
53  
  }*/
54  
55  
  // now all these return a virtual list
56  
  L<Int> toList aka asList aka asVirtualList() {
57  
    ret new RandomAccessAbstractList<Int> {
58  
      public int size() { ret size; }
59  
      public Int get(int i) { ret IntBuffer.this.get(i); }
60  
      public Int set(int i, Int val) {
61  
        Int a = get(i);
62  
        data[i] = val;
63  
        ret a;
64  
      }
65  
    };
66  
  }
67  
  
68  
  void reset { size = 0; }
69  
  void clear { reset(); }
70  
  
71  
  int size() { ret size; }
72  
  bool isEmpty() { ret size == 0; }
73  
  
74  
  int get(int idx) {
75  
    if (idx >= size) fail("Index out of range: " + idx + "/" + size);
76  
    ret data[idx];
77  
  }
78  
79  
  int getOpt(int idx) {
80  
    ret idx >= 0 && idx < size ? data[idx] : 0;
81  
  }
82  
  
83  
  void set(int idx, int value) {
84  
    if (idx >= size) fail("Index out of range: " + idx + "/" + size);
85  
    data[idx] = value;
86  
  }
87  
  
88  
  int popLast() {
89  
    if (size == 0) fail("empty buffer");
90  
    ret data[--size];
91  
  }
92  
  
93  
  int last() { ret data[size-1]; }
94  
  int nextToLast() { ret data[size-2]; }
95  
  
96  
  toString { ret squareBracket(joinWithSpace(toList())); }
97  
  
98  
  public Iterator<Int> iterator() {
99  
    ret new ItIt<Int> {
100  
      int i = 0;
101  
      
102  
      public bool hasNext() { ret i < size; }
103  
      public Int next() {
104  
        //if (!hasNext()) fail("Index out of bounds: " + i);
105  
        ret data[i++];
106  
      }
107  
    };
108  
  }
109  
  
110  
  public IntegerIterator integerIterator() {
111  
    ret new IntegerIterator {
112  
      int i = 0;
113  
      
114  
      public bool hasNext() { ret i < size; }
115  
      public int next() {
116  
        //if (!hasNext()) fail("Index out of bounds: " + i);
117  
        ret data[i++];
118  
      }
119  
      toString { ret "Iterator@" + i + " over " + IntBuffer.this; }
120  
    };
121  
  }
122  
  
123  
  void trimToSize {
124  
    data = resizeIntArray(data, size);
125  
  }
126  
}

download  show line numbers  debug dex  old transpilations   

Travelled to 8 computer(s): bhatertpkbcr, elmgxqgtpvxh, mqqgnosmbjvj, pyentgdyhuwx, pzhvpgtvlbxg, tvejysmllsmz, vouqrxazstgt, xrpafgyirdlv

No comments. add comment

Snippet ID: #1028793
Snippet name: IntBuffer
Eternal ID of this version: #1028793/45
Text MD5: 9f04831a88c86b2346f21e1a3603625f
Transpilation MD5: 9e78d94a8412c33785b7994c2a9ac207
Author: stefan
Category: javax
Type: JavaX fragment (include)
Public (visible to everyone): Yes
Archived (hidden from active list): No
Created/modified: 2025-01-06 11:20:35
Source code size: 3037 bytes / 126 lines
Pitched / IR pitched: No / No
Views / Downloads: 687 / 1303
Version history: 44 change(s)
Referenced in: [show references]