pdb_source_line_writer.h.svn-base
来自「SumatraPDF是一款小型开源的pdf阅读工具。虽然玲珑小巧(只有800多K」· SVN-BASE 代码 · 共 164 行
SVN-BASE
164 行
// Copyright (c) 2006, Google Inc.// All rights reserved.//// Redistribution and use in source and binary forms, with or without// modification, are permitted provided that the following conditions are// met://// * Redistributions of source code must retain the above copyright// notice, this list of conditions and the following disclaimer.// * Redistributions in binary form must reproduce the above// copyright notice, this list of conditions and the following disclaimer// in the documentation and/or other materials provided with the// distribution.// * Neither the name of Google Inc. nor the names of its// contributors may be used to endorse or promote products derived from// this software without specific prior written permission.//// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.// PDBSourceLineWriter uses a pdb file produced by Visual C++ to output// a line/address map for use with BasicSourceLineResolver.#ifndef _PDB_SOURCE_LINE_WRITER_H__#define _PDB_SOURCE_LINE_WRITER_H__#include <atlcomcli.h>#include <string>struct IDiaEnumLineNumbers;struct IDiaSession;struct IDiaSymbol;namespace google_breakpad {using std::wstring;// A structure that carries information that identifies a pdb file.struct PDBModuleInfo { public: // The basename of the pdb file from which information was loaded. wstring debug_file; // The pdb's identifier. For recent pdb files, the identifier consists // of the pdb's guid, in uppercase hexadecimal form without any dashes // or separators, followed immediately by the pdb's age, also in // uppercase hexadecimal form. For older pdb files which have no guid, // the identifier is the pdb's 32-bit signature value, in zero-padded // hexadecimal form, followed immediately by the pdb's age, in lowercase // hexadecimal form. wstring debug_identifier; // A string identifying the cpu that the pdb is associated with. // Currently, this may be "x86" or "unknown". wstring cpu;};class PDBSourceLineWriter { public: enum FileFormat { PDB_FILE, // a .pdb file containing debug symbols EXE_FILE, // a .exe or .dll file ANY_FILE // try PDB_FILE and then EXE_FILE }; explicit PDBSourceLineWriter(); ~PDBSourceLineWriter(); // Opens the given file. For executable files, the corresponding pdb // file must be available; Open will be if it is not. // If there is already a pdb file open, it is automatically closed. // Returns true on success. bool Open(const wstring &file, FileFormat format); // Locates the pdb file for the given executable (exe or dll) file, // and opens it. If there is already a pdb file open, it is automatically // closed. Returns true on success. bool OpenExecutable(const wstring &exe_file); // Writes a map file from the current pdb file to the given file stream. // Returns true on success. bool WriteMap(FILE *map_file); // Closes the current pdb file and its associated resources. void Close(); // Retrieves information about the module's debugging file. Returns // true on success and false on failure. bool GetModuleInfo(PDBModuleInfo *info); // Sets uses_guid to true if the opened file uses a new-style CodeView // record with a 128-bit GUID, or false if the opened file uses an old-style // CodeView record. When no GUID is available, a 32-bit signature should be // used to identify the module instead. If the information cannot be // determined, this method returns false. bool UsesGUID(bool *uses_guid); private: // Outputs the line/address pairs for each line in the enumerator. // Returns true on success. bool PrintLines(IDiaEnumLineNumbers *lines); // Outputs a function address and name, followed by its source line list. // Returns true on success. bool PrintFunction(IDiaSymbol *function); // Outputs all functions as described above. Returns true on success. bool PrintFunctions(); // Outputs all of the source files in the session's pdb file. // Returns true on success. bool PrintSourceFiles(); // Outputs all of the frame information necessary to construct stack // backtraces in the absence of frame pointers. Returns true on success. bool PrintFrameData(); // Outputs a single public symbol address and name, if the symbol corresponds // to a code address. Returns true on success. If symbol is does not // correspond to code, returns true without outputting anything. bool PrintCodePublicSymbol(IDiaSymbol *symbol); // Outputs a line identifying the PDB file that is being dumped, along with // its uuid and age. bool PrintPDBInfo(); // Returns the function name for a symbol. If possible, the name is // undecorated. If the symbol's decorated form indicates the size of // parameters on the stack, this information is returned in stack_param_size. // Returns true on success. If the symbol doesn't encode parameter size // information, stack_param_size is set to -1. static bool GetSymbolFunctionName(IDiaSymbol *function, BSTR *name, int *stack_param_size); // Returns the number of bytes of stack space used for a function's // parameters. function must have the tag SymTagFunction. In the event of // a failure, returns 0, which is also a valid number of bytes. static int GetFunctionStackParamSize(IDiaSymbol *function); // The session for the currently-open pdb file. CComPtr<IDiaSession> session_; // The current output file for this WriteMap invocation. FILE *output_; // Disallow copy ctor and operator= PDBSourceLineWriter(const PDBSourceLineWriter&); void operator=(const PDBSourceLineWriter&);};} // namespace google_breakpad#endif // _PDB_SOURCE_LINE_WRITER_H__
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?