File: dynamic_include.rst

package info (click to toggle)
ocaml-dune 3.20.2-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 33,564 kB
  • sloc: ml: 175,178; asm: 28,570; ansic: 5,251; sh: 1,096; lisp: 625; makefile: 148; python: 125; cpp: 48; javascript: 10
file content (31 lines) | stat: -rw-r--r-- 841 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
.. _dynamic_include:

dynamic_include
---------------

The ``dynamic_include`` stanza allows including the contents of another file in
the current dune file like the ``include`` stanza.  However, the
``dynamic_include`` stanza allows the included file to be the target of a rule
and disallows generating some stanzas.

For instance:

.. code:: dune

   (subdir b
    (dynamic_include ../a/foo.inc))
   (subdir a
    (rule
     (write-file
      foo.inc
      "(rule (write-file file bar))")))

In the example above, the dynamic rule loading and generation are split into
different directories to avoid rule loading cycles as rules are loaded per
directory.

The following stanzas cannot be dynamically generated:

* Libraries, coq theories, library redirects
* Public executables or install section with the ``bin`` section
* Plugin stanzas