Bienvenue à Blogs CodeS-SourceS Identification | Inscription | Aide

Abonnements

Matthieu fait mumuse avec le générateur de classes d'EDM

Dans les premières specs d'EDM, on devait pouvoir utiliser des types enum dans le csdl. Cependant, même si cette idée n'a pas été abandonnée, ce ne sera pas possible avec la V1.

Ce qu'on peut quand même faire c'est se rajouter une propriété de type notre enum qui encapsule la propriété définie avec EDM. D'où mon idée : pourquoi ne pas le faire faire par le générateur de code en fonction des metadatas du csdl.

En repartant du code de Sanjay Nagamangalam, j'ai modifié la méthode OnTypeGenerated pour obtenir le code suivant :

private void OnTypeGenerated(object sender, TypeGeneratedEventArgs eventArgs)

{

    eventArgs.AdditionalAttributes.AddRange(CreateCodeAttributes(eventArgs.TypeSource));

    // MM

    var entityType = eventArgs.TypeSource as System.Data.Metadata.Edm.EntityType;

    if (entityType != null)

    {

        foreach (var prop in entityType.Properties)

        {

            var metadataProp = prop.MetadataProperties.Where(mp => mp.Name == "http://tempuri.org/AttributeEnum:MyCustomAnnotation").FirstOrDefault();

            string enumTypeName;

            var propPrimitiveType = prop.TypeUsage.EdmType as System.Data.Metadata.Edm.PrimitiveType;

            if (metadataProp != null && propPrimitiveType != null && !string.IsNullOrEmpty(enumTypeName = metadataProp.Value.ToString()))

            {

                var propType = propPrimitiveType.ClrEquivalentType.FullName;

                var newProp = new CodeMemberProperty { Name = prop.Name + "Enum", Attributes = MemberAttributes.Public | MemberAttributes.Final };

                if (prop.Nullable)

                {

                    var nullableEnumTypeName = "global::System.Nullable<" + enumTypeName + ">";

                    newProp.Type = new CodeTypeReference(nullableEnumTypeName);

                    newProp.GetStatements.Add(new CodeConditionStatement(new CodeBinaryOperatorExpression(

                        new CodePropertyReferenceExpression(new CodeThisReferenceExpression(), prop.Name), CodeBinaryOperatorType.IdentityEquality,

                        new CodePrimitiveExpression(null)), new CodeStatement[] { new CodeMethodReturnStatement(new CodePrimitiveExpression(null)) },

                        new CodeStatement[]{new CodeMethodReturnStatement(new CodeCastExpression(new CodeTypeReference("global::" + enumTypeName),

                new CodePropertyReferenceExpression(new CodeThisReferenceExpression(), prop.Name)))}));

                    newProp.SetStatements.Add(new CodeConditionStatement(new CodeBinaryOperatorExpression(

                        new CodeArgumentReferenceExpression("value"), CodeBinaryOperatorType.IdentityEquality, new CodePrimitiveExpression(null)),

                        new CodeStatement[]{new CodeAssignStatement(new CodePropertyReferenceExpression(new CodeThisReferenceExpression(), prop.Name),

                    new CodePrimitiveExpression(null))},

                        new CodeStatement[]{new CodeAssignStatement(new CodePropertyReferenceExpression(new CodeThisReferenceExpression(), prop.Name),

                    new CodeCastExpression(new CodeTypeReference(propType),

                        new CodeArgumentReferenceExpression("value")))}));

                }

                else

                {

                    enumTypeName = "global::" + enumTypeName;

                    newProp.Type = new CodeTypeReference(enumTypeName);

                    newProp.GetStatements.Add(new CodeMethodReturnStatement(new CodeCastExpression(new CodeTypeReference(enumTypeName),

                        new CodePropertyReferenceExpression(new CodeThisReferenceExpression(), prop.Name))));

                    newProp.SetStatements.Add(

                        new CodeAssignStatement(

                            new CodePropertyReferenceExpression(new CodeThisReferenceExpression(), prop.Name),

                            new CodeCastExpression(new CodeTypeReference(propType), new CodeArgumentReferenceExpression("value"))));

                }

                eventArgs.AdditionalMembers.Add(newProp);

            }

        }

    }

}

Du coup, les deux propriétés suivantes :

<Property Name="Test" Type="Int32" Nullable="false" xmlns:attr='http://tempuri.org/AttributeEnum' attr:MyCustomAnnotation='ConsoleApplication23.MyEnum' />

<Property Name="Test2" Type="Int32" Nullable="true" xmlns:attr='http://tempuri.org/AttributeEnum' attr:MyCustomAnnotation='ConsoleApplication23.MyEnum' />

donnent le code suivant :

public int Test

{

    get

    {

        return this._Test;

    }

    set

    {

        this.OnTestChanging(value);

        this.ReportPropertyChanging("Test");

        this._Test = global::System.Data.Objects.DataClasses.StructuralObject.SetValidValue(value);

        this.ReportPropertyChanged("Test");

        this.OnTestChanged();

    }

}

public global::System.Nullable<int> Test2

{

    get

    {

        return this._Test2;

    }

    set

    {

        this.OnTest2Changing(value);

        this.ReportPropertyChanging("Test2");

        this._Test2 = global::System.Data.Objects.DataClasses.StructuralObject.SetValidValue(value);

        this.ReportPropertyChanged("Test2");

        this.OnTest2Changed();

    }

}

public global::ConsoleApplication23.MyEnum TestEnum

{

    get

    {

        return ((global::ConsoleApplication23.MyEnum)(this.Test));

    }

    set

    {

        this.Test = ((int)(value));

    }

}

public global::System.Nullable<ConsoleApplication23.MyEnum> Test2Enum

{

    get

    {

        if ((this.Test2 == null))

        {

            return null;

        }

        else

        {

            return ((global::ConsoleApplication23.MyEnum)(this.Test2));

        }

    }

    set

    {

        if ((value == null))

        {

            this.Test2 = null;

        }

        else

        {

            this.Test2 = ((int)(value));

        }

    }

}


Ce post vous a plu ? Ajoutez le dans vos favoris pour ne pas perdre de temps à le retrouver le jour où vous en aurez besoin :

Publié mardi 19 février 2008 02:40 par Matthieu MEZIL

Commentaires

Pas de commentaires

Les commentaires anonymes sont désactivés

Les 10 derniers blogs postés

- ProcDump 6.0 : support du filtrage sur messages d'exceptions .NET, des filtres multiples et du ciblage par nom de service par CoqBlog le 05-20-2013, 14:50

- Votez pour le TOP 10 des influenceurs SharePoint francophones ! par Le blog de Patrick [MVP SharePoint] le 05-20-2013, 12:59

- [Conf’SharePoint] Dernier rappel ! :-) par Le blog de Patrick [MVP SharePoint] le 05-20-2013, 09:09

- [ #SharePoint 2013 ] les modèles de sites standards… par Le blog de Patrick [MVP SharePoint] le 05-20-2013, 09:03

- 10 erreurs de compréhension concernant SharePoint… par Le blog de Patrick [MVP SharePoint] le 05-20-2013, 08:27

- Conf’SharePoint : 10 bonnes raisons pour ne pas la rater par Le petit blog de Pierre / Pierre's little blog le 05-14-2013, 02:24

- [Event] Soirée de lancement Agile .NET France à Lyon par Blog Agile/ALM de Vincent THAVONEKHAM le 05-13-2013, 01:29

- .NET / Debug : inspection de la mémoire d'applications .NET (dump ou processus live) : première livraison d'une librairie .NET par Microsoft par CoqBlog le 05-11-2013, 22:21

- SharePoint : Incompatibilité avec Internet Explorer 10 (IE10) par Blog Technique de Romelard Fabrice le 05-08-2013, 16:29

- AutoSPInstaller pour SharePoint 2013 maintenant disponible en “RTM” par Julien Chable le 05-06-2013, 23:30