Estou executando o Ubuntu 16.04 com um adaptador USB conectado ao controle da minha TV. Estou usando uma versão modificada de este script para iniciar um cec-server
que aceita e envia comandos.
Então, o script funciona; sempre que eu corro manualmente após a inicialização. Quando eu emito o pidof cec-client
, ele me dá um ID e eu posso enviar comandos para o cec-server
que funciona imediatamente. Tudo é ótimo assim.
No entanto, parece que não consigo fazê-lo funcionar através do crontab ou através dos aplicativos de inicialização. pidof cec-client
não retornará um ID e não posso enviar comandos.
TL; DR: O script funciona quando eu o executo manualmente. Não funciona via crontab. Deseja executá-lo automaticamente após a reinicialização.
EDITAR:
O crontabline que eu uso é @reboot /home/server/Documents/cecserver.sh
O script em si:
#!/bin/bash
#
# Set up a fifo and connect cec-client to it
#
# Original By Will Cooke. http://www.whizzy.org
CECLOG="/home/server/Documents/logs/cec.log"
CECDEV="/dev/ttyACM0"
CECFIFO="/home/server/Documents/logs/cec.fifo"
CECCLIENT="/usr/bin/cec-client -d 1 -p 1 -o Codex"
timestamp(){
date +"%Y-%m-%d %T"
}
log(){
echo "SERVER $(timestamp): $1" >> $CECLOG
}
echo "SERVER $(timestamp): File loaded ($1)" >> $CECLOG
log "Starting server. Since only one server can run at a time, stopping first."
log "Begin shutting down..."
declare -a TAILPIDS=('ps aux | grep 'tail -f /dev/null' | egrep -v grep | awk '{print $2}'')
declare -a CATPIDS=('ps aux | grep 'cat $CECFIFO' | egrep -v grep | awk '{print $2}'')
if [ ${#TAILPIDS[@]} -gt 0 ]
then
log "Found some tail processes..."
for i in "${TAILPIDS[@]}"
do
log "Killing $i"
kill $i
done
fi
if [ ${#CATPIDS[@]} -gt 0 ]
then
log "Found some cat processes..."
for i in "${CATPIDS[@]}"
do
log "Killing $i"
kill $i
done
fi
log "Asking cec-client to stop if it's running..."
killall -s 2 cec-client >> $CECLOG
log "Trying to remove FIFO..."
rm $CECFIFO >> $CECLOG
log "Done shutting down."
log "Done stopping, now starting..."
log "Setting up FIFOs..."
mkfifo $CECFIFO
log "Open pipe for writing..."
tail -f /dev/null > $CECFIFO &
log "Opening pipe for reading and start cec-client..."
(cat $CECFIFO | $CECCLIENT &) > /dev/null
log "Start up complete."
exit 0