Bonjour,
je cherche à utiliser la méthode FileExists mais j'aimerai y ajouter un timeout de manière à ne pas passer trop de temps à chercher mon fichier...Y'a t-il une api windows qui me permette de faire quel que chose comme ça ?
Merci
Version imprimable
Bonjour,
je cherche à utiliser la méthode FileExists mais j'aimerai y ajouter un timeout de manière à ne pas passer trop de temps à chercher mon fichier...Y'a t-il une api windows qui me permette de faire quel que chose comme ça ?
Merci
Je ne comprends pas trop ta question.
Avec la fonction FileExists, tu as une réponse immédiate, le fichier il existe ou pas. Pas besoin de timeout.
Tu peux peut être regarder du côté de l'API WIN32 de gestion des fichiers (je ne sais pas d''où vienst FileExists) mais pour savoir si un fichier existe, j'utiliserai GetFileAttributes().
Cette fonction retourne une erreur si le fichier n'existe pas ou alors le type du fichier (fichier, repertoire, ...)
En fait, dans mon appli, je fais appel à FileExists (qui elle fait appel à GetFileAttributes). Le truc, c'est que le fichier que je cherche se trouve sur une bécane distante or il se peut que pour X raison, la réponse à FileExists mette du temps (pour mon cas, elle met 15 secondes à trouver mon fichier).
Il n'y a pas de FileExists dans l'API Win32 (il y en a dans la classe FileSystemObject des scripts, par contre). Serait-ce du Borland?
Je ne crois pas qu'on puisse changer ainsi le timeout d'accès à un fichier Samba distant...
Tu ne peux pas toujours agir sur le timeout du réseau, notamment si le serveur distant n'existe pas par exemple.
Une solution simple et efficace est de threader tout ça, et soit d'attendre le résultat (qui arrivera "un jour"), soit de déclarer un échec au bout de X millisecondes (ce qui est en général le cas, la réponse est habituellement instantanée en cas d'existence).
Dans tous les cas, soit tu flingues le thread au bout d'un temps spécifié, soit tu déclares l'échec et tu attends la confirmation par la suite en laissant le thread se terminer tout seul.
Merci Mac Lak...
oui Médinoc, je bosse avec Delphi (plus Borland mais CodeGear ;) )