IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
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

VB.NET Discussion :

Réecrire la méthode Writelineif des classes Debug et Trace, possible ?


Sujet :

VB.NET

  1. #1
    Membre averti
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2012
    Messages
    640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Bâtiment

    Informations forums :
    Inscription : Mars 2012
    Messages : 640
    Points : 372
    Points
    372
    Par défaut Réecrire la méthode Writelineif des classes Debug et Trace, possible ?
    Bonjour à tous,
    Savez vous si il est possible de réecrire la méthode Writelineif des classes Debug et Trace ?
    Le but est de personnaliser les messages sans toucher à la synthaxe d'origine (Trace.Writelineif...etc) J'ai réussi à la faire en partie, c'est à dire que j'ai écrit une classe qui herite de TraceListener, mais le problème c'est que cette classe est un ecouteur et donc formate les messages uniquement à destination de cet ecouteur.
    J'aimerais que les mêmes messages formatés soit aussi envoyés vers le fenêtre de debogages de Visual Studio. Les classes Debug et Trace etant NonHeritable, je n'ai pas réussi à écrire une classe qui herite directement de celles-ci et donc il ne me semble pas possible de le faire, pouvez vous confirmer ou m'indiquer une autre solution ?
    En remerciant par avance.

  2. #2
    Expert éminent sénior Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 154
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 154
    Points : 25 072
    Points
    25 072
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  3. #3
    Membre averti
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2012
    Messages
    640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Bâtiment

    Informations forums :
    Inscription : Mars 2012
    Messages : 640
    Points : 372
    Points
    372
    Par défaut
    Merci beaucoup pour cette technique que je ne connaissais pas mais malheureusement ca ne fonctionne pas comme je veux.
    C'est à dire que je suis obligé de travailler sur une instance de la classe de base pour que la nouvelle méthode puisse être utilisé et donc en clair je ne peux pas utiliser la syntaxe d'origine.

    La synthaxe d'origine est du type :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Trace.WriteLineIf (condition as boolean, messsage as string)
    La nouvelle syntaxe :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Dim MyTrace1 as Trace
    MyTrace1.WriteLineIf(MyDebugSwitch.TraceVerbose, textLog, True) ' Un 3eme paramètre à été ajouté afin que la signature soit différente de la classe de base et pour que la méthode puisse être appellé à la place de la méthode de base

    Mon module pour étendre la classe :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Imports System.Runtime.CompilerServices
    Module TraceExtensions
        <Extension()>
        Public Sub WriteLineIf(ByVal tc As Trace, ByVal condition As Boolean, ByVal message As String, Optional ByVal Ext As Boolean = Nothing)
            If Ext = True Then
                message = "Mon message formaté 1 = " & message
                Trace.WriteLineIf(condition, message)
            Else
                message = "Mon message formaté 2 = " & message
                Trace.WriteLineIf(condition, message)
            End If
        End Sub
    End Module
    Ce que je veux faire n'a pas l'air d'être possible. Si vous pouvez me contredire j'en serais ravi, ça fait des mois que je cherche.

  4. #4
    Expert éminent sénior Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 154
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 154
    Points : 25 072
    Points
    25 072
    Par défaut
    malheureusement je ne vais pas vous contredire
    j'avais bien cru comprendre que vous vouliez garder la syntaxe de base et la classe de base et que ca appelle un autre code, mais techniquement ca serait étrange de pouvoir faire ca ^^

    il faudra dans tous les cas changer la syntaxe, mais un replace (ctrl+h) doit pouvoir convenir
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  5. #5
    Membre averti
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2012
    Messages
    640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Bâtiment

    Informations forums :
    Inscription : Mars 2012
    Messages : 640
    Points : 372
    Points
    372
    Par défaut
    Bonsoir, oui en effet je voulais garder la syntaxe d'origine. J'en demande peut-être beaucoup mais je pensais que cela devait être faisable. Quoi qu'il en soit merci beaucoup, j'ai appris à étendre les méthodes d'une classe et ça pourra me resservir au besoin. Merci pour la pertinence de votre réponse comme on aimerais en recevoir souvent.

  6. #6
    Membre averti
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2012
    Messages
    640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Bâtiment

    Informations forums :
    Inscription : Mars 2012
    Messages : 640
    Points : 372
    Points
    372
    Par défaut
    Eureka, j'ai trouvé.
    Il faut utiliser la classe TraceSource. Bon c'est vrai je n'avais parler que des classes Debug et Trace mais ca ne me gène pas d'utiliser cette classe. Avec celle-ci je peux réecrire la méthode TraceEvent sans toucher à la syntaxe originale :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Dim Mysource1 As New TraceSource1("MyTraceSource1")
            Mysource1.TraceEvent(TraceEventType.Verbose, 0, "Mon message")
    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
    16
    17
    18
    19
    20
    21
    <configuration>
      <system.diagnostics>
        <sources >
          <source name ="MyTraceSource1" switchName="MySourceSwitch">
            <listeners>
              <add
                   name="MyListener3" 
                   type="System.Diagnostics.TextWriterTraceListener"
                   traceOutputOptions="DateTime"
                   initializeData=".\MyTrace.txt">
              </add>
            </listeners>
          </source>
        </sources>
        		<switches>
                         <add name="MySourceSwitch" value="Verbose"/>
    		</switches>
        <trace autoflush ="true" indentsize ="4">
          </trace>
        </system.diagnostics>
    </configuration>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Public Class TraceSource1
        Inherits TraceSource
        Public Sub New(ByVal name As String)
            MyBase.New(name)
        End Sub
        Public Overloads Sub TraceEvent(eventType As System.Diagnostics.TraceEventType, id As Integer, message As String, Optional ext As Boolean = Nothing)
            message = "MyTraceSource1 formaté = " & message
            MyBase.TraceEvent(eventType, id, message)
        End Sub
    End Class
    A partir de là je peux réecrire et formater mes messages comme je veux, c'est pile ce qu'il me faut y compris dans la fenêtre Visual Studio.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Méthodes intégrant des classes
    Par nicko_73 dans le forum Langage
    Réponses: 2
    Dernier message: 14/06/2009, 16h32
  2. Réponses: 7
    Dernier message: 28/12/2007, 23h08
  3. Réponses: 4
    Dernier message: 27/07/2007, 18h18
  4. Documentation des classes et méthodes
    Par nicocolt dans le forum Langage
    Réponses: 2
    Dernier message: 02/02/2007, 17h14

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo