runtime(java): Complement the recognition of type parameter sections
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>
This commit is contained in:
committed by
Christian Brabandt
parent
1be5b375c4
commit
159d392427
@ -1,11 +1,11 @@
|
||||
// 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;
|
||||
@ -125,6 +125,12 @@ class GenericsTests<T extends Number & Comparable<? super T>, U>
|
||||
: 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
|
||||
|
@ -2,10 +2,10 @@
|
||||
// VIM_TEST_SETUP let g:java_highlight_signature = 1
|
||||
// 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;
|
||||
@ -125,6 +125,12 @@ class Generics$Tests<T extends Number & Comparable<? super T>, U>
|
||||
: 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
|
||||
|
@ -183,4 +183,10 @@ class MethodReferencesTests
|
||||
return T::toString; /* "e" */
|
||||
}
|
||||
}
|
||||
|
||||
static {
|
||||
((Supplier<Class<?>>)((Supplier<C2.C21>)()->new
|
||||
<Object>C2().new <Object> C21(new<Object>
|
||||
C1< Object >((C1<?>)null)))::getClass).get();
|
||||
}
|
||||
}
|
||||
|
@ -183,4 +183,10 @@ class MethodReferences$Tests
|
||||
return T::toString; /* "e" */
|
||||
}
|
||||
}
|
||||
|
||||
static {
|
||||
((Supplier<Class<?>>)((Supplier<C2.C21>)()->new
|
||||
<Object>C2().new <Object> C21(new<Object>
|
||||
C1< Object >((C1<?>)null)))::getClass).get();
|
||||
}
|
||||
}
|
||||
|
@ -1,6 +1,6 @@
|
||||
// VIM_TEST_SETUP let g:java_highlight_functions = 'indent2'
|
||||
// VIM_TEST_SETUP let g:java_highlight_generics = 1
|
||||
// VIM_TEST_SETUP set encoding=utf-8 termencoding=utf-8
|
||||
|
||||
import java.lang.annotation.ElementType;
|
||||
import java.lang.annotation.Target;
|
||||
|
||||
@ -77,6 +77,14 @@ abstract class Indent2MethodsTests
|
||||
|
||||
public static Class<?> classLock() { return Indent2MethodsTests.class; }
|
||||
|
||||
public <E extends Comparable<? super E>> java.util.List<E> filter(
|
||||
java.util.function.Predicate<? super E> filter,
|
||||
java.util.List<? extends E> cs)
|
||||
{
|
||||
return cs.stream().filter(filter)
|
||||
.collect(java.util.stream.Collectors.toUnmodifiableList());
|
||||
}
|
||||
|
||||
@Override @SuppressWarnings("cast")
|
||||
public String toString() { return (String) "Indent2MethodsTests"; }
|
||||
}
|
||||
|
@ -1,6 +1,6 @@
|
||||
// VIM_TEST_SETUP let g:java_highlight_functions = 'indent4'
|
||||
// VIM_TEST_SETUP let g:java_highlight_generics = 1
|
||||
// VIM_TEST_SETUP set encoding=utf-8 termencoding=utf-8
|
||||
|
||||
import java.lang.annotation.ElementType;
|
||||
import java.lang.annotation.Target;
|
||||
|
||||
@ -77,6 +77,14 @@ abstract class Indent4MethodsTests
|
||||
|
||||
public static Class<?> classLock() { return Indent4MethodsTests.class; }
|
||||
|
||||
public <E extends Comparable<? super E>> java.util.List<E> filter(
|
||||
java.util.function.Predicate<? super E> filter,
|
||||
java.util.List<? extends E> cs)
|
||||
{
|
||||
return cs.stream().filter(filter)
|
||||
.collect(java.util.stream.Collectors.toUnmodifiableList());
|
||||
}
|
||||
|
||||
@Override @SuppressWarnings("cast")
|
||||
public String toString() { return (String) "Indent4MethodsTests"; }
|
||||
}
|
||||
|
@ -1,6 +1,6 @@
|
||||
// VIM_TEST_SETUP let g:java_highlight_functions = 'indent8'
|
||||
// VIM_TEST_SETUP let g:java_highlight_generics = 1
|
||||
// VIM_TEST_SETUP set encoding=utf-8 termencoding=utf-8
|
||||
|
||||
import java.lang.annotation.ElementType;
|
||||
import java.lang.annotation.Target;
|
||||
|
||||
@ -77,6 +77,14 @@ abstract class Indent8MethodsTests
|
||||
|
||||
public static Class<?> classLock() { return Indent8MethodsTests.class; }
|
||||
|
||||
public <E extends Comparable<? super E>> java.util.List<E> filter(
|
||||
java.util.function.Predicate<? super E> filter,
|
||||
java.util.List<? extends E> cs)
|
||||
{
|
||||
return cs.stream().filter(filter)
|
||||
.collect(java.util.stream.Collectors.toUnmodifiableList());
|
||||
}
|
||||
|
||||
@Override @SuppressWarnings("cast")
|
||||
public String toString() { return (String) "Indent8MethodsTests"; }
|
||||
}
|
||||
|
@ -1,6 +1,6 @@
|
||||
// VIM_TEST_SETUP let g:java_highlight_functions = 'style'
|
||||
// VIM_TEST_SETUP let g:java_highlight_generics = 1
|
||||
// VIM_TEST_SETUP set encoding=utf-8 termencoding=utf-8
|
||||
|
||||
import java.lang.annotation.ElementType;
|
||||
import java.lang.annotation.Target;
|
||||
|
||||
@ -77,6 +77,14 @@ abstract class StyleMethodsTests
|
||||
|
||||
public static Class<?> classLock() { return StyleMethodsTests.class; }
|
||||
|
||||
public <E extends Comparable<? super E>> java.util.List<E> filter(
|
||||
java.util.function.Predicate<? super E> filter,
|
||||
java.util.List<? extends E> cs)
|
||||
{
|
||||
return cs.stream().filter(filter)
|
||||
.collect(java.util.stream.Collectors.toUnmodifiableList());
|
||||
}
|
||||
|
||||
@Override @SuppressWarnings("cast")
|
||||
public String toString() { return (String) "StyleMethodsTests"; }
|
||||
}
|
||||
|
Reference in New Issue
Block a user