45 lines
1.1 KiB
Text
45 lines
1.1 KiB
Text
/-
|
|
Copyright (c) 2018 Microsoft Corporation. All rights reserved.
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
Author: Sebastian Ullrich
|
|
|
|
Message type used by the Lean frontend
|
|
-/
|
|
prelude
|
|
import init.data.string.basic
|
|
|
|
namespace lean
|
|
structure position :=
|
|
(line column : nat)
|
|
|
|
inductive message_severity
|
|
| information | warning | error
|
|
|
|
structure message :=
|
|
(filename : string)
|
|
(pos : position)
|
|
(end_pos : option position := none)
|
|
(severity : message_severity := message_severity.error)
|
|
(caption : string := "")
|
|
(text : string)
|
|
|
|
structure message_log :=
|
|
-- messages are stored in reverse for efficient append
|
|
(rev_list : list message)
|
|
|
|
namespace message_log
|
|
def empty : message_log :=
|
|
⟨[]⟩
|
|
|
|
def add (msg : message) (log : message_log) : message_log :=
|
|
⟨msg :: log.rev_list⟩
|
|
|
|
def has_errors (log : message_log) : bool :=
|
|
log.rev_list.any $ λ m, match m.severity with
|
|
| message_severity.error := tt
|
|
| _ := ff
|
|
|
|
def to_list (log : message_log) : list message :=
|
|
log.rev_list.reverse
|
|
end message_log
|
|
end lean
|