scala / bug

Scala 2 bug reports only. Please, no questions — proper bug reports only.
https://scala-lang.org
232 stars 21 forks source link

Support for global scaladoc macro definitions #7835

Open scabug opened 11 years ago

scabug commented 11 years ago

I keep finding that I'm defining the same Scaladoc macros at the beginning of each class/object/trait definition. For instance, I like to use a macro for the name of the project that puts the name in italics and links to the project's web-site.

@define MYPROJECT ''[[http://myproject.org/ My Project]]''

This macro ensures consistent formatting, eliminates the risk of URL typos (if I defined it right), and avoids a lot of typing.

But I would like to avoid a lot more typing: specifically, the definition of that macro hundreds of times (which creates a maintenance chore if I need to modify my project's name or URL, and which increases the risk that I will define it incorrectly in some instances).

An obvious solution would be to allow Scaladoc macros to be defined with a global scope. For example, if I specified the $MYPROJECT macro definition in the root package object for a whole library, then all elements belonging to the library would inherit that macro definition and I would only need to type its definition in once!

Alternatively, or additionally, it would be nice to be able to define macros on the Scaladoc command line, that would also be applied globally to all generated Scaladocs. This would be particularly useful if it was necessary to tailor or configure the Scaladoc for a particular application or build.

Would this be possible?

scabug commented 11 years ago

Imported From: https://issues.scala-lang.org/browse/SI-7835?orig=1 Reporter: Mike Allen (mja)

scabug commented 10 years ago

Christian Krause (wookietreiber) said: I would find this very useful, too.

scabug commented 10 years ago

Christian Krause (wookietreiber) said: What I currently do to work around this issue is to define a documentation template trait, e.g.:

package org.my.parent

package object child {
  /**
    * @define foo bar
    */
  private[child] trait DocDummy
}

This works surprisingly well, but has some drawbacks:

But this approach also has some advantages:

scabug commented 7 years ago

Jonathan Brachthäuser (b-studios) said: Please note that [https://wiki.scala-lang.org/display/SW/Tags+and+Annotations] still claims that macro definitions on packages are supported. I was surprised to see that this is not the case as witnessed by this issue.

unkarjedy commented 2 years ago

Somehow similar issue in IntelliJ Scala Plugin: https://youtrack.jetbrains.com/issue/SCL-20122 (see the comment)

From https://docs.scala-lang.org/overviews/scaladoc/for-library-authors.html#macros

@define <name> <definition> allows use of $name in other Scaladoc comments within the same source file which will be expanded to the contents of

som-snytt commented 2 years ago

While fixing Scaladoc errors in the Scala 2 project recently, I noticed that some errors were due to the source file limitation. The naive expectation is that the macro definition is "inherited" from a parent class in a different source file.

unkarjedy commented 2 years ago

Looks like the specification implies that macro can be used in unrelated classes in the same file. There is nothing about inheritance. So you do not even need to inherit from some base class to use some macro in the same file.

Though, from my POV that would be quite a strange behavior. Maybe the spec wording should be refined?