* [PATCH] gwl/ui: Check for log-events configuration
@ 2022-06-03 18:32 Olivier Dion
2022-06-04 15:00 ` Ricardo Wurmus
2022-06-06 19:48 ` [PATCH 1/3] " Olivier Dion
0 siblings, 2 replies; 12+ messages in thread
From: Olivier Dion @ 2022-06-03 18:32 UTC (permalink / raw)
To: gwl-devel; +Cc: Olivier Dion
Some GWL sub-commands such as `graph' do not accept a log event configuration.
This results in returning `#f' from `(%config 'log-events)'
Fix this by checking that 'log-events was configured.
---
gwl/ui.scm | 6 ++++--
1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/gwl/ui.scm b/gwl/ui.scm
index 35bd127..92cf451 100644
--- a/gwl/ui.scm
+++ b/gwl/ui.scm
@@ -65,8 +65,10 @@
(define (log-event type . message)
(define print?
- (or (member 'all (%config 'log-events))
- (member type (%config 'log-events))))
+ (let ((log-events (%config 'log-events)))
+ (and log-events
+ (or (member 'all (%config 'log-events))
+ (member type (%config 'log-events))))))
(when print?
(case type
((error)
--
2.36.1
^ permalink raw reply related [flat|nested] 12+ messages in thread
* Re: [PATCH] gwl/ui: Check for log-events configuration
2022-06-03 18:32 [PATCH] gwl/ui: Check for log-events configuration Olivier Dion
@ 2022-06-04 15:00 ` Ricardo Wurmus
2022-06-04 15:10 ` Olivier Dion via
2022-06-06 19:48 ` [PATCH 1/3] " Olivier Dion
1 sibling, 1 reply; 12+ messages in thread
From: Ricardo Wurmus @ 2022-06-04 15:00 UTC (permalink / raw)
To: Olivier Dion; +Cc: gwl-devel
Olivier Dion <olivier.dion@polymtl.ca> writes:
> Some GWL sub-commands such as `graph' do not accept a log event configuration.
> This results in returning `#f' from `(%config 'log-events)'
I don’t understand how this leads to a problem. Do any of the features
of “graph” use “log-event”?
Generally, I’d prefer to give “log-events” a better default. I can’t
imagine a situation where #F (rather than the empty list) would be
appropriate.
--
Ricardo
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH] gwl/ui: Check for log-events configuration
2022-06-04 15:00 ` Ricardo Wurmus
@ 2022-06-04 15:10 ` Olivier Dion via
2022-06-06 10:32 ` Ricardo Wurmus
0 siblings, 1 reply; 12+ messages in thread
From: Olivier Dion via @ 2022-06-04 15:10 UTC (permalink / raw)
To: Ricardo Wurmus; +Cc: gwl-devel
On Sat, 04 Jun 2022, Ricardo Wurmus <rekado@elephly.net> wrote:
> Olivier Dion <olivier.dion@polymtl.ca> writes:
>
>> Some GWL sub-commands such as `graph' do not accept a log event configuration.
>> This results in returning `#f' from `(%config 'log-events)'
>
> I don’t understand how this leads to a problem. Do any of the features
> of “graph” use “log-event”?
Yes. `load-workflow' -> `load-workflow*' -> `load*' -> `log-event 'info
"Loading workflow file"'.
> Generally, I’d prefer to give “log-events” a better default. I can’t
> imagine a situation where #F (rather than the empty list) would be
> appropriate.
The empty list would be a more sane choice I agree. I'll send a v2 with
this change. Also, the `print?` predicate could be memoize with `mlambda'?
--
Olivier Dion
oldiob.dev
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH] gwl/ui: Check for log-events configuration
2022-06-04 15:10 ` Olivier Dion via
@ 2022-06-06 10:32 ` Ricardo Wurmus
2022-06-06 13:25 ` Olivier Dion via
0 siblings, 1 reply; 12+ messages in thread
From: Ricardo Wurmus @ 2022-06-06 10:32 UTC (permalink / raw)
To: Olivier Dion; +Cc: gwl-devel
Olivier Dion <olivier.dion@polymtl.ca> writes:
> On Sat, 04 Jun 2022, Ricardo Wurmus <rekado@elephly.net> wrote:
>> Olivier Dion <olivier.dion@polymtl.ca> writes:
>>
>>> Some GWL sub-commands such as `graph' do not accept a log event configuration.
>>> This results in returning `#f' from `(%config 'log-events)'
>>
>> I don’t understand how this leads to a problem. Do any of the features
>> of “graph” use “log-event”?
>
> Yes. `load-workflow' -> `load-workflow*' -> `load*' -> `log-event 'info
> "Loading workflow file"'.
I see.
Does it make sense to support the --log-events option on “graph”? Or
should we just work around it in the log-event procedure?
>> Generally, I’d prefer to give “log-events” a better default. I can’t
>> imagine a situation where #F (rather than the empty list) would be
>> appropriate.
>
> The empty list would be a more sane choice I agree. I'll send a v2 with
> this change. Also, the `print?` predicate could be memoize with `mlambda'?
Yes, “print?” could me memoized.
--
Ricardo
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH] gwl/ui: Check for log-events configuration
2022-06-06 10:32 ` Ricardo Wurmus
@ 2022-06-06 13:25 ` Olivier Dion via
2022-06-06 18:51 ` Olivier Dion via
0 siblings, 1 reply; 12+ messages in thread
From: Olivier Dion via @ 2022-06-06 13:25 UTC (permalink / raw)
To: Ricardo Wurmus; +Cc: gwl-devel
On Mon, 06 Jun 2022, Ricardo Wurmus <rekado@elephly.net> wrote:
> Olivier Dion <olivier.dion@polymtl.ca> writes:
>
>> On Sat, 04 Jun 2022, Ricardo Wurmus <rekado@elephly.net> wrote:
>>> Olivier Dion <olivier.dion@polymtl.ca> writes:
>>>
>>>> Some GWL sub-commands such as `graph' do not accept a log event configuration.
>>>> This results in returning `#f' from `(%config 'log-events)'
>>>
>>> I don’t understand how this leads to a problem. Do any of the features
>>> of “graph” use “log-event”?
>>
>> Yes. `load-workflow' -> `load-workflow*' -> `load*' -> `log-event 'info
>> "Loading workflow file"'.
>
> I see.
>
> Does it make sense to support the --log-events option on “graph”? Or
> should we just work around it in the log-event procedure?
I think that in all cases, the default of `(%config 'log-events)' should
be '() like you proposed. In that way, if new commands are added in the
future, this undesired behavior won't re-surface.
As for adding the `--log-events` option to the `graph' command. The
thing is that the output of the graph is printed on stdout. Adding
log-event would add an extra step in order to separate the logs from the
desired output. Thus, I think that if we do that, we also need to add a
`--output=DOT' option for redirecting the graph's output away from the
terminal.
WDY?
--
Olivier Dion
oldiob.dev
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH] gwl/ui: Check for log-events configuration
2022-06-06 13:25 ` Olivier Dion via
@ 2022-06-06 18:51 ` Olivier Dion via
0 siblings, 0 replies; 12+ messages in thread
From: Olivier Dion via @ 2022-06-06 18:51 UTC (permalink / raw)
To: Ricardo Wurmus; +Cc: gwl-devel
On Mon, 06 Jun 2022, Olivier Dion <olivier.dion@polymtl.ca> wrote:
>> Does it make sense to support the --log-events option on “graph”? Or
>> should we just work around it in the log-event procedure?
>
> I think that in all cases, the default of `(%config 'log-events)' should
> be '() like you proposed. In that way, if new commands are added in the
> future, this undesired behavior won't re-surface.
The only clean way I see of doing this is to set the switch as global.
$ guix workflow --log-event=all run|graph|web
--
Olivier Dion
oldiob.dev
^ permalink raw reply [flat|nested] 12+ messages in thread
* [PATCH 1/3] gwl/ui: Check for log-events configuration
2022-06-03 18:32 [PATCH] gwl/ui: Check for log-events configuration Olivier Dion
2022-06-04 15:00 ` Ricardo Wurmus
@ 2022-06-06 19:48 ` Olivier Dion
2022-06-06 19:48 ` [PATCH 2/3] gwl/config: Share log-event switch with subcommands Olivier Dion
` (2 more replies)
1 sibling, 3 replies; 12+ messages in thread
From: Olivier Dion @ 2022-06-06 19:48 UTC (permalink / raw)
To: Olivier Dion, gwl-devel
Some GWL sub-commands might not accept the log-events switch.
This results in returning `#f' from `(%config 'log-events)'
Fix this by checking that 'log-events was configured. Also memoize the result.
---
gwl/ui.scm | 15 +++++++++++----
1 file changed, 11 insertions(+), 4 deletions(-)
diff --git a/gwl/ui.scm b/gwl/ui.scm
index 35bd127..bfe20a9 100644
--- a/gwl/ui.scm
+++ b/gwl/ui.scm
@@ -17,6 +17,8 @@
#:use-module (gwl config)
#:use-module (gwl errors)
#:use-module (guix colors)
+ #:use-module ((guix memoization)
+ #:select (mlambdaq))
#:use-module (srfi srfi-26)
#:use-module (ice-9 format)
#:export (G_
@@ -63,11 +65,16 @@
(format (current-error-port) "~a"
(prefix-color prefix))))
+(define print?
+ (mlambdaq (type)
+ (let ((log-events (%config 'log-events)))
+ (and log-events
+ (or (member 'all log-events)
+ (member type log-events))
+ #t))))
+
(define (log-event type . message)
- (define print?
- (or (member 'all (%config 'log-events))
- (member type (%config 'log-events))))
- (when print?
+ (when (print? type)
(case type
((error)
(print-diagnostic-prefix (G_ "error: ") #:colors %error-color))
--
2.36.1
^ permalink raw reply related [flat|nested] 12+ messages in thread
* [PATCH 2/3] gwl/config: Share log-event switch with subcommands
2022-06-06 19:48 ` [PATCH 1/3] " Olivier Dion
@ 2022-06-06 19:48 ` Olivier Dion
2022-06-12 9:03 ` Ricardo Wurmus
2022-06-06 19:49 ` [PATCH 3/3] graph: Add output switch Olivier Dion
2022-06-12 9:08 ` [PATCH 1/3] gwl/ui: Check for log-events configuration Ricardo Wurmus
2 siblings, 1 reply; 12+ messages in thread
From: Olivier Dion @ 2022-06-06 19:48 UTC (permalink / raw)
To: Olivier Dion, gwl-devel
The alternative would be to define the switch at the top configuration. Using
`(wanted '((keywords . (log-events))))' for sub-configurations. However,
there's seem to be a problem in guile-config for correctly parsing global
keywords and sub-commands at the same time.
---
gwl/config.scm.in | 30 ++++++++++++++++++------------
1 file changed, 18 insertions(+), 12 deletions(-)
diff --git a/gwl/config.scm.in b/gwl/config.scm.in
index 9ab58e5..728eec5 100644
--- a/gwl/config.scm.in
+++ b/gwl/config.scm.in
@@ -42,6 +42,20 @@
(define %gwl-git-browse-url
"https://git.sv.gnu.org/cgit/gwl.git")
+(define log-event-switch
+ (switch
+ (name 'log-events)
+ (character #\l)
+ (synopsis "Events to log")
+ (default '(execute error info))
+ (example "error,info,execute,cache,debug,guix")
+ (test list?)
+ (handler
+ (lambda (value)
+ (when (string? value)
+ (map string->symbol
+ (string-split value #\,)))))))
+
(define config
(configuration
(name '#{guix workflow}#)
@@ -71,6 +85,7 @@ workflow.")
(example "/path/to/my-workflow.w"))))
(keywords
(list
+ log-event-switch
(switch
(name 'verbosity)
(character #\v)
@@ -78,18 +93,6 @@ workflow.")
(default 2)
(test integer?)
(handler string->number))
- (switch
- (name 'log-events)
- (character #\l)
- (synopsis "Events to log")
- (default '(execute error info))
- (example "error,info,execute,cache,debug,guix")
- (test list?)
- (handler
- (lambda (value)
- (when (string? value)
- (map string->symbol
- (string-split value #\,))))))
(switch
(name 'input)
(character #\i)
@@ -143,6 +146,9 @@ workflow.")
(description
"This command generates a visualization (e.g. in Graphviz Dot
format) of the specified workflow.")
+ (keywords
+ (list
+ log-event-switch))
(arguments
(list
(argument
--
2.36.1
^ permalink raw reply related [flat|nested] 12+ messages in thread
* [PATCH 3/3] graph: Add output switch
2022-06-06 19:48 ` [PATCH 1/3] " Olivier Dion
2022-06-06 19:48 ` [PATCH 2/3] gwl/config: Share log-event switch with subcommands Olivier Dion
@ 2022-06-06 19:49 ` Olivier Dion
2022-06-12 9:05 ` Ricardo Wurmus
2022-06-12 9:08 ` [PATCH 1/3] gwl/ui: Check for log-events configuration Ricardo Wurmus
2 siblings, 1 reply; 12+ messages in thread
From: Olivier Dion @ 2022-06-06 19:49 UTC (permalink / raw)
To: Olivier Dion, gwl-devel
---
gwl/config.scm.in | 9 ++++++++-
gwl/main.scm | 13 ++++++++++++-
2 files changed, 20 insertions(+), 2 deletions(-)
diff --git a/gwl/config.scm.in b/gwl/config.scm.in
index 728eec5..1e0b4d0 100644
--- a/gwl/config.scm.in
+++ b/gwl/config.scm.in
@@ -148,7 +148,14 @@ workflow.")
format) of the specified workflow.")
(keywords
(list
- log-event-switch))
+ log-event-switch
+ (switch
+ (name 'output)
+ (character #\o)
+ (default #false)
+ (test string?)
+ (synopsis "Write dot graph to <file>.")
+ (example "<file>"))))
(arguments
(list
(argument
diff --git a/gwl/main.scm b/gwl/main.scm
index 78494fd..7f0fd14 100644
--- a/gwl/main.scm
+++ b/gwl/main.scm
@@ -17,6 +17,7 @@
(define-module (gwl main)
#:use-module (config)
#:use-module (config api)
+ #:use-module ((guix build utils) #:select (mkdir-p))
#:use-module (gwl errors)
#:use-module (gwl process-engines)
#:use-module (gwl web-interface)
@@ -95,5 +96,15 @@
(parameterize ((*current-filename* file-name))
(match (load-workflow file-name)
((? workflow? wf)
- (format #t "~a\n" (workflow->dot wf)))
+
+ (define (flush)
+ (format #t "~a\n" (workflow->dot wf)))
+
+ (define output (%config 'output))
+
+ (if output
+ (begin
+ (mkdir-p (dirname output))
+ (with-output-to-file output flush))
+ (flush)))
(_ (leave (G_ "Failed to process the workflow.~%")))))))))))
--
2.36.1
^ permalink raw reply related [flat|nested] 12+ messages in thread
* Re: [PATCH 2/3] gwl/config: Share log-event switch with subcommands
2022-06-06 19:48 ` [PATCH 2/3] gwl/config: Share log-event switch with subcommands Olivier Dion
@ 2022-06-12 9:03 ` Ricardo Wurmus
0 siblings, 0 replies; 12+ messages in thread
From: Ricardo Wurmus @ 2022-06-12 9:03 UTC (permalink / raw)
To: Olivier Dion; +Cc: gwl-devel
Olivier Dion <olivier.dion@polymtl.ca> writes:
> The alternative would be to define the switch at the top configuration. Using
> `(wanted '((keywords . (log-events))))' for sub-configurations. However,
> there's seem to be a problem in guile-config for correctly parsing global
> keywords and sub-commands at the same time.
Hmm, this patch doesn’t look pretty. What is that problem in
guile-config? Could you please share some details?
--
Ricardo
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH 3/3] graph: Add output switch
2022-06-06 19:49 ` [PATCH 3/3] graph: Add output switch Olivier Dion
@ 2022-06-12 9:05 ` Ricardo Wurmus
0 siblings, 0 replies; 12+ messages in thread
From: Ricardo Wurmus @ 2022-06-12 9:05 UTC (permalink / raw)
To: Olivier Dion; +Cc: gwl-devel
Hi Olivier,
> diff --git a/gwl/main.scm b/gwl/main.scm
> index 78494fd..7f0fd14 100644
> --- a/gwl/main.scm
> +++ b/gwl/main.scm
> @@ -17,6 +17,7 @@
> (define-module (gwl main)
> #:use-module (config)
> #:use-module (config api)
> + #:use-module ((guix build utils) #:select (mkdir-p))
> #:use-module (gwl errors)
> #:use-module (gwl process-engines)
> #:use-module (gwl web-interface)
> @@ -95,5 +96,15 @@
> (parameterize ((*current-filename* file-name))
> (match (load-workflow file-name)
> ((? workflow? wf)
> - (format #t "~a\n" (workflow->dot wf)))
> +
> + (define (flush)
> + (format #t "~a\n" (workflow->dot wf)))
> +
> + (define output (%config 'output))
> +
> + (if output
> + (begin
> + (mkdir-p (dirname output))
> + (with-output-to-file output flush))
> + (flush)))
> (_ (leave (G_ "Failed to process the workflow.~%")))))))))))
The name “flush” really confused me, because it already has a meaning
with regard to buffering.
I’d prefer to rewrite this
(format #t "~a\n" (workflow->dot wf))
to
(format port "~a\n" (workflow->dot wf))
and then arrange for port to either be (current-output-port) or some
file port.
--
Ricardo
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH 1/3] gwl/ui: Check for log-events configuration
2022-06-06 19:48 ` [PATCH 1/3] " Olivier Dion
2022-06-06 19:48 ` [PATCH 2/3] gwl/config: Share log-event switch with subcommands Olivier Dion
2022-06-06 19:49 ` [PATCH 3/3] graph: Add output switch Olivier Dion
@ 2022-06-12 9:08 ` Ricardo Wurmus
2 siblings, 0 replies; 12+ messages in thread
From: Ricardo Wurmus @ 2022-06-12 9:08 UTC (permalink / raw)
To: Olivier Dion; +Cc: gwl-devel
Olivier Dion <olivier.dion@polymtl.ca> writes:
> Some GWL sub-commands might not accept the log-events switch.
> This results in returning `#f' from `(%config 'log-events)'
>
> Fix this by checking that 'log-events was configured. Also memoize the result.
[…]
> +(define print?
> + (mlambdaq (type)
> + (let ((log-events (%config 'log-events)))
> + (and log-events
> + (or (member 'all log-events)
> + (member type log-events))
> + #t))))
> +
You don’t need the #t at the end of the “and”; the previous two values
are already “truthy” or “falsy”.
You could also do this:
(and=> (%config 'log-events)
(lambda (log-events)
(or (member 'all log-events)
(member type log-events))))
--
Ricardo
^ permalink raw reply [flat|nested] 12+ messages in thread
end of thread, other threads:[~2022-06-12 9:12 UTC | newest]
Thread overview: 12+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2022-06-03 18:32 [PATCH] gwl/ui: Check for log-events configuration Olivier Dion
2022-06-04 15:00 ` Ricardo Wurmus
2022-06-04 15:10 ` Olivier Dion via
2022-06-06 10:32 ` Ricardo Wurmus
2022-06-06 13:25 ` Olivier Dion via
2022-06-06 18:51 ` Olivier Dion via
2022-06-06 19:48 ` [PATCH 1/3] " Olivier Dion
2022-06-06 19:48 ` [PATCH 2/3] gwl/config: Share log-event switch with subcommands Olivier Dion
2022-06-12 9:03 ` Ricardo Wurmus
2022-06-06 19:49 ` [PATCH 3/3] graph: Add output switch Olivier Dion
2022-06-12 9:05 ` Ricardo Wurmus
2022-06-12 9:08 ` [PATCH 1/3] gwl/ui: Check for log-events configuration Ricardo Wurmus
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).