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

Contribuez C++ Discussion :

[C++0x]Pas de concepts


Sujet :

Contribuez C++

  1. #1
    Rédacteur/Modérateur
    Avatar de JolyLoic
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    5 463
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2004
    Messages : 5 463
    Points : 16 213
    Points
    16 213
    Par défaut [C++0x]Pas de concepts
    Bonjour,

    Le vote a eu lieu aujourd'hui, et la décision a été prise de ne pas inclure les concepts dans C++0x. Les principaux arguments étaient que beaucoup d'acteurs estimaient que la proposition n'était pas assez mature, et risquait de repousser le standard.

    Nous n'avons pas encore décidé comment le travail sur les concepts doit continuer, et quand ils pourront être intégrés dans le langage.

  2. #2
    Membre actif
    Étudiant
    Inscrit en
    Octobre 2007
    Messages
    189
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2007
    Messages : 189
    Points : 214
    Points
    214
    Par défaut
    Pour les ignorants comme moi, aurais-tu un lien de ce que sont les concepts ?

  3. #3
    Membre chevronné
    Avatar de Goten
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    1 580
    Détails du profil
    Informations personnelles :
    Âge : 34
    Localisation : France

    Informations forums :
    Inscription : Juillet 2008
    Messages : 1 580
    Points : 2 205
    Points
    2 205
    Par défaut
    En gros ça permet de définir une interface que doit fournir un paramètre de template.
    Ca permet en premier lieu d'avoir des erreurs du compilo plus direct, par exemple si t'essayes de stocker dans un vecteur un objet qui n'est pas copi-able.

    Ca aurait permis d'écrire ce genre de chose :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    template <typename T> requires equalityComparable<T>
    bool isEqual(const T& lhs, const T& rhs)
    {
         return lhs==rhs;
    }
     
    // et on définit un concept comme ceci :
     
    auto concept equalityComparable<typename T>
    {
        bool operator==(const T&);
    }
    Désolé pour la pauvreté de l'exemple mais j'ai pas mieux en tête xD. D'ailleurs je suis pas sur de l'exactitude de la syntaxe du concept (au niveau de la définition de l'opérateur)


    J'ai pas de lien très poussé sous la main, jte retrouve ça.

  4. #4
    Rédacteur/Modérateur
    Avatar de JolyLoic
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    5 463
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2004
    Messages : 5 463
    Points : 16 213
    Points
    16 213
    Par défaut
    Un des exemples fondateurs est std::sort. Si tu fais std::sort sur des itérateurs de std::list, tu auras un message d'erreur obscur qui parlera peut-être d'un problème avec un opérateur [] ou un opérateur + dans du code qui n'est pas à toi, mais fait partie de la bibliothèque standard.

    Avec des concepts, tu aurais eu une erreur dans ton code, indiquant que sort a besoin d'itérateurs à accès direct (RandomAccessIterator), et que tu lui as fourni des itérateurs d'un mauvais type.

    Le but étant de rendre les messages d'erreur des templates compréhensibles par le commun des mortels.

    Et ils permettaient aussi bien d'autres choses, entre autre une bonne gestion de l'overloading des templates, ce qui aujourd'hui doit se faire à la main avec des astuces et des classes de traits. Avec les concepts, les classes de traits auraient probablement disparu peu à peu.

  5. #5
    Membre actif
    Étudiant
    Inscrit en
    Octobre 2007
    Messages
    189
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2007
    Messages : 189
    Points : 214
    Points
    214
    Par défaut
    D'accord, merci à vous deux.

    Je crois en fait que j'en avais déjà entendu parler. N'y avait-il pas l'intention d'introduire le mot clef where ?

  6. #6
    Rédacteur
    Avatar de 3DArchi
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    7 634
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 7 634
    Points : 13 017
    Points
    13 017
    Par défaut
    Bonjour,
    Effectivement, c'est dommage.
    Entre autres, les concepts :
    -> jouent le rôle des classes traits : ils spécifient les exigences qu'un paramètre d'une classe/fonction template doit remplir (le code suivant ne suit pas la syntaxe exacte proposée mais illustre le propos ):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    // définition d'un concept :
    concept Comparable<typename T> {
    bool operator<(T, T);
       // On spécifique qu'il doit exister un opérateur '<' de la forme indiquée ci-dessus.
    }
     
    // utilisation dans une fonction template :
    template<class T>
       requires Comparable<T>
    T min(T t1, T T2)
    {...
    _> jouent un peu le rôle des classes politiques avec les concept map : les concepts map permettent de dire comment un concept (un 'require') est rempli par une classe dans le cas où l'exigence n'est pas immédiate :
    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
    22
     
    class personne {
    public:
    std::string nom;
    std::string prénom;
    };
     
    concept Comparable<typename T> {
    bool operator<(T, T);
    }
     
    concept_map Comparable<personne > { 
    // ca ne définit pas un opérateur '<' sur la classe personne
    // mais ça indique comment l'exigence doit être remplie
    bool operator<(const personne& a, const personne& b) {
    return (a.nom == b.nom) ?(
        (a.prénom == b.prénom)?
            false
            : (a.prénom< b.prénom))
        : (a.nom < b.nom)
    ;
    }
    Tu peux trouver des infos sur les concepts ici , ici ou

  7. #7
    Alp
    Alp est déconnecté
    Expert éminent sénior

    Avatar de Alp
    Homme Profil pro
    Inscrit en
    Juin 2005
    Messages
    8 575
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Juin 2005
    Messages : 8 575
    Points : 11 861
    Points
    11 861
    Par défaut
    C'est bien dommage

    Qui plus est, j'avais commencé un article dessus

  8. #8
    Membre chevronné
    Avatar de Goten
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    1 580
    Détails du profil
    Informations personnelles :
    Âge : 34
    Localisation : France

    Informations forums :
    Inscription : Juillet 2008
    Messages : 1 580
    Points : 2 205
    Points
    2 205
    Par défaut
    C'est "qu'un" article (pas péjoratif du tout hein), quand je pense au petit gars des compilo qui implémentait déjà cette feature, les glandes :p.

  9. #9
    Alp
    Alp est déconnecté
    Expert éminent sénior

    Avatar de Alp
    Homme Profil pro
    Inscrit en
    Juin 2005
    Messages
    8 575
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Juin 2005
    Messages : 8 575
    Points : 11 861
    Points
    11 861
    Par défaut
    Citation Envoyé par Goten Voir le message
    C'est "qu'un" article (pas péjoratif du tout hein), quand je pense au petit gars des compilo qui implémentait déjà cette feature, les glandes :p.
    Oui, Doug Gregor doit avoir du mal à digérer ça, il était derrière Concept GCC, et les concepts en général je crois.

  10. #10
    Membre actif
    Étudiant
    Inscrit en
    Octobre 2007
    Messages
    189
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2007
    Messages : 189
    Points : 214
    Points
    214
    Par défaut
    Merci pour les liens.

    De mon point de vue "utilisateur", c'est vrai que je suis déçu que ça soit repoussé au prochain std, mais en même temps je préfère ça à un ajournement du 0x.

    Pour le travail de Doug Gregor, n'y a-t-il pas un "plan" de prévu ? ( Du style une version de gcc qui accepte les concepts ? )

  11. #11
    Alp
    Alp est déconnecté
    Expert éminent sénior

    Avatar de Alp
    Homme Profil pro
    Inscrit en
    Juin 2005
    Messages
    8 575
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Juin 2005
    Messages : 8 575
    Points : 11 861
    Points
    11 861

  12. #12
    Expert éminent

    Inscrit en
    Novembre 2005
    Messages
    5 145
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 5 145
    Points : 6 911
    Points
    6 911
    Par défaut
    Citation Envoyé par 3DArchi Voir le message
    Effectivement, c'est dommage.
    S'il y a des alternatives que j'aurais preferees, il y en a d'autres que
    je craignais. Je ne suis pas sur que ce soit dommage, car je suis loin
    d'etre sur que celles que j'aurais preferefees soient en fait viables.

    Citation Envoyé par Alp Voir le message
    Oui, Doug Gregor doit avoir du mal à digérer ça,
    Loic doit pouvoir commenter mieux que moi sa reaction.

    il était derrière Concept GCC,
    Oui.

    et les concepts en général je crois.
    Oui, mais c'est loin d'etre le seul. J'aurais a citer un seul nom pour
    etre "derriere les concepts en general", je dirais A. Stepanov. Mais je
    connais tres mal ce qui est en rapport avec d'autres langages (si quelqu'un
    veut faire des recherches, de memoire Axiom, OpenAxiom, Aldor sont des
    mots-cles a utiliser).

    Citation Envoyé par hiura Voir le message
    De mon point de vue "utilisateur", c'est vrai que je
    suis déçu que ça soit repoussé au prochain std, mais en même temps je
    préfère ça à un ajournement du 0x.
    Je doute que les concepts en l'etat ait ete utile a quelqu'un qui ne sait
    d'eux que ce qui a ete ecrit ici sans un gros travail de
    comprehension, meme comme simple utilisateur de bibliotheques utilisant les
    concepts.

    Pour le travail de Doug Gregor, n'y a-t-il pas un "plan" de prévu ?
    (Du style une version de gcc qui accepte les concepts ?)
    ConceptGCC est disponible:
    http://www.generic-programming.org/software/ConceptGCC/ mais ce n'est plus
    maintenu depuis un an. Et ca ne correspond meme pas aux concepts tels
    qu'ils etaient proposes alors. Ma comprehension est qu'il n'y avait pas de
    plan d'integrer conceptGCC tel quel dans GCC.

  13. #13
    Membre actif
    Étudiant
    Inscrit en
    Octobre 2007
    Messages
    189
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2007
    Messages : 189
    Points : 214
    Points
    214
    Par défaut
    Citation Envoyé par Jean-Marc.Bourguet Voir le message
    Je doute que les concepts en l'etat ait ete utile a quelqu'un qui ne sait
    d'eux que ce qui a ete ecrit ici sans un gros travail de
    comprehension, meme comme simple utilisateur de bibliotheques utilisant les
    concepts.
    Ben il faut bien en entendre parler à un moment où un autre pour pouvoir s'y intéresser et approfondir le sujet.
    ( Et avec tous les liens qui sont donnés on peut vite se forger une idée du sujet. )

  14. #14
    Rédacteur/Modérateur
    Avatar de JolyLoic
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    5 463
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2004
    Messages : 5 463
    Points : 16 213
    Points
    16 213
    Par défaut
    Citation Envoyé par Alp Voir le message
    Oui, Doug Gregor doit avoir du mal à digérer ça, il était derrière Concept GCC, et les concepts en général je crois.
    J'ai un peu l'impression qu'il en avait déjà fait son deuil avant même la réunion. Bjarne m'avait l'air plus affecté, il était lui aussi derrière ça depuis le début.
    Citation Envoyé par Jean-Marc.Bourguet Voir le message
    Oui, mais c'est loin d'etre le seul. J'aurais a citer un seul nom pour
    etre "derriere les concepts en general", je dirais A. Stepanov. Mais je
    connais tres mal ce qui est en rapport avec d'autres langages (si quelqu'un
    veut faire des recherches, de memoire Axiom, OpenAxiom, Aldor sont des
    mots-cles a utiliser).
    Dans le cadre purement C++, il y avait principalement deux équipes à l'origine sur le sujet, d'un côté Bjarne Stroustrup et Gaby Dos Reis, de l'autre Doug Gregor et Jeremie Siek. Plus plein d'autres contributeurs (James Widman, par exemple), plus tous ceux qui ont travailler sur l'application des concepts à la bibliothèque standard.
    La présence de deux sources différentes de proposition, qui n'ont jamais réussi à vraiment être mergées, et avec des philosophies un peu différentes est certainement une des causes de retard.
    Citation Envoyé par Jean-Marc.Bourguet Voir le message


    Je doute que les concepts en l'etat ait ete utile a quelqu'un qui ne sait
    d'eux que ce qui a ete ecrit ici sans un gros travail de
    comprehension, meme comme simple utilisateur de bibliotheques utilisant les
    concepts.
    C'était un des problèmes principaux : En l'état, les concepts étaient compliqués à comprendre. Et pas uniquement pour les développeurs de bbliothèque, mais peut être aussi pour leurs utilisateurs. Ce qui pour une fonctionnalité destinée à simplifier l'utilisation des templates pourrait sembler paradoxal.
    Citation Envoyé par Jean-Marc.Bourguet Voir le message
    ConceptGCC est disponible:
    http://www.generic-programming.org/software/ConceptGCC/ mais ce n'est plus
    maintenu depuis un an. Et ca ne correspond meme pas aux concepts tels
    qu'ils etaient proposes alors. Ma comprehension est qu'il n'y avait pas de
    plan d'integrer conceptGCC tel quel dans GCC.
    De plus, d'après Doug, les choix de design effectués pour sortir conceptGCC rapidement devraient profondément évoluer pour obtenir une version utilisable (conceptGcc est actuellement calamiteux en temps de compilation). Et il n'est pas sur que ça n'aurait pas demandé aussi un redesign de gcc lui même.
    Citation Envoyé par hiura
    Pour le travail de Doug Gregor, n'y a-t-il pas un "plan" de prévu ? ( Du style une version de gcc qui accepte les concepts ? )
    Je vous tiendrai au courant dès que j'aurai vent de plans de travails pour continuer à faire avancer les concepts.

  15. #15
    Expert éminent

    Inscrit en
    Novembre 2005
    Messages
    5 145
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 5 145
    Points : 6 911
    Points
    6 911
    Par défaut
    Citation Envoyé par hiura Voir le message
    Ben il faut bien en entendre parler à un moment où un autre pour pouvoir s'y intéresser et approfondir le sujet.
    C'etait pas une critique de ton commentaire mais plutot de l'etat des concepts. On est beaucoup trop dans le "il n'y a pas de problemes evidents" plutot que dans le "il est evident qu'il n'y a pas de problemes" que toute conception doit viser.

  16. #16
    Membre actif
    Étudiant
    Inscrit en
    Octobre 2007
    Messages
    189
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2007
    Messages : 189
    Points : 214
    Points
    214
    Par défaut
    Citation Envoyé par JolyLoic Voir le message
    Je vous tiendrai au courant dès que j'aurai vent de plans de travails pour continuer à faire avancer les concepts.
    Merci.

    Citation Envoyé par Jean-Marc.Bourguet Voir le message
    C'etait pas une critique de ton commentaire mais plutot de l'etat des concepts.
    Ha, ok. J'avais compris bien autre chose moa ( que c'était au dessus du niveau de l'amateur ) .

  17. #17
    Expert éminent

    Inscrit en
    Novembre 2005
    Messages
    5 145
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 5 145
    Points : 6 911
    Points
    6 911
    Par défaut
    Citation Envoyé par hiura Voir le message
    ( que c'était au dessus du niveau de l'amateur ) .
    C'est un peu l'idee. Je ne jette la pierre ni a l'amateur, ni a l'idee sous-jacente aux concepts, mais a sa realisation.

  18. #18
    Membre émérite

    Inscrit en
    Mai 2008
    Messages
    1 014
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 1 014
    Points : 2 252
    Points
    2 252
    Par défaut
    Citation Envoyé par JolyLoic Voir le message
    Bjarne m'avait l'air plus affecté, il était lui aussi derrière ça depuis le début.
    Hum, ça ne m'étonne pas trop. Quand on voit la conclusion de son proposal de juin pour simplifier l'utilisation des concepts...
    Citation Envoyé par Bjarne Stroustrup
    The use of concepts is supposed to help people write and use a wide range of templates. The current definition of concept maps and the philosophy that seems to go with them makes it harder.

    Addressing this is important. I suspect that the alternative is widespread disuse of concepts and libraries using concepts. I would consider that a major failure of C++0x.
    Sacré coup de massue.

    Avec un peu de recul, j'ai l'impression que les concepts était une tentative un peu eu... héroique/courageuse/téméraire/folle/désespéré ? pour revitaliser le langage et surtout renouveler l'exploit qu'a déjà fait le C++ dans les années 90 en faisant glisser la programmation objet vers le mainstream, mais cette fois pour la programmation générique.

    Hiura, sans rentrer dans les détails, la promesse des concepts c'était de simplifier l'utilisation des templates, d'éradiquer les messages d'erreurs de trois kilomètres et de balayer la montagne de hack horripilant (classe de traits, metaprogrammation...) qui règne à l'heure actuelle sur la programmation générique. Le but était qu'un programmeur C++ moyen puisse écrire des concepts et des fonctions génériques de temps en temps, de la même façon que tout programmeur C++ moyen écrit des classes mères et utilise le polymorphisme de temps en temps.

    Mais bon, au vu de :
    C'était un des problèmes principaux : En l'état, les concepts étaient compliqués à comprendre. Et pas uniquement pour les développeurs de bbliothèque, mais peut être aussi pour leurs utilisateurs. Ce qui pour une fonctionnalité destinée à simplifier l'utilisation des templates pourrait sembler paradoxal.
    Ca a l'air d'avoir mechamment mal tourné quand même.

    Citation Envoyé par JolyLoic Voir le message
    Je vous tiendrai au courant dès que j'aurai vent de plans de travails pour continuer à faire avancer les concepts.
    Merci.
    En effet, que va-il se passer très concrètement maintenant ? Vu que les concepts serpentent partout dans le draft actuel, une "déconceptualisation" va prendre une energie considérable, non ?

    Si tu as d'autre infos croustillantes, n'hésite pas Loic ! Moi, je grouille d'impatience de voir ce qui va sortir du meeting de cette semaine. Avec la fin de la décennie qui approche, la fenêtre de tir pour la standardisation ISO se referme petit à petit et le comité va devoir prendre des décisions de plus en plus radicale pour terminer à temps. Et vu l'avalanche de proposal dans le mailing de juin, il y a clairement du pain sur la planche

  19. #19
    Membre actif
    Étudiant
    Inscrit en
    Octobre 2007
    Messages
    189
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2007
    Messages : 189
    Points : 214
    Points
    214
    Par défaut
    Citation Envoyé par JolyLoic Voir le message
    Avec un peu de recul, j'ai l'impression que les concepts était une tentative un peu eu... héroique/courageuse/téméraire/folle/désespéré ?
    intéressante ?
    Qu'est-ce qui change avec le recul ? C'était une tache trop grosse ? ( Je sais que je ne suis qu'un amateur ( pour le moment ) mais ça m'intéresse. )

    Citation Envoyé par JolyLoic Voir le message
    Hiura, sans rentrer dans les détails, la promesse des concepts c'était de simplifier l'utilisation des templates, d'éradiquer les messages d'erreurs de trois kilomètres et de balayer la montagne de hack horripilant (classe de traits, metaprogrammation...) qui règne à l'heure actuelle sur la programmation générique.
    Au delà du message d'erreur, c'est quand même de dire clairement avant la compilation ce qui est requis.

    Citation Envoyé par Jean-Marc.Bourguet Voir le message
    Je ne jette la pierre ni a l'amateur, ni a l'idee sous-jacente aux concepts, mais a sa realisation.
    Pourquoi ? Je veux dire : j'ai lu ( de travers ) les papiers donnés précédemment mais je n'ai rien trouvé de si compliqué, du moins rien qui ne soit inaccessible.
    Ou bien tu parles de la réalisation interne ( pas côté utilisateur donc ) ?

  20. #20
    Expert éminent

    Inscrit en
    Novembre 2005
    Messages
    5 145
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 5 145
    Points : 6 911
    Points
    6 911
    Par défaut
    Citation Envoyé par hiura Voir le message
    Au delà du message d'erreur, c'est quand même de dire clairement avant la compilation ce qui est requis.
    D'accord.

    Pourquoi ? Je veux dire : j'ai lu ( de travers ) les papiers donnés précédemment mais je n'ai rien trouvé de si compliqué, du moins rien qui ne soit inaccessible.
    Ou bien tu parles de la réalisation interne ( pas côté utilisateur donc ) ?
    Disons coté gourou à qui on vient poser les questions quand "ça ne marche pas" et qui essaye d'expliquer non seulement les règles mais leur pourquoi.

    Le texte normatif ressemble un peu trop parfois à une description fonctionnelle et pas assez à une spécification (on décrit comment plutôt que quoi).

Discussions similaires

  1. [RDF] Un littéral constante mais pas un concepts
    Par geforce dans le forum Ontologies
    Réponses: 1
    Dernier message: 12/09/2014, 18h18
  2. Je n’appréhende pas le concept GPRS
    Par Henri-gp dans le forum Arduino
    Réponses: 0
    Dernier message: 21/01/2014, 17h39
  3. [MCD] Premiers pas en conception de BDD
    Par Hildeguard dans le forum Schéma
    Réponses: 12
    Dernier message: 22/12/2010, 14h04
  4. [Conception] [débutant] Update ne marche pas
    Par yvandube dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 16/06/2006, 20h28
  5. [Conception] Pk ma valeur par defaut ne se met pas?
    Par kevinf dans le forum PHP & Base de données
    Réponses: 19
    Dernier message: 06/06/2006, 11h44

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