diff options
Diffstat (limited to 'cpp')
| -rwxr-xr-x | cpp/src/qpid/sys/windows/LockFile.cpp | 3 | ||||
| -rw-r--r-- | cpp/src/windows/QpiddBroker.cpp | 11 | 
2 files changed, 13 insertions, 1 deletions
| diff --git a/cpp/src/qpid/sys/windows/LockFile.cpp b/cpp/src/qpid/sys/windows/LockFile.cpp index 6cc710a3df..e9079b6094 100755 --- a/cpp/src/qpid/sys/windows/LockFile.cpp +++ b/cpp/src/qpid/sys/windows/LockFile.cpp @@ -43,7 +43,8 @@ LockFile::LockFile(const std::string& path_, bool create)                            create ? OPEN_ALWAYS : OPEN_EXISTING,                            FILE_FLAG_DELETE_ON_CLOSE, /* Delete file when closed */                            NULL); -    QPID_WINDOWS_CHECK_NOT(h, INVALID_HANDLE_VALUE); +    if (h == INVALID_HANDLE_VALUE) +        throw qpid::Exception(path + qpid::sys::strError(GetLastError()));      impl.reset(new LockFilePrivate(h));  } diff --git a/cpp/src/windows/QpiddBroker.cpp b/cpp/src/windows/QpiddBroker.cpp index a22ccba63f..5c6eef48f8 100644 --- a/cpp/src/windows/QpiddBroker.cpp +++ b/cpp/src/windows/QpiddBroker.cpp @@ -223,6 +223,17 @@ int QpiddBroker::execute (QpiddOptions *options) {          options->broker.port = brokerPtr->getPort("");      std::cout << options->broker.port << std::endl; +    // Make sure the pid directory exists, creating if needed. LockFile +    // will throw an exception that makes little sense if it can't create +    // the file. +    if (!CreateDirectory(myOptions->control.piddir.c_str(), 0)) { +        DWORD err = GetLastError(); +        if (err != ERROR_ALREADY_EXISTS) +            throw qpid::Exception(QPID_MSG("Can't create pid-dir " + +                                           myOptions->control.piddir + +                                           ": " + +                                           qpid::sys::strError(err))); +    }      qpid::sys::LockFile myPid(brokerPidFile(myOptions->control.piddir,                                              options->broker.port),                                true); | 
