mirror of
				https://github.com/vim/vim.git
				synced 2025-10-24 08:54:47 -04:00 
			
		
		
		
	In addition to matching type parameter sections of generic classes and records and interfaces, match such sections of generic methods and constructors. As before, opt for it by defining "g:java_highlight_generics"; the diamond form still does not qualify for this kind of recognition. And make section patterns agree with one another in syntax items. References: https://docs.oracle.com/javase/specs/jls/se21/html/jls-4.html#jls-4.5 https://docs.oracle.com/javase/specs/jls/se21/html/jls-8.html#jls-8.4.4 https://docs.oracle.com/javase/specs/jls/se21/html/jls-8.html#jls-8.8.4 Signed-off-by: Aliaksei Budavei <0x000c70@gmail.com> Signed-off-by: Christian Brabandt <cb@256bit.org>
		
			
				
	
	
		
			163 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			163 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
| // VIM_TEST_SETUP let g:java_highlight_functions = 'style'
 | |
| // VIM_TEST_SETUP let g:java_highlight_generics = 1
 | |
| // VIM_TEST_SETUP let g:java_highlight_java_lang = 1
 | |
| 
 | |
| 
 | |
| // VIM_TEST_SETUP hi link javaGenericsC1 Todo
 | |
| // VIM_TEST_SETUP hi link javaGenericsC2 Error
 | |
| // VIM_TEST_SETUP hi link javaWildcardBound Error
 | |
| 
 | |
| 
 | |
| import java.math.BigInteger;
 | |
| import java.util.function.Consumer;
 | |
| import java.util.function.Function;
 | |
| import java.util.function.LongFunction;
 | |
| import java.util.function.Predicate;
 | |
| 
 | |
| class GenericsTests<T extends Number & Comparable<? super T>, U>
 | |
| {	// JDK 21+.
 | |
| 	static final Function<Function<Object, Object>, Object> PARTIAL =
 | |
| 						GenericsTests.y0();
 | |
| 	static final Function<BigInteger, BigInteger> FACTORIAL_2000 =
 | |
| 				GenericsTests.<BigInteger, BigInteger>y1()
 | |
| 		.apply(f -> x -> (x.compareTo(BigInteger.ONE) < 1)
 | |
| 			? BigInteger.ONE
 | |
| 			: x.multiply(f.apply(x.subtract(BigInteger.ONE))));
 | |
| 
 | |
| 	static <T1> Y0<T1> y0()
 | |
| 	{
 | |
| 		return (Function<T1, T1> f) -> f.apply(
 | |
| 					GenericsTests.<T1>y0()
 | |
| 						.apply(f));
 | |
| 	}
 | |
| 
 | |
| 	static <T1, T2> Y1<T1, T2> y1()
 | |
| 	{
 | |
| 		return (Function<Function<T1, T2>, Function<T1, T2>> f) ->
 | |
| 			(T1 x) -> f.apply(GenericsTests.<T1, T2>y1()
 | |
| 						.apply(f))
 | |
| 				.apply(x);
 | |
| 	}
 | |
| 
 | |
| 	static<T> void noOp(T dummy) { }
 | |
| 
 | |
| 	interface alpha<T> { }
 | |
| 
 | |
| 	interface Y0<T1> extends Function<Function<T1, T1>, T1> { }
 | |
| 
 | |
| 	interface Y1<T1, T2> extends Function<Function<Function<T1, T2>,
 | |
| 					Function<T1, T2>>,
 | |
| 					Function<T1, T2>> { }
 | |
| 
 | |
| 	interface Stackable<E> extends Iterable<E>
 | |
| 	{
 | |
| 		boolean isEmpty();
 | |
| 		E peek();
 | |
| 		E pop();
 | |
| 		Stackable<E> popAll(Stackable<? super E> elements);
 | |
| 		Stackable<E> popSome(Stackable<? super E> elements,
 | |
| 					Predicate<? super E> filter);
 | |
| 		Stackable<E> push(E element);
 | |
| 		Stackable<E> pushAll(Iterable<? extends E> elements);
 | |
| 		Stackable<E> pushSome(Iterable<? extends E> elements,
 | |
| 					Predicate<? super E> filter);
 | |
| 		Stackable<E> wind(Consumer<? super Stackable<E>> action);
 | |
| 	}
 | |
| 
 | |
| 	sealed interface Num<N extends Number>
 | |
| 	{
 | |
| 		int radix();
 | |
| 		N value();
 | |
| 	}
 | |
| 
 | |
| 	record Bin<N extends Number>(N value) implements Num<N>
 | |
| 	{
 | |
| 		public int radix() { return 2; }
 | |
| 	}
 | |
| 
 | |
| 	record Dec<N extends Number>(N value) implements Num<N>
 | |
| 	{
 | |
| 		public int radix() { return 10; }
 | |
| 	}
 | |
| 
 | |
| 	record Hex<N extends Number>(N value) implements Num<N>
 | |
| 	{
 | |
| 		public int radix() { return 16; }
 | |
| 	}
 | |
| 
 | |
| 	record Oct<N extends Number>(N value) implements Num<N>
 | |
| 	{
 | |
| 		public int radix() { return 8; }
 | |
| 	}
 | |
| 
 | |
| 	static Num<Long> fromDecimal(long x, int radix)
 | |
| 	{
 | |
| 		record Pair(LongFunction<Num<Long>> a,
 | |
| 					LongFunction<String> b) { }
 | |
| 		final Pair p = switch (radix) {
 | |
| 			case 2 -> new Pair(Bin::new, Long::toBinaryString);
 | |
| 			case 8 -> new Pair(Oct::new, Long::toOctalString);
 | |
| 			case 16 -> new Pair(Hex::new, Long::toHexString);
 | |
| 			default -> new Pair(Dec::new,
 | |
| 						y -> Long.toString(y));
 | |
| 		};
 | |
| 		return p.a().apply(Long.parseLong(p.b().apply(x), radix));
 | |
| 	}
 | |
| 
 | |
| 	static long toDecimal(Num<Long> x)
 | |
| 	{
 | |
| 		return Long.parseLong(switch (x) {
 | |
| 			case Bin<?>(Long b) -> Long.toBinaryString(b);
 | |
| 			case Oct<?>(Long o) -> Long.toOctalString(o);
 | |
| 			case Hex<?>(Long h) -> Long.toHexString(h);
 | |
| 			default -> Long.toString(x.value());
 | |
| 		}, x.radix());
 | |
| 	}
 | |
| 
 | |
| 	static Class<?> eitherComparableOrIterable(Object o)
 | |
| 	{
 | |
| 		final boolean comparable;
 | |
| 		return ((comparable = o instanceof Comparable) ^
 | |
| 						o instanceof Iterable)
 | |
| 			? (comparable)
 | |
| 				? Comparable.class
 | |
| 				: Iterable.class
 | |
| 			: java.lang.Class.class;
 | |
| 	}
 | |
| 
 | |
| 	<A, T extends java.util.function.Supplier<A>,
 | |
| 		B, U extends java.util.function.Supplier<B>> U convert(T o)
 | |
| 	{
 | |
| 		throw new UnsupportedOperationException("TODO");
 | |
| 	}
 | |
| 
 | |
| 	@java.lang.annotation.Target(
 | |
| 				java.lang.annotation.ElementType.TYPE_USE)
 | |
| 	@interface Taggable
 | |
| 	{
 | |
| 		String value() default "";
 | |
| 	}
 | |
| 
 | |
| 	{
 | |
| 		int N = 0, X = 1, Y = 2;
 | |
| 		Predicate<T> f = y->N<y.intValue();
 | |
| 		Predicate<T> g = y->X<N&&(Integer)y>N;
 | |
| 		boolean[] bb = {
 | |
| 			X<N||N>Y, X < Y, X <Y, X <(Y), X<(Y), (X)<Y,
 | |
| 			Double.isFinite(X<<Y),
 | |
| 			X<=Y, X<(int)(byte)Y, X<~Y, X<-Y, X<+Y,
 | |
| 		};
 | |
| 		Class<?> klass = GenericsTests.class;
 | |
| 		Class< java.lang.Class<@Taggable("<>")int[][]> [] [] >
 | |
| 		[ ] [ ] $ [ ] [ ];
 | |
| 		if (false) { new GenericsTests<>(); }
 | |
| 		alpha<?> ao;
 | |
| 		alpha<U> au;
 | |
| 		alpha<alpha<U>> aau;
 | |
| 		alpha<Y0<?>> ay0o;
 | |
| 		alpha<Y0<U>> ay0u;
 | |
| 		Y0<alpha<?>> y0ao;
 | |
| 		Y0<alpha<U>> y0au;
 | |
| 	}
 | |
| }
 |