Précédent   Forum des professionnels en informatique > Systèmes > Linux > Applications > Shell
Shell Vos questions sur l'utilisation des commandes shell
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 14/01/2011, 00h22   #1
Invité régulier
 
Inscription : mai 2009
Messages : 25
Détails du profil
Informations forums :
Inscription : mai 2009
Messages : 25
Points : 7
Points : 7
Par défaut Algorithme commande find (Unix)

Bonjour à tous,
J'ai cherché une documentation sur la commande find, j'en ai trouvé des dizaines, mais j'ai voulu connaitre le principe de fonctionnement de cette commande, et là j'ai rien trouvé. Mon but est de créer une commande presque similaire à la commande find, mais à partir de zero, et ce en langage C. Est-ce qu'il y aurait quelqu'un qui a une documentation sur cette commande ? je parle de son principe, et/ou son algorithme, car le code source je l'ai mais j'ai rien compris dedans :p. Merci beaucoup pour vos réponses.
Malek_moly est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/01/2011, 01h49   #2
Membre Expert
 
Étudiant
Inscription : août 2004
Messages : 500
Détails du profil
Informations personnelles :
Âge : 22

Informations professionnelles :
Activité : Étudiant

Informations forums :
Inscription : août 2004
Messages : 500
Points : 1 017
Points : 1 017
Envoyer un message via MSN à Senaku-seishin
La commande find est un ls, qui filtre le résulta selon des arguments, comme la date etc... Voici un début :

Code :
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
43
#include
#include
#include
#include
<dirent.h>
<regex.h>
<stdio.h>
<stdlib.h>
regex_t motif_recherche;
int
selection(const struct dirent * entree)
{
if (regexec(& motif_recherche, entree -> d_name, 0, NULL, 0) == 0)
return 1;
return 0;
}
int
main (int argc, char * argv[])
{
struct dirent ** liste;
int
nb_entrees;
int
i;
if (argc != 3) {
fprintf(stderr, "Syntaxe : %s répertoire motif\n", argv [0]);
exit(EXIT_FAILURE);
}
if (regcomp(& motif_recherche, argv[2], REG_NOSUB) !=0) {
fprintf(stderr, "Motif illégal\n");
exit(EXIT_FAILURE);
}
nb_entrees = scandir(argv[1], & liste, selection, alphasort);
if (nb_entrees <= 0)
exit(EXIT_SUCCESS);
for (i = 0; i < nb_entrees; i ++) {
fprintf(stdout, " %s\n", liste[i]->d_name);
free(liste[i]);
}
fprintf(stdout, "\n");
free(liste);
return EXIT_SUCCESS;
}
Source : Programmation C sous Linux, édition Eyerolles.

Si tu souhaite plus de détail sur ce bout de code, n'hésite pas
__________________
Avoir un regard neutre sur notre vie dénuée de sens, c'est la voir tel un ignorant
Senaku-seishin est déconnecté   Envoyer un message privé Réponse avec citation 20
Vieux 14/01/2011, 09h58   #3
Invité régulier
 
Inscription : mai 2009
Messages : 25
Détails du profil
Informations forums :
Inscription : mai 2009
Messages : 25
Points : 7
Points : 7
Merci beaucoup pour ta réponse Senaku-seishin,
J'aimerai bien avoir plus d'explications si c'est possible, merci Je pense que le faite que je sois un peu débutant m'a empéché de bien comprendre ... Je veux juste connaitre le principe comme une analyse procédurale ou modulaire si c'est possible. Merci encore une fois de m'avoir répondu !!
Malek_moly est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/01/2011, 18h51   #4
Membre Expert
 
Étudiant
Inscription : août 2004
Messages : 500
Détails du profil
Informations personnelles :
Âge : 22

Informations professionnelles :
Activité : Étudiant

Informations forums :
Inscription : août 2004
Messages : 500
Points : 1 017
Points : 1 017
Envoyer un message via MSN à Senaku-seishin
Citation:
Je veux juste connaitre le principe comme une analyse procédurale ou modulaire si c'est possible.
Tu veux la logique d'une commande find?
  1. Analyse des arguments. Voir : getopt
  2. Listé les fichiers des répertoires - récursif - dans une pile
  3. Filtré la pile selon les critères demandé.
  4. Trie de la pile
  5. Affiché le contenus de la pile. Voir fprintf

On fusionne généralement l'étape 2 et 3.
Regarde du côté de scandir. Il lit le contenu d'un répertoire, filtre et trie mais non récursif. Ou utilise nftw, récursif mais sans trie.

Le filtre dépendra des critères que tu voudra.
__________________
Avoir un regard neutre sur notre vie dénuée de sens, c'est la voir tel un ignorant
Senaku-seishin est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/01/2011, 19h46   #5
Invité régulier
 
Inscription : mai 2009
Messages : 25
Détails du profil
Informations forums :
Inscription : mai 2009
Messages : 25
Points : 7
Points : 7
Merci beaucoup Senaku-seishin pour ta réponse C'est ce que je voulais effectivement, une analyse logique, je me suis mal exprimé au début Encore merci pour ton aide précieuse !!
Malek_moly est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 00h32.


 
 
 
 
Partenaires

Hébergement Web