File: README.md

package info (click to toggle)
ocaml-obuild 0.2.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,456 kB
  • sloc: ml: 14,491; sh: 211; ansic: 34; makefile: 11
file content (247 lines) | stat: -rw-r--r-- 7,088 bytes parent folder | download
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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
obuild
======

A parallel, incremental and declarative build system for OCaml.

Design
------

The goal is to make a very simple build system for users and developers of
OCaml library and programs.

`obuild` acts as building black box: user declare only what they want to build
and with which sources, and it will be consistently built.  The design is based
on Haskell's Cabal, and borrow most of the layout and way of working,
adapting parts where necessary to support OCaml fully.

There's no way to build things that `obuild` has not been designed to do on
purpose, so that the experience provided is consistent, and all future
improvements to `obuild` will automatically benefit program and libraries using
older versions.  Currently unsupported features should be requested on the
Github issue tracker.

Feature
-------

* Incremental & parallel build system. only rebuilding what's necessary.
* Descriptive configuration file.
* Easy for users: no rules to mess about, just describe what you want.
* No building dependency apart from OCaml's stdlib: easy to build
* No tool or binary dependencies apart from ocaml compilers
* OCamlfind-like support integrated for faster compilation

How to build a project using obuild
-----------------------------------

obuild supports a clean, user-friendly command-line interface with helpful error messages and automatic help generation.

### Quick Start

```bash
# Get help
obuild -h                    # Show all available commands
obuild build -h              # Show build-specific options

# Check version
obuild --version

# Typical workflow
obuild configure --enable-tests
obuild build
obuild test
```

### Available Commands

```
obuild configure    Prepare to build the package
obuild build        Make this package ready for installation
obuild clean        Clean up after a build
obuild install      Install this package
obuild test         Run the tests
obuild doc          Generate documentation
obuild sdist        Generate a source distribution file (.tar.gz)
obuild init         Initialize a new project
obuild get          Get project metadata field
```

### Command Details

**configure** - Prepare the project by checking dependencies and setting build options

```bash
obuild configure [OPTIONS]

Options:
  --enable-tests              Enable building tests
  --enable-examples           Enable building examples
  --enable-library-bytecode   Enable library bytecode compilation
  --enable-library-native     Enable library native compilation
  -g                          Enable debugging symbols
  --annot                     Generate .annot files
```

**build** - Build every buildable target defined by the project

```bash
obuild build [OPTIONS] [TARGETS...]

Options:
  -j, --jobs N               Maximum number of parallel jobs (default: auto-detected)
  --dot                      Dump dependency graphs as .dot files

Examples:
  obuild build                # Build everything
  obuild build -j 4          # Build with 4 parallel jobs
  obuild build mylib myexe   # Build specific targets only
```

**clean** - Remove all build artifacts

**test** - Run all test targets

```bash
obuild test [OPTIONS]

Options:
  --output                   Show test output (default: only show failures)
```

**install** - Install libraries and executables

```bash
obuild install [OPTIONS]

Options:
  --destdir DIR              Override installation directory
  --opam                     Generate .install file for OPAM
```

**get** - Retrieve project metadata

```bash
obuild get FIELD

Fields: name, version, license

Examples:
  obuild get name            # Get project name
  obuild get version         # Get project version
```

### Global Options

These options work with any command:

```bash
-v, --verbose              Verbose output
-q, --quiet                Quiet mode (errors only)
--color                    Enable colored output
--strict                   Enable strict mode
```

### Configuration Files

Obuild supports configuration files for setting default values. Config files use a simple `key = value` format.

**Config file locations** (in order of precedence):

1. `./.obuildrc` - Project-specific settings
2. `~/.obuildrc` - User-wide settings

**Example config file:**

```bash
# ~/.obuildrc - User configuration for obuild

# Set default number of parallel jobs
jobs = 8

# Enable colored output by default
color = true

# Verbose mode
verbose = false
```

**Supported options:**

- `jobs` - Default number of parallel build jobs (integer)
- `color` - Enable colored output (true/false)
- `verbose` - Verbose output mode (true/false)
- `quiet` - Quiet mode (true/false)
- `strict` - Strict mode (true/false)

Command-line arguments always override config file values.

### Shell Completion

Obuild can generate shell completion scripts for bash, zsh, and fish:

```bash
# Generate and install bash completion
obuild completion bash > ~/.bash_completion.d/obuild
source ~/.bash_completion.d/obuild

# Generate zsh completion
obuild completion zsh > ~/.zsh/completions/_obuild

# Generate fish completion
obuild completion fish > ~/.config/fish/completions/obuild.fish
```

How to write a project file
---------------------------

A project file is a file terminated by the `.obuild` extension.
Only one per project is supported.

The content is declarative using a simple layout format.
Every normal line needs to be in a "key: value" format. Multiple lines
are supported by indenting (with spaces) the value related to the key.

```
    name: myproject
    version: 0.0.1
    description:
      This is my new cool project
      .
      This is a long description describing properly what the project does.
    licence: MyLicense
    authors: John Doe <john@doe.com>
    obuild-ver: 1
    homepage: http://my.server.com/myproject
```

The different target types:

* executable: this creates an executable that is going to be installed by default.
* library: create a library that is going to be installed.
* test: create an executable that will not be installed, and will interact with
        obuild according to the test_type field. cabal test will run every built tests
        in a row. for the exit test_type, the exit code is used to signal error (0 = success, anything else = failure)
* bench: create an executable that will not be installed, and will allow to benchmarks,
         some part of the project. This is largely unimplemented and just a placeholder for future development.
* example: create an executable that is not installed, nor compiled by default. you need
           to use configure with --enable-examples. This allow to make sure that examples are compiled with
           the sources to prevent bitrotting. At a later stage that can be used to generate extra documentation.

Declaring an executable
-----------------------

```
    executable myexec
      main-is: mymain.ml
      src-dir: src
      build-deps: unix
```

Declaring a library
-------------------

```
    library mylib
      modules: Module1, Module2
      src-dir: lib
      build-deps: mydep1, mydep2
```