Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions .github/workflows/pull_request.yml
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ on:
pull_request:
branches:
- main
- dev

jobs:
build:
Expand Down
153 changes: 153 additions & 0 deletions src/main/java/common/java/JavaUtil.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,153 @@
package common.java;

import static java.lang.System.arraycopy;
import static java.util.Arrays.*;

public class JavaUtil {

public static <T> T[] concat(T[] first, T[] second) {
T[] result = copyOf(first, first.length + second.length);
arraycopy(second, 0, result, first.length, second.length);
return result;
}

public static <T> T[] flatten(T[][] array) {
int length = 0;
for (T[] subArray : array) {
length += subArray.length;
}
T[] result = copyOf(array[0], length);
int offset = array[0].length;
for (int i = 1; i < array.length; i++) {
arraycopy(array[i], 0, result, offset, array[i].length);
offset += array[i].length;
}
return result;
}

@SuppressWarnings("unchecked")
public static <T> Pair<Integer, T>[] enumerate(T[] array) {
Pair<Integer, T>[] result = new Pair[array.length];
for (int i = 0; i < array.length; i++) {
result[i] = new Pair<>(i, array[i]);
}
return result;
}

@SuppressWarnings("unchecked")
public static <T> Triple<Integer, Integer, T>[] enumerate(T[][] array) {
Triple<Integer, Integer, T>[] result = new Triple[array.length * array[0].length];
int index = 0;
for (int i = 0; i < array.length; i++) {
for (int j = 0; j < array[i].length; j++) {
result[index++] = new Triple<>(i, j, array[i][j]);
}
}
return result;
}

public static class Pair<A, B> {
public A a;
public B b;

public Pair(A a, B b) {
this.a = a;
this.b = b;
}

public A a() {
return a;
}

public B b() {
return b;
}

public A x() {
return a;
}

public B y() {
return b;
}

public A first() {
return a;
}

public B second() {
return b;
}

public A left() {
return a;
}

public B right() {
return b;
}

}

public static class Triple<A, B, C> {
public A a;
public B b;
public C c;

public Triple(A a, B b, C c) {
this.a = a;
this.b = b;
this.c = c;
}

public A a() {
return a;
}

public B b() {
return b;
}

public C c() {
return c;
}

public A x() {
return a;
}

public B y() {
return b;
}

public C z() {
return c;
}

public A first() {
return a;
}

public B second() {
return b;
}

public C third() {
return c;
}

public A left() {
return a;
}

public B middle() {
return b;
}

public C right() {
return c;
}

}

}
91 changes: 91 additions & 0 deletions src/test/java/common/colour/ColourTest.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,91 @@
package common.colour;

import common.math.Vector4f;
import org.junit.jupiter.api.Test;
import static org.junit.jupiter.api.Assertions.*;

public class ColourTest {

@Test
public void testRgb() {
int colour = Colour.rgb(255, 0, 0);
assertEquals(255, Colour.r(colour));
assertEquals(0, Colour.g(colour));
assertEquals(0, Colour.b(colour));
assertEquals(255, Colour.a(colour));
}

@Test
public void testRgba() {
int colour = Colour.rgba(255, 0, 0, 128);
assertEquals(255, Colour.r(colour));
assertEquals(0, Colour.g(colour));
assertEquals(0, Colour.b(colour));
assertEquals(128, Colour.a(colour));
}

@Test
public void testHsl() {
int colour = Colour.hsl(0, 1, 0.5f);
assertEquals(255, Colour.r(colour));
assertEquals(0, Colour.g(colour));
assertEquals(0, Colour.b(colour));
assertEquals(255, Colour.a(colour));
}

@Test
public void testNormalizedR() {
int colour = Colour.rgb(255, 0, 0);
assertEquals(1.0f, Colour.normalizedR(colour));
assertEquals(0.0f, Colour.normalizedG(colour));
assertEquals(0.0f, Colour.normalizedB(colour));
assertEquals(1.0f, Colour.normalizedA(colour));
}

@Test
public void testNormalizedG() {
int colour = Colour.rgb(0, 255, 0);
assertEquals(0.0f, Colour.normalizedR(colour));
assertEquals(1.0f, Colour.normalizedG(colour));
assertEquals(0.0f, Colour.normalizedB(colour));
assertEquals(1.0f, Colour.normalizedA(colour));
}

@Test
public void testNormalizedB() {
int colour = Colour.rgb(0, 0, 255);
assertEquals(0.0f, Colour.normalizedR(colour));
assertEquals(0.0f, Colour.normalizedG(colour));
assertEquals(1.0f, Colour.normalizedB(colour));
assertEquals(1.0f, Colour.normalizedA(colour));
}

@Test
public void testNormalizedA() {
int colour = Colour.rgba(0, 0, 0, 255);
assertEquals(0.0f, Colour.normalizedR(colour));
assertEquals(0.0f, Colour.normalizedG(colour));
assertEquals(0.0f, Colour.normalizedB(colour));
assertEquals(1.0f, Colour.normalizedA(colour));
}

@Test
public void testToVector() {
int colour = Colour.rgba(255, 0, 0, 128);
Vector4f vector = Colour.toVector(colour);
assertEquals(255, vector.x(), 0.01);
assertEquals(0, vector.y(), 0.01);
assertEquals(0, vector.z(), 0.01);
assertEquals(128, vector.w(), 0.01);
}

@Test
public void testToRangedVector() {
int colour = Colour.rgba(255, 0, 0, 128);
Vector4f vector = Colour.toRangedVector(colour);
assertEquals(1.0f, vector.x(), 0.01);
assertEquals(0.0f, vector.y(), 0.01);
assertEquals(0.0f, vector.z(), 0.01);
assertEquals(0.5f, vector.w(), 0.01);
}
}
Loading