summaryrefslogtreecommitdiff
path: root/devdocs/gnu_make/empty-recipes.html
blob: 8e6d21e1a068e9ec6ea649dd48767a38692b8459 (plain)
1
2
3
4
5
6
7
8
  <h1 class="section">Using Empty Recipes</h1>   <p>It is sometimes useful to define recipes which do nothing. This is done simply by giving a recipe that consists of nothing but whitespace. For example: </p> <div class="example"> <pre class="example">target: ;
</pre>
</div> <p>defines an empty recipe for <samp>target</samp>. You could also use a line beginning with a recipe prefix character to define an empty recipe, but this would be confusing because such a line looks empty. </p>  <p>You may be wondering why you would want to define a recipe that does nothing. One reason this is useful is to prevent a target from getting implicit recipes (from implicit rules or the <code>.DEFAULT</code> special target; see <a href="implicit-rules">Implicit Rules</a> and see <a href="last-resort">Defining Last-Resort Default Rules</a>). </p> <p>Empty recipes can also be used to avoid errors for targets that will be created as a side-effect of another recipe: if the target does not exist the empty recipe ensures that <code>make</code> won’t complain that it doesn’t know how to build the target, and <code>make</code> will assume the target is out of date. </p> <p>You may be inclined to define empty recipes for targets that are not actual files, but only exist so that their prerequisites can be remade. However, this is not the best way to do that, because the prerequisites may not be remade properly if the target file actually does exist. See <a href="phony-targets">Phony Targets</a>, for a better way to do this. </p><div class="_attribution">
  <p class="_attribution-p">
    Copyright © 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015, 2016, 2017, 2018, 2019, 2020, 2021, 2022 Free Software Foundation, Inc. <br>Licensed under the GNU Free Documentation License.<br>
    <a href="https://www.gnu.org/software/make/manual/html_node/Empty-Recipes.html" class="_attribution-link">https://www.gnu.org/software/make/manual/html_node/Empty-Recipes.html</a>
  </p>
</div>