[bv-dev] Container element validation for arrays
Emmanuel Bernard
emmanuel at hibernate.org
Wed Apr 19 15:27:34 EDT 2017
not quite
@Target(FIELD)
@interface Size
@Size(2) String[] arrayOfTwoStrings;
is valid in Java 7 and 8
But
@Target(FIELD, TYPE_USE)
@interface Size
@Size(2) String[] arrayOfTwoStrings;
is ambiguous in Java 8
So the JLS is “backward compatible” in the language designer’s view I suppose. They did not anticipate people wanting to add TYPE_USE to an existing annotation and have a side effect on its usage on arrays.
Emmanuel
> On 19 Apr 2017, at 17:38, Matt Benson <mbenson at apache.org> wrote:
>
> My understanding was that using:
>
> @Size(2) String[] arrayOfTwoStrings;
>
> was basically "wrong" according to the new annotation semantics. Rather you'd have:
>
> @Size(2) String[] arrayOfTwoCharacterCodes;
> String @Size(2) [] arrayOfTwoStrings;
>
> The "nuclear" option is to adopt this wholeheartedly in BV 2.0. We could additionally support a "compatibility mode" that, if enabled, would preserve the BV 1.x constrained array semantics, with no Java-based option to validate each element (as the appropriate constraint position has been hijacked). Alternatively, a given BV implementation could support a special mode to turn on the "new" behavior, but that would probably be much more messy for re-unifying the specification and implementations in the future.
>
> Matt
>
> On Wed, Apr 19, 2017 at 10:09 AM, Michael Nascimento <misterm at gmail.com <mailto:misterm at gmail.com>> wrote:
> On Wed, Apr 19, 2017 at 12:03 PM, Gunnar Morling <gunnar at hibernate.org <mailto:gunnar at hibernate.org>> wrote:
> Then we cannot tell what's the target of the @Size annotation, String
> or String[]. As per Java 8's annotation semantics it can be both
> (provided FIELD and TYPE_USE are among the supported element types).
>
> This point worries me. So you're saying there's a flaw in *the language design* for this JSR in this particular case, is that right? I said it before, but since now we got to a point you''re stating (maybe rightfully, don't take me wrong!) the language is broken in the specific case of annotations involving arrays, it would be nice to contact the spec leads for the JSR in order to see (a) if we missed something (then we should revisit the solution) or (b) to get the language fixed for Java SE 10 (for 9 I think it wouldn't make it even though it's a bug fix) and in this case provide no support until we release BV for that version of Java.
>
> Regards,
> Michael
>
> _______________________________________________
> beanvalidation-dev mailing list
> beanvalidation-dev at lists.jboss.org <mailto:beanvalidation-dev at lists.jboss.org>
> https://lists.jboss.org/mailman/listinfo/beanvalidation-dev <https://lists.jboss.org/mailman/listinfo/beanvalidation-dev>
>
> _______________________________________________
> beanvalidation-dev mailing list
> beanvalidation-dev at lists.jboss.org
> https://lists.jboss.org/mailman/listinfo/beanvalidation-dev
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://lists.jboss.org/pipermail/beanvalidation-dev/attachments/20170419/28e4237d/attachment-0001.html
More information about the beanvalidation-dev
mailing list