Jump to content

Recommended Posts

Posted (edited)

Hi,

this is strange:

Since AutoIt V3.3.8.0 the function DriveStatus() always returns "INVALID" for any given EXISTING path - at least on my computer (MS Windows 7 X86). The older version 3.3.6.1 works fine...

Here's a reproducer:

MsgBox(0, "", DriveStatus(@TempDir & ""))

Do I something wrong?

Greets,

-supersonic.

Edited by supersonic
  • Moderators
Posted

supersonic,

It does say the parameter should be "Path of drive" - and it works when you use the drive letter and colon alone: :)

ConsoleWrite(DriveStatus("C:Temp") & @CRLF)
ConsoleWrite(DriveStatus("C:") & @CRLF)
ConsoleWrite(DriveStatus("C") & @CRLF)

And before you ask you can get the drive from a path like this: ;)

$sPath = "C:Temp"
$sDrive = StringRegExpReplace($sPath, ":.*$", ":")
ConsoleWrite($sDrive & @CRLF)

M23

Public_Domain.png.2d871819fcb9957cf44f4514551a2935.png Any of my own code posted anywhere on the forum is available for use by others without any restriction of any kind

Open spoiler to see my UDFs:

  Reveal hidden contents

 

Posted

It appears that the function has been changed in 3.3.8.0 from the way it worked before.

Regardless, I'd use FileExists to see if a path exists rather than DriveGetStatus as it's probably more reliable to use the function designed for such checks.

If I posted any code, assume that code was written using the latest release version unless stated otherwise. Also, if it doesn't work on XP I can't help with that because I don't have access to XP, and I'm not going to.
Give a programmer the correct code and he can do his work for a day. Teach a programmer to debug and he can do his work for a lifetime - by Chirag Gude
How to ask questions the smart way!

  Reveal hidden contents

I hereby grant any person the right to use any code I post, that I am the original author of, on the autoitscript.com forums, unless I've specifically stated otherwise in the code or the thread post. If you do use my code all I ask, as a courtesy, is to make note of where you got it from.

Back up and restore Windows user files _Array.au3 - Modified array functions that include support for 2D arrays.  -  ColorChooser - An add-on for SciTE that pops up a color dialog so you can select and paste a color code into a script.  -  Customizable Splashscreen GUI w/Progress Bar - Create a custom "splash screen" GUI with a progress bar and custom label.  -  _FileGetProperty - Retrieve the properties of a file  -  SciTE Toolbar - A toolbar demo for use with the SciTE editor  -  GUIRegisterMsg demo - Demo script to show how to use the Windows messages to interact with controls and your GUI.  -   Latin Square password generator

Posted

melba,

thank you for the reply.

Hmm... The remarks say: "DriveStatus may even work when a complete directory path [...]".

So, DriveStatus("C:TEMP") should work - shouldn't it?

Posted (edited)

BrewManNH,

in fact, we had to assume that the function has been changed.

Is this change documented somewhere?

EDIT:

I will give FileExists() a chance...

Edited by supersonic
Posted

There's a documented bug fix for DriveStatus for using it with a blank string, which probably affected using it with a path other than just a drive path. The remarks say "DriveStatus may even work " which means it may not work, and as you found out, it doesn't.

DriveStatus is to be used to check the status of a drive, FileExists is used to check the existence of a file/folder/drive path, I'd use that to make sure it exists because folders technically don't have statuses.

If I posted any code, assume that code was written using the latest release version unless stated otherwise. Also, if it doesn't work on XP I can't help with that because I don't have access to XP, and I'm not going to.
Give a programmer the correct code and he can do his work for a day. Teach a programmer to debug and he can do his work for a lifetime - by Chirag Gude
How to ask questions the smart way!

  Reveal hidden contents

I hereby grant any person the right to use any code I post, that I am the original author of, on the autoitscript.com forums, unless I've specifically stated otherwise in the code or the thread post. If you do use my code all I ask, as a courtesy, is to make note of where you got it from.

Back up and restore Windows user files _Array.au3 - Modified array functions that include support for 2D arrays.  -  ColorChooser - An add-on for SciTE that pops up a color dialog so you can select and paste a color code into a script.  -  Customizable Splashscreen GUI w/Progress Bar - Create a custom "splash screen" GUI with a progress bar and custom label.  -  _FileGetProperty - Retrieve the properties of a file  -  SciTE Toolbar - A toolbar demo for use with the SciTE editor  -  GUIRegisterMsg demo - Demo script to show how to use the Windows messages to interact with controls and your GUI.  -   Latin Square password generator

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
  • Recently Browsing   0 members

    • No registered users viewing this page.
×
×
  • Create New...