2019-12-26 10:16:55 +00:00
|
|
|
;;; Guix Data Service -- Information about Guix over time
|
|
|
|
|
;;; Copyright © 2019 Christopher Baines <mail@cbaines.net>
|
|
|
|
|
;;;
|
|
|
|
|
;;; This program is free software: you can redistribute it and/or
|
|
|
|
|
;;; modify it under the terms of the GNU Affero General Public License
|
|
|
|
|
;;; as published by the Free Software Foundation, either version 3 of
|
|
|
|
|
;;; the License, or (at your option) any later version.
|
|
|
|
|
;;;
|
|
|
|
|
;;; This program is distributed in the hope that it will be useful,
|
|
|
|
|
;;; but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
|
;;; Affero General Public License for more details.
|
|
|
|
|
;;;
|
|
|
|
|
;;; You should have received a copy of the GNU Affero General Public
|
|
|
|
|
;;; License along with this program. If not, see
|
|
|
|
|
;;; <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
2019-08-31 12:11:58 +01:00
|
|
|
(define-module (guix-data-service model lint-warning-message)
|
2024-12-05 20:56:23 +00:00
|
|
|
#:use-module (srfi srfi-43)
|
2019-08-31 12:11:58 +01:00
|
|
|
#: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
|
2020-04-04 05:02:11 +02:00
|
|
|
lint-warning-message-locales-for-revision
|
2019-08-31 12:11:58 +01:00
|
|
|
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)
|
2024-12-05 20:56:23 +00:00
|
|
|
(let ((v (list->vector messages-by-locale)))
|
|
|
|
|
(vector-map! (lambda (_ data)
|
|
|
|
|
(match data
|
|
|
|
|
((locale . message)
|
|
|
|
|
(list locale message))))
|
|
|
|
|
v)
|
|
|
|
|
v)))
|
2019-08-31 12:11:58 +01:00
|
|
|
|
|
|
|
|
(define (lint-warning-message-data->lint-warning-message-set-id
|
|
|
|
|
conn
|
|
|
|
|
messages-by-locale)
|
2024-12-05 20:56:23 +00:00
|
|
|
(insert-and-return-id
|
|
|
|
|
conn
|
|
|
|
|
"lint_warning_message_sets"
|
|
|
|
|
'(message_ids)
|
|
|
|
|
(list (lint-warning-message-data->lint-warning-message-ids
|
|
|
|
|
conn
|
|
|
|
|
messages-by-locale))))
|
2020-04-04 05:02:11 +02:00
|
|
|
|
|
|
|
|
(define (lint-warning-message-locales-for-revision conn commit-hash)
|
|
|
|
|
(exec-query
|
|
|
|
|
conn
|
2020-10-02 17:52:07 +01:00
|
|
|
"
|
|
|
|
|
SELECT DISTINCT lint_warning_messages.locale
|
|
|
|
|
FROM lint_warning_messages
|
|
|
|
|
INNER JOIN lint_warning_message_sets
|
|
|
|
|
ON lint_warning_messages.id = ANY (lint_warning_message_sets.message_ids)
|
|
|
|
|
INNER JOIN lint_warnings
|
|
|
|
|
ON lint_warning_message_sets.id = lint_warnings.lint_warning_message_set_id
|
|
|
|
|
INNER JOIN guix_revision_lint_warnings
|
|
|
|
|
ON lint_warnings.id = guix_revision_lint_warnings.lint_warning_id
|
|
|
|
|
INNER JOIN guix_revisions
|
|
|
|
|
ON guix_revision_lint_warnings.guix_revision_id = guix_revisions.id
|
|
|
|
|
AND guix_revisions.commit = $1"
|
2020-04-04 05:02:11 +02:00
|
|
|
(list commit-hash)))
|