Skip to content

Latest commit

 

History

History
203 lines (145 loc) · 3.84 KB

README.md

File metadata and controls

203 lines (145 loc) · 3.84 KB

** REVIEW REQUIRED **

This guide is a WIP.


Intro

Some background here on the history of gopkg.in, major version numbers in paths etc.

Hello, world

Let's write the YAML equivalent of Hello World. Create a directory outside your GOPATH/src tree and change into it:

$ cd $(mktemp -d)
$ mkdir hello
$ cd hello
$ go mod init github.com/you/hello
go: creating new go.mod: module github.com/you/hello

Then create a file hello.go which uses the original v1 of the yaml package:

package main

import (
	"fmt"
	"gopkg.in/yaml.v1"
	"log"
)

type T struct {
	F int "a,omitempty"
	B int
}

func main() {
	t := &T{F: 1}
	out, err := yaml.Marshal(t)
	if err != nil {
		log.Fatalf("cannot marshal %#v: %v", t, err)
	}
	fmt.Printf("we got %q\n", out)
}

Create an empty go.mod file to mark the root of this module, and then build and run your new program:

$ go build
go: finding gopkg.in/yaml.v1 latest
go: downloading gopkg.in/yaml.v1 v1.0.0-20140924161607-9f9df34309c0
$ ./hello
we got "a: 1\nb: 0\n"

Notice how go resolves gopkg.in/yaml.v1, something we can see by inspecting the go.mod file:

$ cat go.mod
module github.com/you/hello

require gopkg.in/yaml.v1 v1.0.0-20140924161607-9f9df34309c0

Now let's assume there was a breaking change announced in the yaml package which necessitated a major version bump, to v2.x.x. We update hello.go:

package main

import (
	"fmt"
	"gopkg.in/yaml.v2"
	"log"
)

type T struct {
	F int "a,omitempty"
	B int
}

func main() {
	t := &T{F: 1}
	out, err := yaml.Marshal(t)
	if err != nil {
		log.Fatalf("cannot marshal %#v: %v", t, err)
	}
	fmt.Printf("we got %q\n", out)
}

Now we go build again; notice the resolution to v2 of the yaml package this time around:

$ go build
go: finding gopkg.in/yaml.v2 v2.2.1
go: downloading gopkg.in/yaml.v2 v2.2.1
go: finding gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405
$ ./hello
we got "a: 1\nb: 0\n"

We can check go.mod for the exact version that was resolved:

$ cat go.mod
module github.com/you/hello

require (
	gopkg.in/yaml.v1 v1.0.0-20140924161607-9f9df34309c0
	gopkg.in/yaml.v2 v2.2.1
)

Notice that the previously resolved v1 of the yaml package remains in the go.mod file. Pruning or trimming of dependencies is being discussed in golang/go#24101.

Version details

go version go1.11.2 linux/amd64