Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

  1. #1
    Rédacteur

    Module PowerShell pour les méthodes d'extension
    Voici un module PowerShell permettant de créer un fichier .ps1xml dédié aux méthodes d'extension contenues dans un fichier assembly dotnet.
    Comme votre projet en propose de nombreuses, je me suis dit qu'il serait bien de faciliter leurs usage sous PowerShell.



    Sous Powershell V1 et V2 on ne peut pas utiliser celles dont le type de this est :
    • un type générique, car le système d'extension de type de PowerShell nécessite de préciser des noms de type fort pour chaque paramètrage de la classe générique,
    • un type interface, car PowerShell ne sait pas nativement 'extraire' une interface particulière à partir d'un objet. De plus le pipeline de PowerShell 'transforme' les objets de type IEnumerable en System.Array.
    Quelques exemples :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    $PathAsm="G:\temp\dvp.net-0.2-beta\Binaries"
    Import-Module  "G:\PS\ExtensionMethod\ExtensionMethod.psm1" -force
     #Charge et retrouve les méthodes d'extension d'un assembly
     # qui n'est pas dans le GAC
    $Result=Add-Type -Path "$PathAsm\Developpez.Dotnet.dll" -Pass|
     Find-ExtensionMethod -ExcludeGeneric
    Pour 'System.Core' la recherche ne renvoi rien, car LINQ est conçu autour de classes génériques et d'interfaces.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     #Charge et retrouve les méthodes d'extension d'un assembly du GAC
     #On charge le namespace Linq du framework 3.5
    $Result=Add-Type -assemblyname "System.Core" -Pass|
     Find-ExtensionMethod -ExcludeGeneric |
      #Recupère les informations des méthodes d'extension.
     Get-ExtensionMethodInfo -ExcludeGeneric -ExcludeInterface
    Récupère dans une hastable les informations sur les méthodes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    $H=Add-Type -Path "$PathAsm\Developpez.Dotnet.dll" -Pass|
     Find-ExtensionMethod -ExcludeGeneric|
     Get-ExtensionMethodInfo -ExcludeGeneric -ExcludeInterface|
      #Crée une hashtable regroupant les méthodes d'extension par type.
     New-HashTable -key "Key" -Value "Value" -MakeArray
    $H."System.IO.TextReader"
    Affiche sur la console,à l'aide d'un 'wrapper' sur le cmdlet Format-Table, la liste des méthodes d'extension regroupées par type :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Add-Type -Path "$PathAsm\Developpez.Dotnet.dll" -Pass|
     Find-ExtensionMethod -ExcludeGeneric|
     Get-ExtensionMethodInfo -ExcludeGeneric -ExcludeInterface|
     New-HashTable -key "Key" -Value "Value" -MakeArray|
      #Affiche le détail des méthodes d'extension trouvées
     Format-TableExtensionMethod
    L'objectif du module, générer un fichier d'extension de type (fichier .ps1xml) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    $TypesFileName="DateTimeExtensionMethod.Types.ps1xml" 
    Add-Type -Path "$PathAsm\Developpez.Dotnet.dll" -Pass|
      #filtre sur le namespace
     # Where {$_.Namespace -eq "Developpez.Dotnet.Reflection"} |
     Find-ExtensionMethod -ExcludeGeneric|
     Get-ExtensionMethodInfo -ExcludeGeneric -ExcludeInterface|
     New-HashTable -key "Key" -Value "Value" -MakeArray|
      #Crée un texte représentant une structure XML que 
      # l'on insére dans un fichier de type PowerShell.
     New-ExtensionMethodTypeData > $TypesFileName
    Et enfin, dans la session courante, chargement et signature si nécessaire, du fichier d'extension de type généré :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    Type $TypesFileName|More 
     #Si la stratégie d'exécution est 'AllSigned' 
     if (Get-ExcecutionPolicy -eq "AllSigned" )
      {
        #Signe $TypesFileName
      }
     #Met à jour la configuration de type étendu (ETS)
    Update-TypeData $TypesFileName 
     
     #usage
    $dt=Get-Date
    $dt.AddDays(1).Next("Sunday")
    # renvoi :
    # dimanche 8 août 2010 16:07:54

  2. #2
    Rédacteur/Modérateur

    Super, merci

    Citation Envoyé par Laurent Dardenne Voir le message
    Sous Powershell V1 et V2 on ne peut pas utiliser celles dont le type de this est :
    • un type générique, car le système d'extension de type de PowerShell nécessite de préciser des noms de type fort pour chaque paramètrage de la classe générique,
    • un type interface, car PowerShell ne sait pas nativement 'extraire' une interface particulière à partir d'un objet. De plus le pipeline de PowerShell 'transforme' les objets de type IEnumerable en System.Array.

    Arf... ça c'est pas cool, surtout que la plupart des méthodes d'extension de la lib sont basées soit sur des interfaces, soit sur des génériques (voire les 2)

    Tu sais si ce sera supporté dans les versions suivantes ?

  3. #3
    Rédacteur

    Citation Envoyé par tomlev Voir le message

    Arf... ça c'est pas cool, surtout que la plupart des méthodes d'extension de la lib sont basées soit sur des interfaces, soit sur des génériques (voire les 2)
    Du coup le nombre de celles restantes est limitées, mais elles restent intéressantes.
    Citation Envoyé par tomlev Voir le message

    Tu sais si ce sera supporté dans les versions suivantes ?
    Aucune info !
    La v2 a améliorée la prise en charge des génériques, concernant l'adaptation de type (ETS) l'équipe de PowerShell a peut être jugé que cela n'était pas prioritaire.
    C'est surtout la communauté des développeurs qui "pousse" pour que ce shell offre une meilleure prise en charge de la POO, puisque l'automatisatoon de tâche ne concerne pas que l'infrastructure.
    Dans la doc de la release de la v2 il est fait mention de mot clés réservés pour la création de classe :

    • Reserved keywords and parameter names
    Windows PowerShell 2.0 has reserved the following keywords and parameter names. Using these keywords and parameter names for other purposes might cause errors.
    o Reserved language keywords: USING, CLASS, DEFINE, and VAR
    o Reserved parameter names: –SelectProperty and –SelectObject
    Je suppose leur modéle de conception assez riche étant donné que la v2 a su évoluer sans rien remettre en cause.
    On peut supposer que ces points seront pris en charge dans la prochaine version, avec la prochaine CTP on sera fixé.

###raw>template_hook.ano_emploi###