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

 C Discussion :

récupérer nom de fichier en stdin


Sujet :

C

  1. #1
    Membre régulier Avatar de J4e8a16n
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    271
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 271
    Points : 119
    Points
    119
    Par défaut récupérer nom de fichier en stdin
    Bonjour à tous,

    Peut-on récupérer le nom d'un fichier redirigé en stdin sans utiliser argv?

    monexe < nomdufichier.txt

    Petit Malin
    "accélérateur . . . qui pousse . . . un électron a passer par deux trous d’un écran en même temps." (Cyrille Burt: "C’est mieux qu’un fantôme") (Janus p.251)
    "Joy is to love what is, pain is to love what is not"
    )

    HP Pavilion Elite Desktop PC 570-p0xx - Window10 64 bits - Intel(R) Core(TM)2 Quad CPU Q8200 @ 3GHz x86_64-w64-mingw32-gcc-7.3.0.exe

  2. #2
    Membre expérimenté Avatar de plxpy
    Homme Profil pro
    Ingénieur géographe
    Inscrit en
    Janvier 2009
    Messages
    792
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 59
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur géographe
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Janvier 2009
    Messages : 792
    Points : 1 481
    Points
    1 481
    Par défaut
    Sous Unix/Linux, j'ai bien peur que non.

    C'est le shell depuis lequel tu tapes cette ligne de commande qui voit "<nomdufichier.txt", ouvre le fichier et écrit son contenu sur l'entrée standard de "monexe" (qu'il lance au préalable).

    "monexe" n'a aucune connaissance du (nom du) fichier utilisé (argc vaut 1 et argv[0], "monexe"). Avec la banalisation des fichiers sous Unix/Linux, "monexe" n'a aucun moyen de faire la différence entre la redirection que tu utilises et des "choses" que tu taperais au clavier (jusqu'à un CTRL-D qui marque la fin de fichier).
    "La simplicité ne précède pas la complexité, elle la suit." - Alan J. Perlis
    DVP ? Pensez aux cours et tutos, ainsi qu'à la FAQ !

  3. #3
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Sous un Windows récent, il doit y avoir moyen de tricher, mais c'est le genre de chose que tu n'es pas censé faire.

    Quel est ton problème exactement?
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  4. #4
    Invité(e)
    Invité(e)
    Par défaut
    Bonjour,
    Sous linux, le répertoire /proc/numero_du_process peut donner ce genre d'informations.

  5. #5
    Rédacteur

    Avatar de ram-0000
    Homme Profil pro
    Consultant en sécurité
    Inscrit en
    Mai 2007
    Messages
    11 517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant en sécurité
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2007
    Messages : 11 517
    Points : 50 367
    Points
    50 367
    Par défaut
    Tu ne peux pas à moins de tricher. C'est le rôle du shell que de mettre le contenu du fichier dans le flux stdin.

    et imagine une commande genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    monexe < `cat fichier.txt | grep "toto"`
    Tu vas récupérer quoi ?
    Est-ce que ce que tu risques de récupérer (peut être) aura un sens ?
    Raymond
    Vous souhaitez participer à la rubrique Réseaux ? Contactez-moi

    Cafuro Cafuro est un outil SNMP dont le but est d'aider les administrateurs système et réseau à configurer leurs équipements SNMP réseau.
    e-verbe Un logiciel de conjugaison des verbes de la langue française.

    Ma page personnelle sur DVP
    .

  6. #6
    Expert éminent
    Avatar de Melem
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2006
    Messages
    3 656
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Janvier 2006
    Messages : 3 656
    Points : 8 389
    Points
    8 389
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    Sous un Windows récent, il doit y avoir moyen de tricher, mais c'est le genre de chose que tu n'es pas censé faire.
    GetCommandLine retourne la ligne de commande entière. Je ne sais pas si le &lt; ... fait aussi partie de la "ligne de commande". A vérifier.

  7. #7
    Rédacteur

    Avatar de ram-0000
    Homme Profil pro
    Consultant en sécurité
    Inscrit en
    Mai 2007
    Messages
    11 517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant en sécurité
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2007
    Messages : 11 517
    Points : 50 367
    Points
    50 367
    Par défaut
    Citation Envoyé par Melem Voir le message
    GetCommandLine retourne la ligne de commande entière. Je ne sais pas si le &lt; ... fait aussi partie de la "ligne de commande". A vérifier.
    Non, à partir du signe <, c'est géré par le shell et donc cela ne va pas au programme appelé. Exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    #include <Windows.h>
    int _tmain(int argc, _TCHAR* argv[])
    {
    	const wchar_t *cmd = GetCommandLine();
    	_tprintf(L"Command = [%s]\n", cmd);
    	return 0;
    }
    pour
    console.exe < fichier_qui_existe.txt
    cela donne:Je pense qu'il n'y a pas moyen de récupérer la commande complète dans ce cas là (sauf à tricher avec le système)
    Raymond
    Vous souhaitez participer à la rubrique Réseaux ? Contactez-moi

    Cafuro Cafuro est un outil SNMP dont le but est d'aider les administrateurs système et réseau à configurer leurs équipements SNMP réseau.
    e-verbe Un logiciel de conjugaison des verbes de la langue française.

    Ma page personnelle sur DVP
    .

  8. #8
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    En fait, je pensais plutôt à GetFileInformationByHandle() sur le handle de l'entrée standard...
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  9. #9
    Expert éminent
    Avatar de Melem
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2006
    Messages
    3 656
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Janvier 2006
    Messages : 3 656
    Points : 8 389
    Points
    8 389
    Par défaut
    Citation Envoyé par ram-0000
    Non, à partir du signe <, c'est géré par le shell et donc cela ne va pas au programme appelé.
    Oui je sais. Ce dont je n'étais pas sûr c'est si GetCommandLine retournait la ligne de commande telle que tapée dans le shell ou la "vraie ligne de commandes" (chemin de l'exe + arguments). Maintenant, nous savons que c'est la seconde .

  10. #10
    Membre expérimenté Avatar de plxpy
    Homme Profil pro
    Ingénieur géographe
    Inscrit en
    Janvier 2009
    Messages
    792
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 59
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur géographe
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Janvier 2009
    Messages : 792
    Points : 1 481
    Points
    1 481
    Par défaut
    Pour Linux, mabu m'a filé le doute avec le pseudo file system /proc mais ce que j'avançais et ce que ram-0000 confirmait n'est pas mis en défaut.

    J'ai écrit quelques lignes de code, autant vous en faire profiter :

    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
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
     
    #include <stdio.h>
    #include <stdlib.h>
    #include <sys/types.h>
    #include <unistd.h>
     
    int main(int argc,char *argv[])
    {
        char   commande[128];
        char   cmdname[64];
        char  *ptr = commande;
        FILE  *cmdfp;
        pid_t  pid = getpid();
        int i;
     
        sprintf(cmdname,"/proc/%lu/cmdline",(unsigned long)pid);
        cmdfp = fopen(cmdname,"r");
        fgets(commande,128,cmdfp);
        fclose(cmdfp);
     
        /*************************
     
        resultat (partiel) de "man proc"
     
           /proc/[number]/cmdline
                  This holds the complete command line for the process, unless the
                  process is a zombie.  In the latter case, there  is  nothing  in
                  this  file:  that  is, a read on this file will return 0 charac‐
                  ters.  The command-line arguments appear in this file as  a  set
                  of null-separated strings, with a further null byte ('\0') after
                  the last string.
     
        **************************/
     
        for (i=0;;i++)
        {
            printf("arg %d : %s\n",i,ptr);
            ptr = strchr(ptr,'\0');
            if (ptr[1] == '\0') break;
            else                ptr++;
        }
    }

    Voici différents résultats, sous Ubuntu (mon exe s'appelle "stdin") :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    plx@sony:~$ ./stdin un 2 trois 4
    arg 0 : ./stdin
    arg 1 : un
    arg 2 : 2
    arg 3 : trois
    arg 4 : 4
    plx@sony:~$ ./stdin 1 deux 3 quatre < stdin.c
    arg 0 : ./stdin
    arg 1 : 1
    arg 2 : deux
    arg 3 : 3
    arg 4 : quatre
    On ne récupère pas plus de choses en allant chercher sous /proc qu'en examinant argc/argv.

    Pour continuer sur ce sujet, ce n'est pas seulement les redirections qui ne sont pas vues par l'exécutable mais aussi tous les "wild-cards" (*, ?, etc...) qui sont traités par le "shell interactif" et c'est pour cela que sous DOS, il y a bien longtemps (je n'ai pas réessayé depuis), un "del *.*" demandait confirmation ("del" voyait le "*.*") et que, sous Linux/Unix, 'un "rm *" ne POUVAIT pas faire la différence entre "rm *" et "rm" suivi de tous les fichiers du répertoire courant.
    "La simplicité ne précède pas la complexité, elle la suit." - Alan J. Perlis
    DVP ? Pensez aux cours et tutos, ainsi qu'à la FAQ !

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

Discussions similaires

  1. récupérer noms des fichiers d'un repertoire
    Par Sun03 dans le forum PL/SQL
    Réponses: 6
    Dernier message: 26/01/2010, 18h32
  2. Récupérer nom des fichiers de données
    Par Milo59000 dans le forum SQL
    Réponses: 10
    Dernier message: 20/05/2008, 15h07
  3. récupérer nom de fichier sans l'extension
    Par ynk68 dans le forum Shell et commandes GNU
    Réponses: 6
    Dernier message: 28/09/2007, 06h38
  4. [VBA-E] récupérer nom utilisateur fichier en lecture seule
    Par cwain dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 23/01/2007, 15h46

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