2014-10-16 3 views
1

Я пытаюсь написать сценарий bash с помощью диалога, а часть, если она включает в себя клонирование нескольких репозиториев git.Получить git-клон прогресс для диалога --gauge

Я бы хотел использовать dialog --gauge, чтобы показать индикатор выполнения, а также показать --tailbox, чтобы показать, что такое git.

До сих пор мне не удавалось получить информацию о ходе работы от git в форме, которую будет понимать диалог.

Это то, что я получил до сих пор:

git clone [email protected]:really-bit-git-repo output-dir --progress 2>&1 | cat > /tmp/gitprocfile & 
cat /tmp/gitprocfile | grep "[0-9]\{1,2\}%" | awk '{print $7}' | dialog --gauge "Progress" 7 50 

Я в конечном итоге с файлом в/TMP/gitprocfile, который выглядит, как этот

Cloning into 'output-dir'... 
remote: Counting objects: 103668, done.[K 
remote: Compressing objects: 0% (1/23688) [K 
remote: Compressing objects: 1% (237/23688) [K 
remote: Compressing objects: 2% (474/23688) [K 
remote: Compressing objects: 3% (711/23688) [K 
remote: Compressing objects: 4% (948/23688) [K 
remote: Compressing objects: 5% (1185/23688) [K 
remote: Compressing objects: 6% (1422/23688) [K 
remote: Compressing objects: 7% (1659/23688) [K 
remote: Compressing objects: 8% (1896/23688) [K 
remote: Compressing objects: 9% (2132/23688) [K 
remote: Compressing objects: 10% (2369/23688) [K 
remote: Compressing objects: 11% (2606/23688) [K 
remote: Compressing objects: 12% (2843/23688) [K 
remote: Compressing objects: 13% (3080/23688) [K 
remote: Compressing objects: 14% (3317/23688) [K 
remote: Compressing objects: 15% (3554/23688) [K 
remote: Compressing objects: 16% (3791/23688) [K 
remote: Compressing objects: 17% (4027/23688) [K 
remote: Compressing objects: 18% (4264/23688) [K 
remote: Compressing objects: 19% (4501/23688) [K 
remote: Compressing objects: 20% (4738/23688) [K 
remote: Compressing objects: 21% (4975/23688) [K 
remote: Compressing objects: 22% (5212/23688) [K 
remote: Compressing objects: 23% (5449/23688) [K 
remote: Compressing objects: 24% (5686/23688) [K 
remote: Compressing objects: 25% (5922/23688) [K 
remote: Compressing objects: 26% (6159/23688) [K 
remote: Compressing objects: 27% (6396/23688) [K 
remote: Compressing objects: 28% (6633/23688) [K 
remote: Compressing objects: 29% (6870/23688) [K 
remote: Compressing objects: 30% (7107/23688) [K 
remote: Compressing objects: 31% (7344/23688) [K 
remote: Compressing objects: 32% (7581/23688) [K 
remote: Compressing objects: 33% (7818/23688) [K 
remote: Compressing objects: 34% (8054/23688) [K 
remote: Compressing objects: 35% (8291/23688) [K 
remote: Compressing objects: 36% (8528/23688) [K 
remote: Compressing objects: 37% (8765/23688) [K 
remote: Compressing objects: 38% (9002/23688) [K 
remote: Compressing objects: 39% (9239/23688) [K 
remote: Compressing objects: 40% (9476/23688) [K 
remote: Compressing objects: 41% (9713/23688) [K 
remote: Compressing objects: 42% (9949/23688) [K 
remote: Compressing objects: 43% (10186/23688) [K 
remote: Compressing objects: 44% (10423/23688) [K 
remote: Compressing objects: 45% (10660/23688) [K 
remote: Compressing objects: 46% (10897/23688) [K 
remote: Compressing objects: 47% (11134/23688) [K 
remote: Compressing objects: 48% (11371/23688) [K 
remote: Compressing objects: 49% (11608/23688) [K 
remote: Compressing objects: 50% (11844/23688) [K 
remote: Compressing objects: 51% (12081/23688) [K 
remote: Compressing objects: 52% (12318/23688) [K 
remote: Compressing objects: 53% (12555/23688) [K 
remote: Compressing objects: 54% (12792/23688) [K 
remote: Compressing objects: 55% (13029/23688) [K 
remote: Compressing objects: 56% (13266/23688) [K 
remote: Compressing objects: 57% (13503/23688) [K 
remote: Compressing objects: 58% (13740/23688) [K 
remote: Compressing objects: 59% (13976/23688) [K 
remote: Compressing objects: 60% (14213/23688) [K 
remote: Compressing objects: 61% (14450/23688) [K 
remote: Compressing objects: 62% (14687/23688) [K 
remote: Compressing objects: 63% (14924/23688) [K 
remote: Compressing objects: 64% (15161/23688) [K 
remote: Compressing objects: 65% (15398/23688) [K 
remote: Compressing objects: 66% (15635/23688) [K 
remote: Compressing objects: 67% (15871/23688) [K 
remote: Compressing objects: 68% (16108/23688) [K 
remote: Compressing objects: 69% (16345/23688) [K 
remote: Compressing objects: 70% (16582/23688) [K 
remote: Compressing objects: 71% (16819/23688) [K 
remote: Compressing objects: 72% (17056/23688) [K 
remote: Compressing objects: 73% (17293/23688) [K 

И прогресс бар, который находится на 0%.

Я пропустил что-то о том, как подключить/grep/awk данные из git в диалог, или этот подход просто не работает?

+0

Большая часть того, что у меня есть, я получил из [this] (http://stackoverflow.com/questions/4062862/git-stderr-output-cant-pipe) вопрос, просто пытающийся заменить zenity на диалог - калибровать. –

+0

диалоговое окно подсказки страниц для руководства предполагает, что вы получите только #s, вы можете попробовать подключиться к awk или что-то, чтобы получить только извлеченные проценты. –

+0

@AndrewC - вот что такое 'grep '[0-9] \ {1,2 \}% "| awk '{print $ 7}' 'бит, но он работает только один раз, вместо того, чтобы постоянно захватывать последнюю строку из файла. –

ответ

1

Как я думаю, что мой комментарий действительно слишком долго и непонятно, вот мой udnerstanding:

git clone [email protected]:really-bit-git-repo output-dir --progress 2>&1 | cat > /tmp/gitprocfile & 

Вызов мерзавца и писать вывод в файл, кот не нужен здесь.

cat /tmp/gitprocfile | grep "[0-9]\{1,2\}%" | awk '{print $7}' | dialog --gauge "Progress" 7 50 

Сразу после prvious команды, показать один файл с кошкой и усеивают Grep и т.д. Таким образом, вы получите содержимое файла только один раз ...

При желании текстовый вывод в конце I будет делать:

git clone [email protected]:really-bit-git-repo output-dir --progress 2>&1 | tee /tmp/gitprocfile | grep "[0-9]\{1,2\}%" | awk '{print $7}' | dialog --gauge "Progress" 7 50 

Если диалог находится в antoher срок, чем gitcommand:

в терминал 1:

echo '' > /tmp/gitprocfile; git clone [email protected]:really-bit-git-repo output-dir --progress 2>&1 >> /tmp/gitprocfile & 

В терминале 2:

tail -f /tmp/gitprocfile | grep "[0-9]\{1,2\}%" | awk '{print $7}' | dialog --gauge "Progress" 7 50 

Я не привык к диалогу, но, по крайней мере, я уверен, что ваша попытка не будет загрузить файл на изменения.

+0

Я не могу использовать 'tail -f', хотя это используется внутри скрипта. Я не хочу, чтобы хвост долго ждал новых строк, он должен выйти, когда клиент git закончит. –

+0

Так что используйте опцию one, tee для файла, чтобы получить полный и файл, или вообще избавиться от файла, если все добавлены в один и тот же термин ... – Tensibai