vim/runtime/syntax/testdir/input/java_lambda_expressions_signature.java
Aliaksei Budavei e73e5b889b
runtime(java): Optionally highlight the :: token for method references
This token will be highlighted, similar to the arrow of
lambda expressions, whenever "g:java_highlight_functions" is
defined.

Also:

- Improve the recognition of _switch-case_ labels
  (D-Cysteine).
- Remove insignificant empty statements in syntax test
  files.

closes: #15322

References:
https://docs.oracle.com/javase/specs/jls/se21/html/jls-15.html#jls-15.13
https://github.com/fleiner/vim/pull/1

Co-authored-by: D-Cysteine <54219287+D-Cysteine@users.noreply.github.com>
Signed-off-by: Aliaksei Budavei <0x000c70@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2024-07-24 20:17:43 +02:00

154 lines
4.8 KiB
Java

// VIM_TEST_SETUP let g:java_highlight_functions = 'style'
// VIM_TEST_SETUP let g:java_highlight_signature = 1
import java.lang.annotation.ElementType;
import java.util.function.BinaryOperator;
import java.util.function.Function;
import java.util.function.Predicate;
class LambdaExpressions$Tests // JDK 21+.
{
<I1, C1, C2, T1, T2, T3, Z1, Z2, Z3, S1, S2, S3> void test()
{ // Schönfinkel's functions.
I<I1> i = x -> x;
C<C1, C2> c = x -> y -> x;
T<T1, T2, T3> t = f -> y -> x -> f.apply(x).apply(y);
Z<Z1, Z2, Z3> z = f -> g -> x -> f.apply(g.apply(x));
S<S1, S2, S3> s = f -> g -> x -> f.apply(x)
.apply(g.apply(x));
I<I1> i01 = (var x) -> x;
I<I1> i02 = (@Taggable var x) -> x;
I<I1> i03 = (@Taggable @Taggable var x) -> x;
I<I1> i04 = (final var x) -> x;
I<I1> i05 = (@Taggable final var x) -> x;
I<I1> i06 = (@Taggable @Taggable final var x) -> x;
I<I1> i07 = (I1 x) -> x;
I<I1> i08 = (@Taggable I1 x) -> x;
I<I1> i09 = (@Taggable @Taggable I1 x) -> x;
I<I1> i10 = (final I1 x) -> x;
I<I1> i11 = (@Taggable final I1 x) -> x;
I<I1> i12 = (@Taggable @Taggable final I1 x) -> x;
I<I1[]> ii01 = (I1... x) -> x;
I<I1[]> ii02 = (@Taggable I1... x) -> x;
I<I1[]> ii03 = (@Taggable @Taggable I1... x) -> x;
I<I1[]> ii04 = (final I1... x) -> x;
I<I1[]> ii05 = (@Taggable final I1... x) -> x;
I<I1[]> ii06 = (@Taggable @Taggable final I1... x) -> x;
BinaryOperator<I1> leftConst01 = (var x, var y) -> x;
BinaryOperator<I1> leftConst02 = (@Taggable var x,
@Taggable var y) -> x;
BinaryOperator<I1> leftConst03 = (@Taggable @Taggable var
x, @Taggable @Taggable var y) -> x;
BinaryOperator<I1> leftConst04 = (final var x,
final var y) -> x;
BinaryOperator<I1> leftConst05 = (@Taggable final
var x, @Taggable final var y) -> x;
BinaryOperator<I1> leftConst06 = (@Taggable
@Taggable final var x,
@Taggable
@Taggable final var y) -> x;
BinaryOperator<I1> leftConst07 = (I1 x, I1 y) -> x;
BinaryOperator<I1> leftConst08 = (@Taggable I1 x,
@Taggable I1 y) -> x;
BinaryOperator<I1> leftConst09 = (@Taggable @Taggable I1
x, @Taggable @Taggable I1 y) -> x;
BinaryOperator<I1> leftConst10 = (final I1 x,
final I1 y) -> x;
BinaryOperator<I1> leftConst11 = (@Taggable final
I1 x, @Taggable final I1 y) -> x;
BinaryOperator<I1> leftConst12 = (@Taggable
@Taggable final I1 x,
@Taggable
@Taggable final I1 y) -> x;
Runnable noOp = () -> {};
BinaryOperator<I1> leftConst = (x, y) -> x;
I<I1> id1 = (x) -> (x);
@SuppressWarnings("unchecked") I<I1> id2 =
((I<I<I1>>) (I<?>) (Function<I1,
I1> x) -> x).apply(switch (0) {
case ((int) (byte) 1) -> (I1 x) -> x;
default -> (@Taggable I1 x) -> x; });
C<C1, C2> const1 = (x) -> (y) -> (x);
C<C1, C2> const2 = switch(switch ("") {
case "->"->"(s)->(s)";
default->"default"; }) {
case ("->")->(var x)->(var y)->(x);
default->(@Taggable var x)->(@Taggable var y)
->(x);
};
}
@java.lang.annotation.Target(ElementType.PARAMETER)
@java.lang.annotation.Repeatable(Taggables.class)
@interface Taggable { String[] value() default ""; }
@java.lang.annotation.Target(ElementType.PARAMETER)
@interface Taggables { Taggable[] value(); }
interface I<A1> extends Function<A1, A1> { }
interface C<A1, A2> extends Function<A1, Function<A2, A1>> { }
interface T<A1, A2, A3> extends
Function<Function<A1, Function<A2, A3>>,
Function<A2,
Function<A1, A3>>> { }
interface Z<A1, A2, A3> extends Function<Function<A2, A3>,
Function<Function<A1, A2>,
Function<A1, A3>>> { }
interface S<A1, A2, A3> extends
Function<Function<A1, Function<A2, A3>>,
Function<Function<A1, A2>,
Function<A1, A3>>> { }
static void echo(Object o) { System.out.println(o); }
static {
enum Letters { OTHER, ALPHA, BETA }
Letters other = Letters.OTHER;
switch (other) {
case Letters alpha when Letters.ALPHA == alpha:
{ echo(alpha); break; }
case Letters beta when Letters.BETA == beta:
{ echo(beta); break; }
default: { echo(other); }
}
echo(switch (other) {
case Letters alpha when Letters.ALPHA == alpha
-> alpha;
case Letters beta when Letters.BETA == beta
-> beta;
default -> other;
});
switch (null) {
case String str when !"<empty>".equals(switch (str) {
case String str_ when
Predicate.<String>not(text ->
!text.isEmpty())
.test(str_)
-> "<empty>";
case String str_ -> str_;
}): { echo(str); break; }
case null: default: { echo("Other"); }
}
echo(switch (null) {
case String str when !"<empty>".equals(
switch (str) {
case String str_ when
Predicate.<String>not(text ->
!text.isEmpty())
.test(str_)
-> "<empty>";
case String str_ -> str_;
}) -> str;
case null, default -> "Other";
});
}
}