Skip to content

Commit

Permalink
Issue #2944: New logging requirements
Browse files Browse the repository at this point in the history
  • Loading branch information
dambatenne committed Oct 25, 2023
1 parent 38e09dd commit f84e818
Showing 1 changed file with 90 additions and 1 deletion.
91 changes: 90 additions & 1 deletion core/src/main/kotlin/utilities/DokkaLogging.kt
Original file line number Diff line number Diff line change
Expand Up @@ -10,10 +10,99 @@ public interface DokkaLogger {
public var warningsCount: Int
public var errorsCount: Int

/**
* This level is for showing significant execution steps.
*
* What could be considered `progress`:
* - Documentation generation started
* - Documentation generation has successfully finished
*
* What could not be considered `progress`:
* - Processing submodules
* - Transforming pages
*
* These can be shown by default if there is no other way to track progress (like Gradle's progress bar),
* and should be at the same level or one of the debug levels otherwise.
*
* Dokka's `progress` maps to:
*
* * CLI - shown by default
* * Gradle - `info`
* * Maven - `debug`
*/
public fun progress(message: String)

/**
* This level is for logging non-user actionable messages,
* like internal errors that cannot be fixed/worked around by users themselves or atomic generation steps.
* These outputs could be attached to particular Dokka issues, so that the Dokka team could analyze them.
*
* What could be considered `debug`:
* * Processing submodules
* * Transforming
*
* What could not be considered `debug`:
* * Cannot resolve a sample for $functionName: $fqLink
*
* Dokka's `debug` maps to:
* * CLI - `debug`
* * Gradle - `debug`
* * Maven - `debug`
*/
public fun debug(message: String)

/**
* This level is for logging useful messages about Dokka usage.
*
* What could be considered `info`:
* * The HTML output is generated here: <PATH>
*
* What could not be considered `info`:
* * Cannot resolve a sample for $functionName: $fqLink
*
* Dokka's `info` maps to:
* * CLI - shown by default
* * Gradle - `info`
* * Maven - `info`
*/
public fun info(message: String)
public fun progress(message: String)

/**
* This level is for logging messages about issues during the documentation generation,
* which do not stop the generation with an error but somehow affect the final result.
* For example, if a particular source link could not be rendered.
* It is mandatory for the messages of this level to be understandable to the user.
*
* What could be considered a `warn`:
* * Cannot resolve a sample for $functionName: $fqLink. Please check the comments for the function.
* The link should be formed according to the following rules:...
*
* What could not be considered a `warn`:
* * Dokka is performing: $generationName
*
* Dokka's `warn` maps to:
* * CLI - `warn`
* * Gradle - `warn`
* * Maven - `warn`
*/
public fun warn(message: String)

/**
* This level is for logging error messages that describe what prevented Dokka from proceeding
* with successful documentation generation. Likely, users will submit these error messages to Dokka's issues.
*
* What could be considered an `error`:
* * Something went wrong, and the generation could not be performed. Please report it to the Dokka team.
*
* What could not be considered an `error`:
* * Cannot resolve a sample for $functionName: $fqLink. Please check the comments for the function.
* The link should be formed according to the following rules:...
*
* Dokka's `error` maps to:
* * CLI - `error`
* * Gradle - `error`
* * Maven - `error`
*/
public fun error(message: String)
}

Expand Down

0 comments on commit f84e818

Please sign in to comment.