summaryrefslogtreecommitdiffstats
path: root/HACKING.md
blob: 15ad62f9702c8c4db873229fe009d2a0d382accd (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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
# Hacking Guide

## Overview

This guide contains instructions for building artifacts contained in this repository.

### Go

This spec includes several Go packages, and a command line tool considered to be a reference implementation of the OCI image specification.

Prerequisites:

- Go - current release only, earlier releases are not supported
- make

The following make targets are relevant for any work involving the Go packages.

### Linting

The included Go source code is being examined for any linting violations not included in the standard Go compiler.
Linting is done using [golangci-lint][golangci-lint].

Invocation:

```shell
make lint
```

### Tests

This target executes all Go based tests.

Invocation:

```shell
make test
make validate-examples
```

### JSON schema formatting

This target auto-formats all JSON files in the `schema` directory using the `jq` tool.

Prerequisites:

- [jq][jq] >=1.5

Invocation:

```shell
make fmt
```

### OCI image specification PDF/HTML documentation files

This target generates a PDF/HTML version of the OCI image specification.

Prerequisites:

- [Docker][docker]

Invocation:

```shell
make docs
```

### License header check

This target checks if the source code includes necessary headers.

Invocation:

```shell
make check-license
```

### Clean build artifacts

This target cleans all generated/compiled artifacts.

Invocation:

```shell
make clean
```

### Create PNG images from dot files

This target generates PNG image files from DOT source files in the `img` directory.

Prerequisites:

- [graphviz][graphviz]

Invocation:

```shell
make img/media-types.png
```

[docker]: https://www.docker.com/
[golangci-lint]: https://github.com/golangci/golangci-lint
[graphviz]: https://www.graphviz.org/
[jq]: https://stedolan.github.io/jq/