Я сейчас на Fedora, но я предлагаю вам внимательно прочитать вики Archlinux , все это: Home и End ключи не рабочий .
Что я сделал, чтобы это исправить:
Нажмите Ctrl-V Home, будет напечатана экранированная последовательность для клавиши Home. Это не \ e [4 ~
и \ e [1 ~
], как я ожидал, глядя на / etc / inputrc
. Это были [H
и [F
Извлечь информацию о терминале infocmp $ TERM> terminfo.src
Откройте этот файл для редактирования, например vim terminfo.src
, найдите khome
и kend
, он назначен чему-то, скажем khome = \ E [1 ~
и kend = \ E [4 ~
, который в этом случае не работает. удалите его и замените последовательностью, которую вы нашли на шаге № 1, поэтому для меня после редактирования это было: khome = \ E [H
и kend = \ E [F
].
Если вы хотите перестраховаться, убедитесь, что [F
и [H
(или любая другая последовательность, которую вы только что использовали) не назначены на что-то еще, иначе все будет испорчено!
запустить tic terminfo.src
, который создает каталог ~ / .terminfo
.
Вверху .zshrc
перед любыми другими командами поместите: export TERMINFO = ~ / .terminfo
Откройте новое окно терминала, и все будет в порядке, домой и в конец должен работать сейчас.
P.S: Теоретически метод bindkey должен работать и проще, но для меня это не так.
Prueba algo como esto en tu 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 tabulaciones, no espacios. por supuesto. También es importante que no haya espacios después de \
en las líneas de continuación -alternativamente, elimine la barra invertida -y conviértala en una línea larga, casi -ilegible)
Esta receta de GNU make
primero verifica que exista un archivo llamado example.gz
(porque lo usaremos con -z
en curl
), y lo crea con touch
si no 't. El toque lo crea con una marca de tiempo de 00 :00 (12 am del día actual ).
Luego usa la opción-z
(--time-cond
)de curl
para descargar solo example.gz
si se ha modificado desde la última vez que se descargó.-z
puede recibir 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.dat
no existe, lo crea con touch
, utilizando una marca de tiempo que garantiza que es más antigua que la de example.gz
. Esto es necesario porque local.dat
tiene que existir para que el siguiente comando use stat
para obtener su marca de tiempo mtime.
Luego, si example.gz
tiene una marca de tiempo más reciente que local.dat
, canaliza example.gz
a transmogrify
y redirige la salida a local.dat
.
Finalmente, se encarga de la contabilidad y la limpieza:
example.gz
(porque solo necesita mantener una marca de tiempo, y no todo el archivo)touch
es example.gz
para que tenga la misma marca de tiempo quelocal.dat
El objetivo.PHONY garantiza que el objetivo local.dat
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 a transmogrify
sin descargarlo primero al 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 exactamente correcta. Lo importante aquí es el método, no una solución de culto de copiar -pegar carga -.
He estado usando variaciones de este método (, es decir,touch
-enviar un archivo de marca de tiempo )con make
durante décadas. Funciona y, por lo general, me permite evitar tener que escribir mi propio código de resolución de dependencia en sh (, aunque tuve que hacer algo similar con stat --printf %Y
aquí ).
Todo el mundo sabe que make
es una gran herramienta para compilar software... En mi opinión, también es una herramienta muy por debajo de -para la administración del sistema y las tareas de secuencias de comandos.
Другой альтернативой является использование системы сборки, которая использует контрольные суммы зависимостей, чтобы определить, следует ли запускать перестроения. Я много раз использовал трюк «касания» с Gnu Make, но это намного проще, когда вы можете указать динамические зависимости и когда файлы, которые не изменяются, не вызывают перестроения. Вот пример использования GoodMake:
#! /usr/local/goodmake.py /bin/sh -se
#! *.date
# Get the last-modified date
curl -s -v -X HEAD http://${1%.date} 2>&1 | grep -i '^< Last-Modified:' >$1
#? local.dat
site=http://example.org/example.gz
$0 $site.date
curl -s $site | gzip -d | transmogrify >$1