Allow to configure the criticality when an include is missing
ggrossetie opened this issue · 7 comments
We might want to introduce an attribute to control the criticality when an include is missing:
kroki-plantuml-unresolved-local-include
warn
: log a warningerror
: throw an exceptionignore
(orsuppress
): silently ignore
We could do the same for remote include. The default value of local include would be error and the default value for remote include would be warn.
Follow-up #141
This just bit me again. the fix of putting in
<c4/C4_Context.puml>
compiles correctly, as mentioned in my bug (#49). but, the
##[error]Skipping preprocessing of PlantUML standard library include file '<c4/C4_Context.puml>'
line is dumped into stderr
which my new build pipeline automatically assumes is an error. I am going to have to get creative with grep or something so i can filter out these errors vs actual errors in my pipeline configs.
just mentioning because it just ground me to a halt for the moment.
Would it be possible that (asciidoctor-)kroki support a special comment in the PlantUML diagram itself?
Eg. if a line starts with 'optional include
then no error is generated if the following include cannot be resolved.
This could solve the problem with plantuml-stdlib/C4-PlantUML#156 if I would add a line like
' convert it with additional command line argument -DRELATIVE_INCLUDE="." to use locally
!if %variable_exists("RELATIVE_INCLUDE")
' optional include: Kroki and Antora can ignore the not supported calculated !include (no command line argument -D is supported at all)
!include %get_variable_value("RELATIVE_INCLUDE")/C4_Context.puml
!else
!include https://raw.githubusercontent.com/kirchsth/C4-PlantUML/extended/C4_Context.puml
!endif
BR Helmut
This just bit me again. the fix of putting in <c4/C4_Context.puml> compiles correctly, as mentioned in my bug (#49). but, the (...) line is dumped into stderr which my new build pipeline automatically assumes is an error. I am going to have to get creative with grep or something so i can filter out these errors vs actual errors in my pipeline configs.
Indeed, console.warn
is an alias of console.error
.
In this case, I think we should use console.log
to print this message to stdout
(instead of stderr
).
Arguably, we could also just suppress this message (by default).
Would it be possible that (asciidoctor-)kroki support a special comment in the PlantUML diagram itself?
Eg. if a line starts with 'optional include then no error is generated if the following include cannot be resolved.
I'm not sure... maybe... 🤔
console.log
instead of error would be nice to be able to filter messages like this using Antora level-key
Skipping preprocessing of PlantUML include, because reading the referenced local file 'C4_Context.puml' caused an error:
Error: ENOENT: no such file or directory, open 'C4_Context.puml'
But maybe I'm missing something? These error messages does not format like the other Antora log messages:
[13:12:33.521] WARN (asciidoctor): unterminated listing block
file: modules/ROOT/pages/information-products/power-redispatch.adoc:192
source: ... (refname: main)
Maybe something more has to be done to send the logs through Antora logger?
We are using console
(https://developer.mozilla.org/en-US/docs/Web/API/Console) whereas Antora is using a proper logger called pino.
I also think that some logs are too pedantic... It's hard to find the right balance 😬
I've decided to reduce the severity from warn to info. I think we should manage the criticality using the logger level.