Zum Inhalt springen
Der Guide für ein smartes Leben.
In Schale geworfen

Teil 13: Die neue PowerShell einsetzen

Autoren: Redaktion pcmagazin und Tobias Weltner • 6.3.2007 • ca. 1:20 Min

Wer bereits erste Schritte in der neuen Microsoft- Programmierwelt .NET unternommen hat, kann mit diesem Wissen die PowerShell sogar erweitern. Möglich sind ebenso eigene neue Commandlets wie eigene Provider, die es dem dir-Befehl zum Beispiel ermöglichen, auch das Active Directory zu durchsuchen....

Wer bereits erste Schritte in der neuen Microsoft- Programmierwelt .NET unternommen hat, kann mit diesem Wissen die PowerShell sogar erweitern. Möglich sind ebenso eigene neue Commandlets wie eigene Provider, die es dem dir-Befehl zum Beispiel ermöglichen, auch das Active Directory zu durchsuchen.

Die neue PowerShell einsetzen
© Archiv

Neue Commandlets zu generieren ist nicht schwierig und gelingt mit reinen Bordmitteln. Die PowerShell kümmert sich dabei um Einund Ausgabe sowie das Objekt-Piping, so dass sich der Autor eines neuen Commandlets bequem zurücklehnen und auf die reine Funktionalität konzentrieren kann, die "sein" neues Commandlet liefern soll.

Das folgende Listing zeigt das Grundgerüst eines einfachen neuen Commandlets namens get-random, das eine Zufallszahl liefert:

using System;
using System.Management.Automation;
// GetRandom.cs
// <>summary>
// Ein Zufallszahlengenerator
// <>summary>
[Cmdlet("get", "random")]
public class GetRandomCommand :
Cmdlet
{
protected override void
EndProcessing()
{
Random r = new Random();
WriteObject(r.Next());
}
}

Der überwiegende Teil des Codes ist formaler Rahmenbau. Wirklich interessant ist nur die Funktion EndProcessing, die das Ergebnis des Commandlets zurückmeldet. Dazu beschafft sich das Commandlet einen Zufallszahlengenerator und meldet über WriteObject diese Zahl zurück an die PowerShell.

Diese Logik kann man übrigens auch direkt in der PowerShell testen, denn als .NET-Anwendung hat man auch von hier aus vollen Zugriff auf alle .NET-Klassen:

(new-object random).next

Damit aus dem Quellcode nun aber eine .NET-DLL wird, muss er kompiliert werden. Auch das leistet die PowerShell:

$ref =
"$MSHHOME/System.Management.Automation.
dll"
$compiler =
"$env:windir/Microsoft.NET/Framework/v2
.0.50727/csc" &$compiler /target:library /r:$ref
GetRandom.cs

Dabei werden zunächst zwei Variablen definiert: $ref liefert den Pfad zur PowerShell-Bibliothek und $compiler den zum Compiler.

Um den Compiler aufzurufen, bedient sich die PowerShellwieder eines schicken Tricks: Über das&-Zeichen kann der Inhalt einer Variablen ausgeführt werden, so als hätte man diesen von Hand eingegeben. &$compiler ruft also den in $compiler gespeicherten Befehl auf.