mirror of
https://github.com/sorenisanerd/gotty.git
synced 2024-11-22 04:14:25 +00:00
Change to go1.6.1 and vendoring
This commit is contained in:
parent
b1c5226875
commit
a350994aa2
14
Godeps/Godeps.json
generated
14
Godeps/Godeps.json
generated
@ -1,6 +1,10 @@
|
|||||||
{
|
{
|
||||||
"ImportPath": "github.com/yudai/gotty",
|
"ImportPath": "github.com/yudai/gotty",
|
||||||
"GoVersion": "go1.5.1",
|
"GoVersion": "go1.6",
|
||||||
|
"GodepVersion": "v62",
|
||||||
|
"Packages": [
|
||||||
|
"./..."
|
||||||
|
],
|
||||||
"Deps": [
|
"Deps": [
|
||||||
{
|
{
|
||||||
"ImportPath": "github.com/braintree/manners",
|
"ImportPath": "github.com/braintree/manners",
|
||||||
@ -37,6 +41,14 @@
|
|||||||
"ImportPath": "github.com/yudai/hcl",
|
"ImportPath": "github.com/yudai/hcl",
|
||||||
"Rev": "5fa2393b3552119bf33a69adb1402a1160cba23d"
|
"Rev": "5fa2393b3552119bf33a69adb1402a1160cba23d"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"ImportPath": "github.com/yudai/hcl/hcl",
|
||||||
|
"Rev": "5fa2393b3552119bf33a69adb1402a1160cba23d"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"ImportPath": "github.com/yudai/hcl/json",
|
||||||
|
"Rev": "5fa2393b3552119bf33a69adb1402a1160cba23d"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"ImportPath": "github.com/yudai/umutex",
|
"ImportPath": "github.com/yudai/umutex",
|
||||||
"Rev": "18216d265c6bc72c3bb0ad9c8103d47d530b7003"
|
"Rev": "18216d265c6bc72c3bb0ad9c8103d47d530b7003"
|
||||||
|
2
Godeps/_workspace/.gitignore
generated
vendored
2
Godeps/_workspace/.gitignore
generated
vendored
@ -1,2 +0,0 @@
|
|||||||
/pkg
|
|
||||||
/bin
|
|
29
Godeps/_workspace/src/github.com/braintree/manners/test_helpers/certs.go
generated
vendored
29
Godeps/_workspace/src/github.com/braintree/manners/test_helpers/certs.go
generated
vendored
@ -1,29 +0,0 @@
|
|||||||
package test_helpers
|
|
||||||
|
|
||||||
// A PEM-encoded TLS cert with SAN IPs "127.0.0.1" and "[::1]", expiring at the
|
|
||||||
// last second of 2049 (the end of ASN.1 time).
|
|
||||||
|
|
||||||
// generated from src/pkg/crypto/tls:
|
|
||||||
// go run generate_cert.go --rsa-bits 512 --host 127.0.0.1,::1,example.com --ca --start-date "Jan 1 00:00:00 1970" --duration=1000000h
|
|
||||||
var (
|
|
||||||
Cert = []byte(`-----BEGIN CERTIFICATE-----
|
|
||||||
MIIBdzCCASOgAwIBAgIBADALBgkqhkiG9w0BAQUwEjEQMA4GA1UEChMHQWNtZSBD
|
|
||||||
bzAeFw03MDAxMDEwMDAwMDBaFw00OTEyMzEyMzU5NTlaMBIxEDAOBgNVBAoTB0Fj
|
|
||||||
bWUgQ28wWjALBgkqhkiG9w0BAQEDSwAwSAJBAN55NcYKZeInyTuhcCwFMhDHCmwa
|
|
||||||
IUSdtXdcbItRB/yfXGBhiex00IaLXQnSU+QZPRZWYqeTEbFSgihqi1PUDy8CAwEA
|
|
||||||
AaNoMGYwDgYDVR0PAQH/BAQDAgCkMBMGA1UdJQQMMAoGCCsGAQUFBwMBMA8GA1Ud
|
|
||||||
EwEB/wQFMAMBAf8wLgYDVR0RBCcwJYILZXhhbXBsZS5jb22HBH8AAAGHEAAAAAAA
|
|
||||||
AAAAAAAAAAAAAAEwCwYJKoZIhvcNAQEFA0EAAoQn/ytgqpiLcZu9XKbCJsJcvkgk
|
|
||||||
Se6AbGXgSlq+ZCEVo0qIwSgeBqmsJxUu7NCSOwVJLYNEBO2DtIxoYVk+MA==
|
|
||||||
-----END CERTIFICATE-----`)
|
|
||||||
|
|
||||||
Key = []byte(`-----BEGIN RSA PRIVATE KEY-----
|
|
||||||
MIIBPAIBAAJBAN55NcYKZeInyTuhcCwFMhDHCmwaIUSdtXdcbItRB/yfXGBhiex0
|
|
||||||
0IaLXQnSU+QZPRZWYqeTEbFSgihqi1PUDy8CAwEAAQJBAQdUx66rfh8sYsgfdcvV
|
|
||||||
NoafYpnEcB5s4m/vSVe6SU7dCK6eYec9f9wpT353ljhDUHq3EbmE4foNzJngh35d
|
|
||||||
AekCIQDhRQG5Li0Wj8TM4obOnnXUXf1jRv0UkzE9AHWLG5q3AwIhAPzSjpYUDjVW
|
|
||||||
MCUXgckTpKCuGwbJk7424Nb8bLzf3kllAiA5mUBgjfr/WtFSJdWcPQ4Zt9KTMNKD
|
|
||||||
EUO0ukpTwEIl6wIhAMbGqZK3zAAFdq8DD2jPx+UJXnh0rnOkZBzDtJ6/iN69AiEA
|
|
||||||
1Aq8MJgTaYsDQWyU/hDq5YkDJc9e9DSCvUIzqxQWMQE=
|
|
||||||
-----END RSA PRIVATE KEY-----`)
|
|
||||||
)
|
|
13
Godeps/_workspace/src/github.com/braintree/manners/test_helpers/conn.go
generated
vendored
13
Godeps/_workspace/src/github.com/braintree/manners/test_helpers/conn.go
generated
vendored
@ -1,13 +0,0 @@
|
|||||||
package test_helpers
|
|
||||||
|
|
||||||
import "net"
|
|
||||||
|
|
||||||
type Conn struct {
|
|
||||||
net.Conn
|
|
||||||
CloseCalled bool
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c *Conn) Close() error {
|
|
||||||
c.CloseCalled = true
|
|
||||||
return nil
|
|
||||||
}
|
|
34
Godeps/_workspace/src/github.com/braintree/manners/test_helpers/listener.go
generated
vendored
34
Godeps/_workspace/src/github.com/braintree/manners/test_helpers/listener.go
generated
vendored
@ -1,34 +0,0 @@
|
|||||||
package test_helpers
|
|
||||||
|
|
||||||
import (
|
|
||||||
"net"
|
|
||||||
"errors"
|
|
||||||
)
|
|
||||||
|
|
||||||
type Listener struct {
|
|
||||||
AcceptRelease chan bool
|
|
||||||
CloseCalled chan bool
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewListener() *Listener {
|
|
||||||
return &Listener{
|
|
||||||
make(chan bool, 1),
|
|
||||||
make(chan bool, 1),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (l *Listener) Addr() net.Addr {
|
|
||||||
addr, _ := net.ResolveTCPAddr("tcp", "127.0.0.1:8080")
|
|
||||||
return addr
|
|
||||||
}
|
|
||||||
|
|
||||||
func (l *Listener) Close() error {
|
|
||||||
l.CloseCalled <- true
|
|
||||||
l.AcceptRelease <- true
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (l *Listener) Accept() (net.Conn, error) {
|
|
||||||
<-l.AcceptRelease
|
|
||||||
return nil, errors.New("connection closed")
|
|
||||||
}
|
|
27
Godeps/_workspace/src/github.com/braintree/manners/test_helpers/temp_file.go
generated
vendored
27
Godeps/_workspace/src/github.com/braintree/manners/test_helpers/temp_file.go
generated
vendored
@ -1,27 +0,0 @@
|
|||||||
package test_helpers
|
|
||||||
|
|
||||||
import (
|
|
||||||
"io/ioutil"
|
|
||||||
"os"
|
|
||||||
)
|
|
||||||
|
|
||||||
type TempFile struct {
|
|
||||||
*os.File
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewTempFile(content []byte) (*TempFile, error) {
|
|
||||||
f, err := ioutil.TempFile("", "graceful-test")
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
f.Write(content)
|
|
||||||
return &TempFile{f}, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (tf *TempFile) Unlink() {
|
|
||||||
if tf.File != nil {
|
|
||||||
os.Remove(tf.Name())
|
|
||||||
tf.File = nil
|
|
||||||
}
|
|
||||||
}
|
|
33
Godeps/_workspace/src/github.com/braintree/manners/test_helpers/wait_group.go
generated
vendored
33
Godeps/_workspace/src/github.com/braintree/manners/test_helpers/wait_group.go
generated
vendored
@ -1,33 +0,0 @@
|
|||||||
package test_helpers
|
|
||||||
|
|
||||||
import "sync"
|
|
||||||
|
|
||||||
type WaitGroup struct {
|
|
||||||
sync.Mutex
|
|
||||||
Count int
|
|
||||||
WaitCalled chan int
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewWaitGroup() *WaitGroup {
|
|
||||||
return &WaitGroup{
|
|
||||||
WaitCalled: make(chan int, 1),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (wg *WaitGroup) Add(delta int) {
|
|
||||||
wg.Lock()
|
|
||||||
wg.Count++
|
|
||||||
wg.Unlock()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (wg *WaitGroup) Done() {
|
|
||||||
wg.Lock()
|
|
||||||
wg.Count--
|
|
||||||
wg.Unlock()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (wg *WaitGroup) Wait() {
|
|
||||||
wg.Lock()
|
|
||||||
wg.WaitCalled <- wg.Count
|
|
||||||
wg.Unlock()
|
|
||||||
}
|
|
13
Godeps/_workspace/src/github.com/codegangsta/cli/autocomplete/bash_autocomplete
generated
vendored
13
Godeps/_workspace/src/github.com/codegangsta/cli/autocomplete/bash_autocomplete
generated
vendored
@ -1,13 +0,0 @@
|
|||||||
#! /bin/bash
|
|
||||||
|
|
||||||
_cli_bash_autocomplete() {
|
|
||||||
local cur prev opts base
|
|
||||||
COMPREPLY=()
|
|
||||||
cur="${COMP_WORDS[COMP_CWORD]}"
|
|
||||||
prev="${COMP_WORDS[COMP_CWORD-1]}"
|
|
||||||
opts=$( ${COMP_WORDS[@]:0:$COMP_CWORD} --generate-bash-completion )
|
|
||||||
COMPREPLY=( $(compgen -W "${opts}" -- ${cur}) )
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
|
|
||||||
complete -F _cli_bash_autocomplete $PROG
|
|
5
Godeps/_workspace/src/github.com/codegangsta/cli/autocomplete/zsh_autocomplete
generated
vendored
5
Godeps/_workspace/src/github.com/codegangsta/cli/autocomplete/zsh_autocomplete
generated
vendored
@ -1,5 +0,0 @@
|
|||||||
autoload -U compinit && compinit
|
|
||||||
autoload -U bashcompinit && bashcompinit
|
|
||||||
|
|
||||||
script_dir=$(dirname $0)
|
|
||||||
source ${script_dir}/bash_autocomplete
|
|
97
Godeps/_workspace/src/github.com/elazarl/go-bindata-assetfs/go-bindata-assetfs/main.go
generated
vendored
97
Godeps/_workspace/src/github.com/elazarl/go-bindata-assetfs/go-bindata-assetfs/main.go
generated
vendored
@ -1,97 +0,0 @@
|
|||||||
package main
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bufio"
|
|
||||||
"bytes"
|
|
||||||
"flag"
|
|
||||||
"fmt"
|
|
||||||
"os"
|
|
||||||
"os/exec"
|
|
||||||
"strings"
|
|
||||||
)
|
|
||||||
|
|
||||||
const bindatafile = "bindata.go"
|
|
||||||
|
|
||||||
func isDebug(args []string) bool {
|
|
||||||
flagset := flag.NewFlagSet("", flag.ContinueOnError)
|
|
||||||
debug := flagset.Bool("debug", false, "")
|
|
||||||
debugArgs := make([]string, 0)
|
|
||||||
for _, arg := range args {
|
|
||||||
if strings.HasPrefix(arg, "-debug") {
|
|
||||||
debugArgs = append(debugArgs, arg)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
flagset.Parse(debugArgs)
|
|
||||||
if debug == nil {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
return *debug
|
|
||||||
}
|
|
||||||
|
|
||||||
func main() {
|
|
||||||
if _, err := exec.LookPath("go-bindata"); err != nil {
|
|
||||||
fmt.Println("Cannot find go-bindata executable in path")
|
|
||||||
fmt.Println("Maybe you need: go get github.com/elazarl/go-bindata-assetfs/...")
|
|
||||||
os.Exit(1)
|
|
||||||
}
|
|
||||||
cmd := exec.Command("go-bindata", os.Args[1:]...)
|
|
||||||
cmd.Stdin = os.Stdin
|
|
||||||
cmd.Stdout = os.Stdout
|
|
||||||
cmd.Stderr = os.Stderr
|
|
||||||
if err := cmd.Run(); err != nil {
|
|
||||||
os.Exit(1)
|
|
||||||
}
|
|
||||||
in, err := os.Open(bindatafile)
|
|
||||||
if err != nil {
|
|
||||||
fmt.Fprintln(os.Stderr, "Cannot read", bindatafile, err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
out, err := os.Create("bindata_assetfs.go")
|
|
||||||
if err != nil {
|
|
||||||
fmt.Fprintln(os.Stderr, "Cannot write 'bindata_assetfs.go'", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
debug := isDebug(os.Args[1:])
|
|
||||||
r := bufio.NewReader(in)
|
|
||||||
done := false
|
|
||||||
for line, isPrefix, err := r.ReadLine(); err == nil; line, isPrefix, err = r.ReadLine() {
|
|
||||||
if !isPrefix {
|
|
||||||
line = append(line, '\n')
|
|
||||||
}
|
|
||||||
if _, err := out.Write(line); err != nil {
|
|
||||||
fmt.Fprintln(os.Stderr, "Cannot write to 'bindata_assetfs.go'", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if !done && !isPrefix && bytes.HasPrefix(line, []byte("import (")) {
|
|
||||||
if debug {
|
|
||||||
fmt.Fprintln(out, "\t\"net/http\"")
|
|
||||||
} else {
|
|
||||||
fmt.Fprintln(out, "\t\"github.com/elazarl/go-bindata-assetfs\"")
|
|
||||||
}
|
|
||||||
done = true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if debug {
|
|
||||||
fmt.Fprintln(out, `
|
|
||||||
func assetFS() http.FileSystem {
|
|
||||||
for k := range _bintree.Children {
|
|
||||||
return http.Dir(k)
|
|
||||||
}
|
|
||||||
panic("unreachable")
|
|
||||||
}`)
|
|
||||||
} else {
|
|
||||||
fmt.Fprintln(out, `
|
|
||||||
func assetFS() *assetfs.AssetFS {
|
|
||||||
for k := range _bintree.Children {
|
|
||||||
return &assetfs.AssetFS{Asset: Asset, AssetDir: AssetDir, Prefix: k}
|
|
||||||
}
|
|
||||||
panic("unreachable")
|
|
||||||
}`)
|
|
||||||
}
|
|
||||||
// Close files BEFORE remove calls (don't use defer).
|
|
||||||
in.Close()
|
|
||||||
out.Close()
|
|
||||||
if err := os.Remove(bindatafile); err != nil {
|
|
||||||
fmt.Fprintln(os.Stderr, "Cannot remove", bindatafile, err)
|
|
||||||
}
|
|
||||||
}
|
|
13
Godeps/_workspace/src/github.com/gorilla/websocket/examples/autobahn/README.md
generated
vendored
13
Godeps/_workspace/src/github.com/gorilla/websocket/examples/autobahn/README.md
generated
vendored
@ -1,13 +0,0 @@
|
|||||||
# Test Server
|
|
||||||
|
|
||||||
This package contains a server for the [Autobahn WebSockets Test Suite](http://autobahn.ws/testsuite).
|
|
||||||
|
|
||||||
To test the server, run
|
|
||||||
|
|
||||||
go run server.go
|
|
||||||
|
|
||||||
and start the client test driver
|
|
||||||
|
|
||||||
wstest -m fuzzingclient -s fuzzingclient.json
|
|
||||||
|
|
||||||
When the client completes, it writes a report to reports/clients/index.html.
|
|
14
Godeps/_workspace/src/github.com/gorilla/websocket/examples/autobahn/fuzzingclient.json
generated
vendored
14
Godeps/_workspace/src/github.com/gorilla/websocket/examples/autobahn/fuzzingclient.json
generated
vendored
@ -1,14 +0,0 @@
|
|||||||
|
|
||||||
{
|
|
||||||
"options": {"failByDrop": false},
|
|
||||||
"outdir": "./reports/clients",
|
|
||||||
"servers": [
|
|
||||||
{"agent": "ReadAllWriteMessage", "url": "ws://localhost:9000/m", "options": {"version": 18}},
|
|
||||||
{"agent": "ReadAllWrite", "url": "ws://localhost:9000/r", "options": {"version": 18}},
|
|
||||||
{"agent": "CopyFull", "url": "ws://localhost:9000/f", "options": {"version": 18}},
|
|
||||||
{"agent": "CopyWriterOnly", "url": "ws://localhost:9000/c", "options": {"version": 18}}
|
|
||||||
],
|
|
||||||
"cases": ["*"],
|
|
||||||
"exclude-cases": [],
|
|
||||||
"exclude-agent-cases": {}
|
|
||||||
}
|
|
246
Godeps/_workspace/src/github.com/gorilla/websocket/examples/autobahn/server.go
generated
vendored
246
Godeps/_workspace/src/github.com/gorilla/websocket/examples/autobahn/server.go
generated
vendored
@ -1,246 +0,0 @@
|
|||||||
// Copyright 2013 The Gorilla WebSocket Authors. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style
|
|
||||||
// license that can be found in the LICENSE file.
|
|
||||||
|
|
||||||
// Command server is a test server for the Autobahn WebSockets Test Suite.
|
|
||||||
package main
|
|
||||||
|
|
||||||
import (
|
|
||||||
"errors"
|
|
||||||
"flag"
|
|
||||||
"github.com/gorilla/websocket"
|
|
||||||
"io"
|
|
||||||
"log"
|
|
||||||
"net/http"
|
|
||||||
"time"
|
|
||||||
"unicode/utf8"
|
|
||||||
)
|
|
||||||
|
|
||||||
var upgrader = websocket.Upgrader{
|
|
||||||
ReadBufferSize: 4096,
|
|
||||||
WriteBufferSize: 4096,
|
|
||||||
CheckOrigin: func(r *http.Request) bool {
|
|
||||||
return true
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
// echoCopy echoes messages from the client using io.Copy.
|
|
||||||
func echoCopy(w http.ResponseWriter, r *http.Request, writerOnly bool) {
|
|
||||||
conn, err := upgrader.Upgrade(w, r, nil)
|
|
||||||
if err != nil {
|
|
||||||
log.Println("Upgrade:", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
defer conn.Close()
|
|
||||||
for {
|
|
||||||
mt, r, err := conn.NextReader()
|
|
||||||
if err != nil {
|
|
||||||
if err != io.EOF {
|
|
||||||
log.Println("NextReader:", err)
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if mt == websocket.TextMessage {
|
|
||||||
r = &validator{r: r}
|
|
||||||
}
|
|
||||||
w, err := conn.NextWriter(mt)
|
|
||||||
if err != nil {
|
|
||||||
log.Println("NextWriter:", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if mt == websocket.TextMessage {
|
|
||||||
r = &validator{r: r}
|
|
||||||
}
|
|
||||||
if writerOnly {
|
|
||||||
_, err = io.Copy(struct{ io.Writer }{w}, r)
|
|
||||||
} else {
|
|
||||||
_, err = io.Copy(w, r)
|
|
||||||
}
|
|
||||||
if err != nil {
|
|
||||||
if err == errInvalidUTF8 {
|
|
||||||
conn.WriteControl(websocket.CloseMessage,
|
|
||||||
websocket.FormatCloseMessage(websocket.CloseInvalidFramePayloadData, ""),
|
|
||||||
time.Time{})
|
|
||||||
}
|
|
||||||
log.Println("Copy:", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
err = w.Close()
|
|
||||||
if err != nil {
|
|
||||||
log.Println("Close:", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func echoCopyWriterOnly(w http.ResponseWriter, r *http.Request) {
|
|
||||||
echoCopy(w, r, true)
|
|
||||||
}
|
|
||||||
|
|
||||||
func echoCopyFull(w http.ResponseWriter, r *http.Request) {
|
|
||||||
echoCopy(w, r, false)
|
|
||||||
}
|
|
||||||
|
|
||||||
// echoReadAll echoes messages from the client by reading the entire message
|
|
||||||
// with ioutil.ReadAll.
|
|
||||||
func echoReadAll(w http.ResponseWriter, r *http.Request, writeMessage bool) {
|
|
||||||
conn, err := upgrader.Upgrade(w, r, nil)
|
|
||||||
if err != nil {
|
|
||||||
log.Println("Upgrade:", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
defer conn.Close()
|
|
||||||
for {
|
|
||||||
mt, b, err := conn.ReadMessage()
|
|
||||||
if err != nil {
|
|
||||||
if err != io.EOF {
|
|
||||||
log.Println("NextReader:", err)
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if mt == websocket.TextMessage {
|
|
||||||
if !utf8.Valid(b) {
|
|
||||||
conn.WriteControl(websocket.CloseMessage,
|
|
||||||
websocket.FormatCloseMessage(websocket.CloseInvalidFramePayloadData, ""),
|
|
||||||
time.Time{})
|
|
||||||
log.Println("ReadAll: invalid utf8")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if writeMessage {
|
|
||||||
err = conn.WriteMessage(mt, b)
|
|
||||||
if err != nil {
|
|
||||||
log.Println("WriteMessage:", err)
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
w, err := conn.NextWriter(mt)
|
|
||||||
if err != nil {
|
|
||||||
log.Println("NextWriter:", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if _, err := w.Write(b); err != nil {
|
|
||||||
log.Println("Writer:", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if err := w.Close(); err != nil {
|
|
||||||
log.Println("Close:", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func echoReadAllWriter(w http.ResponseWriter, r *http.Request) {
|
|
||||||
echoReadAll(w, r, false)
|
|
||||||
}
|
|
||||||
|
|
||||||
func echoReadAllWriteMessage(w http.ResponseWriter, r *http.Request) {
|
|
||||||
echoReadAll(w, r, true)
|
|
||||||
}
|
|
||||||
|
|
||||||
func serveHome(w http.ResponseWriter, r *http.Request) {
|
|
||||||
if r.URL.Path != "/" {
|
|
||||||
http.Error(w, "Not found.", 404)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if r.Method != "GET" {
|
|
||||||
http.Error(w, "Method not allowed", 405)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
w.Header().Set("Content-Type", "text/html; charset=utf-8")
|
|
||||||
io.WriteString(w, "<html><body>Echo Server</body></html>")
|
|
||||||
}
|
|
||||||
|
|
||||||
var addr = flag.String("addr", ":9000", "http service address")
|
|
||||||
|
|
||||||
func main() {
|
|
||||||
flag.Parse()
|
|
||||||
http.HandleFunc("/", serveHome)
|
|
||||||
http.HandleFunc("/c", echoCopyWriterOnly)
|
|
||||||
http.HandleFunc("/f", echoCopyFull)
|
|
||||||
http.HandleFunc("/r", echoReadAllWriter)
|
|
||||||
http.HandleFunc("/m", echoReadAllWriteMessage)
|
|
||||||
err := http.ListenAndServe(*addr, nil)
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal("ListenAndServe: ", err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
type validator struct {
|
|
||||||
state int
|
|
||||||
x rune
|
|
||||||
r io.Reader
|
|
||||||
}
|
|
||||||
|
|
||||||
var errInvalidUTF8 = errors.New("invalid utf8")
|
|
||||||
|
|
||||||
func (r *validator) Read(p []byte) (int, error) {
|
|
||||||
n, err := r.r.Read(p)
|
|
||||||
state := r.state
|
|
||||||
x := r.x
|
|
||||||
for _, b := range p[:n] {
|
|
||||||
state, x = decode(state, x, b)
|
|
||||||
if state == utf8Reject {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
r.state = state
|
|
||||||
r.x = x
|
|
||||||
if state == utf8Reject || (err == io.EOF && state != utf8Accept) {
|
|
||||||
return n, errInvalidUTF8
|
|
||||||
}
|
|
||||||
return n, err
|
|
||||||
}
|
|
||||||
|
|
||||||
// UTF-8 decoder from http://bjoern.hoehrmann.de/utf-8/decoder/dfa/
|
|
||||||
//
|
|
||||||
// Copyright (c) 2008-2009 Bjoern Hoehrmann <bjoern@hoehrmann.de>
|
|
||||||
//
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
// of this software and associated documentation files (the "Software"), to
|
|
||||||
// deal in the Software without restriction, including without limitation the
|
|
||||||
// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
|
||||||
// sell copies of the Software, and to permit persons to whom the Software is
|
|
||||||
// furnished to do so, subject to the following conditions:
|
|
||||||
//
|
|
||||||
// The above copyright notice and this permission notice shall be included in
|
|
||||||
// all copies or substantial portions of the Software.
|
|
||||||
//
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
||||||
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
|
||||||
// IN THE SOFTWARE.
|
|
||||||
var utf8d = [...]byte{
|
|
||||||
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 00..1f
|
|
||||||
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 20..3f
|
|
||||||
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 40..5f
|
|
||||||
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 60..7f
|
|
||||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, // 80..9f
|
|
||||||
7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, // a0..bf
|
|
||||||
8, 8, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, // c0..df
|
|
||||||
0xa, 0x3, 0x3, 0x3, 0x3, 0x3, 0x3, 0x3, 0x3, 0x3, 0x3, 0x3, 0x3, 0x4, 0x3, 0x3, // e0..ef
|
|
||||||
0xb, 0x6, 0x6, 0x6, 0x5, 0x8, 0x8, 0x8, 0x8, 0x8, 0x8, 0x8, 0x8, 0x8, 0x8, 0x8, // f0..ff
|
|
||||||
0x0, 0x1, 0x2, 0x3, 0x5, 0x8, 0x7, 0x1, 0x1, 0x1, 0x4, 0x6, 0x1, 0x1, 0x1, 0x1, // s0..s0
|
|
||||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, // s1..s2
|
|
||||||
1, 2, 1, 1, 1, 1, 1, 2, 1, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 1, 1, 1, 1, 1, 1, 1, 1, // s3..s4
|
|
||||||
1, 2, 1, 1, 1, 1, 1, 1, 1, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 3, 1, 3, 1, 1, 1, 1, 1, 1, // s5..s6
|
|
||||||
1, 3, 1, 1, 1, 1, 1, 3, 1, 3, 1, 1, 1, 1, 1, 1, 1, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // s7..s8
|
|
||||||
}
|
|
||||||
|
|
||||||
const (
|
|
||||||
utf8Accept = 0
|
|
||||||
utf8Reject = 1
|
|
||||||
)
|
|
||||||
|
|
||||||
func decode(state int, x rune, b byte) (int, rune) {
|
|
||||||
t := utf8d[b]
|
|
||||||
if state != utf8Accept {
|
|
||||||
x = rune(b&0x3f) | (x << 6)
|
|
||||||
} else {
|
|
||||||
x = rune((0xff >> t) & b)
|
|
||||||
}
|
|
||||||
state = int(utf8d[256+state*16+int(t)])
|
|
||||||
return state, x
|
|
||||||
}
|
|
20
Godeps/_workspace/src/github.com/gorilla/websocket/examples/chat/README.md
generated
vendored
20
Godeps/_workspace/src/github.com/gorilla/websocket/examples/chat/README.md
generated
vendored
@ -1,20 +0,0 @@
|
|||||||
# Chat Example
|
|
||||||
|
|
||||||
This application shows how to use use the
|
|
||||||
[websocket](https://github.com/gorilla/websocket) package and
|
|
||||||
[jQuery](http://jquery.com) to implement a simple web chat application.
|
|
||||||
|
|
||||||
## Running the example
|
|
||||||
|
|
||||||
The example requires a working Go development environment. The [Getting
|
|
||||||
Started](http://golang.org/doc/install) page describes how to install the
|
|
||||||
development environment.
|
|
||||||
|
|
||||||
Once you have Go up and running, you can download, build and run the example
|
|
||||||
using the following commands.
|
|
||||||
|
|
||||||
$ go get github.com/gorilla/websocket
|
|
||||||
$ cd `go list -f '{{.Dir}}' github.com/gorilla/websocket/examples/chat`
|
|
||||||
$ go run *.go
|
|
||||||
|
|
||||||
To use the chat example, open http://localhost:8080/ in your browser.
|
|
106
Godeps/_workspace/src/github.com/gorilla/websocket/examples/chat/conn.go
generated
vendored
106
Godeps/_workspace/src/github.com/gorilla/websocket/examples/chat/conn.go
generated
vendored
@ -1,106 +0,0 @@
|
|||||||
// Copyright 2013 The Gorilla WebSocket Authors. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style
|
|
||||||
// license that can be found in the LICENSE file.
|
|
||||||
|
|
||||||
package main
|
|
||||||
|
|
||||||
import (
|
|
||||||
"github.com/gorilla/websocket"
|
|
||||||
"log"
|
|
||||||
"net/http"
|
|
||||||
"time"
|
|
||||||
)
|
|
||||||
|
|
||||||
const (
|
|
||||||
// Time allowed to write a message to the peer.
|
|
||||||
writeWait = 10 * time.Second
|
|
||||||
|
|
||||||
// Time allowed to read the next pong message from the peer.
|
|
||||||
pongWait = 60 * time.Second
|
|
||||||
|
|
||||||
// Send pings to peer with this period. Must be less than pongWait.
|
|
||||||
pingPeriod = (pongWait * 9) / 10
|
|
||||||
|
|
||||||
// Maximum message size allowed from peer.
|
|
||||||
maxMessageSize = 512
|
|
||||||
)
|
|
||||||
|
|
||||||
var upgrader = websocket.Upgrader{
|
|
||||||
ReadBufferSize: 1024,
|
|
||||||
WriteBufferSize: 1024,
|
|
||||||
}
|
|
||||||
|
|
||||||
// connection is an middleman between the websocket connection and the hub.
|
|
||||||
type connection struct {
|
|
||||||
// The websocket connection.
|
|
||||||
ws *websocket.Conn
|
|
||||||
|
|
||||||
// Buffered channel of outbound messages.
|
|
||||||
send chan []byte
|
|
||||||
}
|
|
||||||
|
|
||||||
// readPump pumps messages from the websocket connection to the hub.
|
|
||||||
func (c *connection) readPump() {
|
|
||||||
defer func() {
|
|
||||||
h.unregister <- c
|
|
||||||
c.ws.Close()
|
|
||||||
}()
|
|
||||||
c.ws.SetReadLimit(maxMessageSize)
|
|
||||||
c.ws.SetReadDeadline(time.Now().Add(pongWait))
|
|
||||||
c.ws.SetPongHandler(func(string) error { c.ws.SetReadDeadline(time.Now().Add(pongWait)); return nil })
|
|
||||||
for {
|
|
||||||
_, message, err := c.ws.ReadMessage()
|
|
||||||
if err != nil {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
h.broadcast <- message
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// write writes a message with the given message type and payload.
|
|
||||||
func (c *connection) write(mt int, payload []byte) error {
|
|
||||||
c.ws.SetWriteDeadline(time.Now().Add(writeWait))
|
|
||||||
return c.ws.WriteMessage(mt, payload)
|
|
||||||
}
|
|
||||||
|
|
||||||
// writePump pumps messages from the hub to the websocket connection.
|
|
||||||
func (c *connection) writePump() {
|
|
||||||
ticker := time.NewTicker(pingPeriod)
|
|
||||||
defer func() {
|
|
||||||
ticker.Stop()
|
|
||||||
c.ws.Close()
|
|
||||||
}()
|
|
||||||
for {
|
|
||||||
select {
|
|
||||||
case message, ok := <-c.send:
|
|
||||||
if !ok {
|
|
||||||
c.write(websocket.CloseMessage, []byte{})
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if err := c.write(websocket.TextMessage, message); err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
case <-ticker.C:
|
|
||||||
if err := c.write(websocket.PingMessage, []byte{}); err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// serverWs handles websocket requests from the peer.
|
|
||||||
func serveWs(w http.ResponseWriter, r *http.Request) {
|
|
||||||
if r.Method != "GET" {
|
|
||||||
http.Error(w, "Method not allowed", 405)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
ws, err := upgrader.Upgrade(w, r, nil)
|
|
||||||
if err != nil {
|
|
||||||
log.Println(err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
c := &connection{send: make(chan []byte, 256), ws: ws}
|
|
||||||
h.register <- c
|
|
||||||
go c.writePump()
|
|
||||||
c.readPump()
|
|
||||||
}
|
|
92
Godeps/_workspace/src/github.com/gorilla/websocket/examples/chat/home.html
generated
vendored
92
Godeps/_workspace/src/github.com/gorilla/websocket/examples/chat/home.html
generated
vendored
@ -1,92 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<title>Chat Example</title>
|
|
||||||
<script src="//ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js"></script>
|
|
||||||
<script type="text/javascript">
|
|
||||||
$(function() {
|
|
||||||
|
|
||||||
var conn;
|
|
||||||
var msg = $("#msg");
|
|
||||||
var log = $("#log");
|
|
||||||
|
|
||||||
function appendLog(msg) {
|
|
||||||
var d = log[0]
|
|
||||||
var doScroll = d.scrollTop == d.scrollHeight - d.clientHeight;
|
|
||||||
msg.appendTo(log)
|
|
||||||
if (doScroll) {
|
|
||||||
d.scrollTop = d.scrollHeight - d.clientHeight;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$("#form").submit(function() {
|
|
||||||
if (!conn) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (!msg.val()) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
conn.send(msg.val());
|
|
||||||
msg.val("");
|
|
||||||
return false
|
|
||||||
});
|
|
||||||
|
|
||||||
if (window["WebSocket"]) {
|
|
||||||
conn = new WebSocket("ws://{{$}}/ws");
|
|
||||||
conn.onclose = function(evt) {
|
|
||||||
appendLog($("<div><b>Connection closed.</b></div>"))
|
|
||||||
}
|
|
||||||
conn.onmessage = function(evt) {
|
|
||||||
appendLog($("<div/>").text(evt.data))
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
appendLog($("<div><b>Your browser does not support WebSockets.</b></div>"))
|
|
||||||
}
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
<style type="text/css">
|
|
||||||
html {
|
|
||||||
overflow: hidden;
|
|
||||||
}
|
|
||||||
|
|
||||||
body {
|
|
||||||
overflow: hidden;
|
|
||||||
padding: 0;
|
|
||||||
margin: 0;
|
|
||||||
width: 100%;
|
|
||||||
height: 100%;
|
|
||||||
background: gray;
|
|
||||||
}
|
|
||||||
|
|
||||||
#log {
|
|
||||||
background: white;
|
|
||||||
margin: 0;
|
|
||||||
padding: 0.5em 0.5em 0.5em 0.5em;
|
|
||||||
position: absolute;
|
|
||||||
top: 0.5em;
|
|
||||||
left: 0.5em;
|
|
||||||
right: 0.5em;
|
|
||||||
bottom: 3em;
|
|
||||||
overflow: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
#form {
|
|
||||||
padding: 0 0.5em 0 0.5em;
|
|
||||||
margin: 0;
|
|
||||||
position: absolute;
|
|
||||||
bottom: 1em;
|
|
||||||
left: 0px;
|
|
||||||
width: 100%;
|
|
||||||
overflow: hidden;
|
|
||||||
}
|
|
||||||
|
|
||||||
</style>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<div id="log"></div>
|
|
||||||
<form id="form">
|
|
||||||
<input type="submit" value="Send" />
|
|
||||||
<input type="text" id="msg" size="64"/>
|
|
||||||
</form>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
51
Godeps/_workspace/src/github.com/gorilla/websocket/examples/chat/hub.go
generated
vendored
51
Godeps/_workspace/src/github.com/gorilla/websocket/examples/chat/hub.go
generated
vendored
@ -1,51 +0,0 @@
|
|||||||
// Copyright 2013 The Gorilla WebSocket Authors. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style
|
|
||||||
// license that can be found in the LICENSE file.
|
|
||||||
|
|
||||||
package main
|
|
||||||
|
|
||||||
// hub maintains the set of active connections and broadcasts messages to the
|
|
||||||
// connections.
|
|
||||||
type hub struct {
|
|
||||||
// Registered connections.
|
|
||||||
connections map[*connection]bool
|
|
||||||
|
|
||||||
// Inbound messages from the connections.
|
|
||||||
broadcast chan []byte
|
|
||||||
|
|
||||||
// Register requests from the connections.
|
|
||||||
register chan *connection
|
|
||||||
|
|
||||||
// Unregister requests from connections.
|
|
||||||
unregister chan *connection
|
|
||||||
}
|
|
||||||
|
|
||||||
var h = hub{
|
|
||||||
broadcast: make(chan []byte),
|
|
||||||
register: make(chan *connection),
|
|
||||||
unregister: make(chan *connection),
|
|
||||||
connections: make(map[*connection]bool),
|
|
||||||
}
|
|
||||||
|
|
||||||
func (h *hub) run() {
|
|
||||||
for {
|
|
||||||
select {
|
|
||||||
case c := <-h.register:
|
|
||||||
h.connections[c] = true
|
|
||||||
case c := <-h.unregister:
|
|
||||||
if _, ok := h.connections[c]; ok {
|
|
||||||
delete(h.connections, c)
|
|
||||||
close(c.send)
|
|
||||||
}
|
|
||||||
case m := <-h.broadcast:
|
|
||||||
for c := range h.connections {
|
|
||||||
select {
|
|
||||||
case c.send <- m:
|
|
||||||
default:
|
|
||||||
close(c.send)
|
|
||||||
delete(h.connections, c)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
39
Godeps/_workspace/src/github.com/gorilla/websocket/examples/chat/main.go
generated
vendored
39
Godeps/_workspace/src/github.com/gorilla/websocket/examples/chat/main.go
generated
vendored
@ -1,39 +0,0 @@
|
|||||||
// Copyright 2013 The Gorilla WebSocket Authors. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style
|
|
||||||
// license that can be found in the LICENSE file.
|
|
||||||
|
|
||||||
package main
|
|
||||||
|
|
||||||
import (
|
|
||||||
"flag"
|
|
||||||
"log"
|
|
||||||
"net/http"
|
|
||||||
"text/template"
|
|
||||||
)
|
|
||||||
|
|
||||||
var addr = flag.String("addr", ":8080", "http service address")
|
|
||||||
var homeTempl = template.Must(template.ParseFiles("home.html"))
|
|
||||||
|
|
||||||
func serveHome(w http.ResponseWriter, r *http.Request) {
|
|
||||||
if r.URL.Path != "/" {
|
|
||||||
http.Error(w, "Not found", 404)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if r.Method != "GET" {
|
|
||||||
http.Error(w, "Method not allowed", 405)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
w.Header().Set("Content-Type", "text/html; charset=utf-8")
|
|
||||||
homeTempl.Execute(w, r.Host)
|
|
||||||
}
|
|
||||||
|
|
||||||
func main() {
|
|
||||||
flag.Parse()
|
|
||||||
go h.run()
|
|
||||||
http.HandleFunc("/", serveHome)
|
|
||||||
http.HandleFunc("/ws", serveWs)
|
|
||||||
err := http.ListenAndServe(*addr, nil)
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal("ListenAndServe: ", err)
|
|
||||||
}
|
|
||||||
}
|
|
9
Godeps/_workspace/src/github.com/gorilla/websocket/examples/filewatch/README.md
generated
vendored
9
Godeps/_workspace/src/github.com/gorilla/websocket/examples/filewatch/README.md
generated
vendored
@ -1,9 +0,0 @@
|
|||||||
# File Watch example.
|
|
||||||
|
|
||||||
This example sends a file to the browser client for display whenever the file is modified.
|
|
||||||
|
|
||||||
$ go get github.com/gorilla/websocket
|
|
||||||
$ cd `go list -f '{{.Dir}}' github.com/gorilla/websocket/examples/filewatch`
|
|
||||||
$ go run main.go <name of file to watch>
|
|
||||||
# Open http://localhost:8080/ .
|
|
||||||
# Modify the file to see it update in the browser.
|
|
193
Godeps/_workspace/src/github.com/gorilla/websocket/examples/filewatch/main.go
generated
vendored
193
Godeps/_workspace/src/github.com/gorilla/websocket/examples/filewatch/main.go
generated
vendored
@ -1,193 +0,0 @@
|
|||||||
// Copyright 2013 The Gorilla WebSocket Authors. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style
|
|
||||||
// license that can be found in the LICENSE file.
|
|
||||||
|
|
||||||
package main
|
|
||||||
|
|
||||||
import (
|
|
||||||
"flag"
|
|
||||||
"io/ioutil"
|
|
||||||
"log"
|
|
||||||
"net/http"
|
|
||||||
"os"
|
|
||||||
"strconv"
|
|
||||||
"text/template"
|
|
||||||
"time"
|
|
||||||
|
|
||||||
"github.com/gorilla/websocket"
|
|
||||||
)
|
|
||||||
|
|
||||||
const (
|
|
||||||
// Time allowed to write the file to the client.
|
|
||||||
writeWait = 10 * time.Second
|
|
||||||
|
|
||||||
// Time allowed to read the next pong message from the client.
|
|
||||||
pongWait = 60 * time.Second
|
|
||||||
|
|
||||||
// Send pings to client with this period. Must be less than pongWait.
|
|
||||||
pingPeriod = (pongWait * 9) / 10
|
|
||||||
|
|
||||||
// Poll file for changes with this period.
|
|
||||||
filePeriod = 10 * time.Second
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
addr = flag.String("addr", ":8080", "http service address")
|
|
||||||
homeTempl = template.Must(template.New("").Parse(homeHTML))
|
|
||||||
filename string
|
|
||||||
upgrader = websocket.Upgrader{
|
|
||||||
ReadBufferSize: 1024,
|
|
||||||
WriteBufferSize: 1024,
|
|
||||||
}
|
|
||||||
)
|
|
||||||
|
|
||||||
func readFileIfModified(lastMod time.Time) ([]byte, time.Time, error) {
|
|
||||||
fi, err := os.Stat(filename)
|
|
||||||
if err != nil {
|
|
||||||
return nil, lastMod, err
|
|
||||||
}
|
|
||||||
if !fi.ModTime().After(lastMod) {
|
|
||||||
return nil, lastMod, nil
|
|
||||||
}
|
|
||||||
p, err := ioutil.ReadFile(filename)
|
|
||||||
if err != nil {
|
|
||||||
return nil, fi.ModTime(), err
|
|
||||||
}
|
|
||||||
return p, fi.ModTime(), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func reader(ws *websocket.Conn) {
|
|
||||||
defer ws.Close()
|
|
||||||
ws.SetReadLimit(512)
|
|
||||||
ws.SetReadDeadline(time.Now().Add(pongWait))
|
|
||||||
ws.SetPongHandler(func(string) error { ws.SetReadDeadline(time.Now().Add(pongWait)); return nil })
|
|
||||||
for {
|
|
||||||
_, _, err := ws.ReadMessage()
|
|
||||||
if err != nil {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func writer(ws *websocket.Conn, lastMod time.Time) {
|
|
||||||
lastError := ""
|
|
||||||
pingTicker := time.NewTicker(pingPeriod)
|
|
||||||
fileTicker := time.NewTicker(filePeriod)
|
|
||||||
defer func() {
|
|
||||||
pingTicker.Stop()
|
|
||||||
fileTicker.Stop()
|
|
||||||
ws.Close()
|
|
||||||
}()
|
|
||||||
for {
|
|
||||||
select {
|
|
||||||
case <-fileTicker.C:
|
|
||||||
var p []byte
|
|
||||||
var err error
|
|
||||||
|
|
||||||
p, lastMod, err = readFileIfModified(lastMod)
|
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
if s := err.Error(); s != lastError {
|
|
||||||
lastError = s
|
|
||||||
p = []byte(lastError)
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
lastError = ""
|
|
||||||
}
|
|
||||||
|
|
||||||
if p != nil {
|
|
||||||
ws.SetWriteDeadline(time.Now().Add(writeWait))
|
|
||||||
if err := ws.WriteMessage(websocket.TextMessage, p); err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
}
|
|
||||||
case <-pingTicker.C:
|
|
||||||
ws.SetWriteDeadline(time.Now().Add(writeWait))
|
|
||||||
if err := ws.WriteMessage(websocket.PingMessage, []byte{}); err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func serveWs(w http.ResponseWriter, r *http.Request) {
|
|
||||||
ws, err := upgrader.Upgrade(w, r, nil)
|
|
||||||
if err != nil {
|
|
||||||
if _, ok := err.(websocket.HandshakeError); !ok {
|
|
||||||
log.Println(err)
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
var lastMod time.Time
|
|
||||||
if n, err := strconv.ParseInt(r.FormValue("lastMod"), 16, 64); err != nil {
|
|
||||||
lastMod = time.Unix(0, n)
|
|
||||||
}
|
|
||||||
|
|
||||||
go writer(ws, lastMod)
|
|
||||||
reader(ws)
|
|
||||||
}
|
|
||||||
|
|
||||||
func serveHome(w http.ResponseWriter, r *http.Request) {
|
|
||||||
if r.URL.Path != "/" {
|
|
||||||
http.Error(w, "Not found", 404)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if r.Method != "GET" {
|
|
||||||
http.Error(w, "Method not allowed", 405)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
w.Header().Set("Content-Type", "text/html; charset=utf-8")
|
|
||||||
p, lastMod, err := readFileIfModified(time.Time{})
|
|
||||||
if err != nil {
|
|
||||||
p = []byte(err.Error())
|
|
||||||
lastMod = time.Unix(0, 0)
|
|
||||||
}
|
|
||||||
var v = struct {
|
|
||||||
Host string
|
|
||||||
Data string
|
|
||||||
LastMod string
|
|
||||||
}{
|
|
||||||
r.Host,
|
|
||||||
string(p),
|
|
||||||
strconv.FormatInt(lastMod.UnixNano(), 16),
|
|
||||||
}
|
|
||||||
homeTempl.Execute(w, &v)
|
|
||||||
}
|
|
||||||
|
|
||||||
func main() {
|
|
||||||
flag.Parse()
|
|
||||||
if flag.NArg() != 1 {
|
|
||||||
log.Fatal("filename not specified")
|
|
||||||
}
|
|
||||||
filename = flag.Args()[0]
|
|
||||||
http.HandleFunc("/", serveHome)
|
|
||||||
http.HandleFunc("/ws", serveWs)
|
|
||||||
if err := http.ListenAndServe(*addr, nil); err != nil {
|
|
||||||
log.Fatal(err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const homeHTML = `<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<title>WebSocket Example</title>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<pre id="fileData">{{.Data}}</pre>
|
|
||||||
<script type="text/javascript">
|
|
||||||
(function() {
|
|
||||||
var data = document.getElementById("fileData");
|
|
||||||
var conn = new WebSocket("ws://{{.Host}}/ws?lastMod={{.LastMod}}");
|
|
||||||
conn.onclose = function(evt) {
|
|
||||||
data.textContent = 'Connection closed';
|
|
||||||
}
|
|
||||||
conn.onmessage = function(evt) {
|
|
||||||
console.log('file updated');
|
|
||||||
data.textContent = evt.data;
|
|
||||||
}
|
|
||||||
})();
|
|
||||||
</script>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
`
|
|
4
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/array_comment.hcl
generated
vendored
4
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/array_comment.hcl
generated
vendored
@ -1,4 +0,0 @@
|
|||||||
foo = [
|
|
||||||
"1",
|
|
||||||
"2", # comment
|
|
||||||
]
|
|
6
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/assign_colon.hcl
generated
vendored
6
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/assign_colon.hcl
generated
vendored
@ -1,6 +0,0 @@
|
|||||||
resource = [{
|
|
||||||
"foo": {
|
|
||||||
"bar": {},
|
|
||||||
"baz": [1, 2, "foo"],
|
|
||||||
}
|
|
||||||
}]
|
|
5
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/assign_deep.hcl
generated
vendored
5
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/assign_deep.hcl
generated
vendored
@ -1,5 +0,0 @@
|
|||||||
resource = [{
|
|
||||||
foo = [{
|
|
||||||
bar = {}
|
|
||||||
}]
|
|
||||||
}]
|
|
15
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/comment.hcl
generated
vendored
15
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/comment.hcl
generated
vendored
@ -1,15 +0,0 @@
|
|||||||
// Foo
|
|
||||||
|
|
||||||
/* Bar */
|
|
||||||
|
|
||||||
/*
|
|
||||||
/*
|
|
||||||
Baz
|
|
||||||
*/
|
|
||||||
|
|
||||||
# Another
|
|
||||||
|
|
||||||
# Multiple
|
|
||||||
# Lines
|
|
||||||
|
|
||||||
foo = "bar"
|
|
1
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/comment_single.hcl
generated
vendored
1
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/comment_single.hcl
generated
vendored
@ -1 +0,0 @@
|
|||||||
# Hello
|
|
42
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/complex.hcl
generated
vendored
42
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/complex.hcl
generated
vendored
@ -1,42 +0,0 @@
|
|||||||
// This comes from Terraform, as a test
|
|
||||||
variable "foo" {
|
|
||||||
default = "bar"
|
|
||||||
description = "bar"
|
|
||||||
}
|
|
||||||
|
|
||||||
provider "aws" {
|
|
||||||
access_key = "foo"
|
|
||||||
secret_key = "bar"
|
|
||||||
}
|
|
||||||
|
|
||||||
provider "do" {
|
|
||||||
api_key = "${var.foo}"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_security_group" "firewall" {
|
|
||||||
count = 5
|
|
||||||
}
|
|
||||||
|
|
||||||
resource aws_instance "web" {
|
|
||||||
ami = "${var.foo}"
|
|
||||||
security_groups = [
|
|
||||||
"foo",
|
|
||||||
"${aws_security_group.firewall.foo}"
|
|
||||||
]
|
|
||||||
|
|
||||||
network_interface {
|
|
||||||
device_index = 0
|
|
||||||
description = "Main network interface"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_instance" "db" {
|
|
||||||
security_groups = "${aws_security_group.firewall.*.id}"
|
|
||||||
VPC = "foo"
|
|
||||||
|
|
||||||
depends_on = ["aws_instance.web"]
|
|
||||||
}
|
|
||||||
|
|
||||||
output "web_ip" {
|
|
||||||
value = "${aws_instance.web.private_ip}"
|
|
||||||
}
|
|
1
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/complex_key.hcl
generated
vendored
1
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/complex_key.hcl
generated
vendored
@ -1 +0,0 @@
|
|||||||
foo.bar = "baz"
|
|
0
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/empty.hcl
generated
vendored
0
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/empty.hcl
generated
vendored
1
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/list.hcl
generated
vendored
1
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/list.hcl
generated
vendored
@ -1 +0,0 @@
|
|||||||
foo = [1, 2, "foo", true]
|
|
1
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/list_comma.hcl
generated
vendored
1
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/list_comma.hcl
generated
vendored
@ -1 +0,0 @@
|
|||||||
foo = [1, 2, "foo",]
|
|
2
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/multiple.hcl
generated
vendored
2
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/multiple.hcl
generated
vendored
@ -1,2 +0,0 @@
|
|||||||
foo = "bar"
|
|
||||||
key = 7
|
|
5
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/null.hcl
generated
vendored
5
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/null.hcl
generated
vendored
@ -1,5 +0,0 @@
|
|||||||
foo = null
|
|
||||||
bar = [1, null, 3]
|
|
||||||
baz {
|
|
||||||
foo = null
|
|
||||||
}
|
|
3
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/old.hcl
generated
vendored
3
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/old.hcl
generated
vendored
@ -1,3 +0,0 @@
|
|||||||
default = {
|
|
||||||
"eu-west-1": "ami-b1cf19c6",
|
|
||||||
}
|
|
5
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/structure.hcl
generated
vendored
5
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/structure.hcl
generated
vendored
@ -1,5 +0,0 @@
|
|||||||
// This is a test structure for the lexer
|
|
||||||
foo bar "baz" {
|
|
||||||
key = 7
|
|
||||||
foo = "bar"
|
|
||||||
}
|
|
5
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/structure_basic.hcl
generated
vendored
5
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/structure_basic.hcl
generated
vendored
@ -1,5 +0,0 @@
|
|||||||
foo {
|
|
||||||
value = 7
|
|
||||||
"value" = 8
|
|
||||||
"complex::value" = 9
|
|
||||||
}
|
|
1
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/structure_empty.hcl
generated
vendored
1
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/structure_empty.hcl
generated
vendored
@ -1 +0,0 @@
|
|||||||
resource "foo" "bar" {}
|
|
8
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/types.hcl
generated
vendored
8
Godeps/_workspace/src/github.com/yudai/hcl/hcl/test-fixtures/types.hcl
generated
vendored
@ -1,8 +0,0 @@
|
|||||||
foo = "bar"
|
|
||||||
bar = 7
|
|
||||||
baz = [1,2,3]
|
|
||||||
foo = -12
|
|
||||||
bar = 3.14159
|
|
||||||
foo = true
|
|
||||||
bar = false
|
|
||||||
baz = null
|
|
4
Godeps/_workspace/src/github.com/yudai/hcl/json/test-fixtures/array.json
generated
vendored
4
Godeps/_workspace/src/github.com/yudai/hcl/json/test-fixtures/array.json
generated
vendored
@ -1,4 +0,0 @@
|
|||||||
{
|
|
||||||
"foo": [1, 2, "bar"],
|
|
||||||
"bar": "baz"
|
|
||||||
}
|
|
3
Godeps/_workspace/src/github.com/yudai/hcl/json/test-fixtures/basic.json
generated
vendored
3
Godeps/_workspace/src/github.com/yudai/hcl/json/test-fixtures/basic.json
generated
vendored
@ -1,3 +0,0 @@
|
|||||||
{
|
|
||||||
"foo": "bar"
|
|
||||||
}
|
|
5
Godeps/_workspace/src/github.com/yudai/hcl/json/test-fixtures/object.json
generated
vendored
5
Godeps/_workspace/src/github.com/yudai/hcl/json/test-fixtures/object.json
generated
vendored
@ -1,5 +0,0 @@
|
|||||||
{
|
|
||||||
"foo": {
|
|
||||||
"bar": [1,2]
|
|
||||||
}
|
|
||||||
}
|
|
10
Godeps/_workspace/src/github.com/yudai/hcl/json/test-fixtures/types.json
generated
vendored
10
Godeps/_workspace/src/github.com/yudai/hcl/json/test-fixtures/types.json
generated
vendored
@ -1,10 +0,0 @@
|
|||||||
{
|
|
||||||
"foo": "bar",
|
|
||||||
"bar": 7,
|
|
||||||
"baz": [1,2,3],
|
|
||||||
"foo": -12,
|
|
||||||
"bar": 3.14159,
|
|
||||||
"foo": true,
|
|
||||||
"bar": false,
|
|
||||||
"foo": null
|
|
||||||
}
|
|
2
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/basic.hcl
generated
vendored
2
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/basic.hcl
generated
vendored
@ -1,2 +0,0 @@
|
|||||||
foo = "bar"
|
|
||||||
bar = "${file("bing/bong.txt")}"
|
|
4
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/basic.json
generated
vendored
4
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/basic.json
generated
vendored
@ -1,4 +0,0 @@
|
|||||||
{
|
|
||||||
"foo": "bar",
|
|
||||||
"bar": "${file(\"bing/bong.txt\")}"
|
|
||||||
}
|
|
1
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/basic_int_string.hcl
generated
vendored
1
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/basic_int_string.hcl
generated
vendored
@ -1 +0,0 @@
|
|||||||
count = "3"
|
|
3
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/basic_squish.hcl
generated
vendored
3
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/basic_squish.hcl
generated
vendored
@ -1,3 +0,0 @@
|
|||||||
foo="bar"
|
|
||||||
bar="${file("bing/bong.txt")}"
|
|
||||||
foo-bar="baz"
|
|
15
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/decode_policy.hcl
generated
vendored
15
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/decode_policy.hcl
generated
vendored
@ -1,15 +0,0 @@
|
|||||||
key "" {
|
|
||||||
policy = "read"
|
|
||||||
}
|
|
||||||
|
|
||||||
key "foo/" {
|
|
||||||
policy = "write"
|
|
||||||
}
|
|
||||||
|
|
||||||
key "foo/bar/" {
|
|
||||||
policy = "read"
|
|
||||||
}
|
|
||||||
|
|
||||||
key "foo/bar/baz" {
|
|
||||||
policy = "deny"
|
|
||||||
}
|
|
19
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/decode_policy.json
generated
vendored
19
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/decode_policy.json
generated
vendored
@ -1,19 +0,0 @@
|
|||||||
{
|
|
||||||
"key": {
|
|
||||||
"": {
|
|
||||||
"policy": "read"
|
|
||||||
},
|
|
||||||
|
|
||||||
"foo/": {
|
|
||||||
"policy": "write"
|
|
||||||
},
|
|
||||||
|
|
||||||
"foo/bar/": {
|
|
||||||
"policy": "read"
|
|
||||||
},
|
|
||||||
|
|
||||||
"foo/bar/baz": {
|
|
||||||
"policy": "deny"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
10
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/decode_tf_variable.hcl
generated
vendored
10
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/decode_tf_variable.hcl
generated
vendored
@ -1,10 +0,0 @@
|
|||||||
variable "foo" {
|
|
||||||
default = "bar"
|
|
||||||
description = "bar"
|
|
||||||
}
|
|
||||||
|
|
||||||
variable "amis" {
|
|
||||||
default = {
|
|
||||||
east = "foo"
|
|
||||||
}
|
|
||||||
}
|
|
14
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/decode_tf_variable.json
generated
vendored
14
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/decode_tf_variable.json
generated
vendored
@ -1,14 +0,0 @@
|
|||||||
{
|
|
||||||
"variable": {
|
|
||||||
"foo": {
|
|
||||||
"default": "bar",
|
|
||||||
"description": "bar"
|
|
||||||
},
|
|
||||||
|
|
||||||
"amis": {
|
|
||||||
"default": {
|
|
||||||
"east": "foo"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
1
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/empty.hcl
generated
vendored
1
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/empty.hcl
generated
vendored
@ -1 +0,0 @@
|
|||||||
resource "foo" {}
|
|
1
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/escape.hcl
generated
vendored
1
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/escape.hcl
generated
vendored
@ -1 +0,0 @@
|
|||||||
foo = "bar\"baz\\n"
|
|
2
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/flat.hcl
generated
vendored
2
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/flat.hcl
generated
vendored
@ -1,2 +0,0 @@
|
|||||||
foo = "bar"
|
|
||||||
Key = 7
|
|
1
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/float.hcl
generated
vendored
1
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/float.hcl
generated
vendored
@ -1 +0,0 @@
|
|||||||
a = 1.02
|
|
3
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/float.json
generated
vendored
3
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/float.json
generated
vendored
@ -1,3 +0,0 @@
|
|||||||
{
|
|
||||||
"a": 1.02
|
|
||||||
}
|
|
3
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/multiline.json
generated
vendored
3
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/multiline.json
generated
vendored
@ -1,3 +0,0 @@
|
|||||||
{
|
|
||||||
"foo": "bar\nbaz"
|
|
||||||
}
|
|
4
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/multiline_bad.hcl
generated
vendored
4
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/multiline_bad.hcl
generated
vendored
@ -1,4 +0,0 @@
|
|||||||
foo = <<EOF
|
|
||||||
bar
|
|
||||||
baz
|
|
||||||
EOF
|
|
5
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/nested_block_comment.hcl
generated
vendored
5
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/nested_block_comment.hcl
generated
vendored
@ -1,5 +0,0 @@
|
|||||||
/*
|
|
||||||
foo = "bar/*"
|
|
||||||
*/
|
|
||||||
|
|
||||||
bar = "value"
|
|
1
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/null.hcl
generated
vendored
1
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/null.hcl
generated
vendored
@ -1 +0,0 @@
|
|||||||
foo = null
|
|
6
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/scientific.hcl
generated
vendored
6
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/scientific.hcl
generated
vendored
@ -1,6 +0,0 @@
|
|||||||
a = 1e-10
|
|
||||||
b = 1e+10
|
|
||||||
c = 1e10
|
|
||||||
d = 1.2e-10
|
|
||||||
e = 1.2e+10
|
|
||||||
f = 1.2e10
|
|
8
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/scientific.json
generated
vendored
8
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/scientific.json
generated
vendored
@ -1,8 +0,0 @@
|
|||||||
{
|
|
||||||
"a": 1e-10,
|
|
||||||
"b": 1e+10,
|
|
||||||
"c": 1e10,
|
|
||||||
"d": 1.2e-10,
|
|
||||||
"e": 1.2e+10,
|
|
||||||
"f": 1.2e10
|
|
||||||
}
|
|
5
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/structure.hcl
generated
vendored
5
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/structure.hcl
generated
vendored
@ -1,5 +0,0 @@
|
|||||||
// This is a test structure for the lexer
|
|
||||||
foo "baz" {
|
|
||||||
key = 7
|
|
||||||
foo = "bar"
|
|
||||||
}
|
|
8
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/structure.json
generated
vendored
8
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/structure.json
generated
vendored
@ -1,8 +0,0 @@
|
|||||||
{
|
|
||||||
"foo": [{
|
|
||||||
"baz": [{
|
|
||||||
"key": 7,
|
|
||||||
"foo": "bar"
|
|
||||||
}]
|
|
||||||
}]
|
|
||||||
}
|
|
9
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/structure2.hcl
generated
vendored
9
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/structure2.hcl
generated
vendored
@ -1,9 +0,0 @@
|
|||||||
// This is a test structure for the lexer
|
|
||||||
foo "baz" {
|
|
||||||
key = 7
|
|
||||||
foo = "bar"
|
|
||||||
}
|
|
||||||
|
|
||||||
foo {
|
|
||||||
key = 7
|
|
||||||
}
|
|
10
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/structure2.json
generated
vendored
10
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/structure2.json
generated
vendored
@ -1,10 +0,0 @@
|
|||||||
{
|
|
||||||
"foo": [{
|
|
||||||
"baz": {
|
|
||||||
"key": 7,
|
|
||||||
"foo": "bar"
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
"key": 7
|
|
||||||
}]
|
|
||||||
}
|
|
8
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/structure_flat.json
generated
vendored
8
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/structure_flat.json
generated
vendored
@ -1,8 +0,0 @@
|
|||||||
{
|
|
||||||
"foo": {
|
|
||||||
"baz": {
|
|
||||||
"key": 7,
|
|
||||||
"foo": "bar"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
7
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/structure_flatmap.hcl
generated
vendored
7
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/structure_flatmap.hcl
generated
vendored
@ -1,7 +0,0 @@
|
|||||||
foo {
|
|
||||||
key = 7
|
|
||||||
}
|
|
||||||
|
|
||||||
foo {
|
|
||||||
foo = "bar"
|
|
||||||
}
|
|
6
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/structure_list.hcl
generated
vendored
6
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/structure_list.hcl
generated
vendored
@ -1,6 +0,0 @@
|
|||||||
foo {
|
|
||||||
key = 7
|
|
||||||
}
|
|
||||||
foo {
|
|
||||||
key = 12
|
|
||||||
}
|
|
7
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/structure_list.json
generated
vendored
7
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/structure_list.json
generated
vendored
@ -1,7 +0,0 @@
|
|||||||
{
|
|
||||||
"foo": [{
|
|
||||||
"key": 7
|
|
||||||
}, {
|
|
||||||
"key": 12
|
|
||||||
}]
|
|
||||||
}
|
|
16
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/structure_list_deep.json
generated
vendored
16
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/structure_list_deep.json
generated
vendored
@ -1,16 +0,0 @@
|
|||||||
{
|
|
||||||
"bar": {
|
|
||||||
"foo": {
|
|
||||||
"name": "terraform_example",
|
|
||||||
"ingress": [
|
|
||||||
{
|
|
||||||
"from_port": 22
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"from_port": 80
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
7
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/structure_multi.hcl
generated
vendored
7
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/structure_multi.hcl
generated
vendored
@ -1,7 +0,0 @@
|
|||||||
foo "baz" {
|
|
||||||
key = 7
|
|
||||||
}
|
|
||||||
|
|
||||||
foo "bar" {
|
|
||||||
key = 12
|
|
||||||
}
|
|
11
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/structure_multi.json
generated
vendored
11
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/structure_multi.json
generated
vendored
@ -1,11 +0,0 @@
|
|||||||
{
|
|
||||||
"foo": {
|
|
||||||
"baz": {
|
|
||||||
"key": 7
|
|
||||||
},
|
|
||||||
|
|
||||||
"bar": {
|
|
||||||
"key": 12
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
5
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/terraform_heroku.hcl
generated
vendored
5
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/terraform_heroku.hcl
generated
vendored
@ -1,5 +0,0 @@
|
|||||||
name = "terraform-test-app"
|
|
||||||
|
|
||||||
config_vars {
|
|
||||||
FOO = "bar"
|
|
||||||
}
|
|
6
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/terraform_heroku.json
generated
vendored
6
Godeps/_workspace/src/github.com/yudai/hcl/test-fixtures/terraform_heroku.json
generated
vendored
@ -1,6 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "terraform-test-app",
|
|
||||||
"config_vars": {
|
|
||||||
"FOO": "bar"
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,2 +0,0 @@
|
|||||||
/*
|
|
||||||
Foo
|
|
8
Makefile
8
Makefile
@ -1,7 +1,7 @@
|
|||||||
OUTPUT_DIR = ./builds
|
OUTPUT_DIR = ./builds
|
||||||
|
|
||||||
gotty: app/resource.go main.go app/*.go
|
gotty: app/resource.go main.go app/*.go
|
||||||
go build
|
godep go build
|
||||||
|
|
||||||
resource: app/resource.go
|
resource: app/resource.go
|
||||||
|
|
||||||
@ -35,12 +35,10 @@ tools:
|
|||||||
go get github.com/tools/godep
|
go get github.com/tools/godep
|
||||||
go get github.com/mitchellh/gox
|
go get github.com/mitchellh/gox
|
||||||
go get github.com/tcnksm/ghr
|
go get github.com/tcnksm/ghr
|
||||||
|
go get github.com/jteeuwen/go-bindata/...
|
||||||
deps:
|
|
||||||
godep restore
|
|
||||||
|
|
||||||
test:
|
test:
|
||||||
if [ `go fmt ./... | wc -l` -gt 0 ]; then echo "go fmt error"; exit 1; fi
|
if [ `go fmt $(go list ./... | grep -v /vendor/) | wc -l` -gt 0 ]; then echo "go fmt error"; exit 1; fi
|
||||||
|
|
||||||
cross_compile:
|
cross_compile:
|
||||||
GOARM=5 gox -os="darwin linux freebsd netbsd openbsd" -arch="386 amd64 arm" -output "${OUTPUT_DIR}/pkg/{{.OS}}_{{.Arch}}/{{.Dir}}"
|
GOARM=5 gox -os="darwin linux freebsd netbsd openbsd" -arch="386 amd64 arm" -output "${OUTPUT_DIR}/pkg/{{.OS}}_{{.Arch}}/{{.Dir}}"
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user