aboutsummaryrefslogtreecommitdiff
path: root/stdlib/source/library/lux/locale.lux
blob: ac8c05384bb71b0ce402fbbf6ea36dfc16f8095e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
(.module:
  [library
   [lux #*
    [abstract
     [equivalence (#+ Equivalence)]
     ["." hash (#+ Hash)]]
    [control
     ["." maybe ("#\." functor)]]
    [data
     ["." text
      ["%" format (#+ format)]
      ["." encoding (#+ Encoding)]]]
    [type
     abstract]]]
  [/
   ["." language (#+ Language)]
   ["." territory (#+ Territory)]])

(abstract: .public Locale
  {}
  
  Text

  (def: territory_separator "_")
  (def: encoding_separator ".")

  (def: .public (locale language territory encoding)
    (-> Language (Maybe Territory) (Maybe Encoding) Locale)
    (:abstraction (format (language.code language)
                          (|> territory
                              (maybe\each (|>> territory.long_code (format ..territory_separator)))
                              (maybe.else ""))
                          (|> encoding
                              (maybe\each (|>> encoding.name (format ..encoding_separator)))
                              (maybe.else "")))))

  (def: .public code
    (-> Locale Text)
    (|>> :representation))

  (def: .public hash
    (Hash Locale)
    (\ hash.functor each ..code text.hash))

  (def: .public equivalence
    (Equivalence Locale)
    (\ ..hash &equivalence))
  )