Pruebe algo como esto en su Makefile:
.PHONY: local.dat
local.dat:
    [ -e example.gz ] || touch -d '00:00' example.gz
    curl -z example.gz -s http://example.org/example.gz -o example.gz
    [ -e $@ ] || touch -d 'yesterday 00:00' $@
    if [     "$(shell stat --printf '%Y' example.gz)" \
         -gt "$(shell stat --printf '%Y' $@)"         ] ; then \
      zcat example.gz | transmogrify >$@ ; \
    fi
    truncate -s 0 example.gz
    touch -r $@ example.gz
(nota: este es un Makefile, por lo que las sangrías son pestañas, no espacios. Por supuesto. También es importante que no haya espacios después \de las líneas de continuación; alternativamente, elimine los escapes de barra invertida y hágalo uno largo, línea casi ilegible)
Esta makereceta de GNU primero verifica que example.gzexista un archivo llamado (porque lo vamos a usar con -zin curl), y lo crea con touchsi no es así. El toque lo crea con una marca de tiempo de 00:00 (12am del día actual).
Luego usa curlla opción 's -z( --time-cond) para descargar solo example.gzsi se ha modificado desde la última vez que se descargó.  -zse le puede dar una expresión de fecha real o un nombre de archivo. Si se le da un nombre de archivo, utilizará la hora de modificación del archivo como condición de tiempo.  
Después de eso, si local.datno existe, lo crea con touchuna marca de tiempo que es más antigua que la de example.gz. Esto es necesario porque local.dattiene que existir para que el siguiente comando lo use statpara obtener su marca de tiempo mtime.
Entonces, si example.gztiene una marca de tiempo más reciente que local.dat, tuberías de TI example.gzen transmogrifyy redirige la salida a local.dat.
Finalmente, hace las tareas de contabilidad y limpieza:
- se trunca 
example.gz(porque solo necesita mantener una marca de tiempo, y no todo el archivo) 
touches example.gzpara que tenga la misma marca de tiempo quelocal.dat 
El objetivo .PHONY asegura que el local.datobjetivo siempre se ejecute, incluso si el archivo con ese nombre ya existe.
Gracias a @Toby Speight por señalar en los comentarios que mi versión original no funcionaría y por qué.
Alternativamente, si desea canalizar el archivo directamente transmogrifysin descargarlo primero en el sistema de archivos:
.PHONY: local.dat
local.dat:
    [ -e example.gz ] || touch -d '00:00' example.gz
    [ -e $@ ] || touch -d 'yesterday 00:00' $@
    if [     "$(shell stat --printf '%Y' example.gz)" \
         -gt "$(shell stat --printf '%Y' $@)"         ] ; then \
      curl -z example.gz -s http://example.org/example.gz | transmogrify >$@ ; \
    fi
    touch -r $@ example.gz
NOTA: esto no se ha probado en su mayoría, por lo que puede requerir algunos cambios menores para obtener la sintaxis correcta Lo importante aquí es el método, no una solución de culto de carga de copiar y pegar.
He estado usando variaciones de este método (es decir, touchmarcando un archivo de marca de tiempo) makedurante décadas. Funciona, y generalmente me permite evitar tener que escribir mi propio código de resolución de dependencia en sh (aunque he tenido que hacer algo similar stat --printf %Yaquí).
Todo el mundo sabe que makees una gran herramienta para compilar software ... En mi opinión, también es una herramienta muy subestimada para las tareas de administración de scripts y administración del sistema.
                 
                
-zbandera, por supuesto, supone que el servidor remoto usaIf-Modified-Sinceencabezados. Esto podría no ser necesariamente el caso. Dependiendo de la configuración del servidor, es posible que deba hacer algo conETag, o al verificar losCache-Controlencabezados, o al verificar un archivo de suma de verificación por separado (por ejemplo, si el servidor proporciona unsha1sum).make, usarcmpo algo para comparar archivos viejos y nuevos, ymv newfile oldfilesi son diferentes) . Por cierto, los encabezados de control de caché no le dicen si el archivo es más nuevo que un momento dado. te dicen por cuánto tiempo los administradores del servidor quieren que guardes en caché un archivo determinado, y los droides de marketing a menudo los usan como una práctica para eliminar caché para "mejorar" sus estadísticas web.ETages otra forma de hacerlo, ya que es un archivo de suma de verificación separado. Todo depende de cómo esté configurado el servidor. Por ejemplo, uno podría obtener cdimage.debian.org/debian-cd/current/amd64/iso-cd/SHA1SUMS y verificar si ha cambiado antes de decidir obtener el ISO completo. ETag hace lo mismo, usando un encabezado en lugar de un archivo separado (y, comoIf-Modified-Since, depende del servidor HTTP que lo implementa).Cache-Controlsería una opción de último recurso antes de descargar el archivo si no se admiten otros métodos; ciertamente es el menos preciso ya que trata de predecir el futuro.ETag/If-None-Matchy otras sumas de verificación son más confiables queIf-Modified-Sincetambién. En cualquier caso, estos comentarios solo intentan exponer los supuestos de la respuesta (es decir, que-zasume el soporte del servidor): el método básico debería ser bastante fácil de adaptar a otros algoritmos de verificación de cambios.Otra alternativa es usar un sistema de compilación que use sumas de verificación de dependencia para determinar si se activarán las reconstrucciones. He usado el truco "táctil" con Gnu Make mucho, pero es mucho más simple cuando puedes especificar dependencias dinámicas y cuando los archivos que no cambian no desencadenan reconstrucciones. Aquí hay un ejemplo usando GoodMake :
fuente
-X HEAD, la página de manual de curl recomienda usar-I: "(-X) solo cambia la palabra real utilizada en la solicitud HTTP, no altera el comportamiento de curl. Entonces, por ejemplo, si desea hacer una solicitud HEAD adecuada, use -X HEAD no será suficiente. Necesitas usar la opción -I, - head ".