lin
2025-06-05 ed3dd9d3e7519a82bb871d5eedb24a2fa0c91f47
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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
// Copyright 2018 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
 
// +build js,wasm
 
package time
 
import (
   "runtime"
   "syscall/js"
)
 
var zoneSources = []string{
   "/usr/share/zoneinfo/",
   "/usr/share/lib/zoneinfo/",
   "/usr/lib/locale/TZ/",
   runtime.GOROOT() + "/lib/time/zoneinfo.zip",
}
 
func initLocal() {
   localLoc.name = "Local"
 
   z := zone{}
   d := js.Global().Get("Date").New()
   offset := d.Call("getTimezoneOffset").Int() * -1
   z.offset = offset * 60
   // According to https://tc39.github.io/ecma262/#sec-timezoneestring,
   // the timezone name from (new Date()).toTimeString() is an implementation-dependent
   // result, and in Google Chrome, it gives the fully expanded name rather than
   // the abbreviation.
   // Hence, we construct the name from the offset.
   z.name = "UTC"
   if offset < 0 {
       z.name += "-"
       offset *= -1
   } else {
       z.name += "+"
   }
   z.name += itoa(offset / 60)
   min := offset % 60
   if min != 0 {
       z.name += ":" + itoa(min)
   }
   localLoc.zone = []zone{z}
}
 
// itoa is like strconv.Itoa but only works for values of i in range [0,99].
// It panics if i is out of range.
func itoa(i int) string {
   if i < 10 {
       return digits[i : i+1]
   }
   return smallsString[i*2 : i*2+2]
}
 
const smallsString = "00010203040506070809" +
   "10111213141516171819" +
   "20212223242526272829" +
   "30313233343536373839" +
   "40414243444546474849" +
   "50515253545556575859" +
   "60616263646566676869" +
   "70717273747576777879" +
   "80818283848586878889" +
   "90919293949596979899"
const digits = "0123456789"