2019-08-31 13:11:58 +02:00
|
|
|
(define-module (guix-data-service model lint-warning-message)
|
|
|
|
#:use-module (ice-9 match)
|
|
|
|
#:use-module (squee)
|
|
|
|
#:use-module (guix-data-service database)
|
|
|
|
#:use-module (guix-data-service model utils)
|
|
|
|
#:export (lint-warning-message-data->lint-warning-message-ids
|
|
|
|
|
|
|
|
lint-warning-message-data->lint-warning-message-set-id))
|
|
|
|
|
|
|
|
(define (lint-warning-message-data->lint-warning-message-ids conn
|
|
|
|
messages-by-locale)
|
|
|
|
(insert-missing-data-and-return-all-ids
|
|
|
|
conn
|
|
|
|
"lint_warning_messages"
|
2019-09-04 12:57:06 +02:00
|
|
|
'(locale message)
|
2019-08-31 13:11:58 +02:00
|
|
|
(map (match-lambda
|
|
|
|
((locale . message)
|
|
|
|
(list locale message)))
|
|
|
|
messages-by-locale)))
|
|
|
|
|
|
|
|
(define (insert-lint-warning-message-set conn lint-message-ids)
|
|
|
|
(let ((query
|
|
|
|
(string-append
|
|
|
|
"INSERT INTO lint_warning_message_sets (message_ids) VALUES "
|
|
|
|
(string-append
|
|
|
|
"('{"
|
|
|
|
(string-join
|
|
|
|
(map number->string
|
2019-09-04 19:24:22 +02:00
|
|
|
(sort lint-message-ids <))
|
2019-08-31 13:11:58 +02:00
|
|
|
", ")
|
|
|
|
"}')")
|
|
|
|
" RETURNING id")))
|
|
|
|
|
|
|
|
(match (exec-query conn query)
|
|
|
|
(((id)) id))))
|
|
|
|
|
|
|
|
(define (lint-warning-message-data->lint-warning-message-set-id
|
|
|
|
conn
|
|
|
|
messages-by-locale)
|
|
|
|
|
|
|
|
(let* ((lint-warning-message-ids
|
|
|
|
(lint-warning-message-data->lint-warning-message-ids
|
|
|
|
conn messages-by-locale))
|
|
|
|
(lint-message-set-id
|
|
|
|
(exec-query
|
|
|
|
conn
|
|
|
|
(string-append
|
|
|
|
"SELECT id FROM lint_warning_message_sets "
|
|
|
|
"WHERE message_ids = ARRAY["
|
2019-09-04 19:24:22 +02:00
|
|
|
(string-join (map number->string lint-warning-message-ids) ", ")
|
2019-08-31 13:11:58 +02:00
|
|
|
"]"))))
|
|
|
|
|
2019-09-04 19:24:22 +02:00
|
|
|
(string->number
|
|
|
|
(match lint-message-set-id
|
|
|
|
(((id)) id)
|
|
|
|
(()
|
|
|
|
(insert-lint-warning-message-set conn lint-warning-message-ids))))))
|