| OLD | NEW | 
|---|
| 1 // Copyright 2015 The Crashpad Authors. All rights reserved. | 1 // Copyright 2015 The Crashpad Authors. All rights reserved. | 
| 2 // | 2 // | 
| 3 // Licensed under the Apache License, Version 2.0 (the "License"); | 3 // Licensed under the Apache License, Version 2.0 (the "License"); | 
| 4 // you may not use this file except in compliance with the License. | 4 // you may not use this file except in compliance with the License. | 
| 5 // You may obtain a copy of the License at | 5 // You may obtain a copy of the License at | 
| 6 // | 6 // | 
| 7 //     http://www.apache.org/licenses/LICENSE-2.0 | 7 //     http://www.apache.org/licenses/LICENSE-2.0 | 
| 8 // | 8 // | 
| 9 // Unless required by applicable law or agreed to in writing, software | 9 // Unless required by applicable law or agreed to in writing, software | 
| 10 // distributed under the License is distributed on an "AS IS" BASIS, | 10 // distributed under the License is distributed on an "AS IS" BASIS, | 
| 11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
| 12 // See the License for the specific language governing permissions and | 12 // See the License for the specific language governing permissions and | 
| 13 // limitations under the License. | 13 // limitations under the License. | 
| 14 | 14 | 
| 15 #ifndef CRASHPAD_UTIL_WIN_MODULE_VERSION_H_ | 15 #ifndef CRASHPAD_UTIL_WIN_CRITICAL_SECTION_WITH_DEBUG_INFO_H_ | 
| 16 #define CRASHPAD_UTIL_WIN_MODULE_VERSION_H_ | 16 #define CRASHPAD_UTIL_WIN_CRITICAL_SECTION_WITH_DEBUG_INFO_H_ | 
| 17 | 17 | 
| 18 #include <windows.h> | 18 #include <windows.h> | 
| 19 | 19 | 
| 20 #include "base/files/file_path.h" |  | 
| 21 |  | 
| 22 namespace crashpad { | 20 namespace crashpad { | 
| 23 | 21 | 
| 24 //! \brief Retrieve the type and version information from a given module (exe, | 22 //! \brief Equivalent to `InitializeCritialSection()`, but attempts to allocate | 
| 25 //!     dll, etc.) | 23 //!     with a valid `.DebugInfo` field on versions of Windows where it's | 
| 26 //! | 24 //!     possible to do so. | 
| 27 //! \param[in] path The path to the module to be inspected. |  | 
| 28 //! \param[out] vs_fixedfileinfo The VS_FIXEDFILEINFO on success. `dwFileFlags` |  | 
| 29 //!     will have been masked with `dwFileFlagsMask` already. |  | 
| 30 //! | 25 //! | 
| 31 //! \return `true` on success, or `false` on failure with a message logged. | 26 //! \return `true` on success, or `false` on failure with a message logged. | 
| 32 bool GetModuleVersionAndType(const base::FilePath& path, | 27 //!     Success means that the critical section was successfully initialized, | 
| 33                              VS_FIXEDFILEINFO* vs_fixedfileinfo); | 28 //!     but it does not necessarily have a valid `.DebugInfo` field. | 
|  | 29 bool InitializeCriticalSectionWithDebugInfoIfPossible( | 
|  | 30     CRITICAL_SECTION* critical_section); | 
| 34 | 31 | 
| 35 }  // namespace crashpad | 32 }  // namespace crashpad | 
| 36 | 33 | 
| 37 #endif  // CRASHPAD_UTIL_WIN_MODULE_VERSION_H_ | 34 #endif  // CRASHPAD_UTIL_WIN_CRITICAL_SECTION_WITH_DEBUG_INFO_H_ | 
| OLD | NEW | 
|---|