Uploaded image for project: 'JDK'
  1. JDK
  2. JDK-6998735

Variable arity parameter type involving arrays

XMLWordPrintable

    • Icon: Enhancement Enhancement
    • Resolution: Fixed
    • Icon: P4 P4
    • 7
    • 7
    • specification
    • None
    • rc
    • generic
    • generic
    • Verified

      JLS3 allows legacy array syntax ('int x[]') for a variable-arity parameter ('int... x[]') but neither javac nor Eclipse ever supported it. We should seize this opportunity to ban it by allowing only an identifier after '...' in 8.4.1:

      LastFormalParameter:
        VariableModifiers_opt Type '...' Identifier // Note '...' is not _opt
        FormalParameter

      "The last formal parameter in a list may be a variable arity parameter, indicated by an ellipsis following the type. ***Legacy array syntax (10.2) is not supported for a variable arity parameter.***"

      Regarding legacy array syntax elsewhere in the JLS:

      JLS3 14.4.1 says: "The type of the variable is denoted by the Type that appears in the local variable declaration, followed by any bracket pairs that follows the Identifier in the declarator."

      This text applies to any variable declaration at an array type, so JLS 10.2 should include it (suitably modified) after the paragraph "The [] may appear as part...". 8.3's paragraph "Variable declarations involving array types are discussed in 10.2" then has more utility.

      10.2's reference to 8.3 should also point to 14.4.1.

            abuckley Alex Buckley
            abuckley Alex Buckley
            Votes:
            0 Vote for this issue
            Watchers:
            0 Start watching this issue

              Created:
              Updated:
              Resolved:
              Imported:
              Indexed: