summaryrefslogtreecommitdiffstats
path: root/doc/scripts/man-cheatmake.1.docbook
blob: 4fdb94985438bdbe14a84bf4fba513dac23a99d1 (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
<?xml version="1.0" ?>
<!DOCTYPE refentry PUBLIC "-//KDE//DTD DocBook XML V4.2-Based Variant V1.1//EN" "dtd/kdex.dtd" [
<!ENTITY % English "INCLUDE">
]>

<refentry lang="&language;">
<refentryinfo>
<date>March 8, 2003</date>
</refentryinfo>

<refmeta>
<refentrytitle><command>cheatmake</command></refentrytitle>
<manvolnum>1</manvolnum>
</refmeta>

<refnamediv>
<refname><command>cheatmake</command></refname>
<refpurpose>fool <command>make</command> into not rebuilding certain files</refpurpose>
</refnamediv>

<refsynopsisdiv>
<cmdsynopsis>
<command>cheatmake</command>

<group><option>hidechange</option> <replaceable>file</replaceable></group>
<group><option>show</option></group>
<group><option>why</option> <replaceable>file</replaceable></group>
</cmdsynopsis>
</refsynopsisdiv>

<refsect1>
<title>Description</title>

<para><command>cheatmake</command> is used to save time when
recompiling. It can fool make into skipping files that haven't changed
in a meaningful way. This can be used for instance when you change a
comment in a file but none of the actual code.</para>

<para>This utility is part of the &kde; Software Development Kit. </para>

</refsect1>

<refsect1>
<title>Options</title>

<variablelist>
<varlistentry>
<term><option>hidechange</option> <replaceable>file</replaceable></term>
<listitem><para>Hides the fact that file was changed by setting the timestamp into the past.  Use with care!</para>
</listitem>
</varlistentry>
<varlistentry>
<term><option>show</option></term>
<listitem><para>Lists what files <command>make</command> currently needs to rebuild</para></listitem>
</varlistentry>
<varlistentry>
<term><option>why</option> <replaceable>file</replaceable></term>
<listitem><para>Explains why make must rebuild file</para></listitem>
</varlistentry>
</variablelist>
</refsect1>

<refsect1>
<title>Environment</title>

<para>One of the following variables (but not both) should be set if
the source directory is different from the build directory. If the
build directory is simply a subdirectory of the source directory, the
simpler variable <envar>OBJ_SUBDIR</envar> should be used. </para>

<variablelist>
<varlistentry>
<term><envar>OBJ_SUBJDIR</envar></term>
<listitem><para>Indicates that the build directory is in the given subdirectory of the source directory. For instance, if the source directory is <filename class="directory">kdesdk</filename> and the build directory is <filename class="directory">kdesdk/obj-i386-linux</filename>, then <envar>OBJ_SUBDIR</envar> should be set to <parameter>obj-i386-linux</parameter>.</para></listitem>
</varlistentry>
<varlistentry>
<term><envar>OBJ_REPLACEMENT</envar></term>
<listitem><para>A <command>sed</command> expression that is used to transform the source directory into the build directory.  For instance, if the source directory is <filename class="directory">kdesdk/obj-i386-linux</filename>, then <envar>OBJ_REPLACEMENT</envar> should be set to <parameter>s#kdesdk#kdesdk-obj#</parameter>.</para>
</listitem>
</varlistentry>
</variablelist>

</refsect1>

<refsect1>
<title>See Also</title>

<para>make(1)</para>

</refsect1>

<refsect1>
<title>Authors</title>

<para><command>cheatmake</command> was written by &David.Faure; &David.Faure.mail;.  This manual page was
prepared by <personname><firstname>Ben</firstname><surname>Burton</surname></personname>
<email>bab@debian.org</email> for the Debian
<acronym>GNU</acronym>/&Linux; system (but may be used by
others).</para>

</refsect1>

</refentry>