aboutsummaryrefslogtreecommitdiff
path: root/src/libexpr/print.hh
blob: f9cfc3964b47c4a2814c7656fd2da4094a706d46 (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
#pragma once
/**
 * @file
 * @brief Common printing functions for the Nix language
 *
 * While most types come with their own methods for printing, they share some
 * functions that are placed here.
 */

#include <iostream>

namespace nix {
    /**
     * Print a string as a Nix string literal.
     *
     * Quotes and fairly minimal escaping are added.
     *
     * @param s The logical string
     */
    std::ostream & printLiteralString(std::ostream & o, std::string_view s);
    inline std::ostream & printLiteralString(std::ostream & o, const char * s) {
        return printLiteralString(o, std::string_view(s));
    }
    inline std::ostream & printLiteralString(std::ostream & o, const std::string & s) {
        return printLiteralString(o, std::string_view(s));
    }

    /** Print `true` or `false`. */
    std::ostream & printLiteralBool(std::ostream & o, bool b);

    /**
     * Print a string as an attribute name in the Nix expression language syntax.
     *
     * Prints a quoted string if necessary.
     */
    std::ostream & printAttributeName(std::ostream & o, std::string_view s);

    /**
     * Print a string as an identifier in the Nix expression language syntax.
     *
     * FIXME: "identifier" is ambiguous. Identifiers do not have a single
     *        textual representation. They can be used in variable references,
     *        let bindings, left-hand sides or attribute names in a select
     *        expression, or something else entirely, like JSON. Use one of the
     *        `print*` functions instead.
     */
    std::ostream & printIdentifier(std::ostream & o, std::string_view s);
}