NAME
Prty::Shell - Ausführung von Shell-Kommandos
BASE CLASS
METHODS
Konstruktor/Destruktor
new() - Konstruktor
Synopsis
$sh = $class->new(@opt);
Description
Instantiiere ein Shell-Objekt, und liefere eine Referenz auf dieses Objekt zurück.
Options
- cmdPrefix => $str (Default: '')
-
Zeichenkette, der jeder Kommandozeile im Log vorangestellt wird.
- dryRun => $bool (Default: 0)
-
Führe Kommandos nicht aus, sondern logge sie nur (impliziert log=>1).
- log => $bool (Default: 0)
-
Log Commands to STDOUT.
- logDest => $fd (Default: *STDOUT)
-
Datei-Deskriptor, auf den die Logmeldungen geschrieben werden.
- msgPrefix => $str (Default: '')
-
Zeichenkette, die jeder Meldung im Log vorangestellt wird.
- time => $bool (Default: 0)
-
Gib nach jedem Kommando die Zeit aus, die es benötigt hat.
- timePrefix => $str (Default: '')
-
Zeichenkette, die jeder Zeitausgabe vorangestellt wird.
- timeSummary => $bool (Default: 0)
-
Gib zum Schluss bei der Destrukturierung des Objekts die Gesamtausführungszeit aus.
DESTROY() - Destruktor
Synopsis
$sh->%METH;
Description
Wenn timeSummary gesetzt ist, wird im Zuge der Destruktuierung die Gesamtausführungszeit für alle Kommandos, die über das Shell-Objekt ausgeführt wurden, ausgegeben.
Kommando ausführen
exec() - Führe Kommando aus
Synopsis
$str|@arr = $this->exec($cmd,@opt);
Description
Führe Kommando $cmd aus. Im Falle eines Fehlers löse eine Exception aus.
Beginnt das Kommando $cmd mit einem Bindestrich, wird implizit die Option -sloppy gesetzt.
Options
- -capture => $channels (Default: keiner)
-
Liefere die die Programmausgabe auf dem Kanal bzw. den Kanälen $channels zurück. Mögliche Werte für $channels:
- 'stdout'
-
Liefere Ausgabe auf stdout, unterdrücke stderr.
- 'stderr'
-
Liefere Ausgabe auf stderr, unterdrücke stdout.
- 'stdout+stderr'
-
Liefere Ausgabe auf stdout und stderr zusammen.
- 'stdout,stderr'
-
Liefere Ausgabe auf stdout und stderr getrennt.
Für Beispiele siehe Abschnitt "exec/Examples".
- -quiet => $bool (Default: 0)
-
Unterdrücke Programmausgabe auf stdout und stderr.
- -sloppy => $bool (Default: 0)
-
Wirf keine Exception, wenn das Programm fehlschlägt, sondern liefere dessen Exitcode. Ist gleichzeitig die Option -capture angegeben, hat diese hinsichtlich des Rückgabewerts Priorität.
Returns
Der Rückgabewert richtet sich nach den Optionen @opt. Ist -capture definiert, wird die angegebene Programmausgabe geliefert. Ist -sloppy wahr, wird der Exitcode geliefert. Die Option -capture hat Priorität gegenüber der Option -sloppy. Sind weder -capture noch -sloppy angegeben, liefert die Methode keinen Wert.
Examples
Unterdrücke Ausgabe auf stdout und stderr:
$this->exec($cmd,-quiet=>1);
Liefere Ausgabe auf stdout:
$stdout = $this->exec($cmd,-capture=>'stdout');
Liefere Ausgabe auf stderr:
$stderr = $this->exec($cmd,-capture=>'stderr');
Liefere Ausgabe auf stdout und stderr zusammen:
$output = $this->exec($cmd,-capture=>'stdout+stderr');
Liefere Ausgabe auf stdout und stderr getrennt:
($stdout,$stderr) = $this->exec($cmd,-capture=>'stdout,stderr');
Keine Exception, liefere Exitcode:
$exitCode = $this->exec($cmd,-sloppy=>1);
Arbeitsverzeichnis wechseln
cd() - Wechsele das Arbeitsverzeichnis
Synopsis
$sh->cd($dir);
Description
Wechsle in Arbeitsverzeichnis $dir. Anmerkung: Diese Änderung gilt für den gesamten Prozess, nicht nur für das Shell-Objekt.
Returns
Die Methode liefert keinen Wert zurück.
back() - Wechsele ins vorige Arbeitsverzeichnis zurück
Synopsis
$this->back;
Fehlerbehandlung
checkError() - Löse Exception bei Kommandofehler aus
Synopsis
$this->checkError($code,$errMsg,@cmd);
Description
Prüfe den Status einer vorhergehenden Programmausführung und löse eine Execption aus, wenn der Status ungleich 0 ist.
Returns
nichts
Examples
Prüfe den Ausführungsstatus von system():
system($cmd);
Prty::Shell->checkError($?,$!,$cmd);
Prüfe den Ausführungsstatus des Backtick-Operators:
$str = `$cmd`;
Prty::Shell->checkError($?,$!,$cmd);
VERSION
1.118
AUTHOR
Frank Seitz, http://fseitz.de/
COPYRIGHT
Copyright (C) 2017 Frank Seitz
LICENSE
This code is free software; you can redistribute it and/or modify it under the same terms as Perl itself.