From 9f4bc95bd406adecf8803b455cb20e79f3cccadb Mon Sep 17 00:00:00 2001 From: pixel Date: Sun, 12 Oct 2003 13:51:09 +0000 Subject: Some minor fixes and improvements --- MSVC/Tools/master.mak | 4 ++-- cd-tool.cpp | 21 +++++++++++++++++++++ lib/cdabstract.cpp | 21 ++++++++++++++++++++- lib/cdreader.cpp | 6 ++++++ 4 files changed, 49 insertions(+), 3 deletions(-) diff --git a/MSVC/Tools/master.mak b/MSVC/Tools/master.mak index 11ee305..4243a99 100644 --- a/MSVC/Tools/master.mak +++ b/MSVC/Tools/master.mak @@ -48,9 +48,9 @@ _XSD=xsd.exe #define our basic link line for managed code !IFDEF DEBUG -_LINK=link.exe /INCREMENTAL /NOLOGO /DEBUG /MACHINE:I386 /NODEFAULTLIB:LIBC USER32.LIB +_LINK=link.exe /INCREMENTAL /NOLOGO /DEBUG /MACHINE:I386 /NODEFAULTLIB:LIBC !ELSE -_LINK=link.exe /INCREMENTAL /NOLOGO /MACHINE:I386 /NODEFAULTLIB:LIBCD USER32.LIB +_LINK=link.exe /INCREMENTAL /NOLOGO /MACHINE:I386 /NODEFAULTLIB:LIBCD !ENDIF #this is used for compiling C# samples diff --git a/cd-tool.cpp b/cd-tool.cpp index d5d766b..e828233 100644 --- a/cd-tool.cpp +++ b/cd-tool.cpp @@ -74,6 +74,22 @@ void showhelp(void) { "\n", argv[0]); } +void probe(void) { + std::vector p; + + if (!cdabstract::canprobe()) { + printm(M_ERROR, "Can't probe on this platform.\n"); + exit(-1); + } + + p = cdabstract::probe(); + + printm(M_BARE, "Alvaible devices:\n"); + for (std::vector::iterator i = p.begin(); i != p.end(); i++) { + printm(M_BARE, *i + "\n"); + } +} + virtual int startup() throw (GeneralException) { int type = GUESS, c, size, force = 0, sector; char * ppf = 0, * iso_name = 0, * arg1 = 0, * arg2 = 0, * f; @@ -106,6 +122,11 @@ virtual int startup() throw (GeneralException) { } iso_name = argv[optind++]; + + if (!strcmp(iso_name, "probe")) { + probe(); + exit(-1); + } if (argc == optind) { showhelp(); diff --git a/lib/cdabstract.cpp b/lib/cdabstract.cpp index f5f0d08..ce22fad 100644 --- a/lib/cdabstract.cpp +++ b/lib/cdabstract.cpp @@ -38,6 +38,7 @@ bool cdabstract::canprobe() { } std::vector cdabstract::probe() throw (GeneralException) { + int i; std::vector r; String probed; @@ -45,9 +46,27 @@ std::vector cdabstract::probe() throw (GeneralException) { throw GeneralException("Can't probe CD devices on this platform."); #ifdef __linux__ + if (subprobe(probed = "/dev/cdrom")) + r.push_back(probed); + + for (i = 0; i < 63; i++) { + probed.set("/dev/cdroms/cdrom%i", i); + if (subprobe(probed)) + r.push_back(probed); + } + for (i = 'a'; i <= 'z'; i++) { + probed.set("/dev/hd%c", i); + if (subprobe(probed)) + r.push_back(probed); + } #endif #if defined (_MSC_VER) || defined (__MINGW32__) + for (i = 'A'; i <= 'Z'; i++) { + probed.set("%c:\\", i); + if (subprobe(probed)) + r.push_back(probed); + } #endif return r; @@ -69,7 +88,7 @@ HANDLE cdabstract::OpenIOCTLFile(char cLetter) { dwFlags = GENERIC_READ | GENERIC_WRITE; // add gen write on W2k/XP else dwFlags = GENERIC_READ; - wsprintf(szFName, "\\\\.\\%c:", cLetter); + sprintf(szFName, "\\\\.\\%c:", cLetter); hF = CreateFile(szFName, dwFlags, FILE_SHARE_READ, // open drive NULL, OPEN_EXISTING, dwIOCTLAttr, NULL); diff --git a/lib/cdreader.cpp b/lib/cdreader.cpp index 5e88e98..bb785cf 100644 --- a/lib/cdreader.cpp +++ b/lib/cdreader.cpp @@ -168,6 +168,12 @@ void cdreader::getsector(void *buf, int sec) throw (GeneralException) { buf, 2352, &dwRet, NULL); if (!bStat) { DWORD dwErrCode = GetLastError(); + if (dwErrCode == ERROR_INVALID_FUNCTION) { + if (rawIOCTL.TrackMode == YellowMode2) { + rawIOCTL.TrackMode = XAForm2; + continue; + } + } if (dwErrCode != ERROR_IO_PENDING) { throw GeneralException("Gave up on reading CD"); } -- cgit v1.2.3