Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/andyglow/scaladoc
Deps-Free Scaladoc AST, Parser and Macro-based Extractor and Compiler Plugin to carry over
https://github.com/andyglow/scaladoc
ast compiler-plugin parser scala scaladoc
Last synced: 3 months ago
JSON representation
Deps-Free Scaladoc AST, Parser and Macro-based Extractor and Compiler Plugin to carry over
- Host: GitHub
- URL: https://github.com/andyglow/scaladoc
- Owner: andyglow
- Created: 2020-04-21T22:36:33.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-09-26T12:43:51.000Z (3 months ago)
- Last Synced: 2024-10-03T08:12:49.410Z (3 months ago)
- Topics: ast, compiler-plugin, parser, scala, scaladoc
- Language: Scala
- Homepage:
- Size: 150 KB
- Stars: 2
- Watchers: 4
- Forks: 1
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
#### WORK IS STILL PRIMARILY IN PROGRESS, BUT...
# Scaladoc
[![Build Status](https://cloud.drone.io/api/badges/andyglow/scaladoc/status.svg)](https://cloud.drone.io/andyglow/scaladocx)
[![codecov](https://codecov.io/gh/andyglow/scaladocx/branch/master/graph/badge.svg)](https://codecov.io/gh/andyglow/scaladocx)
![Sonatype Nexus (Releases)](https://img.shields.io/nexus/r/com.github.andyglow/scaladoc-ast_2.11?nexusVersion=2&server=https%3A%2F%2Foss.sonatype.org)
[![mvn: 2.11](https://img.shields.io/badge/dynamic/json.svg?label=mvn%3A%202.11&query=%24.response.docs%5B0%5D.latestVersion&url=https%3A%2F%2Fsearch.maven.org%2Fsolrsearch%2Fselect%3Fq%3Dscaladoc-ast_2.13%26start%3D0%26rows%3D1)](https://search.maven.org/artifact/com.github.andyglow/scaladoc-ast_2.11/)
[![mvn: 2.12](https://img.shields.io/badge/dynamic/json.svg?label=mvn%3A%202.12&query=%24.response.docs%5B0%5D.latestVersion&url=https%3A%2F%2Fsearch.maven.org%2Fsolrsearch%2Fselect%3Fq%3Dscaladoc-ast_2.13%26start%3D0%26rows%3D1)](https://search.maven.org/artifact/com.github.andyglow/scaladoc-ast_2.12/)
[![mvn: 2.13](https://img.shields.io/badge/dynamic/json.svg?label=mvn%3A%202.13&query=%24.response.docs%5B0%5D.latestVersion&url=https%3A%2F%2Fsearch.maven.org%2Fsolrsearch%2Fselect%3Fq%3Dscaladoc-ast_2.13%26start%3D0%26rows%3D1)](https://search.maven.org/artifact/com.github.andyglow/scaladoc-ast_2.13/)This project aims to provide comprehensive toolset for scaladoc manipulations.
- Scaladoc AST (Tags, Markdown)
- Parser
- Compiler Plugin that can be used to embed scaladocs of classes into classes bytecode so this can be reused later on
- Extractor that can be used to extract scaladocs for class from
- attachments (see scala macro for attachments)
- class bytecode
- source file> Original `Scaladoc` [Documentation link](https://docs.scala-lang.org/overviews/scaladoc/for-library-authors.html)
## Scaladoc AST
This Scaladoc model allows user to have pretty detailed view on class description.
It covers not only scaladoc tags but also recognizes markdown markup if used for certain type of tags.Here is the model.
```
Span = PlainText (String)
| Monospace (String)
| Italic (String)
| Bold (String)
| Underline (String)
| Superscript (String)
| Subscript (String)
| Link (String)
| CodeBlock (String)Markup = Span
| Heading (Level String)
| Paragraph (List Span)
| Document (List Markup)Tag = Description (Markup)
| Constructor (Markup)
| Param (String Markup)
| TypeParam (String Markup)
| Returns (Markup)
| Throws (String Markup)
| See (Markup)
| Note (Markup)
| Example (Markup)
| UseCase (Markup)
| Author (String)
| Version (String)
| Since (String)
| Todo (Markup)
| Deprecated (Markup)
| Migration (Markup)
| Group (String)
| GroupName (String String)
| GroupDescription (String Markup)
| GroupPriority (String Int)
| Documentable
| InheritDoc
| OtherTag (String Markup)
Scaladoc = List Tag
```## Parser
Parser is just parser. Takes text and either gives you parsed model or an error.
```scala
import scaladoc._val text = """/** = Title =
| *
| * Description
| *
| * @param a Param A
| * @param b Param B
| */
|""".stripMarginval scaladoc = Scaladoc fromString text
```
## Compiler plugin
In scala world we got used to the idea that pretty much anything we can derive
out of whatever we have - case classes (product), sealed traits (sum), etc.
And that is cool. But sometimes you need more, you want tour models to be documented and moreover,
that documentation to be distributed alongside with the bytecode and can be used by other
tools that derives something.Like tools that derives json schemas, avro schemas, swagger, openapi, etc. could use that info
to enrich resulted schemas with titles, descriptions, etc based on only scaladoc.So what this plugin does is
- validate scaladoc
- packs it into java annotation so that it could be carried over## Extractor
This guy is used to extract scaladoc information from specified type.
It will inspect all possible places to get the job done, it will check attachments,
java annotations and lastly source code (if available) to provide your tool with extracted scaladoc.```scala
import scaladoc._val scaladoc = Scaladoc.of[Foo]
```## Usage
For AST, Parser and Extractor please add following two lines into your `build.sbt`
```sbt
libraryDependencies += "com.github.andyglow" %% "scaladoc-ast" % ""
libraryDependencies += "com.github.andyglow" %% "scaladoc-parser" % ""
```For scaladoc embedding functionality, please consider adding these lines into your `build.sbt`
```sbt
autoCompilerPlugins := truelibraryDependencies += compilerPlugin("com.github.andyglow" % ("scaladoc-compiler-plugin_" + scalaVersion.value) % "")
libraryDependencies += "com.github.andyglow" %% "scaladoc-parser" % "" % Provided
libraryDependencies += "com.github.andyglow" %% "scaladoc-ast" % ""
```