MAKE(1) Ordenes de usuario MAKE(1) NOMBRE make - GNU Make utility to maintain groups of programs SINOPSIS make [OPTION]... [TARGET]... DESCRIPCION El proposito de la utilidad make es determinar automaticamente que partes de un programa grande necesitan ser recompiladas, y ejecutar las ordenes pertinentes para recompilarlas. Este manual describe la implementacion de make del proyecto GNU, que ha sido escrita por Richard Stallman y Roland McGrath. Nuestros ejemplos muestran programas en C, que es lo mas comun, pero se puede emplear make con cualquier lenguaje de programacion cuyo compilador pueda ejecutarse con una orden del shell. De hecho, make no esta limitado a compilar programas. Se puede usar para describir cualquier tarea donde algunos ficheros deban ser actualizados automaticamente a partir de otros en cualquier momento en que estos cambien. Para prepararnos a utilizar make, debemos escribir antes un fichero llamado el makefile que describe las relaciones entre los ficheros de nuestro programa, y las ordenes necesarias para actualizar cada fichero. En un programa, normalmente el fichero ejecutable se actualiza a partir de los ficheros o modulos objeto, los cuales a su vez se construyen mediante la compilacion de los ficheros con el codigo fuente. Una vez que exista un makefile apropiado, cada vez que cambiemos algun fichero fuente, esta simple orden: make es suficiente para que se realicen todas las recompilaciones necesarias. El programa make emplea los datos del makefile (y otros internos) y los tiempos de ultima modificacion de los ficheros para decidir cuales de ellos necesitan ser actualizados. Para cada uno de esos ficheros, ejecuta las ordenes indicadas en el makefile. make executes commands in the makefile to update one or more targets, where target is typically a program. If no -f option is present, make will look for the makefiles GNUmakefile, makefile, and Makefile, in that order. Normally you should call your makefile either makefile or Makefile. (We recommend Makefile because it appears prominently near the beginning of a directory listing, right near other important files such as README.) The first name checked, GNUmakefile, is not recommended for most makefiles. You should use this name if you have a makefile that is specific to GNU Make, and will not be understood by other versions of make. If makefile is '-', the standard input is read. make actualiza un objetivo si este depende de ficheros de prerrequisito (o dependencias) que hayan sido modificados desde la ultima modificacion del objetivo, o si este no existe. OPCIONES -b, -m Estas opciones no hacen nada, y solo se reconocen por compatibilidad con otras versiones de make. -B, --always-make Ejecuta incondicionalmente todos los objetivos. -C dir, --directory=dir Cambia el directorio de trabajo a dir antes de leer los makefiles o hacer otra cosa. Si se especifican varias opciones -C, cada una se interpreta en relacion a la anterior: -C / -C etc es equivalente a -C /etc. Esto se usa tipicamente en llamadas recursivas a make. -d Muestra informacion de depuracion ademas del procesamiento normal. Esta informacion dice que ficheros estan siendo considerados para ser rehechos, que tiempos de ficheros estan siendo comparados y con que resultados, que ficheros necesitan realmente ser rehechos, que reglas implicitas estan siendo tenidas en cuenta y cuales se estan aplicando: o sea, todo lo interesante sobre como make decide las cosas que tiene que hacer. --debug[=FLAGS] Print debugging information in addition to normal processing. If the FLAGS are omitted, then the behavior is the same as if -d was specified. FLAGS may be any or all of the following names, comma- or space-separated. Only the first character is significant: the rest may be omitted: all for all debugging output (same as using -d), basic for basic debugging, verbose for more verbose basic debugging, implicit for showing implicit rule search operations, jobs for details on invocation of commands, makefile for debugging while remaking makefiles, print shows all recipes that are run even if they are silent, and why shows the reason make decided to rebuild each target. Use none to disable all previous debugging flags. -e, --environment-overrides Da a las variables que vienen del entorno precedencia a las que vienen de los makefiles. -E cadena, --eval cadena Interpret string using the eval function, before parsing any makefiles. -f fichero, --file=fichero, --makefile=FICHERO Emplea fichero como un makefile. -i, --ignore-errors No tiene en cuenta ningun error en las ordenes ejecutadas para reconstruir ficheros. -I dir, --include-dir=dir Especifica un directorio dir en donde buscar makefiles incluidos. Si se usan varias opciones -I para especificar varios directorios, estos se buscan en el orden dado. De forma distinta a como se deben dar los argumentos de otras opciones de make, los directorios dados en las opciones -I pueden ir inmediatamente tras la I: o sea, se permite tanto -Idir como -I dir. Esta sintaxis se permite por compatibilidad con la misma opcion -I del preprocesador de C. -j [trabajos], --jobs[=trabajos] Especifica el numero de trabajos (ordenes) que se deban ejecutar simultaneamente. Si hay mas de una opcion -j, solo la ultima vale. Si se da la opcion -j sin ningun argumento, make no pondra limites al numero de trabajos que puedan ejecutarse simultaneamente. --jobserver-style=estilo] The style of jobserver to use. The style may be one of fifo, pipe, or sem (Windows only). -k, --keep-going Continua tanto como sea posible tras un error. Mientras que el objetivo que ha fallado, y los que dependen de el, no pueden ser reconstruidos, las otras dependencias de estos objetivos si que pueden procesarse, asi que con esta opcion se procesan. -l [carga], --load-average[=carga] Dice que no debera empezarse ningun nuevo trabajo (mandato) si hay otros trabajos en ejecucion y la carga media es como poco carga (un numero real, en coma flotante). Sin el argumento, anula un limite anterior de carga, si lo hubiera. -L, --check-symlink-times Emplea el tiempo de la ultima modificacion entre los enlaces simbolicos y el objetivo. -n, --just-print, --dry-run, --recon Muestra las ordenes que se ejecutarian, pero no se ejecutan salvo en alguna circunstancia concreta. -o fichero, --old-file=fichero, --assume-old=fichero No reconstruye el fichero especificado, incluso siendo mas antiguo que sus dependencias, y tampoco reconstruye nada que dependa de cambios en fichero. Esencialmente el fichero se trata como muy viejo, y sus reglas no son tenidas en cuenta. -O[tipo], --output-sync[=tipo] When running multiple jobs in parallel with -j, ensure the output of each job is collected together rather than interspersed with output from other jobs. If type is not specified or is target the output from the entire recipe for each target is grouped together. If type is line the output from each command line within a recipe is grouped together. If type is recurse output from an entire recursive make is grouped together. If type is none output synchronization is disabled. -p, --print-data-base Muestra la base de datos (reglas y valores de variables) que resultan de leer los makefiles; luego todo se procesa de la forma usual o de la que se haya especificado. Tambien se muestra la informacion de version dada por la opcion -v (vea mas abajo). Para ver la base de datos sin hacer ninguna otra cosa, de la orden make -p -f/dev/null. -q, --question "Modo de interrogacion (Query)". No ejecuta ninguna orden ni muestra nada; solo devuelve un status de salida cero si los objetivos especificados ya estan actualizados, o no cero si no lo estan. -r, --no-builtin-rules Elimina el empleo de las reglas implicitas incorporadas. Tambien borra la lista predeterminada de sufijos para las reglas de sufijo. -R, --no-builtin-variables No define ninguna variable interna. -s, --silent, --quiet Modo de operacion silencioso; no muestra las ordenes que se estan ejecutando. --no-silent Cancela el efectvo de la opcion -s. -S, --no-keep-going, --stop Cancela el efecto de la opcion -k. -t, --touch Toca los ficheros (los marca como actualizados sin cambiarlos realmente) en vez de ejecutar las ordenes pertientes. Esto se emplea para pretender que las ordenes han sido ejecutadas, con el fin de enganar a futuras ejecuciones de make. --trace Information about the disposition of each target is printed (why the target is being rebuilt and what commands are run to rebuild it). -v, --version Print the version of the make program plus a copyright, a list of authors and a notice that there is no warranty. -w, --print-directory Muestra un mensaje conteniendo el directorio de trabajo antes y despues de otro procesamiento. Esto puede ser util para seguir la pista a errores que vienen de anidamientos complicados de ordenes make recursivas. --no-print-directory Desactiva -w aunque haya sido indicada expresamente. --shuffle[=MODO] Enable shuffling of goal and prerequisite ordering. MODE is one of none to disable shuffle mode, random to shuffle prerequisites in random order, reverse to consider prerequisites in reverse order, or an integer which enables random mode with a specific seed value. If MODE is omitted the default is random. -W fichero, --what-if=fichero, --new-file=fichero, --assume-new=fichero Pretende que el objetivo fichero acaba de ser modificado. Cuando se emplea con la opcion -n, esto nos ensena lo que pasaria si fueramos a modificar ese fichero. Sin -n, es casi lo mismo que ejecutar la orden touch en el fichero dado antes de dar la orden make, salvo en que el tiempo de modificacion se cambia solamente en la imaginacion de make. --warn-undefined-variables Avisa en caso de referenciar alguna variable sin definir. ESTADO DE SALIDA GNU Make exits with a status of zero if all makefiles were successfully parsed and no targets that were built failed. A status of one will be returned if the -q flag was used and make determines that a target needs to be rebuilt. A status of two will be returned if any errors were encountered. VEASE TAMBIEN La documentacion completa de make se mantiene como manual Texinfo. Si los programas info y make estan adecuadamente instalados en su sistema, la orden info make deberia acceder al manual completo. ERRORES Consulte el capitulo "Problems and Bugs" en The GNU Make Manual. AUTOR Dennis Morse, de la Stanford University, escribio originalmente esta pagina del Manual. Mike Frysinger y Roland McGrath trabajaron posteriormente en ella.Actualmente la mantiene Paul Smith. COPYRIGHT Copyright (C) 1992-1993, 1996-2023 Free Software Foundation, Inc. This file is part of GNU Make. GNU Make is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see https://www.gnu.org/licenses/. TRADUCCION La traduccion al espanol de esta pagina del manual fue creada por Gerardo Aburruzaga Garcia y Marcos Fouces Esta traduccion es documentacion libre; lea la GNU General Public License Version 3 o posterior con respecto a las condiciones de copyright. No existe NINGUNA RESPONSABILIDAD. Si encuentra algun error en la traduccion de esta pagina del manual, envie un correo electronico a . GNU 26 May 2023 MAKE(1)