Portál AbcLinuxu, 10. května 2025 09:58

Dotaz: Bash - přesměrování stdout funkce do proměnné bez subshellu

4.8.2010 09:07 dustin | skóre: 63 | blog: dustin
Bash - přesměrování stdout funkce do proměnné bez subshellu
Přečteno: 1286×
Odpovědět | Admin
Zdravím,

mám funkci, která nastavuje "globální" proměnné. Tedy ji nemohu spouštět v subshellu. Jenže současně bych potřeboval stdout všech jejích příkazů uložit do nějaké proměnné, kterou bych vypsal až později, pokud bude něco splněné (voláno z cronu, chci mít prázdný výstup if globální proměnná nastavená ve funkci je OK, aby zbytečně nechodily maily).

Tedy nemohu použít jednoduché volání

VYSTUP=$( funkce )

Přesměrovat lze i voláním exec, ale zase nevím, jak takovým způsobem přesměrovat do proměnné. Samozřejmě mohu použít pomocné soubory, ale to bych viděl až jako krajní ošklivou možnost.

Předem díky moc za rady.
Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

4.8.2010 09:40 NN
Rozbalit Rozbalit vše Re: Bash - přesměrování stdout funkce do proměnné bez subshellu
Odpovědět | | Sbalit | Link | Blokovat | Admin
Nechapu, nemuzes si ten stdout nastavit do promene uz v te funkci a pak ji zavolat normalne ?

NN
4.8.2010 09:53 dustin | skóre: 63 | blog: dustin
Rozbalit Rozbalit vše Re: Bash - přesměrování stdout funkce do proměnné bez subshellu
Je tam spoustu příkazů, nechci všechny obalovat, navíc s jejich result cody se pracuje v podmínkách (if nebo &&/||), nastavují se tam pak ty globální proměnné atd. Chci přesměrovat celý výstup funkce.
4.8.2010 09:46 Adnusem | skóre: 14 | blog: Hmmmm | Praha
Rozbalit Rozbalit vše Re: Bash - přesměrování stdout funkce do proměnné bez subshellu
Odpovědět | | Sbalit | Link | Blokovat | Admin
Osobně nevidím žádnou "ošklivost" v pomocných souborech ... Bash není zrovna jazyk ve kterém by šlo psát hezky, sám "pomocné" soubory využívám stále - ničemu to nevadí a předpokládám že ten skript do soutěže o nejhezčí a nejpropracovanější kód dávat nebudeš :)
tmp=`tempfile`
funkce &> $tmp
... $tmp ...
rm $tmp
4.8.2010 09:55 dustin | skóre: 63 | blog: dustin
Rozbalit Rozbalit vše Re: Bash - přesměrování stdout funkce do proměnné bez subshellu
Jako krajní možnost to samozřejmě zůstává, raději bych bez nich, nemám je moc rád. Při násilném přerušení skriptu zůstávají, zas.rají temp, je to ošklivý hack.
4.8.2010 10:08 chrono
Rozbalit Rozbalit vše Re: Bash - přesměrování stdout funkce do proměnné bez subshellu
Keď dáš do skriptu aj obsluhu správnych signálov, tak nie je problém vymazať pomocné súbory aj pri násilnom ukončení.
4.8.2010 10:12 dustin | skóre: 63 | blog: dustin
Rozbalit Rozbalit vše Re: Bash - přesměrování stdout funkce do proměnné bez subshellu
Jasně, ale to je zase další komplikace, testování, příležitost k chybám.
David Watzke avatar 4.8.2010 10:21 David Watzke | skóre: 74 | blog: Blog... | Praha
Rozbalit Rozbalit vše Re: Bash - přesměrování stdout funkce do proměnné bez subshellu
Odpovědět | | Sbalit | Link | Blokovat | Admin
Co takhle použít tee?
funkce | tee soubor.txt
či
funkce 2>&1 | tee soubor.txt
“Being honest may not get you a lot of friends but it’ll always get you the right ones” ―John Lennon
David Watzke avatar 4.8.2010 10:24 David Watzke | skóre: 74 | blog: Blog... | Praha
Rozbalit Rozbalit vše Re: Bash - přesměrování stdout funkce do proměnné bez subshellu
Jo aha, ty nechceš soubory, nějak mi nedošlo, že ani s tee si nepomůžeš. No tak nevím, mám takovej pocit, že tvůj problém nemá řešení, pokud to nebudeš ukládat přímo v tý funkci.
“Being honest may not get you a lot of friends but it’ll always get you the right ones” ―John Lennon
David Watzke avatar 4.8.2010 10:30 David Watzke | skóre: 74 | blog: Blog... | Praha
Rozbalit Rozbalit vše Re: Bash - přesměrování stdout funkce do proměnné bez subshellu
Odpovědět | | Sbalit | Link | Blokovat | Admin
Tohle vypadá docela slibně.
“Being honest may not get you a lot of friends but it’ll always get you the right ones” ―John Lennon
frEon avatar 4.8.2010 11:52 frEon | skóre: 40 | Praha
Rozbalit Rozbalit vše Re: Bash - přesměrování stdout funkce do proměnné bez subshellu
Odpovědět | | Sbalit | Link | Blokovat | Admin
man exec
Talking about music is like dancing to architecture.
4.8.2010 11:56 dustin | skóre: 63 | blog: dustin
Rozbalit Rozbalit vše Re: Bash - přesměrování stdout funkce do proměnné bez subshellu
Ale jak ten text dočasně uložit a vypsat až na požádání, bez využití dočasných souborů, tedy předpokládám s využitím proměnné bashe? Pouhé přesměrování do souboru nebo pipy pomocí execu není problém, ale aby se to rovnou načetlo do proměnné, to neumím.
frEon avatar 4.8.2010 20:29 frEon | skóre: 40 | Praha
Rozbalit Rozbalit vše Re: Bash - přesměrování stdout funkce do proměnné bez subshellu
ja mel na mysli presmerovat stdout do stdin, vypsat co potrebujes a pak pomoci read nacist do promenne. ale vyzkousene, ze to funguje nemam
Talking about music is like dancing to architecture.
4.8.2010 12:41 NN
Rozbalit Rozbalit vše Re: Bash - přesměrování stdout funkce do proměnné bez subshellu
Odpovědět | | Sbalit | Link | Blokovat | Admin
Shell functions may be exported to children via the environment using export -f
NN
4.8.2010 13:01 dustin | skóre: 63 | blog: dustin
Rozbalit Rozbalit vše Re: Bash - přesměrování stdout funkce do proměnné bez subshellu
Díky, ale jde mi o opačnou cestu - když v potomkovi (funkce volaná přes command substitution) nastavím "globální proměnnou", tak se hodnota nedostane do volajícího předka, kde se s ní dále pracuje.
4.8.2010 21:39 pht | skóre: 48 | blog: pht
Rozbalit Rozbalit vše Re: Bash - přesměrování stdout funkce do proměnné bez subshellu
Odpovědět | | Sbalit | Link | Blokovat | Admin
Ten požadavek je dobytčina. Funkce by měla mít jeden vstup a jeden výstup. Tj. buď všechno do proměnných a nebo všechno do stdout.
In Ada the typical infinite loop would normally be terminated by detonation.
4.8.2010 22:33 dustin | skóre: 63 | blog: dustin
Rozbalit Rozbalit vše Re: Bash - přesměrování stdout funkce do proměnné bez subshellu
Jde o kus konfiguračního kódu, který je potřeba vykonat ve více různých skriptech. Vůbec by to nemuselo být jako funkce, stačil by include přes source (stejně je ta fce v samostatném souboru), v podstatě nic by se na zadání neměnilo. Ten kód zjišťuje a nastavuje řadu proměnných a přitom hláškami komentuje, co dělá. A já se ptám, zda lze ty hlášky posílané na stdout přesměrovat zvenku toho kódu do proměnné, abych je mohl vypsat, až když je po provedení toho konfiguračního kódu splněná nějaká podmínka. Je to celkem běžná situace.

Odpovědí samozřejmě může být "bez pomocných souborů nelze", jako ostatně v bashi bohužel často.

Zřejmě máš nějaké pěkné řešení, když očividně víš, jak se mají věci dělat správně. Zatím ses s ním ale nepochlubil.
4.8.2010 22:44 Ash | skóre: 53
Rozbalit Rozbalit vše Re: Bash - přesměrování stdout funkce do proměnné bez subshellu
O nějaké try... catch... :D bych se v Bashi nesnažil, když se něco vypisuje tak by v té chvíli mělo být známo, jestli to vypsat, nebo ne.

Chtělo by to udělat obráceně -- upravit ty funkce, aby si výpisy dělaly třeba do proměnné, a na konci pokud bude potřeba je vypsaly na stdout.
4.8.2010 22:57 dustin | skóre: 63 | blog: dustin
Rozbalit Rozbalit vše Re: Bash - přesměrování stdout funkce do proměnné bez subshellu
Díky za tip. Jasně, že přepsáním toho kódu to lze vyřešit. Mě prostě zajímalo, zda lze přesměrovat stdout kusu kódu do proměnné, bez pomocných souborů (ošklivé) a subshellu (nelze předávat hodnoty proměnných zpátky nahoru). Zřejmě ne, minimálně zatím nikdo nevěděl, jak by to šlo, na googlu jsem o tom taky nic nenašel.

OK, funkci přepíšu, nemá cenu se s tím dále zabývat. A pro další složitější skripty zkusím python, protože produktivita složitějšího skriptování v bashi je tristní. Nakonec taky dobrý závěr :)
default avatar 5.8.2010 10:45 default | skóre: 22 | Madrid
Rozbalit Rozbalit vše Re: Bash - přesměrování stdout funkce do proměnné bez subshellu
No, ono to vypadá, že subshell si vytváří svojí vlastní kopii prostředí, která je odizolovaná od nadřazeného shellu. Takže nějaký export do nadřazenýho shellu fungovat nebude.

Aspoň takhle jsem to pochopil z dokumentace…
5.8.2010 11:33 dustin | skóre: 63 | blog: dustin
Rozbalit Rozbalit vše Re: Bash - přesměrování stdout funkce do proměnné bez subshellu
To určitě nefunguje, mnohokrát bolestivě znovupřipomenuté např. v řetězci rour (ten taky běží v subshellu). Přesně proto jsem se ptal, jak stdout přesměrovat do proměnné, bez použití pomocných souborů a bez volání daného kusu kódu (fce) v command substitution (tedy subshellu) :)
5.8.2010 14:13 l4m4
Rozbalit Rozbalit vše Re: Bash - přesměrování stdout funkce do proměnné bez subshellu
Většinou, když potřebuji dostat ven proměnné z podřízeného shellu, tak prostě vypíšu
declare -p seznam jmen proměnných
kamkoli, kde to caller může zachytit (filedeskriptor, dočasný soubor, ...), a ten to následně provede, takže si ty proměnné nastaví. Jelikož declare řeší atributy i quotting, je to poměrně blbuvzdorné.
5.8.2010 16:01 dustin | skóre: 63 | blog: dustin
Rozbalit Rozbalit vše Re: Bash - přesměrování stdout funkce do proměnné bez subshellu
Zajímavé, o declare jsem nevěděl. Díky za tip.

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.