mirror of
https://github.com/jfmengels/elm-review.git
synced 2024-11-25 10:04:38 +03:00
67 lines
1.3 KiB
Elm
67 lines
1.3 KiB
Elm
module RangeDict exposing (RangeDict, empty, fromList, get, insert, member, modify, values)
|
|
|
|
import Dict exposing (Dict)
|
|
import Elm.Syntax.Range exposing (Range)
|
|
|
|
|
|
type alias RangeDict v =
|
|
Dict String v
|
|
|
|
|
|
empty : RangeDict v
|
|
empty =
|
|
Dict.empty
|
|
|
|
|
|
fromList : List ( Range, v ) -> RangeDict v
|
|
fromList entries =
|
|
entries
|
|
|> List.map (Tuple.mapFirst rangeAsString)
|
|
|> Dict.fromList
|
|
|
|
|
|
insert : Range -> v -> RangeDict v -> RangeDict v
|
|
insert range =
|
|
Dict.insert (rangeAsString range)
|
|
|
|
|
|
modify : Range -> (v -> v) -> RangeDict v -> RangeDict v
|
|
modify range mapper dict =
|
|
let
|
|
key : String
|
|
key =
|
|
rangeAsString range
|
|
in
|
|
case Dict.get key dict of
|
|
Just value ->
|
|
Dict.insert (rangeAsString range) (mapper value) dict
|
|
|
|
Nothing ->
|
|
dict
|
|
|
|
|
|
values : RangeDict v -> List v
|
|
values rangeDict =
|
|
Dict.values rangeDict
|
|
|
|
|
|
get : Range -> RangeDict v -> Maybe v
|
|
get range =
|
|
Dict.get (rangeAsString range)
|
|
|
|
|
|
member : Range -> RangeDict v -> Bool
|
|
member range =
|
|
Dict.member (rangeAsString range)
|
|
|
|
|
|
rangeAsString : Range -> String
|
|
rangeAsString range =
|
|
[ range.start.row
|
|
, range.start.column
|
|
, range.end.row
|
|
, range.end.column
|
|
]
|
|
|> List.map String.fromInt
|
|
|> String.join "_"
|