On 06/04/2014 12:34 PM, Paul Sandoz wrote:
On Jun 4, 2014, at 12:25 PM, Paul Sandoz <paul.san...@oracle.com> wrote:
You might consider the following a more streamy way, not tested! up to you :-)

    private static Object[][] provider() {
        Stream<? extends Executable> s = filterData(Test.class.getMethods(), 
null);
        s = Stream.concat(s, filterData(Test.class.getConstructors(), null));
        s = Stream.concat(s, filterData(Test.class.getConstructors(), null));
        return streamToArray(s);
    }

    private static Stream<? extends Executable> filterData(Executable[] es, 
Class<?> c) {
        return Stream.of(es).filter(m -> m.getDeclaringClass() == c);
    }
Plus you can drop the "? extends" bit of "? extends Executable", that was a 
hangover from some other mini experiment.

returning a Foo<? extends XXX> is usually a design error (apart from covariant return type in case of overriding but usually it's because the API was designed before the introduction of generics), because all client codes will have to declare a Foo<? extends XXX>.
Here, it's better to introduce a type variable

    private static <E extends Executable> Stream<E> filterData(E[] es, Class<?> 
c) {
       return Stream.of(es).filter(m -> m.getDeclaringClass() == c);
    }



Paul.



regards,
Rémi

Reply via email to