crashpad/doc/generated/doxygen/namespacecrashpad.html
2016-11-11 12:39:21 -05:00

6490 lines
515 KiB
HTML
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
<meta name="generator" content="Doxygen 1.8.12"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>Crashpad: crashpad Namespace Reference</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="dynsections.js"></script>
<link href="search/search.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="search/searchdata.js"></script>
<script type="text/javascript" src="search/search.js"></script>
<link href="doxygen.css" rel="stylesheet" type="text/css" />
<link href="crashpad_doxygen.css" rel="stylesheet" type="text/css"/>
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
<tbody>
<tr style="height: 56px;">
<td id="projectalign" style="padding-left: 0.5em;">
<div id="projectname">Crashpad
</div>
</td>
</tr>
</tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.12 -->
<script type="text/javascript">
var searchBox = new SearchBox("searchBox", "search",false,'Search');
</script>
<script type="text/javascript" src="menudata.js"></script>
<script type="text/javascript" src="menu.js"></script>
<script type="text/javascript">
$(function() {
initMenu('',true,false,'search.php','Search');
$(document).ready(function() { init_search(); });
});
</script>
<div id="main-nav"></div>
<!-- window showing the filter options -->
<div id="MSearchSelectWindow"
onmouseover="return searchBox.OnSearchSelectShow()"
onmouseout="return searchBox.OnSearchSelectHide()"
onkeydown="return searchBox.OnSearchSelectKey(event)">
</div>
<!-- iframe showing the search results (closed by default) -->
<div id="MSearchResultsWindow">
<iframe src="javascript:void(0)" frameborder="0"
name="MSearchResults" id="MSearchResults">
</iframe>
</div>
</div><!-- top -->
<div class="header">
<div class="summary">
<a href="#namespaces">Namespaces</a> &#124;
<a href="#nested-classes">Classes</a> &#124;
<a href="#typedef-members">Typedefs</a> &#124;
<a href="#enum-members">Enumerations</a> &#124;
<a href="#func-members">Functions</a> &#124;
<a href="#var-members">Variables</a> </div>
<div class="headertitle">
<div class="title">crashpad Namespace Reference</div> </div>
</div><!--header-->
<div class="contents">
<p>The main namespace.
<a href="#details">More...</a></p>
<table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="namespaces"></a>
Namespaces</h2></td></tr>
<tr class="memitem:namespacecrashpad_1_1internal"><td class="memItemLeft" align="right" valign="top"> &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad_1_1internal.html">internal</a></td></tr>
<tr class="memdesc:namespacecrashpad_1_1internal"><td class="mdescLeft">&#160;</td><td class="mdescRight">The internal namespace, not for public use. <br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:namespacecrashpad_1_1test"><td class="memItemLeft" align="right" valign="top"> &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad_1_1test.html">test</a></td></tr>
<tr class="memdesc:namespacecrashpad_1_1test"><td class="mdescLeft">&#160;</td><td class="mdescRight">The testing namespace, for use in test code only. <br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="nested-classes"></a>
Classes</h2></td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1AgePruneCondition.html">AgePruneCondition</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A <a class="el" href="classcrashpad_1_1PruneCondition.html" title="An abstract base class for evaluating crash reports for deletion. ">PruneCondition</a> that deletes reports older than the specified number days. <a href="classcrashpad_1_1AgePruneCondition.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1AlignedAllocator.html">AlignedAllocator</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A standard allocator that aligns its allocations as requested, suitable for use as an allocator in standard containers. <a href="structcrashpad_1_1AlignedAllocator.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1BinaryPruneCondition.html">BinaryPruneCondition</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A <a class="el" href="classcrashpad_1_1PruneCondition.html" title="An abstract base class for evaluating crash reports for deletion. ">PruneCondition</a> that conjoins two other PruneConditions. <a href="classcrashpad_1_1BinaryPruneCondition.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1CheckedRange.html">CheckedRange</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Ensures that a range, composed of a base and size, does not overflow its data type. <a href="classcrashpad_1_1CheckedRange.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1ChildPortHandshake.html">ChildPortHandshake</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Implements a handshake protocol that allows processes to exchange port rights. <a href="classcrashpad_1_1ChildPortHandshake.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1ChildPortServer.html">ChildPortServer</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A server interface for the <code>child_port</code> Mach subsystem. <a href="classcrashpad_1_1ChildPortServer.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1ClientToServerMessage.html">ClientToServerMessage</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The message passed from client to server by <a class="el" href="namespacecrashpad.html#a638d7916642f81df8063d300f08ff2ca" title="Connect over the given pipe_name, passing message to the server, storing the server&#39;s reply into resp...">SendToCrashHandlerServer()</a>. <a href="structcrashpad_1_1ClientToServerMessage.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1CodeViewRecordPDB20.html">CodeViewRecordPDB20</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A CodeView record linking to a <code>.pdb</code> 2.0 file. <a href="structcrashpad_1_1CodeViewRecordPDB20.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1CodeViewRecordPDB70.html">CodeViewRecordPDB70</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A CodeView record linking to a <code>.pdb</code> 7.0 file. <a href="structcrashpad_1_1CodeViewRecordPDB70.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1CompositeHTTPBodyStream.html">CompositeHTTPBodyStream</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">An implementation of <a class="el" href="classcrashpad_1_1HTTPBodyStream.html" title="An interface to a stream that can be used for an HTTP request body. ">HTTPBodyStream</a> that combines an array of several other <a class="el" href="classcrashpad_1_1HTTPBodyStream.html" title="An interface to a stream that can be used for an HTTP request body. ">HTTPBodyStream</a> objects into a single, unified stream. <a href="classcrashpad_1_1CompositeHTTPBodyStream.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1CompositeMachMessageServer.html">CompositeMachMessageServer</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Adapts multiple <a class="el" href="classcrashpad_1_1MachMessageServer_1_1Interface.html" title="A Mach RPC callback interface, called by Run(). ">MachMessageServer::Interface</a> implementations for simultaneous use in a single <a class="el" href="classcrashpad_1_1MachMessageServer.html#ace981f2e495984f119aa074f7d33bff6" title="Runs a Mach message server to handle a Mach RPC request for MIG servers. ">MachMessageServer::Run()</a> call. <a href="classcrashpad_1_1CompositeMachMessageServer.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1CPUContext.html">CPUContext</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A context structure capable of carrying the context of any supported CPU architecture. <a href="structcrashpad_1_1CPUContext.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1CPUContextX86.html">CPUContextX86</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A context structure carrying 32-bit x86 CPU state. <a href="structcrashpad_1_1CPUContextX86.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1CPUContextX86__64.html">CPUContextX86_64</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A context structure carrying x86_64 CPU state. <a href="structcrashpad_1_1CPUContextX86__64.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1CrashpadClient.html">CrashpadClient</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The primary interface for an application to have Crashpad monitor it for crashes. <a href="classcrashpad_1_1CrashpadClient.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1CrashpadInfo.html">CrashpadInfo</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A structure that can be used by a Crashpad-enabled program to provide information to the Crashpad crash handler. <a href="structcrashpad_1_1CrashpadInfo.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1CrashpadInfoClientOptions.html">CrashpadInfoClientOptions</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Options represented in a clients <a class="el" href="structcrashpad_1_1CrashpadInfo.html" title="A structure that can be used by a Crashpad-enabled program to provide information to the Crashpad cra...">CrashpadInfo</a> structure. <a href="structcrashpad_1_1CrashpadInfoClientOptions.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1CrashReportDatabase.html">CrashReportDatabase</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">An interface for managing a collection of crash report files and metadata associated with the crash reports. <a href="classcrashpad_1_1CrashReportDatabase.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1CrashReportExceptionHandler.html">CrashReportExceptionHandler</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">An exception handler that writes crash reports for exception messages to a <a class="el" href="classcrashpad_1_1CrashReportDatabase.html" title="An interface for managing a collection of crash report files and metadata associated with the crash r...">CrashReportDatabase</a>. <a href="classcrashpad_1_1CrashReportExceptionHandler.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1CrashReportUploadThread.html">CrashReportUploadThread</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A thread that processes pending crash reports in a <a class="el" href="classcrashpad_1_1CrashReportDatabase.html" title="An interface for managing a collection of crash report files and metadata associated with the crash r...">CrashReportDatabase</a> by uploading them or marking them as completed without upload, as desired. <a href="classcrashpad_1_1CrashReportUploadThread.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1DatabaseSizePruneCondition.html">DatabaseSizePruneCondition</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A <a class="el" href="classcrashpad_1_1PruneCondition.html" title="An abstract base class for evaluating crash reports for deletion. ">PruneCondition</a> that deletes older reports to keep the total Crashpad database size under the specified limit. <a href="classcrashpad_1_1DatabaseSizePruneCondition.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1ExceptionHandlerServer.html">ExceptionHandlerServer</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Runs the main exception-handling server in Crashpads handler process. <a href="classcrashpad_1_1ExceptionHandlerServer.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1ExceptionInformation.html">ExceptionInformation</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Structure read out of the client process by the crash handler when an exception occurs. <a href="structcrashpad_1_1ExceptionInformation.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1ExceptionPorts.html">ExceptionPorts</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A better interface to <code>*_get_exception_ports()</code> and <code>*_set_exception_ports()</code>. <a href="classcrashpad_1_1ExceptionPorts.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1ExceptionSnapshot.html">ExceptionSnapshot</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">An abstract interface to a snapshot representing an exception that a snapshot process sustained and triggered the snapshot being taken. <a href="classcrashpad_1_1ExceptionSnapshot.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1FileHTTPBodyStream.html">FileHTTPBodyStream</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">An implementation of <a class="el" href="classcrashpad_1_1HTTPBodyStream.html" title="An interface to a stream that can be used for an HTTP request body. ">HTTPBodyStream</a> that reads from the specified file and provides its contents for an HTTP body. <a href="classcrashpad_1_1FileHTTPBodyStream.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1FileReader.html">FileReader</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A file reader implementation that wraps traditional system file operations on files accessed through the filesystem. <a href="classcrashpad_1_1FileReader.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1FileReaderInterface.html">FileReaderInterface</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">An interface to read to files and other file-like objects with semantics matching the underlying platform (POSIX or Windows). <a href="classcrashpad_1_1FileReaderInterface.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1FileSeekerInterface.html">FileSeekerInterface</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">An interface to seek in files and other file-like objects with semantics matching the underlying platform (POSIX or Windows). <a href="classcrashpad_1_1FileSeekerInterface.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1FileWriter.html">FileWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A file writer implementation that wraps traditional system file operations on files accessed through the filesystem. <a href="classcrashpad_1_1FileWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1FileWriterInterface.html">FileWriterInterface</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">An interface to write to files and other file-like objects with semantics matching the underlying platform (POSIX or Windows). <a href="classcrashpad_1_1FileWriterInterface.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1HandleSnapshot.html">HandleSnapshot</a></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1HTTPBodyStream.html">HTTPBodyStream</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">An interface to a stream that can be used for an HTTP request body. <a href="classcrashpad_1_1HTTPBodyStream.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1HTTPMultipartBuilder.html">HTTPMultipartBuilder</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">This class is used to build a MIME multipart message, conforming to RFC 2046, for use as a HTTP request body. <a href="classcrashpad_1_1HTTPMultipartBuilder.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1HTTPTransport.html">HTTPTransport</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight"><a class="el" href="classcrashpad_1_1HTTPTransport.html" title="HTTPTransport executes a HTTP request using the specified URL, HTTP method, headers, and body. This class can only issue a synchronous HTTP request. ">HTTPTransport</a> executes a HTTP request using the specified URL, HTTP method, headers, and body. This class can only issue a synchronous HTTP request. <a href="classcrashpad_1_1HTTPTransport.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1InitialClientData.html">InitialClientData</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A container for the data associated with the <code>--initial-client-data</code> method for initializing the handler process on Windows. <a href="classcrashpad_1_1InitialClientData.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1InitializationState.html">InitializationState</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Tracks whether data are initialized. <a href="classcrashpad_1_1InitializationState.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1InitializationStateDcheck.html">InitializationStateDcheck</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Tracks whether data are initialized, triggering a DCHECK assertion on an invalid data access. <a href="classcrashpad_1_1InitializationStateDcheck.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MachMessageServer.html">MachMessageServer</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Runs a Mach message server to handle a Mach RPC request for MIG servers. <a href="classcrashpad_1_1MachMessageServer.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MachOImageAnnotationsReader.html">MachOImageAnnotationsReader</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A reader for annotations stored in a Mach-O image mapped into another process. <a href="classcrashpad_1_1MachOImageAnnotationsReader.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MachOImageReader.html">MachOImageReader</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A reader for Mach-O images mapped into another process. <a href="classcrashpad_1_1MachOImageReader.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MachOImageSegmentReader.html">MachOImageSegmentReader</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A reader for <code>LC_SEGMENT</code> or <code>LC_SEGMENT_64</code> load commands in Mach-O images mapped into another process. <a href="classcrashpad_1_1MachOImageSegmentReader.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MachOImageSymbolTableReader.html">MachOImageSymbolTableReader</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A reader for symbol tables in Mach-O images mapped into another process. <a href="classcrashpad_1_1MachOImageSymbolTableReader.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MemoryMapRegionSnapshot.html">MemoryMapRegionSnapshot</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">An abstract interface to a snapshot representing a region of the memory map present in the snapshot process. <a href="classcrashpad_1_1MemoryMapRegionSnapshot.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MemorySnapshot.html">MemorySnapshot</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">An abstract interface to a snapshot representing a region of memory present in a snapshot process. <a href="classcrashpad_1_1MemorySnapshot.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1Metrics.html">Metrics</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Container class to hold shared UMA metrics integration points. <a href="classcrashpad_1_1Metrics.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1MinidumpContextAMD64.html">MinidumpContextAMD64</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">An x86_64 (AMD64) CPU context (register state) carried in a minidump file. <a href="structcrashpad_1_1MinidumpContextAMD64.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpContextAMD64Writer.html">MinidumpContextAMD64Writer</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for a <a class="el" href="structcrashpad_1_1MinidumpContextAMD64.html" title="An x86_64 (AMD64) CPU context (register state) carried in a minidump file. ">MinidumpContextAMD64</a> structure in a minidump file. <a href="classcrashpad_1_1MinidumpContextAMD64Writer.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpContextWriter.html">MinidumpContextWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The base class for writers of CPU context structures in minidump files. <a href="classcrashpad_1_1MinidumpContextWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1MinidumpContextX86.html">MinidumpContextX86</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A 32-bit x86 CPU context (register state) carried in a minidump file. <a href="structcrashpad_1_1MinidumpContextX86.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpContextX86Writer.html">MinidumpContextX86Writer</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for a <a class="el" href="structcrashpad_1_1MinidumpContextX86.html" title="A 32-bit x86 CPU context (register state) carried in a minidump file. ">MinidumpContextX86</a> structure in a minidump file. <a href="classcrashpad_1_1MinidumpContextX86Writer.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1MinidumpCrashpadInfo.html">MinidumpCrashpadInfo</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Additional Crashpad-specific information carried within a minidump file. <a href="structcrashpad_1_1MinidumpCrashpadInfo.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpCrashpadInfoWriter.html">MinidumpCrashpadInfoWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for a <a class="el" href="structcrashpad_1_1MinidumpCrashpadInfo.html" title="Additional Crashpad-specific information carried within a minidump file. ">MinidumpCrashpadInfo</a> stream in a minidump file. <a href="classcrashpad_1_1MinidumpCrashpadInfoWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpExceptionWriter.html">MinidumpExceptionWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for a <a class="el" href="structMINIDUMP__EXCEPTION__STREAM.html" title="Information about the exception that triggered a minidump files generation. ">MINIDUMP_EXCEPTION_STREAM</a> stream in a minidump file. <a href="classcrashpad_1_1MinidumpExceptionWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpFileWriter.html">MinidumpFileWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The root-level object in a minidump file. <a href="classcrashpad_1_1MinidumpFileWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpHandleDataWriter.html">MinidumpHandleDataWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for a MINIDUMP_HANDLE_DATA_STREAM stream in a minidump and its contained <a class="el" href="structMINIDUMP__HANDLE__DESCRIPTOR.html" title="Contains the state of an individual system handle at the time the snapshot was taken. This structure is Windows-specific. ">MINIDUMP_HANDLE_DESCRIPTOR</a> s. <a href="classcrashpad_1_1MinidumpHandleDataWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpMemoryInfoListWriter.html">MinidumpMemoryInfoListWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for a <a class="el" href="structMINIDUMP__MEMORY__INFO__LIST.html" title="Contains a list of memory regions. ">MINIDUMP_MEMORY_INFO_LIST</a> stream in a minidump file, containing a list of <a class="el" href="structMINIDUMP__MEMORY__INFO.html" title="Describes a region of memory. ">MINIDUMP_MEMORY_INFO</a> objects. <a href="classcrashpad_1_1MinidumpMemoryInfoListWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpMemoryListWriter.html">MinidumpMemoryListWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for a <a class="el" href="structMINIDUMP__MEMORY__LIST.html" title="Information about memory regions within the process. ">MINIDUMP_MEMORY_LIST</a> stream in a minidump file, containing a list of <a class="el" href="structMINIDUMP__MEMORY__DESCRIPTOR.html" title="A pointer to a snapshot of a region of memory contained within a minidump file. ">MINIDUMP_MEMORY_DESCRIPTOR</a> objects. <a href="classcrashpad_1_1MinidumpMemoryListWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpMiscInfoWriter.html">MinidumpMiscInfoWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for a stream in the <a class="el" href="structMINIDUMP__MISC__INFO.html" title="Information about the process that the minidump file contains a snapshot of, as well as the system th...">MINIDUMP_MISC_INFO</a> family in a minidump file. <a href="classcrashpad_1_1MinidumpMiscInfoWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpModuleCodeViewRecordPDB20Writer.html">MinidumpModuleCodeViewRecordPDB20Writer</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for a <a class="el" href="structcrashpad_1_1CodeViewRecordPDB20.html" title="A CodeView record linking to a .pdb 2.0 file. ">CodeViewRecordPDB20</a> object in a minidump file. <a href="classcrashpad_1_1MinidumpModuleCodeViewRecordPDB20Writer.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpModuleCodeViewRecordPDB70Writer.html">MinidumpModuleCodeViewRecordPDB70Writer</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for a <a class="el" href="structcrashpad_1_1CodeViewRecordPDB70.html" title="A CodeView record linking to a .pdb 7.0 file. ">CodeViewRecordPDB70</a> object in a minidump file. <a href="classcrashpad_1_1MinidumpModuleCodeViewRecordPDB70Writer.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpModuleCodeViewRecordWriter.html">MinidumpModuleCodeViewRecordWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The base class for writers of CodeView records referenced by <a class="el" href="structMINIDUMP__MODULE.html#acd07e35faf066880eeabea8a91aa887a" title="A pointer to the modules CodeView record, typically a link to its debugging information in crashpad...">MINIDUMP_MODULE::CvRecord</a> in minidump files. <a href="classcrashpad_1_1MinidumpModuleCodeViewRecordWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1MinidumpModuleCrashpadInfo.html">MinidumpModuleCrashpadInfo</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Additional Crashpad-specific information about a module carried within a minidump file. <a href="structcrashpad_1_1MinidumpModuleCrashpadInfo.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1MinidumpModuleCrashpadInfoLink.html">MinidumpModuleCrashpadInfoLink</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A link between a <a class="el" href="structMINIDUMP__MODULE.html" title="Information about a specific module loaded within the process at the time the snapshot was taken...">MINIDUMP_MODULE</a> structure and additional Crashpad-specific information about a module carried within a minidump file. <a href="structcrashpad_1_1MinidumpModuleCrashpadInfoLink.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1MinidumpModuleCrashpadInfoList.html">MinidumpModuleCrashpadInfoList</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Additional Crashpad-specific information about modules carried within a minidump file. <a href="structcrashpad_1_1MinidumpModuleCrashpadInfoList.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpModuleCrashpadInfoListWriter.html">MinidumpModuleCrashpadInfoListWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for a <a class="el" href="structcrashpad_1_1MinidumpModuleCrashpadInfoList.html" title="Additional Crashpad-specific information about modules carried within a minidump file. ">MinidumpModuleCrashpadInfoList</a> object in a minidump file, containing a list of <a class="el" href="structcrashpad_1_1MinidumpModuleCrashpadInfo.html" title="Additional Crashpad-specific information about a module carried within a minidump file...">MinidumpModuleCrashpadInfo</a> objects. <a href="classcrashpad_1_1MinidumpModuleCrashpadInfoListWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpModuleCrashpadInfoWriter.html">MinidumpModuleCrashpadInfoWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for a <a class="el" href="structcrashpad_1_1MinidumpModuleCrashpadInfo.html" title="Additional Crashpad-specific information about a module carried within a minidump file...">MinidumpModuleCrashpadInfo</a> object in a minidump file. <a href="classcrashpad_1_1MinidumpModuleCrashpadInfoWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpModuleListWriter.html">MinidumpModuleListWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for a <a class="el" href="structMINIDUMP__MODULE__LIST.html" title="Information about all modules loaded within the process at the time the snapshot was taken...">MINIDUMP_MODULE_LIST</a> stream in a minidump file, containing a list of <a class="el" href="structMINIDUMP__MODULE.html" title="Information about a specific module loaded within the process at the time the snapshot was taken...">MINIDUMP_MODULE</a> objects. <a href="classcrashpad_1_1MinidumpModuleListWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpModuleMiscDebugRecordWriter.html">MinidumpModuleMiscDebugRecordWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for an <a class="el" href="structIMAGE__DEBUG__MISC.html" title="Miscellaneous debugging record. ">IMAGE_DEBUG_MISC</a> object in a minidump file. <a href="classcrashpad_1_1MinidumpModuleMiscDebugRecordWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpModuleWriter.html">MinidumpModuleWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for a <a class="el" href="structMINIDUMP__MODULE.html" title="Information about a specific module loaded within the process at the time the snapshot was taken...">MINIDUMP_MODULE</a> object in a minidump file. <a href="classcrashpad_1_1MinidumpModuleWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1MinidumpRVAList.html">MinidumpRVAList</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A list of <a class="el" href="dbghelp_8h.html#acf465a1a77ecf067a9d946583bc6a3f8" title="An offset within a minidump file, relative to the start of its MINIDUMP_HEADER. ">RVA</a> pointers. <a href="structcrashpad_1_1MinidumpRVAList.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1MinidumpSimpleStringDictionary.html">MinidumpSimpleStringDictionary</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A list of key-value pairs. <a href="structcrashpad_1_1MinidumpSimpleStringDictionary.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1MinidumpSimpleStringDictionaryEntry.html">MinidumpSimpleStringDictionaryEntry</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A key-value pair. <a href="structcrashpad_1_1MinidumpSimpleStringDictionaryEntry.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpSimpleStringDictionaryEntryWriter.html">MinidumpSimpleStringDictionaryEntryWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for a <a class="el" href="structcrashpad_1_1MinidumpSimpleStringDictionaryEntry.html" title="A key-value pair. ">MinidumpSimpleStringDictionaryEntry</a> object in a minidump file. <a href="classcrashpad_1_1MinidumpSimpleStringDictionaryEntryWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpSimpleStringDictionaryWriter.html">MinidumpSimpleStringDictionaryWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for a <a class="el" href="structcrashpad_1_1MinidumpSimpleStringDictionary.html" title="A list of key-value pairs. ">MinidumpSimpleStringDictionary</a> object in a minidump file, containing a list of <a class="el" href="structcrashpad_1_1MinidumpSimpleStringDictionaryEntry.html" title="A key-value pair. ">MinidumpSimpleStringDictionaryEntry</a> objects. <a href="classcrashpad_1_1MinidumpSimpleStringDictionaryWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpSystemInfoWriter.html">MinidumpSystemInfoWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for a <a class="el" href="structMINIDUMP__SYSTEM__INFO.html" title="Information about the system that hosted the process that the minidump file contains a snapshot of...">MINIDUMP_SYSTEM_INFO</a> stream in a minidump file. <a href="classcrashpad_1_1MinidumpSystemInfoWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpThreadListWriter.html">MinidumpThreadListWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for a <a class="el" href="structMINIDUMP__THREAD__LIST.html" title="Information about all threads within the process. ">MINIDUMP_THREAD_LIST</a> stream in a minidump file, containing a list of <a class="el" href="structMINIDUMP__THREAD.html" title="Information about a specific thread within the process. ">MINIDUMP_THREAD</a> objects. <a href="classcrashpad_1_1MinidumpThreadListWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpThreadWriter.html">MinidumpThreadWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for a <a class="el" href="structMINIDUMP__THREAD.html" title="Information about a specific thread within the process. ">MINIDUMP_THREAD</a> object in a minidump file. <a href="classcrashpad_1_1MinidumpThreadWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpUnloadedModuleListWriter.html">MinidumpUnloadedModuleListWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for a <a class="el" href="structMINIDUMP__UNLOADED__MODULE__LIST.html" title="Information about all modules recorded as unloaded when the snapshot was taken. ">MINIDUMP_UNLOADED_MODULE_LIST</a> stream in a minidump file, containing a list of <a class="el" href="structMINIDUMP__UNLOADED__MODULE.html" title="Information about a specific module that was recorded as being unloaded at the time the snapshot was ...">MINIDUMP_UNLOADED_MODULE</a> objects. <a href="classcrashpad_1_1MinidumpUnloadedModuleListWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpUnloadedModuleWriter.html">MinidumpUnloadedModuleWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for a <a class="el" href="structMINIDUMP__UNLOADED__MODULE.html" title="Information about a specific module that was recorded as being unloaded at the time the snapshot was ...">MINIDUMP_UNLOADED_MODULE</a> object in a minidump file. <a href="classcrashpad_1_1MinidumpUnloadedModuleWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1MinidumpUserStreamWriter.html">MinidumpUserStreamWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The writer for a MINIDUMP_USER_STREAM in a minidump file. <a href="classcrashpad_1_1MinidumpUserStreamWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1MinidumpUTF8String.html">MinidumpUTF8String</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A variable-length UTF-8-encoded string carried within a minidump file. <a href="structcrashpad_1_1MinidumpUTF8String.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1ModuleSnapshot.html">ModuleSnapshot</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">An abstract interface to a snapshot representing a code module (binary image) loaded into a snapshot process. <a href="classcrashpad_1_1ModuleSnapshot.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1NotifyServer.html">NotifyServer</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A server interface for the <code>notify</code> Mach subsystem. <a href="classcrashpad_1_1NotifyServer.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1PEImageAnnotationsReader.html">PEImageAnnotationsReader</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A reader of annotations stored in a PE image mapped into another process. <a href="classcrashpad_1_1PEImageAnnotationsReader.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1PEImageReader.html">PEImageReader</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A reader for PE images mapped into another process. <a href="classcrashpad_1_1PEImageReader.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1PEImageResourceReader.html">PEImageResourceReader</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A reader for resources stored in PE images mapped into another process. <a href="classcrashpad_1_1PEImageResourceReader.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1PointerContainer.html">PointerContainer</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Allows a standard container to “own” pointer elements stored in it. <a href="classcrashpad_1_1PointerContainer.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1ProcessInfo.html">ProcessInfo</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Gathers information about a process given its <code>HANDLE</code>. This consists primarily of information stored in the Process Environment Block. <a href="classcrashpad_1_1ProcessInfo.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1ProcessReader.html">ProcessReader</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Accesses information about another process, identified by a Mach task. <a href="classcrashpad_1_1ProcessReader.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1ProcessReaderWin.html">ProcessReaderWin</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Accesses information about another process, identified by a <code>HANDLE</code>. <a href="classcrashpad_1_1ProcessReaderWin.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1ProcessSnapshot.html">ProcessSnapshot</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">An abstract interface to a snapshot representing the state of a process. <a href="classcrashpad_1_1ProcessSnapshot.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1ProcessSnapshotMac.html">ProcessSnapshotMac</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A <a class="el" href="classcrashpad_1_1ProcessSnapshot.html" title="An abstract interface to a snapshot representing the state of a process. ">ProcessSnapshot</a> of a running (or crashed) process running on a macOS system. <a href="classcrashpad_1_1ProcessSnapshotMac.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1ProcessSnapshotMinidump.html">ProcessSnapshotMinidump</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A <a class="el" href="classcrashpad_1_1ProcessSnapshot.html" title="An abstract interface to a snapshot representing the state of a process. ">ProcessSnapshot</a> based on a minidump file. <a href="classcrashpad_1_1ProcessSnapshotMinidump.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1ProcessSnapshotWin.html">ProcessSnapshotWin</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A <a class="el" href="classcrashpad_1_1ProcessSnapshot.html" title="An abstract interface to a snapshot representing the state of a process. ">ProcessSnapshot</a> of a running (or crashed) process running on a Windows system. <a href="classcrashpad_1_1ProcessSnapshotWin.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1ProcessSubrangeReader.html">ProcessSubrangeReader</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A wrapper for <a class="el" href="classcrashpad_1_1ProcessReaderWin.html" title="Accesses information about another process, identified by a HANDLE. ">ProcessReaderWin</a> that only allows a specific subrange to be read from. <a href="classcrashpad_1_1ProcessSubrangeReader.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1PruneCondition.html">PruneCondition</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">An abstract base class for evaluating crash reports for deletion. <a href="classcrashpad_1_1PruneCondition.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1PruneCrashReportThread.html">PruneCrashReportThread</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A thread that periodically prunes crash reports from the database using the specified condition. <a href="classcrashpad_1_1PruneCrashReportThread.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1RegistrationRequest.html">RegistrationRequest</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A client registration request. <a href="structcrashpad_1_1RegistrationRequest.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1RegistrationResponse.html">RegistrationResponse</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A client registration response. <a href="structcrashpad_1_1RegistrationResponse.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1RTL__UNLOAD__EVENT__TRACE.html">RTL_UNLOAD_EVENT_TRACE</a></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1ScopedForbidReturn.html">ScopedForbidReturn</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Asserts that a scope must not be exited while unsafe. <a href="classcrashpad_1_1ScopedForbidReturn.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1ScopedProcessSuspend.html">ScopedProcessSuspend</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Manages the suspension of another process. <a href="classcrashpad_1_1ScopedProcessSuspend.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1ScopedTaskSuspend.html">ScopedTaskSuspend</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Manages the suspension of another task. <a href="classcrashpad_1_1ScopedTaskSuspend.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1Semaphore.html">Semaphore</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">An anonymous in-process counting sempahore. <a href="classcrashpad_1_1Semaphore.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">union &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="unioncrashpad_1_1ServerToClientMessage.html">ServerToClientMessage</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The response sent back to the client via <a class="el" href="namespacecrashpad.html#a638d7916642f81df8063d300f08ff2ca" title="Connect over the given pipe_name, passing message to the server, storing the server&#39;s reply into resp...">SendToCrashHandlerServer()</a>. <a href="unioncrashpad_1_1ServerToClientMessage.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1Settings.html">Settings</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">An interface for accessing and modifying the settings of a <a class="el" href="classcrashpad_1_1CrashReportDatabase.html" title="An interface for managing a collection of crash report files and metadata associated with the crash r...">CrashReportDatabase</a>. <a href="classcrashpad_1_1Settings.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1ShutdownRequest.html">ShutdownRequest</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A message only sent to the server by itself to trigger shutdown. <a href="structcrashpad_1_1ShutdownRequest.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1SnapshotMinidumpMemoryWriter.html">SnapshotMinidumpMemoryWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The base class for writers of memory ranges pointed to by <a class="el" href="structMINIDUMP__MEMORY__DESCRIPTOR.html" title="A pointer to a snapshot of a region of memory contained within a minidump file. ">MINIDUMP_MEMORY_DESCRIPTOR</a> objects in a minidump file. <a href="classcrashpad_1_1SnapshotMinidumpMemoryWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1StringFile.html">StringFile</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A file reader and writer backed by a virtual file, as opposed to a file on disk or other operating system file descriptor-based file. <a href="classcrashpad_1_1StringFile.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1StringHTTPBodyStream.html">StringHTTPBodyStream</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">An implementation of <a class="el" href="classcrashpad_1_1HTTPBodyStream.html" title="An interface to a stream that can be used for an HTTP request body. ">HTTPBodyStream</a> that turns a fixed string into a stream. <a href="classcrashpad_1_1StringHTTPBodyStream.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1SystemSnapshot.html">SystemSnapshot</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">An abstract interface to a snapshot representing the state of a system, comprising an operating system, CPU architecture, and various other characteristics. <a href="classcrashpad_1_1SystemSnapshot.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1TaskMemory.html">TaskMemory</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Accesses the memory of another Mach task. <a href="classcrashpad_1_1TaskMemory.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1Thread.html">Thread</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Basic thread abstraction. Users should derive from this class and implement ThreadMain(). <a href="classcrashpad_1_1Thread.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1ThreadLogMessages.html">ThreadLogMessages</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Captures log messages produced on the current thread during an objects lifetime. <a href="classcrashpad_1_1ThreadLogMessages.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1ThreadSnapshot.html">ThreadSnapshot</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">An abstract interface to a snapshot representing a thread (lightweight process) present in a snapshot process. <a href="classcrashpad_1_1ThreadSnapshot.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1ToolSupport.html">ToolSupport</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Common functions used by command line tools. <a href="classcrashpad_1_1ToolSupport.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1TSimpleAddressRangeBag.html">TSimpleAddressRangeBag</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A bag implementation using a fixed amount of storage, so that it does not perform any dynamic allocations for its operations. <a href="classcrashpad_1_1TSimpleAddressRangeBag.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1TSimpleStringDictionary.html">TSimpleStringDictionary</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A map/dictionary collection implementation using a fixed amount of storage, so that it does not perform any dynamic allocations for its operations. <a href="classcrashpad_1_1TSimpleStringDictionary.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1uint128__struct.html">uint128_struct</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Stores a 128-bit quantity. <a href="structcrashpad_1_1uint128__struct.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1UniversalMachExcServer.html">UniversalMachExcServer</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A server interface for the <code>exc</code> and <code>mach_exc</code> Mach subsystems, unified to handle exceptions delivered to either subsystem, and simplified to have only a single interface method needing implementation. <a href="classcrashpad_1_1UniversalMachExcServer.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1UnloadedModuleSnapshot.html">UnloadedModuleSnapshot</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Information about an unloaded module that was previously loaded into a snapshot process. <a href="classcrashpad_1_1UnloadedModuleSnapshot.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1UserMinidumpStream.html">UserMinidumpStream</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Information describing a custom user data stream in a minidump. <a href="classcrashpad_1_1UserMinidumpStream.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1UUID.html">UUID</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A universally unique identifier (UUID). <a href="structcrashpad_1_1UUID.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1WeakFileHandleFileReader.html">WeakFileHandleFileReader</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A file reader backed by a FileHandle. <a href="classcrashpad_1_1WeakFileHandleFileReader.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1WeakFileHandleFileWriter.html">WeakFileHandleFileWriter</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A file writer backed by a FileHandle. <a href="classcrashpad_1_1WeakFileHandleFileWriter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1WeakStdioFileReader.html">WeakStdioFileReader</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A file reader backed by a standard input/output <code>FILE*</code>. <a href="classcrashpad_1_1WeakStdioFileReader.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classcrashpad_1_1WorkerThread.html">WorkerThread</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A <a class="el" href="classcrashpad_1_1WorkerThread.html" title="A WorkerThread executes its Delegate&#39;s DoWork method repeatedly on a dedicated thread at a set time i...">WorkerThread</a> executes its <a class="el" href="classcrashpad_1_1WorkerThread_1_1Delegate.html" title="An interface for doing work on a WorkerThread. ">Delegate</a>'s DoWork method repeatedly on a dedicated thread at a set time interval. <a href="classcrashpad_1_1WorkerThread.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structcrashpad_1_1WritableIoVec.html">WritableIoVec</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A version of <code>iovec</code> with a <code>const</code> <a class="el" href="structcrashpad_1_1WritableIoVec.html#abcf5d801519cf50aa286c3baa8f55d05" title="The base address of a memory region for output. ">iov_base</a> field. <a href="structcrashpad_1_1WritableIoVec.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="typedef-members"></a>
Typedefs</h2></td></tr>
<tr class="memitem:a3843475bf1f7956af4153e33bd1bd298"><td class="memItemLeft" align="right" valign="top"><a id="a3843475bf1f7956af4153e33bd1bd298"></a>
using&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a3843475bf1f7956af4153e33bd1bd298">SimpleAddressRangeBag</a> = <a class="el" href="classcrashpad_1_1TSimpleAddressRangeBag.html">TSimpleAddressRangeBag</a>&lt; 64 &gt;</td></tr>
<tr class="memdesc:a3843475bf1f7956af4153e33bd1bd298"><td class="mdescLeft">&#160;</td><td class="mdescRight">A <a class="el" href="classcrashpad_1_1TSimpleAddressRangeBag.html" title="A bag implementation using a fixed amount of storage, so that it does not perform any dynamic allocat...">TSimpleAddressRangeBag</a> with default template parameters. <br /></td></tr>
<tr class="separator:a3843475bf1f7956af4153e33bd1bd298"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac21afdb4f6e3c57ccf3bd34ea8410978"><td class="memItemLeft" align="right" valign="top">using&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ac21afdb4f6e3c57ccf3bd34ea8410978">SimpleStringDictionary</a> = <a class="el" href="classcrashpad_1_1TSimpleStringDictionary.html">TSimpleStringDictionary</a>&lt; 256, 256, 64 &gt;</td></tr>
<tr class="memdesc:ac21afdb4f6e3c57ccf3bd34ea8410978"><td class="mdescLeft">&#160;</td><td class="mdescRight">A <a class="el" href="classcrashpad_1_1TSimpleStringDictionary.html" title="A map/dictionary collection implementation using a fixed amount of storage, so that it does not perfo...">TSimpleStringDictionary</a> with default template parameters. <a href="#ac21afdb4f6e3c57ccf3bd34ea8410978">More...</a><br /></td></tr>
<tr class="separator:ac21afdb4f6e3c57ccf3bd34ea8410978"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a5271a1e77e5f5f6489d6695cf4f5e5b7"><td class="memItemLeft" align="right" valign="top"><a id="a5271a1e77e5f5f6489d6695cf4f5e5b7"></a>
using&#160;</td><td class="memItemRight" valign="bottom"><b>MinidumpUTF16StringListWriter</b> = <a class="el" href="classcrashpad_1_1internal_1_1MinidumpStringListWriter.html">internal::MinidumpStringListWriter</a>&lt; <a class="el" href="classcrashpad_1_1internal_1_1MinidumpUTF16StringWriter.html">internal::MinidumpUTF16StringWriter</a> &gt;</td></tr>
<tr class="separator:a5271a1e77e5f5f6489d6695cf4f5e5b7"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ad1d380a185db166c94450cc237765f72"><td class="memItemLeft" align="right" valign="top"><a id="ad1d380a185db166c94450cc237765f72"></a>
using&#160;</td><td class="memItemRight" valign="bottom"><b>MinidumpUTF8StringListWriter</b> = <a class="el" href="classcrashpad_1_1internal_1_1MinidumpStringListWriter.html">internal::MinidumpStringListWriter</a>&lt; <a class="el" href="classcrashpad_1_1internal_1_1MinidumpUTF8StringWriter.html">internal::MinidumpUTF8StringWriter</a> &gt;</td></tr>
<tr class="separator:ad1d380a185db166c94450cc237765f72"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ae426d8c91f5448aaf543f91478d831da"><td class="memItemLeft" align="right" valign="top">using&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ae426d8c91f5448aaf543f91478d831da">MinidumpThreadIDMap</a> = std::map&lt; uint64_t, uint32_t &gt;</td></tr>
<tr class="memdesc:ae426d8c91f5448aaf543f91478d831da"><td class="mdescLeft">&#160;</td><td class="mdescRight">A map that connects 64-bit snapshot thread IDs to 32-bit minidump thread IDs. <a href="#ae426d8c91f5448aaf543f91478d831da">More...</a><br /></td></tr>
<tr class="separator:ae426d8c91f5448aaf543f91478d831da"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a07f8e33c4fdeba3783277f9f2563e48a"><td class="memItemLeft" align="right" valign="top"><a id="a07f8e33c4fdeba3783277f9f2563e48a"></a>
using&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a> = int</td></tr>
<tr class="memdesc:a07f8e33c4fdeba3783277f9f2563e48a"><td class="mdescLeft">&#160;</td><td class="mdescRight">Platform-specific alias for a low-level file handle. <br /></td></tr>
<tr class="separator:a07f8e33c4fdeba3783277f9f2563e48a"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a1e53a1957d9edcba8b406ea632b6daf2"><td class="memItemLeft" align="right" valign="top"><a id="a1e53a1957d9edcba8b406ea632b6daf2"></a>
using&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a1e53a1957d9edcba8b406ea632b6daf2">FileOffset</a> = off_t</td></tr>
<tr class="memdesc:a1e53a1957d9edcba8b406ea632b6daf2"><td class="mdescLeft">&#160;</td><td class="mdescRight">Platform-specific alias for a position in an open file. <br /></td></tr>
<tr class="separator:a1e53a1957d9edcba8b406ea632b6daf2"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a9daa1b956487883acd9f43d13cc77339"><td class="memItemLeft" align="right" valign="top"><a id="a9daa1b956487883acd9f43d13cc77339"></a>
using&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a9daa1b956487883acd9f43d13cc77339">ScopedFileHandle</a> = base::ScopedFD</td></tr>
<tr class="memdesc:a9daa1b956487883acd9f43d13cc77339"><td class="mdescLeft">&#160;</td><td class="mdescRight">Scoped wrapper of a FileHandle. <br /></td></tr>
<tr class="separator:a9daa1b956487883acd9f43d13cc77339"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a25465a3a2d289a06addf93c346c6f917"><td class="memItemLeft" align="right" valign="top"><a id="a25465a3a2d289a06addf93c346c6f917"></a>
using&#160;</td><td class="memItemRight" valign="bottom"><b>FileOperationResult</b> = ssize_t</td></tr>
<tr class="separator:a25465a3a2d289a06addf93c346c6f917"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a8d7f0170c573e59ca6b02e29735f4fad"><td class="memItemLeft" align="right" valign="top">using&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a8d7f0170c573e59ca6b02e29735f4fad">CheckedMachAddressRange</a> = <a class="el" href="classcrashpad_1_1internal_1_1CheckedAddressRangeGeneric.html">internal::CheckedAddressRangeGeneric</a>&lt; mach_vm_address_t, mach_vm_size_t &gt;</td></tr>
<tr class="memdesc:a8d7f0170c573e59ca6b02e29735f4fad"><td class="mdescLeft">&#160;</td><td class="mdescRight">Ensures that a range, composed of a base and a size, does not overflow the pointer type of the process it describes a range in. <a href="#a8d7f0170c573e59ca6b02e29735f4fad">More...</a><br /></td></tr>
<tr class="separator:a8d7f0170c573e59ca6b02e29735f4fad"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a72fa9ea632f7f1ec93ec3c1b1d300db6"><td class="memItemLeft" align="right" valign="top">using&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a72fa9ea632f7f1ec93ec3c1b1d300db6">ConstThreadState</a> = const natural_t *</td></tr>
<tr class="memdesc:a72fa9ea632f7f1ec93ec3c1b1d300db6"><td class="mdescLeft">&#160;</td><td class="mdescRight">A const version of <code>thread_state_t</code>. <a href="#a72fa9ea632f7f1ec93ec3c1b1d300db6">More...</a><br /></td></tr>
<tr class="separator:a72fa9ea632f7f1ec93ec3c1b1d300db6"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a34f36473e385b19eb229798ab2f7210c"><td class="memItemLeft" align="right" valign="top">using&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a34f36473e385b19eb229798ab2f7210c">MachMessageDeadline</a> = uint64_t</td></tr>
<tr class="memdesc:a34f36473e385b19eb229798ab2f7210c"><td class="mdescLeft">&#160;</td><td class="mdescRight">The time before which a <a class="el" href="namespacecrashpad.html#a35293418a0b7637a00631807ac4b431e" title="Runs mach_msg() with a deadline, as opposed to a timeout. ">MachMessageWithDeadline()</a> call should complete. <a href="#a34f36473e385b19eb229798ab2f7210c">More...</a><br /></td></tr>
<tr class="separator:a34f36473e385b19eb229798ab2f7210c"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a0f13feba965ef7750b3d49064936e5ee"><td class="memItemLeft" align="right" valign="top"><a id="a0f13feba965ef7750b3d49064936e5ee"></a>
using&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a0f13feba965ef7750b3d49064936e5ee">SymbolicConstantToStringOptions</a> = unsigned int</td></tr>
<tr class="memdesc:a0f13feba965ef7750b3d49064936e5ee"><td class="mdescLeft">&#160;</td><td class="mdescRight">A bitfield containing values of <a class="el" href="namespacecrashpad.html#a7856b82b71167792ea6103debb5105ed" title="Options for various *ToString functions in symbolic_constants_* files. ">SymbolicConstantToStringOptionBits</a>. <br /></td></tr>
<tr class="separator:a0f13feba965ef7750b3d49064936e5ee"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a14f1de509869f929122998a2f88f08a6"><td class="memItemLeft" align="right" valign="top"><a id="a14f1de509869f929122998a2f88f08a6"></a>
using&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a14f1de509869f929122998a2f88f08a6">StringToSymbolicConstantOptions</a> = unsigned int</td></tr>
<tr class="memdesc:a14f1de509869f929122998a2f88f08a6"><td class="mdescLeft">&#160;</td><td class="mdescRight">A bitfield containing values of <a class="el" href="namespacecrashpad.html#a8387ad067a7e6a1735ab97a1af450d2b" title="Options for various StringTo* functions in symbolic_constants_* files. ">StringToSymbolicConstantOptionBits</a>. <br /></td></tr>
<tr class="separator:a14f1de509869f929122998a2f88f08a6"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:af6ffe10a8131fab8d1f8de60d9a812f9"><td class="memItemLeft" align="right" valign="top"><a id="af6ffe10a8131fab8d1f8de60d9a812f9"></a>
using&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#af6ffe10a8131fab8d1f8de60d9a812f9">HTTPHeaders</a> = std::map&lt; std::string, std::string &gt;</td></tr>
<tr class="memdesc:af6ffe10a8131fab8d1f8de60d9a812f9"><td class="mdescLeft">&#160;</td><td class="mdescRight">A map of HTTP header fields to their values. <br /></td></tr>
<tr class="separator:af6ffe10a8131fab8d1f8de60d9a812f9"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a86fa676850a73fb41a996c8fe256c175"><td class="memTemplParams" colspan="2">template&lt;typename T , size_t Alignment = ALIGNOF(T)&gt; </td></tr>
<tr class="memitem:a86fa676850a73fb41a996c8fe256c175"><td class="memTemplItemLeft" align="right" valign="top">using&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a86fa676850a73fb41a996c8fe256c175">AlignedVector</a> = std::vector&lt; T, <a class="el" href="structcrashpad_1_1AlignedAllocator.html">AlignedAllocator</a>&lt; T, Alignment &gt;&gt;</td></tr>
<tr class="memdesc:a86fa676850a73fb41a996c8fe256c175"><td class="mdescLeft">&#160;</td><td class="mdescRight">A <code>std::vector</code> using <a class="el" href="structcrashpad_1_1AlignedAllocator.html" title="A standard allocator that aligns its allocations as requested, suitable for use as an allocator in st...">AlignedAllocator</a>. <a href="#a86fa676850a73fb41a996c8fe256c175">More...</a><br /></td></tr>
<tr class="separator:a86fa676850a73fb41a996c8fe256c175"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a9cae195b61eb9fe7cd4ae9a66e13f00f"><td class="memTemplParams" colspan="2">template&lt;typename T &gt; </td></tr>
<tr class="memitem:a9cae195b61eb9fe7cd4ae9a66e13f00f"><td class="memTemplItemLeft" align="right" valign="top">using&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a9cae195b61eb9fe7cd4ae9a66e13f00f">PointerVector</a> = <a class="el" href="classcrashpad_1_1PointerContainer.html">PointerContainer</a>&lt; std::vector&lt; T * &gt;&gt;</td></tr>
<tr class="memdesc:a9cae195b61eb9fe7cd4ae9a66e13f00f"><td class="mdescLeft">&#160;</td><td class="mdescRight">Allows a <code>std::vector</code> to “own” pointer elements stored in it. <a href="#a9cae195b61eb9fe7cd4ae9a66e13f00f">More...</a><br /></td></tr>
<tr class="separator:a9cae195b61eb9fe7cd4ae9a66e13f00f"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a368af6d88f68998b5c5eb80b8f6ebb76"><td class="memItemLeft" align="right" valign="top"><a id="a368af6d88f68998b5c5eb80b8f6ebb76"></a>
using&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a368af6d88f68998b5c5eb80b8f6ebb76">WinVMAddress</a> = uint64_t</td></tr>
<tr class="memdesc:a368af6d88f68998b5c5eb80b8f6ebb76"><td class="mdescLeft">&#160;</td><td class="mdescRight">Type used to represent an address in a process, potentially across bitness. <br /></td></tr>
<tr class="separator:a368af6d88f68998b5c5eb80b8f6ebb76"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a1bac9f2a189b24737e743d6690362239"><td class="memItemLeft" align="right" valign="top"><a id="a1bac9f2a189b24737e743d6690362239"></a>
using&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a1bac9f2a189b24737e743d6690362239">WinVMSize</a> = uint64_t</td></tr>
<tr class="memdesc:a1bac9f2a189b24737e743d6690362239"><td class="mdescLeft">&#160;</td><td class="mdescRight">Type used to represent the size of a memory range (with a WinVMAddress), potentially across bitness. <br /></td></tr>
<tr class="separator:a1bac9f2a189b24737e743d6690362239"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ad171ce8db60c84b2d875f7acd3b90f1e"><td class="memItemLeft" align="right" valign="top">using&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ad171ce8db60c84b2d875f7acd3b90f1e">CheckedWinAddressRange</a> = <a class="el" href="classcrashpad_1_1internal_1_1CheckedAddressRangeGeneric.html">internal::CheckedAddressRangeGeneric</a>&lt; <a class="el" href="namespacecrashpad.html#a368af6d88f68998b5c5eb80b8f6ebb76">WinVMAddress</a>, <a class="el" href="namespacecrashpad.html#a1bac9f2a189b24737e743d6690362239">WinVMSize</a> &gt;</td></tr>
<tr class="memdesc:ad171ce8db60c84b2d875f7acd3b90f1e"><td class="mdescLeft">&#160;</td><td class="mdescRight">Ensures that a range, composed of a base and a size, does not overflow the pointer type of the process it describes a range in. <a href="#ad171ce8db60c84b2d875f7acd3b90f1e">More...</a><br /></td></tr>
<tr class="separator:ad171ce8db60c84b2d875f7acd3b90f1e"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a1cbecef0a25523acb23bd161b99bc4ac"><td class="memItemLeft" align="right" valign="top"><a id="a1cbecef0a25523acb23bd161b99bc4ac"></a>
using&#160;</td><td class="memItemRight" valign="bottom"><b>ScopedFileHANDLE</b> = base::ScopedGeneric&lt; HANDLE, <a class="el" href="structcrashpad_1_1internal_1_1ScopedFileHANDLECloseTraits.html">internal::ScopedFileHANDLECloseTraits</a> &gt;</td></tr>
<tr class="separator:a1cbecef0a25523acb23bd161b99bc4ac"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a76696c6339810ca1c46878023cb7bb09"><td class="memItemLeft" align="right" valign="top"><a id="a76696c6339810ca1c46878023cb7bb09"></a>
using&#160;</td><td class="memItemRight" valign="bottom"><b>ScopedKernelHANDLE</b> = base::ScopedGeneric&lt; HANDLE, <a class="el" href="structcrashpad_1_1internal_1_1ScopedKernelHANDLECloseTraits.html">internal::ScopedKernelHANDLECloseTraits</a> &gt;</td></tr>
<tr class="separator:a76696c6339810ca1c46878023cb7bb09"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a9593ac07cbe5f4d3aa01f657e4744214"><td class="memItemLeft" align="right" valign="top"><a id="a9593ac07cbe5f4d3aa01f657e4744214"></a>
using&#160;</td><td class="memItemRight" valign="bottom"><b>ScopedLocalAlloc</b> = base::ScopedGeneric&lt; HLOCAL, <a class="el" href="structcrashpad_1_1internal_1_1LocalAllocTraits.html">internal::LocalAllocTraits</a> &gt;</td></tr>
<tr class="separator:a9593ac07cbe5f4d3aa01f657e4744214"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="enum-members"></a>
Enumerations</h2></td></tr>
<tr class="memitem:a835e6bd6cb3f97c99c572596878c1573"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a835e6bd6cb3f97c99c572596878c1573">MinidumpContextFlags</a> : uint32_t <tr class="memdesc:a835e6bd6cb3f97c99c572596878c1573"><td class="mdescLeft">&#160;</td><td class="mdescRight">Architecture-independent flags for <code>context_flags</code> fields in Minidump context structures. <a href="namespacecrashpad.html#a835e6bd6cb3f97c99c572596878c1573">More...</a><br /></td></tr>
</td></tr>
<tr class="separator:a835e6bd6cb3f97c99c572596878c1573"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a2a503f0a39ec98188b60178edbc1fc55"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a2a503f0a39ec98188b60178edbc1fc55">MinidumpContextX86Flags</a> : uint32_t <tr class="memdesc:a2a503f0a39ec98188b60178edbc1fc55"><td class="mdescLeft">&#160;</td><td class="mdescRight">32-bit x86-specifc flags for MinidumpContextX86::context_flags. <a href="namespacecrashpad.html#a2a503f0a39ec98188b60178edbc1fc55">More...</a><br /></td></tr>
</td></tr>
<tr class="separator:a2a503f0a39ec98188b60178edbc1fc55"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aa197c419950bae99f1ba663f10b1891c"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#aa197c419950bae99f1ba663f10b1891c">MinidumpContextAMD64Flags</a> : uint32_t <tr class="memdesc:aa197c419950bae99f1ba663f10b1891c"><td class="mdescLeft">&#160;</td><td class="mdescRight">x86_64-specific flags for MinidumpContextAMD64::context_flags. <a href="namespacecrashpad.html#aa197c419950bae99f1ba663f10b1891c">More...</a><br /></td></tr>
</td></tr>
<tr class="separator:aa197c419950bae99f1ba663f10b1891c"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a88363a45a4af1a16f542a8c1ff522ab9"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a88363a45a4af1a16f542a8c1ff522ab9">MinidumpStreamType</a> : uint32_t <tr class="memdesc:a88363a45a4af1a16f542a8c1ff522ab9"><td class="mdescLeft">&#160;</td><td class="mdescRight">Minidump stream type values for <a class="el" href="structMINIDUMP__DIRECTORY.html#a425b8b68da6810a126c759c5f5a94f7d" title="The type of stream referenced, a value of MINIDUMP_STREAM_TYPE. ">MINIDUMP_DIRECTORY::StreamType</a>. Each stream structure has a corresponding stream type value to identify it. <a href="namespacecrashpad.html#a88363a45a4af1a16f542a8c1ff522ab9">More...</a><br /></td></tr>
</td></tr>
<tr class="separator:a88363a45a4af1a16f542a8c1ff522ab9"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a98e532bb06fc5ffdd93e0ceb6d789eb1"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a98e532bb06fc5ffdd93e0ceb6d789eb1">MinidumpCPUArchitecture</a> : uint16_t <tr class="memdesc:a98e532bb06fc5ffdd93e0ceb6d789eb1"><td class="mdescLeft">&#160;</td><td class="mdescRight">CPU type values for <a class="el" href="structMINIDUMP__SYSTEM__INFO.html#adc85b29d7df8943baf1a96af23051ca8" title="The systems CPU architecture. This may be a PROCESSOR_ARCHITECTURE_* value, or a member of crashpad...">MINIDUMP_SYSTEM_INFO::ProcessorArchitecture</a>. <a href="namespacecrashpad.html#a98e532bb06fc5ffdd93e0ceb6d789eb1">More...</a><br /></td></tr>
</td></tr>
<tr class="separator:a98e532bb06fc5ffdd93e0ceb6d789eb1"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a3bf5a6562c9ccee9b4ef3ae4d9ac0be7"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a3bf5a6562c9ccee9b4ef3ae4d9ac0be7">MinidumpOSType</a> : uint8_t <tr class="memdesc:a3bf5a6562c9ccee9b4ef3ae4d9ac0be7"><td class="mdescLeft">&#160;</td><td class="mdescRight">Operating system type values for <a class="el" href="structMINIDUMP__SYSTEM__INFO.html#a9aac8ed4707ea43563fed1776454bad5" title="The systems operating system type, which distinguishes between “desktop” or “workstation” syste...">MINIDUMP_SYSTEM_INFO::ProductType</a>. <a href="namespacecrashpad.html#a3bf5a6562c9ccee9b4ef3ae4d9ac0be7">More...</a><br /></td></tr>
</td></tr>
<tr class="separator:a3bf5a6562c9ccee9b4ef3ae4d9ac0be7"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a9be77c6f7868f00c2f279006a1abe26a"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a9be77c6f7868f00c2f279006a1abe26a">MinidumpOS</a> : uint32_t <tr class="memdesc:a9be77c6f7868f00c2f279006a1abe26a"><td class="mdescLeft">&#160;</td><td class="mdescRight">Operating system family values for <a class="el" href="structMINIDUMP__SYSTEM__INFO.html#a214e7bd61a89343a80a3c9a265fbbe96" title="The systems operating system family. This may be a VER_PLATFORM_* value, or a member of crashpad::M...">MINIDUMP_SYSTEM_INFO::PlatformId</a>. <a href="namespacecrashpad.html#a9be77c6f7868f00c2f279006a1abe26a">More...</a><br /></td></tr>
</td></tr>
<tr class="separator:a9be77c6f7868f00c2f279006a1abe26a"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a270e290ba558e948eb6690bd217cbb71"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a270e290ba558e948eb6690bd217cbb71">CPUArchitecture</a> <tr class="memdesc:a270e290ba558e948eb6690bd217cbb71"><td class="mdescLeft">&#160;</td><td class="mdescRight">A systems CPU architecture. <a href="namespacecrashpad.html#a270e290ba558e948eb6690bd217cbb71">More...</a><br /></td></tr>
</td></tr>
<tr class="separator:a270e290ba558e948eb6690bd217cbb71"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ab96bb7edb42a2e1ce28eda205a18a17a"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ab96bb7edb42a2e1ce28eda205a18a17a">ProcessSuspensionState</a> : bool <tr class="memdesc:ab96bb7edb42a2e1ce28eda205a18a17a"><td class="mdescLeft">&#160;</td><td class="mdescRight">State of process being read by ProcessReaderWin. <a href="namespacecrashpad.html#ab96bb7edb42a2e1ce28eda205a18a17a">More...</a><br /></td></tr>
</td></tr>
<tr class="separator:ab96bb7edb42a2e1ce28eda205a18a17a"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:afa69b0967d9a6df659ff5d2a02ff3e51"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#afa69b0967d9a6df659ff5d2a02ff3e51">FileWriteMode</a> <tr class="memdesc:afa69b0967d9a6df659ff5d2a02ff3e51"><td class="mdescLeft">&#160;</td><td class="mdescRight">Determines the mode that <a class="el" href="namespacecrashpad.html#a62fc6876cc0c660f0ea8bd1dd0a07e82" title="Wraps OpenFileForWrite(), logging an error if the operation fails. ">LoggingOpenFileForWrite()</a> uses. <a href="namespacecrashpad.html#afa69b0967d9a6df659ff5d2a02ff3e51">More...</a><br /></td></tr>
</td></tr>
<tr class="separator:afa69b0967d9a6df659ff5d2a02ff3e51"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a034ccc90eb0d1f587ee89275d822175d"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a034ccc90eb0d1f587ee89275d822175d">FilePermissions</a> : bool <tr class="memdesc:a034ccc90eb0d1f587ee89275d822175d"><td class="mdescLeft">&#160;</td><td class="mdescRight">Determines the permissions bits for files created on POSIX systems. <a href="namespacecrashpad.html#a034ccc90eb0d1f587ee89275d822175d">More...</a><br /></td></tr>
</td></tr>
<tr class="separator:a034ccc90eb0d1f587ee89275d822175d"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a3753a95b02e5c96c6e20017e467cef07"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a3753a95b02e5c96c6e20017e467cef07">FileLocking</a> : bool <tr class="memdesc:a3753a95b02e5c96c6e20017e467cef07"><td class="mdescLeft">&#160;</td><td class="mdescRight">Determines the locking mode that <a class="el" href="namespacecrashpad.html#acd02263566d8c43fc7886f88a13b364f" title="Locks the given file using flock() on POSIX or LockFileEx() on Windows. ">LoggingLockFile()</a> uses. <a href="namespacecrashpad.html#a3753a95b02e5c96c6e20017e467cef07">More...</a><br /></td></tr>
</td></tr>
<tr class="separator:a3753a95b02e5c96c6e20017e467cef07"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a589b4d9bd6f2233b67148ab6793c3c13"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a589b4d9bd6f2233b67148ab6793c3c13">XattrStatus</a> <tr class="memdesc:a589b4d9bd6f2233b67148ab6793c3c13"><td class="mdescLeft">&#160;</td><td class="mdescRight">The result code for a ReadXattr operation. <a href="namespacecrashpad.html#a589b4d9bd6f2233b67148ab6793c3c13">More...</a><br /></td></tr>
</td></tr>
<tr class="separator:a589b4d9bd6f2233b67148ab6793c3c13"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a9c82d3742b041daf266c44df253ef02d"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom">: mach_msg_timeout_t <tr class="memdesc:a9c82d3742b041daf266c44df253ef02d"><td class="mdescLeft">&#160;</td><td class="mdescRight">Special constants used as <code>mach_msg_timeout_t</code> values. <a href="namespacecrashpad.html#a9c82d3742b041daf266c44df253ef02d">More...</a><br /></td></tr>
</td></tr>
<tr class="separator:a9c82d3742b041daf266c44df253ef02d"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a163a3ceac0adcb2419bb8d97e1425b94"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom">: MachMessageDeadline <tr class="memdesc:a163a3ceac0adcb2419bb8d97e1425b94"><td class="mdescLeft">&#160;</td><td class="mdescRight">Special constants used as <a class="el" href="namespacecrashpad.html#a34f36473e385b19eb229798ab2f7210c">MachMessageDeadline</a> values. <a href="namespacecrashpad.html#a163a3ceac0adcb2419bb8d97e1425b94">More...</a><br /></td></tr>
</td></tr>
<tr class="separator:a163a3ceac0adcb2419bb8d97e1425b94"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a7856b82b71167792ea6103debb5105ed"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a7856b82b71167792ea6103debb5105ed">SymbolicConstantToStringOptionBits</a> <tr class="memdesc:a7856b82b71167792ea6103debb5105ed"><td class="mdescLeft">&#160;</td><td class="mdescRight">Options for various <code>*ToString</code> functions in <code>symbolic_constants_*</code> files. <a href="namespacecrashpad.html#a7856b82b71167792ea6103debb5105ed">More...</a><br /></td></tr>
</td></tr>
<tr class="separator:a7856b82b71167792ea6103debb5105ed"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a8387ad067a7e6a1735ab97a1af450d2b"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a8387ad067a7e6a1735ab97a1af450d2b">StringToSymbolicConstantOptionBits</a> <tr class="memdesc:a8387ad067a7e6a1735ab97a1af450d2b"><td class="mdescLeft">&#160;</td><td class="mdescRight">Options for various <code>StringTo*</code> functions in <code>symbolic_constants_*</code> files. <a href="namespacecrashpad.html#a8387ad067a7e6a1735ab97a1af450d2b">More...</a><br /></td></tr>
</td></tr>
<tr class="separator:a8387ad067a7e6a1735ab97a1af450d2b"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a3b405c19a5787fabcfba96001d49f292"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a3b405c19a5787fabcfba96001d49f292">TriState</a> : uint8_t <tr class="memdesc:a3b405c19a5787fabcfba96001d49f292"><td class="mdescLeft">&#160;</td><td class="mdescRight">A tri-state value that can be unset, on, or off. <a href="namespacecrashpad.html#a3b405c19a5787fabcfba96001d49f292">More...</a><br /></td></tr>
</td></tr>
<tr class="separator:a3b405c19a5787fabcfba96001d49f292"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ad189907e982265e173839f234d7a095b"><td class="memItemLeft" align="right" valign="top"><a id="ad189907e982265e173839f234d7a095b"></a>enum &#160;</td><td class="memItemRight" valign="bottom"></td></tr>
<tr class="separator:ad189907e982265e173839f234d7a095b"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a9db1ed26b36a3dd229fb4e8411340eee"><td class="memItemLeft" align="right" valign="top"><a id="a9db1ed26b36a3dd229fb4e8411340eee"></a>enum &#160;</td><td class="memItemRight" valign="bottom"></td></tr>
<tr class="separator:a9db1ed26b36a3dd229fb4e8411340eee"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:acf909fcc58999f95ab1a2d485a3b884f"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#acf909fcc58999f95ab1a2d485a3b884f">TerminationCodes</a> : unsigned int <tr class="memdesc:acf909fcc58999f95ab1a2d485a3b884f"><td class="mdescLeft">&#160;</td><td class="mdescRight">Crashpad-specific codes that are used as arguments to <code>TerminateProcess()</code> in unusual circumstances. <a href="namespacecrashpad.html#acf909fcc58999f95ab1a2d485a3b884f">More...</a><br /></td></tr>
</td></tr>
<tr class="separator:acf909fcc58999f95ab1a2d485a3b884f"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a29691961b22233f7519b41a78fd99449"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"></td></tr>
<tr class="separator:a29691961b22233f7519b41a78fd99449"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="func-members"></a>
Functions</h2></td></tr>
<tr class="memitem:ac25486c6b4c38fc7c7868e978094edcf"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ac25486c6b4c38fc7c7868e978094edcf">CaptureContext</a> (NativeCPUContext *cpu_context)</td></tr>
<tr class="memdesc:ac25486c6b4c38fc7c7868e978094edcf"><td class="mdescLeft">&#160;</td><td class="mdescRight">Saves the CPU context. <a href="#ac25486c6b4c38fc7c7868e978094edcf">More...</a><br /></td></tr>
<tr class="separator:ac25486c6b4c38fc7c7868e978094edcf"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a87aa3a36a41939af1166c336db41ec11"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a87aa3a36a41939af1166c336db41ec11">PruneCrashReportDatabase</a> (<a class="el" href="classcrashpad_1_1CrashReportDatabase.html">CrashReportDatabase</a> *database, <a class="el" href="classcrashpad_1_1PruneCondition.html">PruneCondition</a> *condition)</td></tr>
<tr class="memdesc:a87aa3a36a41939af1166c336db41ec11"><td class="mdescLeft">&#160;</td><td class="mdescRight">Deletes crash reports from <em>database</em> that match <em>condition</em>. <a href="#a87aa3a36a41939af1166c336db41ec11">More...</a><br /></td></tr>
<tr class="separator:a87aa3a36a41939af1166c336db41ec11"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a5386e76e74bf6200e1959dddb99509b3"><td class="memItemLeft" align="right" valign="top"><a id="a5386e76e74bf6200e1959dddb99509b3"></a>
std::unique_ptr&lt; <a class="el" href="classcrashpad_1_1PruneCondition.html">PruneCondition</a> &gt;&#160;</td><td class="memItemRight" valign="bottom"><b>GetDefaultDatabasePruneCondition</b> ()</td></tr>
<tr class="separator:a5386e76e74bf6200e1959dddb99509b3"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a45a44a5552e00ceaf0917f94433ac104"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a45a44a5552e00ceaf0917f94433ac104">SimulateCrash</a> (const NativeCPUContext &amp;cpu_context)</td></tr>
<tr class="memdesc:a45a44a5552e00ceaf0917f94433ac104"><td class="mdescLeft">&#160;</td><td class="mdescRight">Simulates a exception without crashing. <a href="#a45a44a5552e00ceaf0917f94433ac104">More...</a><br /></td></tr>
<tr class="separator:a45a44a5552e00ceaf0917f94433ac104"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aaad18d253c543d4f003b5803fd295f91"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#aaad18d253c543d4f003b5803fd295f91">HandlerMain</a> (int argc, char *argv[])</td></tr>
<tr class="memdesc:aaad18d253c543d4f003b5803fd295f91"><td class="mdescLeft">&#160;</td><td class="mdescRight">The <code>main()</code> of the <code>crashpad_handler</code> binary. <a href="#aaad18d253c543d4f003b5803fd295f91">More...</a><br /></td></tr>
<tr class="separator:aaad18d253c543d4f003b5803fd295f91"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a58169a74e32daa2888614fcd2f2381ce"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a58169a74e32daa2888614fcd2f2381ce">BuildMinidumpThreadIDMap</a> (const std::vector&lt; const <a class="el" href="classcrashpad_1_1ThreadSnapshot.html">ThreadSnapshot</a> * &gt; &amp;thread_snapshots, <a class="el" href="namespacecrashpad.html#ae426d8c91f5448aaf543f91478d831da">MinidumpThreadIDMap</a> *thread_id_map)</td></tr>
<tr class="memdesc:a58169a74e32daa2888614fcd2f2381ce"><td class="mdescLeft">&#160;</td><td class="mdescRight">Builds a MinidumpThreadIDMap for a group of <a class="el" href="classcrashpad_1_1ThreadSnapshot.html" title="An abstract interface to a snapshot representing a thread (lightweight process) present in a snapshot...">ThreadSnapshot</a> objects. <a href="#a58169a74e32daa2888614fcd2f2381ce">More...</a><br /></td></tr>
<tr class="separator:a58169a74e32daa2888614fcd2f2381ce"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aaccce94b8a0b7b0ada3391216706e599"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#aaccce94b8a0b7b0ada3391216706e599">ReadModuleAnnotations</a> (HANDLE process, HMODULE module, std::map&lt; std::string, std::string &gt; *annotations)</td></tr>
<tr class="memdesc:aaccce94b8a0b7b0ada3391216706e599"><td class="mdescLeft">&#160;</td><td class="mdescRight">Reads the module annotations from another process. <a href="#aaccce94b8a0b7b0ada3391216706e599">More...</a><br /></td></tr>
<tr class="separator:aaccce94b8a0b7b0ada3391216706e599"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ae24e1ae9b86058543755d67f7b9f4507"><td class="memItemLeft" align="right" valign="top"><a id="ae24e1ae9b86058543755d67f7b9f4507"></a>
void&#160;</td><td class="memItemRight" valign="bottom"><b>InitializeX86Context</b> (const CONTEXT &amp;context, <a class="el" href="structcrashpad_1_1CPUContextX86.html">CPUContextX86</a> *out)</td></tr>
<tr class="separator:ae24e1ae9b86058543755d67f7b9f4507"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a5fc668a00f655e2ca484a3cd6f88e938"><td class="memItemLeft" align="right" valign="top"><a id="a5fc668a00f655e2ca484a3cd6f88e938"></a>
void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a5fc668a00f655e2ca484a3cd6f88e938">InitializeX86Context</a> (const WOW64_CONTEXT &amp;context, <a class="el" href="structcrashpad_1_1CPUContextX86.html">CPUContextX86</a> *out)</td></tr>
<tr class="memdesc:a5fc668a00f655e2ca484a3cd6f88e938"><td class="mdescLeft">&#160;</td><td class="mdescRight">Initializes a <a class="el" href="structcrashpad_1_1CPUContextX86.html" title="A context structure carrying 32-bit x86 CPU state. ">CPUContextX86</a> structure from a native context structure on Windows. <br /></td></tr>
<tr class="separator:a5fc668a00f655e2ca484a3cd6f88e938"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a1841e343addd4079444c944116d6df77"><td class="memItemLeft" align="right" valign="top"><a id="a1841e343addd4079444c944116d6df77"></a>
void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a1841e343addd4079444c944116d6df77">InitializeX64Context</a> (const CONTEXT &amp;context, <a class="el" href="structcrashpad_1_1CPUContextX86__64.html">CPUContextX86_64</a> *out)</td></tr>
<tr class="memdesc:a1841e343addd4079444c944116d6df77"><td class="mdescLeft">&#160;</td><td class="mdescRight">Initializes a <a class="el" href="structcrashpad_1_1CPUContextX86__64.html" title="A context structure carrying x86_64 CPU state. ">CPUContextX86_64</a> structure from a native context structure on Windows. <br /></td></tr>
<tr class="separator:a1841e343addd4079444c944116d6df77"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a743f7c71d235eb21a742679a639f6aa7"><td class="memItemLeft" align="right" valign="top"><a id="a743f7c71d235eb21a742679a639f6aa7"></a>
template bool&#160;</td><td class="memItemRight" valign="bottom"><b>PEImageReader::GetCrashpadInfo&lt; process_types::internal::Traits32 &gt;</b> (<a class="el" href="structcrashpad_1_1process__types_1_1CrashpadInfo.html">process_types::CrashpadInfo</a>&lt; <a class="el" href="structcrashpad_1_1process__types_1_1internal_1_1Traits32.html">process_types::internal::Traits32</a> &gt; *crashpad_info) const</td></tr>
<tr class="separator:a743f7c71d235eb21a742679a639f6aa7"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a0a621015141b7331ca152909781cc29a"><td class="memItemLeft" align="right" valign="top"><a id="a0a621015141b7331ca152909781cc29a"></a>
template bool&#160;</td><td class="memItemRight" valign="bottom"><b>PEImageReader::GetCrashpadInfo&lt; process_types::internal::Traits64 &gt;</b> (<a class="el" href="structcrashpad_1_1process__types_1_1CrashpadInfo.html">process_types::CrashpadInfo</a>&lt; <a class="el" href="structcrashpad_1_1process__types_1_1internal_1_1Traits64.html">process_types::internal::Traits64</a> &gt; *crashpad_info) const</td></tr>
<tr class="separator:a0a621015141b7331ca152909781cc29a"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:abd2a51526c1f15e3f21a962457cbc53a"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#abd2a51526c1f15e3f21a962457cbc53a">LoggingReadFile</a> (<a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a> file, void *buffer, size_t size)</td></tr>
<tr class="memdesc:abd2a51526c1f15e3f21a962457cbc53a"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps <a class="el" href="namespacecrashpad.html#a8599600814a17d622766decd5f122a96" title="Reads from a file, retrying when interrupted on POSIX or following a short read. ">ReadFile()</a>, ensuring that exactly <em>size</em> bytes are read. <a href="#abd2a51526c1f15e3f21a962457cbc53a">More...</a><br /></td></tr>
<tr class="separator:abd2a51526c1f15e3f21a962457cbc53a"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a8a91af9c690d2a280c463596bf82070b"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a8a91af9c690d2a280c463596bf82070b">LoggingWriteFile</a> (<a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a> file, const void *buffer, size_t size)</td></tr>
<tr class="memdesc:a8a91af9c690d2a280c463596bf82070b"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps <a class="el" href="namespacecrashpad.html#ab9dded3137add283f6cf32facb86641a" title="Writes to a file, retrying when interrupted or following a short write on POSIX. ">WriteFile()</a>, ensuring that exactly <em>size</em> bytes are written. <a href="#a8a91af9c690d2a280c463596bf82070b">More...</a><br /></td></tr>
<tr class="separator:a8a91af9c690d2a280c463596bf82070b"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aee611c7116746b846a3cf79e65619f4d"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#aee611c7116746b846a3cf79e65619f4d">CheckedReadFile</a> (<a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a> file, void *buffer, size_t size)</td></tr>
<tr class="memdesc:aee611c7116746b846a3cf79e65619f4d"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps <a class="el" href="namespacecrashpad.html#a8599600814a17d622766decd5f122a96" title="Reads from a file, retrying when interrupted on POSIX or following a short read. ">ReadFile()</a>, ensuring that exactly <em>size</em> bytes are read. <a href="#aee611c7116746b846a3cf79e65619f4d">More...</a><br /></td></tr>
<tr class="separator:aee611c7116746b846a3cf79e65619f4d"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a74c74fefa3b1f5e0c1b885755c9f9cf6"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a74c74fefa3b1f5e0c1b885755c9f9cf6">CheckedWriteFile</a> (<a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a> file, const void *buffer, size_t size)</td></tr>
<tr class="memdesc:a74c74fefa3b1f5e0c1b885755c9f9cf6"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps <a class="el" href="namespacecrashpad.html#ab9dded3137add283f6cf32facb86641a" title="Writes to a file, retrying when interrupted or following a short write on POSIX. ">WriteFile()</a>, ensuring that exactly <em>size</em> bytes are written. <a href="#a74c74fefa3b1f5e0c1b885755c9f9cf6">More...</a><br /></td></tr>
<tr class="separator:a74c74fefa3b1f5e0c1b885755c9f9cf6"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac8e7e1b1a4b89b489964ffee54d0d9df"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ac8e7e1b1a4b89b489964ffee54d0d9df">CheckedReadFileAtEOF</a> (<a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a> file)</td></tr>
<tr class="memdesc:ac8e7e1b1a4b89b489964ffee54d0d9df"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps <a class="el" href="namespacecrashpad.html#a8599600814a17d622766decd5f122a96" title="Reads from a file, retrying when interrupted on POSIX or following a short read. ">ReadFile()</a>, ensuring that it indicates end-of-file. <a href="#ac8e7e1b1a4b89b489964ffee54d0d9df">More...</a><br /></td></tr>
<tr class="separator:ac8e7e1b1a4b89b489964ffee54d0d9df"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac7cb2e4837a6fda169cbe92d1603460f"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ac7cb2e4837a6fda169cbe92d1603460f">CheckedCloseFile</a> (<a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a> file)</td></tr>
<tr class="memdesc:ac7cb2e4837a6fda169cbe92d1603460f"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps <code>close()</code> or <code>CloseHandle()</code>, ensuring that it succeeds. <a href="#ac7cb2e4837a6fda169cbe92d1603460f">More...</a><br /></td></tr>
<tr class="separator:ac7cb2e4837a6fda169cbe92d1603460f"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a8599600814a17d622766decd5f122a96"><td class="memItemLeft" align="right" valign="top">FileOperationResult&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a8599600814a17d622766decd5f122a96">ReadFile</a> (<a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a> file, void *buffer, size_t size)</td></tr>
<tr class="memdesc:a8599600814a17d622766decd5f122a96"><td class="mdescLeft">&#160;</td><td class="mdescRight">Reads from a file, retrying when interrupted on POSIX or following a short read. <a href="#a8599600814a17d622766decd5f122a96">More...</a><br /></td></tr>
<tr class="separator:a8599600814a17d622766decd5f122a96"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ab9dded3137add283f6cf32facb86641a"><td class="memItemLeft" align="right" valign="top">FileOperationResult&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ab9dded3137add283f6cf32facb86641a">WriteFile</a> (<a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a> file, const void *buffer, size_t size)</td></tr>
<tr class="memdesc:ab9dded3137add283f6cf32facb86641a"><td class="mdescLeft">&#160;</td><td class="mdescRight">Writes to a file, retrying when interrupted or following a short write on POSIX. <a href="#ab9dded3137add283f6cf32facb86641a">More...</a><br /></td></tr>
<tr class="separator:ab9dded3137add283f6cf32facb86641a"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a7987df05e1260e6d8d93ee3a21e9b0eb"><td class="memItemLeft" align="right" valign="top"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a7987df05e1260e6d8d93ee3a21e9b0eb">OpenFileForRead</a> (const base::FilePath &amp;path)</td></tr>
<tr class="memdesc:a7987df05e1260e6d8d93ee3a21e9b0eb"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps <code>open()</code> or <code>CreateFile()</code>, opening an existing file for reading. <a href="#a7987df05e1260e6d8d93ee3a21e9b0eb">More...</a><br /></td></tr>
<tr class="separator:a7987df05e1260e6d8d93ee3a21e9b0eb"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ad8e8848af82384f7757108c8c445f18d"><td class="memItemLeft" align="right" valign="top"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ad8e8848af82384f7757108c8c445f18d">OpenFileForWrite</a> (const base::FilePath &amp;path, <a class="el" href="namespacecrashpad.html#afa69b0967d9a6df659ff5d2a02ff3e51">FileWriteMode</a> mode, <a class="el" href="namespacecrashpad.html#a034ccc90eb0d1f587ee89275d822175d">FilePermissions</a> permissions)</td></tr>
<tr class="memdesc:ad8e8848af82384f7757108c8c445f18d"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps <code>open()</code> or <code>CreateFile()</code>, creating a file for output. <a href="#ad8e8848af82384f7757108c8c445f18d">More...</a><br /></td></tr>
<tr class="separator:ad8e8848af82384f7757108c8c445f18d"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:abe6238b18be49921772c14dd25a624de"><td class="memItemLeft" align="right" valign="top"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#abe6238b18be49921772c14dd25a624de">OpenFileForReadAndWrite</a> (const base::FilePath &amp;path, <a class="el" href="namespacecrashpad.html#afa69b0967d9a6df659ff5d2a02ff3e51">FileWriteMode</a> mode, <a class="el" href="namespacecrashpad.html#a034ccc90eb0d1f587ee89275d822175d">FilePermissions</a> permissions)</td></tr>
<tr class="memdesc:abe6238b18be49921772c14dd25a624de"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps <code>open()</code> or <code>CreateFile()</code>, creating a file for both input and output. <a href="#abe6238b18be49921772c14dd25a624de">More...</a><br /></td></tr>
<tr class="separator:abe6238b18be49921772c14dd25a624de"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ab3712d59104f641109b170c78a912b4d"><td class="memItemLeft" align="right" valign="top"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ab3712d59104f641109b170c78a912b4d">LoggingOpenFileForRead</a> (const base::FilePath &amp;path)</td></tr>
<tr class="memdesc:ab3712d59104f641109b170c78a912b4d"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps <a class="el" href="namespacecrashpad.html#a7987df05e1260e6d8d93ee3a21e9b0eb" title="Wraps open() or CreateFile(), opening an existing file for reading. ">OpenFileForRead()</a>, logging an error if the operation fails. <a href="#ab3712d59104f641109b170c78a912b4d">More...</a><br /></td></tr>
<tr class="separator:ab3712d59104f641109b170c78a912b4d"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a62fc6876cc0c660f0ea8bd1dd0a07e82"><td class="memItemLeft" align="right" valign="top"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a62fc6876cc0c660f0ea8bd1dd0a07e82">LoggingOpenFileForWrite</a> (const base::FilePath &amp;path, <a class="el" href="namespacecrashpad.html#afa69b0967d9a6df659ff5d2a02ff3e51">FileWriteMode</a> mode, <a class="el" href="namespacecrashpad.html#a034ccc90eb0d1f587ee89275d822175d">FilePermissions</a> permissions)</td></tr>
<tr class="memdesc:a62fc6876cc0c660f0ea8bd1dd0a07e82"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps <a class="el" href="namespacecrashpad.html#ad8e8848af82384f7757108c8c445f18d" title="Wraps open() or CreateFile(), creating a file for output. ">OpenFileForWrite()</a>, logging an error if the operation fails. <a href="#a62fc6876cc0c660f0ea8bd1dd0a07e82">More...</a><br /></td></tr>
<tr class="separator:a62fc6876cc0c660f0ea8bd1dd0a07e82"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aab3e964bdba04aaf74e7a27a36efe108"><td class="memItemLeft" align="right" valign="top"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#aab3e964bdba04aaf74e7a27a36efe108">LoggingOpenFileForReadAndWrite</a> (const base::FilePath &amp;path, <a class="el" href="namespacecrashpad.html#afa69b0967d9a6df659ff5d2a02ff3e51">FileWriteMode</a> mode, <a class="el" href="namespacecrashpad.html#a034ccc90eb0d1f587ee89275d822175d">FilePermissions</a> permissions)</td></tr>
<tr class="memdesc:aab3e964bdba04aaf74e7a27a36efe108"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps <a class="el" href="namespacecrashpad.html#abe6238b18be49921772c14dd25a624de" title="Wraps open() or CreateFile(), creating a file for both input and output. ">OpenFileForReadAndWrite()</a>, logging an error if the operation fails. <a href="#aab3e964bdba04aaf74e7a27a36efe108">More...</a><br /></td></tr>
<tr class="separator:aab3e964bdba04aaf74e7a27a36efe108"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:acd02263566d8c43fc7886f88a13b364f"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#acd02263566d8c43fc7886f88a13b364f">LoggingLockFile</a> (<a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a> file, <a class="el" href="namespacecrashpad.html#a3753a95b02e5c96c6e20017e467cef07">FileLocking</a> locking)</td></tr>
<tr class="memdesc:acd02263566d8c43fc7886f88a13b364f"><td class="mdescLeft">&#160;</td><td class="mdescRight">Locks the given <em>file</em> using <code>flock()</code> on POSIX or <code>LockFileEx()</code> on Windows. <a href="#acd02263566d8c43fc7886f88a13b364f">More...</a><br /></td></tr>
<tr class="separator:acd02263566d8c43fc7886f88a13b364f"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a15c1f3a2c6f04e944fdca12e22b0cb6e"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a15c1f3a2c6f04e944fdca12e22b0cb6e">LoggingUnlockFile</a> (<a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a> file)</td></tr>
<tr class="memdesc:a15c1f3a2c6f04e944fdca12e22b0cb6e"><td class="mdescLeft">&#160;</td><td class="mdescRight">Unlocks a file previously locked with <a class="el" href="namespacecrashpad.html#acd02263566d8c43fc7886f88a13b364f" title="Locks the given file using flock() on POSIX or LockFileEx() on Windows. ">LoggingLockFile()</a>. <a href="#a15c1f3a2c6f04e944fdca12e22b0cb6e">More...</a><br /></td></tr>
<tr class="separator:a15c1f3a2c6f04e944fdca12e22b0cb6e"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a3d6cedc10e24145d4a0c1000c33f8a10"><td class="memItemLeft" align="right" valign="top"><a class="el" href="namespacecrashpad.html#a1e53a1957d9edcba8b406ea632b6daf2">FileOffset</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a3d6cedc10e24145d4a0c1000c33f8a10">LoggingSeekFile</a> (<a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a> file, <a class="el" href="namespacecrashpad.html#a1e53a1957d9edcba8b406ea632b6daf2">FileOffset</a> offset, int whence)</td></tr>
<tr class="memdesc:a3d6cedc10e24145d4a0c1000c33f8a10"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps <code>lseek()</code> or <code>SetFilePointerEx()</code>. Logs an error if the operation fails. <a href="#a3d6cedc10e24145d4a0c1000c33f8a10">More...</a><br /></td></tr>
<tr class="separator:a3d6cedc10e24145d4a0c1000c33f8a10"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a06ba30c1a4b2974f1d4ea842db55b068"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a06ba30c1a4b2974f1d4ea842db55b068">LoggingTruncateFile</a> (<a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a> file)</td></tr>
<tr class="memdesc:a06ba30c1a4b2974f1d4ea842db55b068"><td class="mdescLeft">&#160;</td><td class="mdescRight">Truncates the given <em>file</em> to zero bytes in length. <a href="#a06ba30c1a4b2974f1d4ea842db55b068">More...</a><br /></td></tr>
<tr class="separator:a06ba30c1a4b2974f1d4ea842db55b068"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ab9db00544fd57cfde0bb03d32b989221"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ab9db00544fd57cfde0bb03d32b989221">LoggingCloseFile</a> (<a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a> file)</td></tr>
<tr class="memdesc:ab9db00544fd57cfde0bb03d32b989221"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps <code>close()</code> or <code>CloseHandle()</code>, logging an error if the operation fails. <a href="#ab9db00544fd57cfde0bb03d32b989221">More...</a><br /></td></tr>
<tr class="separator:ab9db00544fd57cfde0bb03d32b989221"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a0224d5a689cdb8c2315c255fd6ea6b5c"><td class="memItemLeft" align="right" valign="top"><a class="el" href="namespacecrashpad.html#a1e53a1957d9edcba8b406ea632b6daf2">FileOffset</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a0224d5a689cdb8c2315c255fd6ea6b5c">LoggingFileSizeByHandle</a> (<a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a> file)</td></tr>
<tr class="memdesc:a0224d5a689cdb8c2315c255fd6ea6b5c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Determines the size of a file. <a href="#a0224d5a689cdb8c2315c255fd6ea6b5c">More...</a><br /></td></tr>
<tr class="separator:a0224d5a689cdb8c2315c255fd6ea6b5c"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a616ed0784021ecbd2f0f14b7e75c068c"><td class="memItemLeft" align="right" valign="top">launch_data_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a616ed0784021ecbd2f0f14b7e75c068c">CFPropertyToLaunchData</a> (CFPropertyListRef property_cf)</td></tr>
<tr class="memdesc:a616ed0784021ecbd2f0f14b7e75c068c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Converts a Core Foundation-type property list to a launchd-type <code>launch_data_t</code>. <a href="#a616ed0784021ecbd2f0f14b7e75c068c">More...</a><br /></td></tr>
<tr class="separator:a616ed0784021ecbd2f0f14b7e75c068c"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ab05052e02f3c3605fd7bae0f006d2cba"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ab05052e02f3c3605fd7bae0f006d2cba">MacOSXMinorVersion</a> ()</td></tr>
<tr class="memdesc:ab05052e02f3c3605fd7bae0f006d2cba"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns the version of the running operating system. <a href="#ab05052e02f3c3605fd7bae0f006d2cba">More...</a><br /></td></tr>
<tr class="separator:ab05052e02f3c3605fd7bae0f006d2cba"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a99a833f0c39ce203b49862367494a923"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a99a833f0c39ce203b49862367494a923">MacOSXVersion</a> (int *major, int *minor, int *bugfix, std::string *build, bool *server, std::string *version_string)</td></tr>
<tr class="memdesc:a99a833f0c39ce203b49862367494a923"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns the version of the running operating system. <a href="#a99a833f0c39ce203b49862367494a923">More...</a><br /></td></tr>
<tr class="separator:a99a833f0c39ce203b49862367494a923"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a71c79500b827d06b190e30b7cc016c35"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a71c79500b827d06b190e30b7cc016c35">MacModelAndBoard</a> (std::string *model, std::string *board_id)</td></tr>
<tr class="memdesc:a71c79500b827d06b190e30b7cc016c35"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns the model name and board ID of the running system. <a href="#a71c79500b827d06b190e30b7cc016c35">More...</a><br /></td></tr>
<tr class="separator:a71c79500b827d06b190e30b7cc016c35"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a97ebbbac4c7f27e2e3ba2b9c080ed0f3"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a97ebbbac4c7f27e2e3ba2b9c080ed0f3">ServiceManagementSubmitJob</a> (CFDictionaryRef job_cf)</td></tr>
<tr class="memdesc:a97ebbbac4c7f27e2e3ba2b9c080ed0f3"><td class="mdescLeft">&#160;</td><td class="mdescRight">Submits a job to the user launchd domain as in <code>SMJobSubmit()</code>. <a href="#a97ebbbac4c7f27e2e3ba2b9c080ed0f3">More...</a><br /></td></tr>
<tr class="separator:a97ebbbac4c7f27e2e3ba2b9c080ed0f3"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a8cc130fecf996b7d7c76a56200afccb1"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a8cc130fecf996b7d7c76a56200afccb1">ServiceManagementRemoveJob</a> (const std::string &amp;label, bool wait)</td></tr>
<tr class="memdesc:a8cc130fecf996b7d7c76a56200afccb1"><td class="mdescLeft">&#160;</td><td class="mdescRight">Removes a job from the user launchd domain as in <code>SMJobRemove()</code>. <a href="#a8cc130fecf996b7d7c76a56200afccb1">More...</a><br /></td></tr>
<tr class="separator:a8cc130fecf996b7d7c76a56200afccb1"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aead5f04bd94549956a7f2826aeccf495"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#aead5f04bd94549956a7f2826aeccf495">ServiceManagementIsJobLoaded</a> (const std::string &amp;label)</td></tr>
<tr class="memdesc:aead5f04bd94549956a7f2826aeccf495"><td class="mdescLeft">&#160;</td><td class="mdescRight">Determines whether a specified job is loaded in the user launchd domain. <a href="#aead5f04bd94549956a7f2826aeccf495">More...</a><br /></td></tr>
<tr class="separator:aead5f04bd94549956a7f2826aeccf495"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a3bc3a94386dd27968d48619f42154463"><td class="memItemLeft" align="right" valign="top">pid_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a3bc3a94386dd27968d48619f42154463">ServiceManagementIsJobRunning</a> (const std::string &amp;label)</td></tr>
<tr class="memdesc:a3bc3a94386dd27968d48619f42154463"><td class="mdescLeft">&#160;</td><td class="mdescRight">Determines whether a specified job is running in the user launchd domain. <a href="#a3bc3a94386dd27968d48619f42154463">More...</a><br /></td></tr>
<tr class="separator:a3bc3a94386dd27968d48619f42154463"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac86f028e5f175cccfcab418346d7bcfe"><td class="memItemLeft" align="right" valign="top"><a class="el" href="namespacecrashpad.html#a589b4d9bd6f2233b67148ab6793c3c13">XattrStatus</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ac86f028e5f175cccfcab418346d7bcfe">ReadXattr</a> (const base::FilePath &amp;file, const base::StringPiece &amp;name, std::string *value)</td></tr>
<tr class="memdesc:ac86f028e5f175cccfcab418346d7bcfe"><td class="mdescLeft">&#160;</td><td class="mdescRight">Reads an extended attribute on a file. <a href="#ac86f028e5f175cccfcab418346d7bcfe">More...</a><br /></td></tr>
<tr class="separator:ac86f028e5f175cccfcab418346d7bcfe"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a6842e0ae3110f04477765c771c04dc60"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a6842e0ae3110f04477765c771c04dc60">WriteXattr</a> (const base::FilePath &amp;file, const base::StringPiece &amp;name, const std::string &amp;value)</td></tr>
<tr class="memdesc:a6842e0ae3110f04477765c771c04dc60"><td class="mdescLeft">&#160;</td><td class="mdescRight">Writes an extended attribute on a file. <a href="#a6842e0ae3110f04477765c771c04dc60">More...</a><br /></td></tr>
<tr class="separator:a6842e0ae3110f04477765c771c04dc60"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ab8c682ff6d5f00ca828640a72436e196"><td class="memItemLeft" align="right" valign="top"><a class="el" href="namespacecrashpad.html#a589b4d9bd6f2233b67148ab6793c3c13">XattrStatus</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ab8c682ff6d5f00ca828640a72436e196">ReadXattrBool</a> (const base::FilePath &amp;file, const base::StringPiece &amp;name, bool *value)</td></tr>
<tr class="memdesc:ab8c682ff6d5f00ca828640a72436e196"><td class="mdescLeft">&#160;</td><td class="mdescRight">Reads an extended attribute on a file. <a href="#ab8c682ff6d5f00ca828640a72436e196">More...</a><br /></td></tr>
<tr class="separator:ab8c682ff6d5f00ca828640a72436e196"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ae086861e350e7225e4ea065d941e664f"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ae086861e350e7225e4ea065d941e664f">WriteXattrBool</a> (const base::FilePath &amp;file, const base::StringPiece &amp;name, bool value)</td></tr>
<tr class="memdesc:ae086861e350e7225e4ea065d941e664f"><td class="mdescLeft">&#160;</td><td class="mdescRight">Writes an extended attribute on a file. <a href="#ae086861e350e7225e4ea065d941e664f">More...</a><br /></td></tr>
<tr class="separator:ae086861e350e7225e4ea065d941e664f"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a0c28700ce2629c13b5b8bb1392625ef4"><td class="memItemLeft" align="right" valign="top"><a class="el" href="namespacecrashpad.html#a589b4d9bd6f2233b67148ab6793c3c13">XattrStatus</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a0c28700ce2629c13b5b8bb1392625ef4">ReadXattrInt</a> (const base::FilePath &amp;file, const base::StringPiece &amp;name, int *value)</td></tr>
<tr class="memdesc:a0c28700ce2629c13b5b8bb1392625ef4"><td class="mdescLeft">&#160;</td><td class="mdescRight">Reads an extended attribute on a file. <a href="#a0c28700ce2629c13b5b8bb1392625ef4">More...</a><br /></td></tr>
<tr class="separator:a0c28700ce2629c13b5b8bb1392625ef4"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a85a3551184d900a1d970bd8fa0be0ec3"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a85a3551184d900a1d970bd8fa0be0ec3">WriteXattrInt</a> (const base::FilePath &amp;file, const base::StringPiece &amp;name, int value)</td></tr>
<tr class="memdesc:a85a3551184d900a1d970bd8fa0be0ec3"><td class="mdescLeft">&#160;</td><td class="mdescRight">Writes an extended attribute on a file. <a href="#a85a3551184d900a1d970bd8fa0be0ec3">More...</a><br /></td></tr>
<tr class="separator:a85a3551184d900a1d970bd8fa0be0ec3"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a71572c94f27aba3f34938d3a0d9030a3"><td class="memItemLeft" align="right" valign="top"><a class="el" href="namespacecrashpad.html#a589b4d9bd6f2233b67148ab6793c3c13">XattrStatus</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a71572c94f27aba3f34938d3a0d9030a3">ReadXattrTimeT</a> (const base::FilePath &amp;file, const base::StringPiece &amp;name, time_t *value)</td></tr>
<tr class="memdesc:a71572c94f27aba3f34938d3a0d9030a3"><td class="mdescLeft">&#160;</td><td class="mdescRight">Reads an extended attribute on a file. <a href="#a71572c94f27aba3f34938d3a0d9030a3">More...</a><br /></td></tr>
<tr class="separator:a71572c94f27aba3f34938d3a0d9030a3"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ae63f9a1eeeec00b78c216f72b1ca1327"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ae63f9a1eeeec00b78c216f72b1ca1327">WriteXattrTimeT</a> (const base::FilePath &amp;file, const base::StringPiece &amp;name, time_t value)</td></tr>
<tr class="memdesc:ae63f9a1eeeec00b78c216f72b1ca1327"><td class="mdescLeft">&#160;</td><td class="mdescRight">Writes an extended attribute on a file. <a href="#ae63f9a1eeeec00b78c216f72b1ca1327">More...</a><br /></td></tr>
<tr class="separator:ae63f9a1eeeec00b78c216f72b1ca1327"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a354d84b9ce60fa7d437c2ee6f58ea05f"><td class="memItemLeft" align="right" valign="top"><a class="el" href="namespacecrashpad.html#a589b4d9bd6f2233b67148ab6793c3c13">XattrStatus</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a354d84b9ce60fa7d437c2ee6f58ea05f">RemoveXattr</a> (const base::FilePath &amp;file, const base::StringPiece &amp;name)</td></tr>
<tr class="memdesc:a354d84b9ce60fa7d437c2ee6f58ea05f"><td class="mdescLeft">&#160;</td><td class="mdescRight">Removes an extended attribute from a file. <a href="#a354d84b9ce60fa7d437c2ee6f58ea05f">More...</a><br /></td></tr>
<tr class="separator:a354d84b9ce60fa7d437c2ee6f58ea05f"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a34001ec0bfa5e0815fa478a8cf025c61"><td class="memItemLeft" align="right" valign="top">kern_return_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a34001ec0bfa5e0815fa478a8cf025c61">UniversalExceptionRaise</a> (exception_behavior_t behavior, exception_handler_t exception_port, thread_t thread, task_t task, exception_type_t exception, const mach_exception_data_type_t *code, mach_msg_type_number_t code_count, thread_state_flavor_t *flavor, <a class="el" href="namespacecrashpad.html#a72fa9ea632f7f1ec93ec3c1b1d300db6">ConstThreadState</a> old_state, mach_msg_type_number_t old_state_count, thread_state_t new_state, mach_msg_type_number_t *new_state_count)</td></tr>
<tr class="memdesc:a34001ec0bfa5e0815fa478a8cf025c61"><td class="mdescLeft">&#160;</td><td class="mdescRight">Calls the appropriate <code>*exception_raise*()</code> function for the specified <em>behavior</em>. <a href="#a34001ec0bfa5e0815fa478a8cf025c61">More...</a><br /></td></tr>
<tr class="separator:a34001ec0bfa5e0815fa478a8cf025c61"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a2112e7fcb6a2fc7f9b6b0ff8856e8466"><td class="memItemLeft" align="right" valign="top">kern_return_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a2112e7fcb6a2fc7f9b6b0ff8856e8466">ExcServerSuccessfulReturnValue</a> (exception_type_t exception, exception_behavior_t behavior, bool set_thread_state)</td></tr>
<tr class="memdesc:a2112e7fcb6a2fc7f9b6b0ff8856e8466"><td class="mdescLeft">&#160;</td><td class="mdescRight">Computes an approriate successful return value for an exception handler function. <a href="#a2112e7fcb6a2fc7f9b6b0ff8856e8466">More...</a><br /></td></tr>
<tr class="separator:a2112e7fcb6a2fc7f9b6b0ff8856e8466"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac192440e1d208f5dd348f0cba652d93a"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ac192440e1d208f5dd348f0cba652d93a">ExcServerCopyState</a> (exception_behavior_t behavior, <a class="el" href="namespacecrashpad.html#a72fa9ea632f7f1ec93ec3c1b1d300db6">ConstThreadState</a> old_state, mach_msg_type_number_t old_state_count, thread_state_t new_state, mach_msg_type_number_t *new_state_count)</td></tr>
<tr class="memdesc:ac192440e1d208f5dd348f0cba652d93a"><td class="mdescLeft">&#160;</td><td class="mdescRight">Copies the old state to the new state for state-carrying exceptions. <a href="#ac192440e1d208f5dd348f0cba652d93a">More...</a><br /></td></tr>
<tr class="separator:ac192440e1d208f5dd348f0cba652d93a"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:acea6434eb784ccde471620e9d79ba8c1"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#acea6434eb784ccde471620e9d79ba8c1">ExceptionBehaviorHasState</a> (exception_behavior_t behavior)</td></tr>
<tr class="memdesc:acea6434eb784ccde471620e9d79ba8c1"><td class="mdescLeft">&#160;</td><td class="mdescRight">Determines whether <em>behavior</em> indicates an exception behavior that carries thread state information. <a href="#acea6434eb784ccde471620e9d79ba8c1">More...</a><br /></td></tr>
<tr class="separator:acea6434eb784ccde471620e9d79ba8c1"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a5d424769dc3683b809a9783f9319d4ab"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a5d424769dc3683b809a9783f9319d4ab">ExceptionBehaviorHasIdentity</a> (exception_behavior_t behavior)</td></tr>
<tr class="memdesc:a5d424769dc3683b809a9783f9319d4ab"><td class="mdescLeft">&#160;</td><td class="mdescRight">Determines whether <em>behavior</em> indicates an exception behavior that carries thread and task identities. <a href="#a5d424769dc3683b809a9783f9319d4ab">More...</a><br /></td></tr>
<tr class="separator:a5d424769dc3683b809a9783f9319d4ab"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a6cd35f65144317021b4ea09a2b779bfb"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a6cd35f65144317021b4ea09a2b779bfb">ExceptionBehaviorHasMachExceptionCodes</a> (exception_behavior_t behavior)</td></tr>
<tr class="memdesc:a6cd35f65144317021b4ea09a2b779bfb"><td class="mdescLeft">&#160;</td><td class="mdescRight">Determines whether <em>behavior</em> indicates an exception behavior that carries 64-bit exception codes (“Mach exception codes”). <a href="#a6cd35f65144317021b4ea09a2b779bfb">More...</a><br /></td></tr>
<tr class="separator:a6cd35f65144317021b4ea09a2b779bfb"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a2e26b5b9a8355ab15063b1c07fa6dff7"><td class="memItemLeft" align="right" valign="top">exception_behavior_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a2e26b5b9a8355ab15063b1c07fa6dff7">ExceptionBehaviorBasic</a> (exception_behavior_t behavior)</td></tr>
<tr class="memdesc:a2e26b5b9a8355ab15063b1c07fa6dff7"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns the basic behavior value of <em>behavior</em>, its value without <code>MACH_EXCEPTION_CODES</code> set. <a href="#a2e26b5b9a8355ab15063b1c07fa6dff7">More...</a><br /></td></tr>
<tr class="separator:a2e26b5b9a8355ab15063b1c07fa6dff7"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a830c754edaa401f7d866e69369f76ae1"><td class="memItemLeft" align="right" valign="top">exception_type_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a830c754edaa401f7d866e69369f76ae1">ExcCrashRecoverOriginalException</a> (mach_exception_code_t code_0, mach_exception_code_t *original_code_0, int *signal)</td></tr>
<tr class="memdesc:a830c754edaa401f7d866e69369f76ae1"><td class="mdescLeft">&#160;</td><td class="mdescRight">Recovers the original exception, first exception code, and signal from the encoded form of the first exception code delivered with <code>EXC_CRASH</code> exceptions. <a href="#a830c754edaa401f7d866e69369f76ae1">More...</a><br /></td></tr>
<tr class="separator:a830c754edaa401f7d866e69369f76ae1"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ad2ac0b9fe2a066fecac5e8d9b977e892"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ad2ac0b9fe2a066fecac5e8d9b977e892">IsExceptionNonfatalResource</a> (exception_type_t exception, mach_exception_code_t code_0, pid_t pid)</td></tr>
<tr class="memdesc:ad2ac0b9fe2a066fecac5e8d9b977e892"><td class="mdescLeft">&#160;</td><td class="mdescRight">Determines whether an exception is a non-fatal <code>EXC_RESOURCE</code>. <a href="#ad2ac0b9fe2a066fecac5e8d9b977e892">More...</a><br /></td></tr>
<tr class="separator:ad2ac0b9fe2a066fecac5e8d9b977e892"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a79ee9764b34c0267b58f54404946275a"><td class="memItemLeft" align="right" valign="top">thread_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a79ee9764b34c0267b58f54404946275a">MachThreadSelf</a> ()</td></tr>
<tr class="memdesc:a79ee9764b34c0267b58f54404946275a"><td class="mdescLeft">&#160;</td><td class="mdescRight">Like <code>mach_thread_self()</code>, but without the obligation to release the send right. <a href="#a79ee9764b34c0267b58f54404946275a">More...</a><br /></td></tr>
<tr class="separator:a79ee9764b34c0267b58f54404946275a"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a9c9bc6ad9973f794c425707617b63278"><td class="memItemLeft" align="right" valign="top">mach_port_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a9c9bc6ad9973f794c425707617b63278">NewMachPort</a> (mach_port_right_t right)</td></tr>
<tr class="memdesc:a9c9bc6ad9973f794c425707617b63278"><td class="mdescLeft">&#160;</td><td class="mdescRight">Creates a new Mach port in the current task. <a href="#a9c9bc6ad9973f794c425707617b63278">More...</a><br /></td></tr>
<tr class="separator:a9c9bc6ad9973f794c425707617b63278"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a194e0575e09db56e4107e1c41b27c941"><td class="memItemLeft" align="right" valign="top">exception_mask_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a194e0575e09db56e4107e1c41b27c941">ExcMaskAll</a> ()</td></tr>
<tr class="memdesc:a194e0575e09db56e4107e1c41b27c941"><td class="mdescLeft">&#160;</td><td class="mdescRight">The value for <code>EXC_MASK_ALL</code> appropriate for the operating system at run time. <a href="#a194e0575e09db56e4107e1c41b27c941">More...</a><br /></td></tr>
<tr class="separator:a194e0575e09db56e4107e1c41b27c941"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a18e47623f33e0c86fef1d08a82b28cc9"><td class="memItemLeft" align="right" valign="top">exception_mask_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a18e47623f33e0c86fef1d08a82b28cc9">ExcMaskValid</a> ()</td></tr>
<tr class="memdesc:a18e47623f33e0c86fef1d08a82b28cc9"><td class="mdescLeft">&#160;</td><td class="mdescRight">An exception mask containing every possible exception understood by the operating system at run time. <a href="#a18e47623f33e0c86fef1d08a82b28cc9">More...</a><br /></td></tr>
<tr class="separator:a18e47623f33e0c86fef1d08a82b28cc9"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:af63980b36cac449785c26cee00c89205"><td class="memItemLeft" align="right" valign="top">base::mac::ScopedMachReceiveRight&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#af63980b36cac449785c26cee00c89205">BootstrapCheckIn</a> (const std::string &amp;service_name)</td></tr>
<tr class="memdesc:af63980b36cac449785c26cee00c89205"><td class="mdescLeft">&#160;</td><td class="mdescRight">Makes a <code>boostrap_check_in()</code> call to the process bootstrap server. <a href="#af63980b36cac449785c26cee00c89205">More...</a><br /></td></tr>
<tr class="separator:af63980b36cac449785c26cee00c89205"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a32e6cb4455e49ede76dab41a256962ee"><td class="memItemLeft" align="right" valign="top">base::mac::ScopedMachSendRight&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a32e6cb4455e49ede76dab41a256962ee">BootstrapLookUp</a> (const std::string &amp;service_name)</td></tr>
<tr class="memdesc:a32e6cb4455e49ede76dab41a256962ee"><td class="mdescLeft">&#160;</td><td class="mdescRight">Makes a <code>boostrap_look_up()</code> call to the process bootstrap server. <a href="#a32e6cb4455e49ede76dab41a256962ee">More...</a><br /></td></tr>
<tr class="separator:a32e6cb4455e49ede76dab41a256962ee"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a47204f3a62646651e8f393cac2a6316b"><td class="memItemLeft" align="right" valign="top">base::mac::ScopedMachSendRight&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a47204f3a62646651e8f393cac2a6316b">SystemCrashReporterHandler</a> ()</td></tr>
<tr class="memdesc:a47204f3a62646651e8f393cac2a6316b"><td class="mdescLeft">&#160;</td><td class="mdescRight">Obtains the systems default Mach exception handler for crash-type exceptions. <a href="#a47204f3a62646651e8f393cac2a6316b">More...</a><br /></td></tr>
<tr class="separator:a47204f3a62646651e8f393cac2a6316b"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aa31f495c675536bcb30d1267c3a9b696"><td class="memItemLeft" align="right" valign="top"><a class="el" href="namespacecrashpad.html#a34f36473e385b19eb229798ab2f7210c">MachMessageDeadline</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#aa31f495c675536bcb30d1267c3a9b696">MachMessageDeadlineFromTimeout</a> (mach_msg_timeout_t timeout_ms)</td></tr>
<tr class="memdesc:aa31f495c675536bcb30d1267c3a9b696"><td class="mdescLeft">&#160;</td><td class="mdescRight">Computes the deadline for a specified timeout value. <a href="#aa31f495c675536bcb30d1267c3a9b696">More...</a><br /></td></tr>
<tr class="separator:aa31f495c675536bcb30d1267c3a9b696"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a35293418a0b7637a00631807ac4b431e"><td class="memItemLeft" align="right" valign="top">mach_msg_return_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a35293418a0b7637a00631807ac4b431e">MachMessageWithDeadline</a> (mach_msg_header_t *message, mach_msg_option_t options, mach_msg_size_t receive_size, mach_port_name_t receive_port, <a class="el" href="namespacecrashpad.html#a34f36473e385b19eb229798ab2f7210c">MachMessageDeadline</a> deadline, mach_port_name_t notify_port, bool run_even_if_expired)</td></tr>
<tr class="memdesc:a35293418a0b7637a00631807ac4b431e"><td class="mdescLeft">&#160;</td><td class="mdescRight">Runs <code>mach_msg()</code> with a deadline, as opposed to a timeout. <a href="#a35293418a0b7637a00631807ac4b431e">More...</a><br /></td></tr>
<tr class="separator:a35293418a0b7637a00631807ac4b431e"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a2274adc0459f68b93ffe51d8f975f14e"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a2274adc0459f68b93ffe51d8f975f14e">PrepareMIGReplyFromRequest</a> (const mach_msg_header_t *in_header, mach_msg_header_t *out_header)</td></tr>
<tr class="memdesc:a2274adc0459f68b93ffe51d8f975f14e"><td class="mdescLeft">&#160;</td><td class="mdescRight">Initializes a reply message for a MIG server routine based on its corresponding request. <a href="#a2274adc0459f68b93ffe51d8f975f14e">More...</a><br /></td></tr>
<tr class="separator:a2274adc0459f68b93ffe51d8f975f14e"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aa023691aedd4f3e6faa923e8d2095947"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#aa023691aedd4f3e6faa923e8d2095947">SetMIGReplyError</a> (mach_msg_header_t *out_header, kern_return_t error)</td></tr>
<tr class="memdesc:aa023691aedd4f3e6faa923e8d2095947"><td class="mdescLeft">&#160;</td><td class="mdescRight">Sets the error code in a reply message for a MIG server routine. <a href="#aa023691aedd4f3e6faa923e8d2095947">More...</a><br /></td></tr>
<tr class="separator:aa023691aedd4f3e6faa923e8d2095947"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a979ca1d327dcf56488d3304efa9680eb"><td class="memItemLeft" align="right" valign="top">const mach_msg_trailer_t *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a979ca1d327dcf56488d3304efa9680eb">MachMessageTrailerFromHeader</a> (const mach_msg_header_t *header)</td></tr>
<tr class="memdesc:a979ca1d327dcf56488d3304efa9680eb"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns a Mach message trailer for a message that has been received. <a href="#a979ca1d327dcf56488d3304efa9680eb">More...</a><br /></td></tr>
<tr class="separator:a979ca1d327dcf56488d3304efa9680eb"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a2c18eae8148ec3304733581a28c2da3b"><td class="memItemLeft" align="right" valign="top">pid_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a2c18eae8148ec3304733581a28c2da3b">AuditPIDFromMachMessageTrailer</a> (const mach_msg_trailer_t *trailer)</td></tr>
<tr class="memdesc:a2c18eae8148ec3304733581a28c2da3b"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns the process ID of a Mach messages sender from its audit trailer. <a href="#a2c18eae8148ec3304733581a28c2da3b">More...</a><br /></td></tr>
<tr class="separator:a2c18eae8148ec3304733581a28c2da3b"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a2670a96d46f33b0e88db50a6222c0b47"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a2670a96d46f33b0e88db50a6222c0b47">MachMessageDestroyReceivedPort</a> (mach_port_t port, mach_msg_type_name_t port_right_type)</td></tr>
<tr class="memdesc:a2670a96d46f33b0e88db50a6222c0b47"><td class="mdescLeft">&#160;</td><td class="mdescRight">Destroys or deallocates a Mach port received in a Mach message. <a href="#a2670a96d46f33b0e88db50a6222c0b47">More...</a><br /></td></tr>
<tr class="separator:a2670a96d46f33b0e88db50a6222c0b47"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a05296bfd23550f42639067355410811e"><td class="memItemLeft" align="right" valign="top">std::string&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a05296bfd23550f42639067355410811e">ExceptionToString</a> (exception_type_t exception, <a class="el" href="namespacecrashpad.html#a0f13feba965ef7750b3d49064936e5ee">SymbolicConstantToStringOptions</a> options)</td></tr>
<tr class="memdesc:a05296bfd23550f42639067355410811e"><td class="mdescLeft">&#160;</td><td class="mdescRight">Converts a Mach exception value to a textual representation. <a href="#a05296bfd23550f42639067355410811e">More...</a><br /></td></tr>
<tr class="separator:a05296bfd23550f42639067355410811e"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a229a9b5ddd24c6722e413e6132d0acf0"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a229a9b5ddd24c6722e413e6132d0acf0">StringToException</a> (const base::StringPiece &amp;string, <a class="el" href="namespacecrashpad.html#a14f1de509869f929122998a2f88f08a6">StringToSymbolicConstantOptions</a> options, exception_type_t *exception)</td></tr>
<tr class="memdesc:a229a9b5ddd24c6722e413e6132d0acf0"><td class="mdescLeft">&#160;</td><td class="mdescRight">Converts a string to its corresponding Mach exception value. <a href="#a229a9b5ddd24c6722e413e6132d0acf0">More...</a><br /></td></tr>
<tr class="separator:a229a9b5ddd24c6722e413e6132d0acf0"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a8ee31102507c0f75d82496dcd6f6b53b"><td class="memItemLeft" align="right" valign="top">std::string&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a8ee31102507c0f75d82496dcd6f6b53b">ExceptionMaskToString</a> (exception_mask_t exception_mask, <a class="el" href="namespacecrashpad.html#a0f13feba965ef7750b3d49064936e5ee">SymbolicConstantToStringOptions</a> options)</td></tr>
<tr class="memdesc:a8ee31102507c0f75d82496dcd6f6b53b"><td class="mdescLeft">&#160;</td><td class="mdescRight">Converts a Mach exception mask value to a textual representation. <a href="#a8ee31102507c0f75d82496dcd6f6b53b">More...</a><br /></td></tr>
<tr class="separator:a8ee31102507c0f75d82496dcd6f6b53b"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a7ab63868a738f3bfd4d2449e60607dec"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a7ab63868a738f3bfd4d2449e60607dec">StringToExceptionMask</a> (const base::StringPiece &amp;string, <a class="el" href="namespacecrashpad.html#a14f1de509869f929122998a2f88f08a6">StringToSymbolicConstantOptions</a> options, exception_mask_t *exception_mask)</td></tr>
<tr class="memdesc:a7ab63868a738f3bfd4d2449e60607dec"><td class="mdescLeft">&#160;</td><td class="mdescRight">Converts a string to its corresponding Mach exception mask value. <a href="#a7ab63868a738f3bfd4d2449e60607dec">More...</a><br /></td></tr>
<tr class="separator:a7ab63868a738f3bfd4d2449e60607dec"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a53fd131112ba6eba0d81467733a7643a"><td class="memItemLeft" align="right" valign="top">std::string&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a53fd131112ba6eba0d81467733a7643a">ExceptionBehaviorToString</a> (exception_behavior_t behavior, <a class="el" href="namespacecrashpad.html#a0f13feba965ef7750b3d49064936e5ee">SymbolicConstantToStringOptions</a> options)</td></tr>
<tr class="memdesc:a53fd131112ba6eba0d81467733a7643a"><td class="mdescLeft">&#160;</td><td class="mdescRight">Converts a Mach exception behavior value to a textual representation. <a href="#a53fd131112ba6eba0d81467733a7643a">More...</a><br /></td></tr>
<tr class="separator:a53fd131112ba6eba0d81467733a7643a"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a957c7de6eb716bf1662c08333b1f7e21"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a957c7de6eb716bf1662c08333b1f7e21">StringToExceptionBehavior</a> (const base::StringPiece &amp;string, <a class="el" href="namespacecrashpad.html#a14f1de509869f929122998a2f88f08a6">StringToSymbolicConstantOptions</a> options, exception_behavior_t *behavior)</td></tr>
<tr class="memdesc:a957c7de6eb716bf1662c08333b1f7e21"><td class="mdescLeft">&#160;</td><td class="mdescRight">Converts a string to its corresponding Mach exception behavior value. <a href="#a957c7de6eb716bf1662c08333b1f7e21">More...</a><br /></td></tr>
<tr class="separator:a957c7de6eb716bf1662c08333b1f7e21"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a857f6b2f39cb21b22891242df26757e0"><td class="memItemLeft" align="right" valign="top">std::string&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a857f6b2f39cb21b22891242df26757e0">ThreadStateFlavorToString</a> (thread_state_flavor_t flavor, <a class="el" href="namespacecrashpad.html#a0f13feba965ef7750b3d49064936e5ee">SymbolicConstantToStringOptions</a> options)</td></tr>
<tr class="memdesc:a857f6b2f39cb21b22891242df26757e0"><td class="mdescLeft">&#160;</td><td class="mdescRight">Converts a thread state flavor value to a textual representation. <a href="#a857f6b2f39cb21b22891242df26757e0">More...</a><br /></td></tr>
<tr class="separator:a857f6b2f39cb21b22891242df26757e0"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a2fdb1f659a2813e80d5b644020a44208"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a2fdb1f659a2813e80d5b644020a44208">StringToThreadStateFlavor</a> (const base::StringPiece &amp;string, <a class="el" href="namespacecrashpad.html#a14f1de509869f929122998a2f88f08a6">StringToSymbolicConstantOptions</a> options, thread_state_flavor_t *flavor)</td></tr>
<tr class="memdesc:a2fdb1f659a2813e80d5b644020a44208"><td class="mdescLeft">&#160;</td><td class="mdescRight">Converts a string to its corresponding thread state flavor value. <a href="#a2fdb1f659a2813e80d5b644020a44208">More...</a><br /></td></tr>
<tr class="separator:a2fdb1f659a2813e80d5b644020a44208"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aeff94a266a84248b3ff0defae01efd8d"><td class="memItemLeft" align="right" valign="top">task_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#aeff94a266a84248b3ff0defae01efd8d">TaskForPID</a> (pid_t pid)</td></tr>
<tr class="memdesc:aeff94a266a84248b3ff0defae01efd8d"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps <code>task_for_pid()</code>. <a href="#aeff94a266a84248b3ff0defae01efd8d">More...</a><br /></td></tr>
<tr class="separator:aeff94a266a84248b3ff0defae01efd8d"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aa93af751a4a09c316fb3de1a90e03fe8"><td class="memItemLeft" align="right" valign="top">uint64_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#aa93af751a4a09c316fb3de1a90e03fe8">ClockMonotonicNanoseconds</a> ()</td></tr>
<tr class="memdesc:aa93af751a4a09c316fb3de1a90e03fe8"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns the value of the systems monotonic clock. <a href="#aa93af751a4a09c316fb3de1a90e03fe8">More...</a><br /></td></tr>
<tr class="separator:aa93af751a4a09c316fb3de1a90e03fe8"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a8f1db976c6e43d3731c26df569368592"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a8f1db976c6e43d3731c26df569368592">SleepNanoseconds</a> (uint64_t nanoseconds)</td></tr>
<tr class="memdesc:a8f1db976c6e43d3731c26df569368592"><td class="mdescLeft">&#160;</td><td class="mdescRight">Sleeps for the specified duration. <a href="#a8f1db976c6e43d3731c26df569368592">More...</a><br /></td></tr>
<tr class="separator:a8f1db976c6e43d3731c26df569368592"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a076e2d18f70b3edd2e1195fe699aeb73"><td class="memTemplParams" colspan="2"><a id="a076e2d18f70b3edd2e1195fe699aeb73"></a>
template&lt;typename To , typename From &gt; </td></tr>
<tr class="memitem:a076e2d18f70b3edd2e1195fe699aeb73"><td class="memTemplItemLeft" align="right" valign="top">To&#160;</td><td class="memTemplItemRight" valign="bottom"><b>implicit_cast</b> (From const &amp;f)</td></tr>
<tr class="separator:a076e2d18f70b3edd2e1195fe699aeb73"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ab15d0aff86a0aafe6f33cbd8913441c7"><td class="memItemLeft" align="right" valign="top">std::string&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ab15d0aff86a0aafe6f33cbd8913441c7">RandomString</a> ()</td></tr>
<tr class="memdesc:ab15d0aff86a0aafe6f33cbd8913441c7"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns a random string. <a href="#ab15d0aff86a0aafe6f33cbd8913441c7">More...</a><br /></td></tr>
<tr class="separator:ab15d0aff86a0aafe6f33cbd8913441c7"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a6e1b1c536af301cd418dad62348b1d29"><td class="memTemplParams" colspan="2">template&lt;typename Destination , typename Source &gt; </td></tr>
<tr class="memitem:a6e1b1c536af301cd418dad62348b1d29"><td class="memTemplItemLeft" align="right" valign="top">Destination&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a6e1b1c536af301cd418dad62348b1d29">InRangeCast</a> (Source source, Destination default_value)</td></tr>
<tr class="memdesc:a6e1b1c536af301cd418dad62348b1d29"><td class="mdescLeft">&#160;</td><td class="mdescRight">Casts to a different type if it can be done without data loss, logging a warning message and returing a default value otherwise. <a href="#a6e1b1c536af301cd418dad62348b1d29">More...</a><br /></td></tr>
<tr class="separator:a6e1b1c536af301cd418dad62348b1d29"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aeb040202b4562c8c4087b9c9db2ce430"><td class="memTemplParams" colspan="2">template&lt;typename Destination , typename Source &gt; </td></tr>
<tr class="memitem:aeb040202b4562c8c4087b9c9db2ce430"><td class="memTemplItemLeft" align="right" valign="top">bool&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#aeb040202b4562c8c4087b9c9db2ce430">AssignIfInRange</a> (Destination *destination, Source source)</td></tr>
<tr class="memdesc:aeb040202b4562c8c4087b9c9db2ce430"><td class="mdescLeft">&#160;</td><td class="mdescRight">Performs an assignment if it can be done safely, and signals if it cannot be done safely. <a href="#aeb040202b4562c8c4087b9c9db2ce430">More...</a><br /></td></tr>
<tr class="separator:aeb040202b4562c8c4087b9c9db2ce430"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a003f563ef0fe26081b4520012e0c1ef8"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a003f563ef0fe26081b4520012e0c1ef8">CloseMultipleNowOrOnExec</a> (int fd, int preserve_fd)</td></tr>
<tr class="memdesc:a003f563ef0fe26081b4520012e0c1ef8"><td class="mdescLeft">&#160;</td><td class="mdescRight">Close multiple file descriptors or mark them close-on-exec. <a href="#a003f563ef0fe26081b4520012e0c1ef8">More...</a><br /></td></tr>
<tr class="separator:a003f563ef0fe26081b4520012e0c1ef8"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aa8a3145ce95463d1638428b2547cde4d"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#aa8a3145ce95463d1638428b2547cde4d">CloseStdinAndStdout</a> ()</td></tr>
<tr class="memdesc:aa8a3145ce95463d1638428b2547cde4d"><td class="mdescLeft">&#160;</td><td class="mdescRight">Closes <code>stdin</code> and <code>stdout</code> by opening <code>/dev/null</code> over them. <a href="#aa8a3145ce95463d1638428b2547cde4d">More...</a><br /></td></tr>
<tr class="separator:aa8a3145ce95463d1638428b2547cde4d"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a5e5ee7c62768446ceb8fa8a76db99952"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a5e5ee7c62768446ceb8fa8a76db99952">DropPrivileges</a> ()</td></tr>
<tr class="memdesc:a5e5ee7c62768446ceb8fa8a76db99952"><td class="mdescLeft">&#160;</td><td class="mdescRight">Permanently drops privileges conferred by being a setuid or setgid executable. <a href="#a5e5ee7c62768446ceb8fa8a76db99952">More...</a><br /></td></tr>
<tr class="separator:a5e5ee7c62768446ceb8fa8a76db99952"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a97b946d80de148d1fd2452af38b220f4"><td class="memItemLeft" align="right" valign="top">std::string&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a97b946d80de148d1fd2452af38b220f4">SignalToString</a> (int signal, <a class="el" href="namespacecrashpad.html#a0f13feba965ef7750b3d49064936e5ee">SymbolicConstantToStringOptions</a> options)</td></tr>
<tr class="memdesc:a97b946d80de148d1fd2452af38b220f4"><td class="mdescLeft">&#160;</td><td class="mdescRight">Converts a POSIX signal value to a textual representation. <a href="#a97b946d80de148d1fd2452af38b220f4">More...</a><br /></td></tr>
<tr class="separator:a97b946d80de148d1fd2452af38b220f4"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a6249dd58c6a81b300d64b25a943fa25c"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a6249dd58c6a81b300d64b25a943fa25c">StringToSignal</a> (const base::StringPiece &amp;string, <a class="el" href="namespacecrashpad.html#a14f1de509869f929122998a2f88f08a6">StringToSymbolicConstantOptions</a> options, int *signal)</td></tr>
<tr class="memdesc:a6249dd58c6a81b300d64b25a943fa25c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Converts a string to its corresponding POSIX signal value. <a href="#a6249dd58c6a81b300d64b25a943fa25c">More...</a><br /></td></tr>
<tr class="separator:a6249dd58c6a81b300d64b25a943fa25c"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:afcda4999ed1b6ac03aab90c8833dbebb"><td class="memTemplParams" colspan="2"><a id="afcda4999ed1b6ac03aab90c8833dbebb"></a>
template&lt;class T1 , class T2 , size_t Alignment&gt; </td></tr>
<tr class="memitem:afcda4999ed1b6ac03aab90c8833dbebb"><td class="memTemplItemLeft" align="right" valign="top">bool&#160;</td><td class="memTemplItemRight" valign="bottom"><b>operator==</b> (const <a class="el" href="structcrashpad_1_1AlignedAllocator.html">AlignedAllocator</a>&lt; T1, Alignment &gt; &amp;lhs, const <a class="el" href="structcrashpad_1_1AlignedAllocator.html">AlignedAllocator</a>&lt; T2, Alignment &gt; &amp;rhs) CRASHPAD_NOEXCEPT</td></tr>
<tr class="separator:afcda4999ed1b6ac03aab90c8833dbebb"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a9f9985c36e027f96f920b48d3c89aec7"><td class="memTemplParams" colspan="2"><a id="a9f9985c36e027f96f920b48d3c89aec7"></a>
template&lt;class T1 , class T2 , size_t Alignment&gt; </td></tr>
<tr class="memitem:a9f9985c36e027f96f920b48d3c89aec7"><td class="memTemplItemLeft" align="right" valign="top">bool&#160;</td><td class="memTemplItemRight" valign="bottom"><b>operator!=</b> (const <a class="el" href="structcrashpad_1_1AlignedAllocator.html">AlignedAllocator</a>&lt; T1, Alignment &gt; &amp;lhs, const <a class="el" href="structcrashpad_1_1AlignedAllocator.html">AlignedAllocator</a>&lt; T2, Alignment &gt; &amp;rhs) CRASHPAD_NOEXCEPT</td></tr>
<tr class="separator:a9f9985c36e027f96f920b48d3c89aec7"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a0486df983d8e9cecbe1e46e0059806df"><td class="memTemplParams" colspan="2">template&lt;typename T &gt; </td></tr>
<tr class="memitem:a0486df983d8e9cecbe1e46e0059806df"><td class="memTemplItemLeft" align="right" valign="top">bool&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a0486df983d8e9cecbe1e46e0059806df">MapInsertOrReplace</a> (T *map, const typename T::key_type &amp;key, const typename T::mapped_type &amp;value, typename T::mapped_type *old_value)</td></tr>
<tr class="memdesc:a0486df983d8e9cecbe1e46e0059806df"><td class="mdescLeft">&#160;</td><td class="mdescRight">Inserts a mapping from <em>key</em> to <em>value</em> into <em>map</em>, or replaces an existing mapping so that <em>key</em> maps to <em>value</em>. <a href="#a0486df983d8e9cecbe1e46e0059806df">More...</a><br /></td></tr>
<tr class="separator:a0486df983d8e9cecbe1e46e0059806df"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ab42fe62040bb628fb134573bb2131955"><td class="memItemLeft" align="right" valign="top">size_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ab42fe62040bb628fb134573bb2131955">c16lcpy</a> (base::char16 *destination, const base::char16 *source, size_t length)</td></tr>
<tr class="memdesc:ab42fe62040bb628fb134573bb2131955"><td class="mdescLeft">&#160;</td><td class="mdescRight">Copy a <code>NUL</code>-terminated char16-based string to a fixed-size buffer. <a href="#ab42fe62040bb628fb134573bb2131955">More...</a><br /></td></tr>
<tr class="separator:ab42fe62040bb628fb134573bb2131955"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac8605dea4710c2630ccdd21439e05999"><td class="memItemLeft" align="right" valign="top">size_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ac8605dea4710c2630ccdd21439e05999">strnlen</a> (const char *string, size_t max_length)</td></tr>
<tr class="memdesc:ac8605dea4710c2630ccdd21439e05999"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns the length of a string, not to exceed a maximum. <a href="#ac8605dea4710c2630ccdd21439e05999">More...</a><br /></td></tr>
<tr class="separator:ac8605dea4710c2630ccdd21439e05999"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a1b3aaf00fdc6fef366afb2a00062c97f"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a1b3aaf00fdc6fef366afb2a00062c97f">SplitStringFirst</a> (const std::string &amp;string, char delimiter, std::string *left, std::string *right)</td></tr>
<tr class="memdesc:a1b3aaf00fdc6fef366afb2a00062c97f"><td class="mdescLeft">&#160;</td><td class="mdescRight">Splits a string into two parts at the first delimiter found. <a href="#a1b3aaf00fdc6fef366afb2a00062c97f">More...</a><br /></td></tr>
<tr class="separator:a1b3aaf00fdc6fef366afb2a00062c97f"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:abb5d05de37d3f1a92ce36c3ce37842b7"><td class="memItemLeft" align="right" valign="top">std::vector&lt; std::string &gt;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#abb5d05de37d3f1a92ce36c3ce37842b7">SplitString</a> (const std::string &amp;string, char delimiter)</td></tr>
<tr class="memdesc:abb5d05de37d3f1a92ce36c3ce37842b7"><td class="mdescLeft">&#160;</td><td class="mdescRight">Splits a string into multiple parts on the given delimiter. <a href="#abb5d05de37d3f1a92ce36c3ce37842b7">More...</a><br /></td></tr>
<tr class="separator:abb5d05de37d3f1a92ce36c3ce37842b7"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:adbc9204d047dd250fe5f6b4ce0dd27ae"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#adbc9204d047dd250fe5f6b4ce0dd27ae">CaptureContext</a> (CONTEXT *context)</td></tr>
<tr class="memdesc:adbc9204d047dd250fe5f6b4ce0dd27ae"><td class="mdescLeft">&#160;</td><td class="mdescRight">Saves the CPU context. <a href="#adbc9204d047dd250fe5f6b4ce0dd27ae">More...</a><br /></td></tr>
<tr class="separator:adbc9204d047dd250fe5f6b4ce0dd27ae"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a52a7dee343e392e5bf1794e8136df7f9"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a52a7dee343e392e5bf1794e8136df7f9">AppendCommandLineArgument</a> (const std::wstring &amp;argument, std::wstring *command_line)</td></tr>
<tr class="memdesc:a52a7dee343e392e5bf1794e8136df7f9"><td class="mdescLeft">&#160;</td><td class="mdescRight">Utility function for building escaped command lines. <a href="#a52a7dee343e392e5bf1794e8136df7f9">More...</a><br /></td></tr>
<tr class="separator:a52a7dee343e392e5bf1794e8136df7f9"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:af8340c24a2983e788d2a3ba90d1d4846"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#af8340c24a2983e788d2a3ba90d1d4846">InitializeCriticalSectionWithDebugInfoIfPossible</a> (CRITICAL_SECTION *critical_section)</td></tr>
<tr class="memdesc:af8340c24a2983e788d2a3ba90d1d4846"><td class="mdescLeft">&#160;</td><td class="mdescRight">Equivalent to <code>InitializeCritialSection()</code>, but attempts to allocate with a valid <code>.DebugInfo</code> field on versions of Windows where it's possible to do so. <a href="#af8340c24a2983e788d2a3ba90d1d4846">More...</a><br /></td></tr>
<tr class="separator:af8340c24a2983e788d2a3ba90d1d4846"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a3746e63a20ecf254ab6ec0a2a3fc9072"><td class="memItemLeft" align="right" valign="top"><a id="a3746e63a20ecf254ab6ec0a2a3fc9072"></a>
BOOL&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a3746e63a20ecf254ab6ec0a2a3fc9072">CrashpadGetModuleInformation</a> (HANDLE process, HMODULE module, MODULEINFO *module_info, DWORD cb)</td></tr>
<tr class="memdesc:a3746e63a20ecf254ab6ec0a2a3fc9072"><td class="mdescLeft">&#160;</td><td class="mdescRight">Proxy function for <code>GetModuleInformation()</code>. <br /></td></tr>
<tr class="separator:a3746e63a20ecf254ab6ec0a2a3fc9072"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ae643b5c6bce4e11a0f51eb2f4d5fa1de"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ae643b5c6bce4e11a0f51eb2f4d5fa1de">HandleToInt</a> (HANDLE handle)</td></tr>
<tr class="memdesc:ae643b5c6bce4e11a0f51eb2f4d5fa1de"><td class="mdescLeft">&#160;</td><td class="mdescRight">Converts a <code>HANDLE</code> to an <code>int</code>. <a href="#ae643b5c6bce4e11a0f51eb2f4d5fa1de">More...</a><br /></td></tr>
<tr class="separator:ae643b5c6bce4e11a0f51eb2f4d5fa1de"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a83df06f1e4dc470676c1f86e93b6bc63"><td class="memItemLeft" align="right" valign="top">HANDLE&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a83df06f1e4dc470676c1f86e93b6bc63">IntToHandle</a> (int handle_int)</td></tr>
<tr class="memdesc:a83df06f1e4dc470676c1f86e93b6bc63"><td class="mdescLeft">&#160;</td><td class="mdescRight">Converts an <code>int</code> to an <code>HANDLE</code>. <a href="#a83df06f1e4dc470676c1f86e93b6bc63">More...</a><br /></td></tr>
<tr class="separator:a83df06f1e4dc470676c1f86e93b6bc63"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:af5f4414be804bdcd71f57053d7147eff"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#af5f4414be804bdcd71f57053d7147eff">GetModuleVersionAndType</a> (const base::FilePath &amp;path, <a class="el" href="structVS__FIXEDFILEINFO.html">VS_FIXEDFILEINFO</a> *vs_fixedfileinfo)</td></tr>
<tr class="memdesc:af5f4414be804bdcd71f57053d7147eff"><td class="mdescLeft">&#160;</td><td class="mdescRight">Retrieve the type and version information from a given module (exe, dll, etc.) <a href="#af5f4414be804bdcd71f57053d7147eff">More...</a><br /></td></tr>
<tr class="separator:af5f4414be804bdcd71f57053d7147eff"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:af98625fc4ae740c7acf83914cb9d2eea"><td class="memItemLeft" align="right" valign="top"><a id="af98625fc4ae740c7acf83914cb9d2eea"></a>
NTSTATUS&#160;</td><td class="memItemRight" valign="bottom"><b>NtClose</b> (HANDLE handle)</td></tr>
<tr class="separator:af98625fc4ae740c7acf83914cb9d2eea"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a4fd167fde965614b528333f1d6af3a17"><td class="memItemLeft" align="right" valign="top"><a id="a4fd167fde965614b528333f1d6af3a17"></a>
NTSTATUS&#160;</td><td class="memItemRight" valign="bottom"><b>NtCreateThreadEx</b> (PHANDLE thread_handle, ACCESS_MASK desired_access, POBJECT_ATTRIBUTES object_attributes, HANDLE process_handle, PVOID start_routine, PVOID argument, ULONG create_flags, SIZE_T zero_bits, SIZE_T stack_size, SIZE_T maximum_stack_size, PVOID attribute_list)</td></tr>
<tr class="separator:a4fd167fde965614b528333f1d6af3a17"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a1362e2105b0e5a1a96908dff0bf17f1b"><td class="memItemLeft" align="right" valign="top"><a id="a1362e2105b0e5a1a96908dff0bf17f1b"></a>
NTSTATUS&#160;</td><td class="memItemRight" valign="bottom"><b>NtQuerySystemInformation</b> (SYSTEM_INFORMATION_CLASS system_information_class, PVOID system_information, ULONG system_information_length, PULONG return_length)</td></tr>
<tr class="separator:a1362e2105b0e5a1a96908dff0bf17f1b"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aaadf7c489cec5aaec6941ed84349a687"><td class="memItemLeft" align="right" valign="top"><a id="aaadf7c489cec5aaec6941ed84349a687"></a>
NTSTATUS&#160;</td><td class="memItemRight" valign="bottom"><b>NtQueryInformationThread</b> (HANDLE thread_handle, THREADINFOCLASS thread_information_class, PVOID thread_information, ULONG thread_information_length, PULONG return_length)</td></tr>
<tr class="separator:aaadf7c489cec5aaec6941ed84349a687"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a9bf0b422cad7e39f59f33ba59e1c4f63"><td class="memTemplParams" colspan="2"><a id="a9bf0b422cad7e39f59f33ba59e1c4f63"></a>
template&lt;class Traits &gt; </td></tr>
<tr class="memitem:a9bf0b422cad7e39f59f33ba59e1c4f63"><td class="memTemplItemLeft" align="right" valign="top">NTSTATUS&#160;</td><td class="memTemplItemRight" valign="bottom"><b>NtOpenThread</b> (PHANDLE thread_handle, ACCESS_MASK desired_access, POBJECT_ATTRIBUTES object_attributes, const <a class="el" href="structcrashpad_1_1process__types_1_1CLIENT__ID.html">process_types::CLIENT_ID</a>&lt; Traits &gt; *client_id)</td></tr>
<tr class="separator:a9bf0b422cad7e39f59f33ba59e1c4f63"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a62ddfe7ead9fb78e8dc69e3aef201591"><td class="memItemLeft" align="right" valign="top"><a id="a62ddfe7ead9fb78e8dc69e3aef201591"></a>
NTSTATUS&#160;</td><td class="memItemRight" valign="bottom"><b>NtQueryObject</b> (HANDLE handle, OBJECT_INFORMATION_CLASS object_information_class, void *object_information, ULONG object_information_length, ULONG *return_length)</td></tr>
<tr class="separator:a62ddfe7ead9fb78e8dc69e3aef201591"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a0a7f5dacb7838eff13fc227543946514"><td class="memItemLeft" align="right" valign="top"><a id="a0a7f5dacb7838eff13fc227543946514"></a>
NTSTATUS&#160;</td><td class="memItemRight" valign="bottom"><b>NtSuspendProcess</b> (HANDLE handle)</td></tr>
<tr class="separator:a0a7f5dacb7838eff13fc227543946514"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a4b4c03e99b85dc3f8bc3c9a0d13cea67"><td class="memItemLeft" align="right" valign="top"><a id="a4b4c03e99b85dc3f8bc3c9a0d13cea67"></a>
NTSTATUS&#160;</td><td class="memItemRight" valign="bottom"><b>NtResumeProcess</b> (HANDLE handle)</td></tr>
<tr class="separator:a4b4c03e99b85dc3f8bc3c9a0d13cea67"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a330814d77bd394c6955fdde0bc098508"><td class="memTemplParams" colspan="2"><a id="a330814d77bd394c6955fdde0bc098508"></a>
template&lt;class Traits &gt; </td></tr>
<tr class="memitem:a330814d77bd394c6955fdde0bc098508"><td class="memTemplItemLeft" align="right" valign="top"><a class="el" href="structcrashpad_1_1RTL__UNLOAD__EVENT__TRACE.html">RTL_UNLOAD_EVENT_TRACE</a>&lt; Traits &gt; *&#160;</td><td class="memTemplItemRight" valign="bottom"><b>RtlGetUnloadEventTrace</b> ()</td></tr>
<tr class="separator:a330814d77bd394c6955fdde0bc098508"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:abcbe51e96d3012cb4751d48d0c920d6c"><td class="memItemLeft" align="right" valign="top"><a id="abcbe51e96d3012cb4751d48d0c920d6c"></a>
template NTSTATUS&#160;</td><td class="memItemRight" valign="bottom"><b>NtOpenThread&lt; process_types::internal::Traits32 &gt;</b> (PHANDLE thread_handle, ACCESS_MASK desired_access, POBJECT_ATTRIBUTES object_attributes, const <a class="el" href="structcrashpad_1_1process__types_1_1CLIENT__ID.html">process_types::CLIENT_ID</a>&lt; <a class="el" href="structcrashpad_1_1process__types_1_1internal_1_1Traits32.html">process_types::internal::Traits32</a> &gt; *client_id)</td></tr>
<tr class="separator:abcbe51e96d3012cb4751d48d0c920d6c"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac78cb91133d0fd98a7895856e36eaf74"><td class="memItemLeft" align="right" valign="top"><a id="ac78cb91133d0fd98a7895856e36eaf74"></a>
template NTSTATUS&#160;</td><td class="memItemRight" valign="bottom"><b>NtOpenThread&lt; process_types::internal::Traits64 &gt;</b> (PHANDLE thread_handle, ACCESS_MASK desired_access, POBJECT_ATTRIBUTES object_attributes, const <a class="el" href="structcrashpad_1_1process__types_1_1CLIENT__ID.html">process_types::CLIENT_ID</a>&lt; <a class="el" href="structcrashpad_1_1process__types_1_1internal_1_1Traits64.html">process_types::internal::Traits64</a> &gt; *client_id)</td></tr>
<tr class="separator:ac78cb91133d0fd98a7895856e36eaf74"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ad889f0a78c58d9d87a4353ef43aecfb8"><td class="memItemLeft" align="right" valign="top"><a id="ad889f0a78c58d9d87a4353ef43aecfb8"></a>
template <a class="el" href="structcrashpad_1_1RTL__UNLOAD__EVENT__TRACE.html">RTL_UNLOAD_EVENT_TRACE</a>&lt; <a class="el" href="structcrashpad_1_1process__types_1_1internal_1_1Traits32.html">process_types::internal::Traits32</a> &gt; *&#160;</td><td class="memItemRight" valign="bottom"><b>RtlGetUnloadEventTrace&lt; process_types::internal::Traits32 &gt;</b> ()</td></tr>
<tr class="separator:ad889f0a78c58d9d87a4353ef43aecfb8"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a1a33b1185bc218a2c671db2589b26aba"><td class="memItemLeft" align="right" valign="top"><a id="a1a33b1185bc218a2c671db2589b26aba"></a>
template <a class="el" href="structcrashpad_1_1RTL__UNLOAD__EVENT__TRACE.html">RTL_UNLOAD_EVENT_TRACE</a>&lt; <a class="el" href="structcrashpad_1_1process__types_1_1internal_1_1Traits64.html">process_types::internal::Traits64</a> &gt; *&#160;</td><td class="memItemRight" valign="bottom"><b>RtlGetUnloadEventTrace&lt; process_types::internal::Traits64 &gt;</b> ()</td></tr>
<tr class="separator:a1a33b1185bc218a2c671db2589b26aba"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a04af5fe26b32e7a7bdd363017251fe00"><td class="memTemplParams" colspan="2"><a id="a04af5fe26b32e7a7bdd363017251fe00"></a>
template&lt;class Traits &gt; </td></tr>
<tr class="memitem:a04af5fe26b32e7a7bdd363017251fe00"><td class="memTemplItemLeft" align="right" valign="top">bool&#160;</td><td class="memTemplItemRight" valign="bottom"><b>GetProcessBasicInformation</b> (HANDLE process, bool is_wow64, <a class="el" href="classcrashpad_1_1ProcessInfo.html">ProcessInfo</a> *process_info, <a class="el" href="namespacecrashpad.html#a368af6d88f68998b5c5eb80b8f6ebb76">WinVMAddress</a> *peb_address, <a class="el" href="namespacecrashpad.html#a1bac9f2a189b24737e743d6690362239">WinVMSize</a> *peb_size)</td></tr>
<tr class="separator:a04af5fe26b32e7a7bdd363017251fe00"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ab0e1c8286ac56df129481b4d26b1aa9d"><td class="memTemplParams" colspan="2"><a id="ab0e1c8286ac56df129481b4d26b1aa9d"></a>
template&lt;class Traits &gt; </td></tr>
<tr class="memitem:ab0e1c8286ac56df129481b4d26b1aa9d"><td class="memTemplItemLeft" align="right" valign="top">bool&#160;</td><td class="memTemplItemRight" valign="bottom"><b>ReadProcessData</b> (HANDLE process, <a class="el" href="namespacecrashpad.html#a368af6d88f68998b5c5eb80b8f6ebb76">WinVMAddress</a> peb_address_vmaddr, <a class="el" href="classcrashpad_1_1ProcessInfo.html">ProcessInfo</a> *process_info)</td></tr>
<tr class="separator:ab0e1c8286ac56df129481b4d26b1aa9d"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a44ff5b9a1ac8271ebf0977880ec95ac3"><td class="memItemLeft" align="right" valign="top"><a id="a44ff5b9a1ac8271ebf0977880ec95ac3"></a>
bool&#160;</td><td class="memItemRight" valign="bottom"><b>ReadMemoryInfo</b> (HANDLE process, bool is_64_bit, <a class="el" href="classcrashpad_1_1ProcessInfo.html">ProcessInfo</a> *process_info)</td></tr>
<tr class="separator:a44ff5b9a1ac8271ebf0977880ec95ac3"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a794c1a44de599deb3e261eab0bd6c03b"><td class="memItemLeft" align="right" valign="top">std::vector&lt; <a class="el" href="classcrashpad_1_1CheckedRange.html">CheckedRange</a>&lt; <a class="el" href="namespacecrashpad.html#a368af6d88f68998b5c5eb80b8f6ebb76">WinVMAddress</a>, <a class="el" href="namespacecrashpad.html#a1bac9f2a189b24737e743d6690362239">WinVMSize</a> &gt; &gt;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a794c1a44de599deb3e261eab0bd6c03b">GetReadableRangesOfMemoryMap</a> (const <a class="el" href="classcrashpad_1_1CheckedRange.html">CheckedRange</a>&lt; <a class="el" href="namespacecrashpad.html#a368af6d88f68998b5c5eb80b8f6ebb76">WinVMAddress</a>, <a class="el" href="namespacecrashpad.html#a1bac9f2a189b24737e743d6690362239">WinVMSize</a> &gt; &amp;range, const <a class="el" href="classcrashpad_1_1ProcessInfo.html#a9b1bd70d4a58ec0afe0ce742f0e3fea8">ProcessInfo::MemoryBasicInformation64Vector</a> &amp;memory_info)</td></tr>
<tr class="memdesc:a794c1a44de599deb3e261eab0bd6c03b"><td class="mdescLeft">&#160;</td><td class="mdescRight">Given a memory map of a process, and a range to be read from the target process, returns a vector of ranges, representing the readable portions of the original range. <a href="#a794c1a44de599deb3e261eab0bd6c03b">More...</a><br /></td></tr>
<tr class="separator:a794c1a44de599deb3e261eab0bd6c03b"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a638d7916642f81df8063d300f08ff2ca"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a638d7916642f81df8063d300f08ff2ca">SendToCrashHandlerServer</a> (const base::string16 &amp;pipe_name, const <a class="el" href="structcrashpad_1_1ClientToServerMessage.html">ClientToServerMessage</a> &amp;message, <a class="el" href="unioncrashpad_1_1ServerToClientMessage.html">ServerToClientMessage</a> *response)</td></tr>
<tr class="memdesc:a638d7916642f81df8063d300f08ff2ca"><td class="mdescLeft">&#160;</td><td class="mdescRight">Connect over the given <em>pipe_name</em>, passing <em>message</em> to the server, storing the server's reply into <em>response</em>. <a href="#a638d7916642f81df8063d300f08ff2ca">More...</a><br /></td></tr>
<tr class="separator:a638d7916642f81df8063d300f08ff2ca"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a1bb7596acd0c7d75d0608ffafc6028e8"><td class="memItemLeft" align="right" valign="top">HANDLE&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a1bb7596acd0c7d75d0608ffafc6028e8">CreateNamedPipeInstance</a> (const std::wstring &amp;pipe_name, bool first_instance)</td></tr>
<tr class="memdesc:a1bb7596acd0c7d75d0608ffafc6028e8"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps CreateNamedPipe() to create a single named pipe instance. <a href="#a1bb7596acd0c7d75d0608ffafc6028e8">More...</a><br /></td></tr>
<tr class="separator:a1bb7596acd0c7d75d0608ffafc6028e8"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a12442a42a099c4b68211fd230e94f42c"><td class="memItemLeft" align="right" valign="top"><a id="a12442a42a099c4b68211fd230e94f42c"></a>
timeval&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a12442a42a099c4b68211fd230e94f42c">FiletimeToTimevalEpoch</a> (const FILETIME &amp;filetime)</td></tr>
<tr class="memdesc:a12442a42a099c4b68211fd230e94f42c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Convert Windows <code>FILETIME</code> to <code>timeval</code>, converting from Windows epoch to POSIX epoch. <br /></td></tr>
<tr class="separator:a12442a42a099c4b68211fd230e94f42c"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a2597c6565e3733dceb0f933cea2146a1"><td class="memItemLeft" align="right" valign="top"><a id="a2597c6565e3733dceb0f933cea2146a1"></a>
timeval&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a2597c6565e3733dceb0f933cea2146a1">FiletimeToTimevalInterval</a> (const FILETIME &amp;filetime)</td></tr>
<tr class="memdesc:a2597c6565e3733dceb0f933cea2146a1"><td class="mdescLeft">&#160;</td><td class="mdescRight">Convert Windows <code>FILETIME</code> to <code>timeval</code>, treating the values as an interval of elapsed time. <br /></td></tr>
<tr class="separator:a2597c6565e3733dceb0f933cea2146a1"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ad150794de658f3bec7f37aa33ac521c4"><td class="memItemLeft" align="right" valign="top"><a id="ad150794de658f3bec7f37aa33ac521c4"></a>
void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ad150794de658f3bec7f37aa33ac521c4">GetTimeOfDay</a> (timeval *tv)</td></tr>
<tr class="memdesc:ad150794de658f3bec7f37aa33ac521c4"><td class="mdescLeft">&#160;</td><td class="mdescRight">Similar to POSIX gettimeofday(), gets the current system time in UTC. <br /></td></tr>
<tr class="separator:ad150794de658f3bec7f37aa33ac521c4"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr><td colspan="2"><div class="groupHeader"></div></td></tr>
<tr class="memitem:aec89d58359f33bb2ba3671feea0c15f4"><td class="memItemLeft" align="right" valign="top">launch_data_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#aec89d58359f33bb2ba3671feea0c15f4">LaunchDataAlloc</a> (launch_data_type_t type)</td></tr>
<tr class="memdesc:aec89d58359f33bb2ba3671feea0c15f4"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps the <code>&lt;launch.h&gt;</code> function of the same name. <a href="#aec89d58359f33bb2ba3671feea0c15f4">More...</a><br /></td></tr>
<tr class="separator:aec89d58359f33bb2ba3671feea0c15f4"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a765503fd97e9e3d622d3b30bff543fb9"><td class="memItemLeft" align="right" valign="top">launch_data_type_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a765503fd97e9e3d622d3b30bff543fb9">LaunchDataGetType</a> (const launch_data_t data)</td></tr>
<tr class="memdesc:a765503fd97e9e3d622d3b30bff543fb9"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps the <code>&lt;launch.h&gt;</code> function of the same name. <a href="#a765503fd97e9e3d622d3b30bff543fb9">More...</a><br /></td></tr>
<tr class="separator:a765503fd97e9e3d622d3b30bff543fb9"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a6075a91ef08754a4f6f1d1cc4f4243d2"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a6075a91ef08754a4f6f1d1cc4f4243d2">LaunchDataFree</a> (launch_data_t data)</td></tr>
<tr class="memdesc:a6075a91ef08754a4f6f1d1cc4f4243d2"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps the <code>&lt;launch.h&gt;</code> function of the same name. <a href="#a6075a91ef08754a4f6f1d1cc4f4243d2">More...</a><br /></td></tr>
<tr class="separator:a6075a91ef08754a4f6f1d1cc4f4243d2"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a5637f13db21865305a5d09b123647ee0"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a5637f13db21865305a5d09b123647ee0">LaunchDataDictInsert</a> (launch_data_t dict, const launch_data_t value, const char *key)</td></tr>
<tr class="memdesc:a5637f13db21865305a5d09b123647ee0"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps the <code>&lt;launch.h&gt;</code> function of the same name. <a href="#a5637f13db21865305a5d09b123647ee0">More...</a><br /></td></tr>
<tr class="separator:a5637f13db21865305a5d09b123647ee0"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a7d4549b38faef80da81a53b88b1a27ac"><td class="memItemLeft" align="right" valign="top">launch_data_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a7d4549b38faef80da81a53b88b1a27ac">LaunchDataDictLookup</a> (const launch_data_t dict, const char *key)</td></tr>
<tr class="memdesc:a7d4549b38faef80da81a53b88b1a27ac"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps the <code>&lt;launch.h&gt;</code> function of the same name. <a href="#a7d4549b38faef80da81a53b88b1a27ac">More...</a><br /></td></tr>
<tr class="separator:a7d4549b38faef80da81a53b88b1a27ac"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aedb99d12b989d048f972d843a2aea013"><td class="memItemLeft" align="right" valign="top">size_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#aedb99d12b989d048f972d843a2aea013">LaunchDataDictGetCount</a> (launch_data_t dict)</td></tr>
<tr class="memdesc:aedb99d12b989d048f972d843a2aea013"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps the <code>&lt;launch.h&gt;</code> function of the same name. <a href="#aedb99d12b989d048f972d843a2aea013">More...</a><br /></td></tr>
<tr class="separator:aedb99d12b989d048f972d843a2aea013"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a075be3843e4294e446c40022ba6661c4"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a075be3843e4294e446c40022ba6661c4">LaunchDataArraySetIndex</a> (launch_data_t array, const launch_data_t value, size_t index)</td></tr>
<tr class="memdesc:a075be3843e4294e446c40022ba6661c4"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps the <code>&lt;launch.h&gt;</code> function of the same name. <a href="#a075be3843e4294e446c40022ba6661c4">More...</a><br /></td></tr>
<tr class="separator:a075be3843e4294e446c40022ba6661c4"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a46e5304477aab0ad1d165869557eb3b5"><td class="memItemLeft" align="right" valign="top">launch_data_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a46e5304477aab0ad1d165869557eb3b5">LaunchDataArrayGetIndex</a> (launch_data_t array, size_t index)</td></tr>
<tr class="memdesc:a46e5304477aab0ad1d165869557eb3b5"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps the <code>&lt;launch.h&gt;</code> function of the same name. <a href="#a46e5304477aab0ad1d165869557eb3b5">More...</a><br /></td></tr>
<tr class="separator:a46e5304477aab0ad1d165869557eb3b5"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:abeb060347d9343e720856380234cd6ff"><td class="memItemLeft" align="right" valign="top">size_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#abeb060347d9343e720856380234cd6ff">LaunchDataArrayGetCount</a> (launch_data_t array)</td></tr>
<tr class="memdesc:abeb060347d9343e720856380234cd6ff"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps the <code>&lt;launch.h&gt;</code> function of the same name. <a href="#abeb060347d9343e720856380234cd6ff">More...</a><br /></td></tr>
<tr class="separator:abeb060347d9343e720856380234cd6ff"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a7b4bfcaae95ef3a81e3ec2d27f059bab"><td class="memItemLeft" align="right" valign="top">launch_data_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a7b4bfcaae95ef3a81e3ec2d27f059bab">LaunchDataNewInteger</a> (long long integer)</td></tr>
<tr class="memdesc:a7b4bfcaae95ef3a81e3ec2d27f059bab"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps the <code>&lt;launch.h&gt;</code> function of the same name. <a href="#a7b4bfcaae95ef3a81e3ec2d27f059bab">More...</a><br /></td></tr>
<tr class="separator:a7b4bfcaae95ef3a81e3ec2d27f059bab"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a19e679e954d2d8ca88ace03ccab5c4df"><td class="memItemLeft" align="right" valign="top">launch_data_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a19e679e954d2d8ca88ace03ccab5c4df">LaunchDataNewBool</a> (bool boolean)</td></tr>
<tr class="memdesc:a19e679e954d2d8ca88ace03ccab5c4df"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps the <code>&lt;launch.h&gt;</code> function of the same name. <a href="#a19e679e954d2d8ca88ace03ccab5c4df">More...</a><br /></td></tr>
<tr class="separator:a19e679e954d2d8ca88ace03ccab5c4df"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aa78698056108819fe4bd268cc55801c3"><td class="memItemLeft" align="right" valign="top">launch_data_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#aa78698056108819fe4bd268cc55801c3">LaunchDataNewReal</a> (double real)</td></tr>
<tr class="memdesc:aa78698056108819fe4bd268cc55801c3"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps the <code>&lt;launch.h&gt;</code> function of the same name. <a href="#aa78698056108819fe4bd268cc55801c3">More...</a><br /></td></tr>
<tr class="separator:aa78698056108819fe4bd268cc55801c3"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a7ae48002caa906acb164114bc290b048"><td class="memItemLeft" align="right" valign="top">launch_data_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a7ae48002caa906acb164114bc290b048">LaunchDataNewString</a> (const char *string)</td></tr>
<tr class="memdesc:a7ae48002caa906acb164114bc290b048"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps the <code>&lt;launch.h&gt;</code> function of the same name. <a href="#a7ae48002caa906acb164114bc290b048">More...</a><br /></td></tr>
<tr class="separator:a7ae48002caa906acb164114bc290b048"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a5af22dade75539fd9e5032acf799c945"><td class="memItemLeft" align="right" valign="top">launch_data_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a5af22dade75539fd9e5032acf799c945">LaunchDataNewOpaque</a> (const void *opaque, size_t size)</td></tr>
<tr class="memdesc:a5af22dade75539fd9e5032acf799c945"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps the <code>&lt;launch.h&gt;</code> function of the same name. <a href="#a5af22dade75539fd9e5032acf799c945">More...</a><br /></td></tr>
<tr class="separator:a5af22dade75539fd9e5032acf799c945"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a54549da20f78530f300712625fc0ba5a"><td class="memItemLeft" align="right" valign="top">long long&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a54549da20f78530f300712625fc0ba5a">LaunchDataGetInteger</a> (const launch_data_t data)</td></tr>
<tr class="memdesc:a54549da20f78530f300712625fc0ba5a"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps the <code>&lt;launch.h&gt;</code> function of the same name. <a href="#a54549da20f78530f300712625fc0ba5a">More...</a><br /></td></tr>
<tr class="separator:a54549da20f78530f300712625fc0ba5a"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a6fd262daa89e57ffd897e4b583d44d44"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a6fd262daa89e57ffd897e4b583d44d44">LaunchDataGetBool</a> (const launch_data_t data)</td></tr>
<tr class="memdesc:a6fd262daa89e57ffd897e4b583d44d44"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps the <code>&lt;launch.h&gt;</code> function of the same name. <a href="#a6fd262daa89e57ffd897e4b583d44d44">More...</a><br /></td></tr>
<tr class="separator:a6fd262daa89e57ffd897e4b583d44d44"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a21114f1a9f28bfb065033f569d466a09"><td class="memItemLeft" align="right" valign="top">double&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a21114f1a9f28bfb065033f569d466a09">LaunchDataGetReal</a> (const launch_data_t data)</td></tr>
<tr class="memdesc:a21114f1a9f28bfb065033f569d466a09"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps the <code>&lt;launch.h&gt;</code> function of the same name. <a href="#a21114f1a9f28bfb065033f569d466a09">More...</a><br /></td></tr>
<tr class="separator:a21114f1a9f28bfb065033f569d466a09"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a30a24e225530ab7feeb3e12df480f5c5"><td class="memItemLeft" align="right" valign="top">const char *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a30a24e225530ab7feeb3e12df480f5c5">LaunchDataGetString</a> (const launch_data_t data)</td></tr>
<tr class="memdesc:a30a24e225530ab7feeb3e12df480f5c5"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps the <code>&lt;launch.h&gt;</code> function of the same name. <a href="#a30a24e225530ab7feeb3e12df480f5c5">More...</a><br /></td></tr>
<tr class="separator:a30a24e225530ab7feeb3e12df480f5c5"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aaf2fbe2de028de73c9013d6c0759bc2b"><td class="memItemLeft" align="right" valign="top">void *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#aaf2fbe2de028de73c9013d6c0759bc2b">LaunchDataGetOpaque</a> (const launch_data_t data)</td></tr>
<tr class="memdesc:aaf2fbe2de028de73c9013d6c0759bc2b"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps the <code>&lt;launch.h&gt;</code> function of the same name. <a href="#aaf2fbe2de028de73c9013d6c0759bc2b">More...</a><br /></td></tr>
<tr class="separator:aaf2fbe2de028de73c9013d6c0759bc2b"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a6ed0f2e24befe2e6faa94445bb03e054"><td class="memItemLeft" align="right" valign="top">size_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a6ed0f2e24befe2e6faa94445bb03e054">LaunchDataGetOpaqueSize</a> (const launch_data_t data)</td></tr>
<tr class="memdesc:a6ed0f2e24befe2e6faa94445bb03e054"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps the <code>&lt;launch.h&gt;</code> function of the same name. <a href="#a6ed0f2e24befe2e6faa94445bb03e054">More...</a><br /></td></tr>
<tr class="separator:a6ed0f2e24befe2e6faa94445bb03e054"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a5637cdc78caedaaadb2c0e47857ccf78"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a5637cdc78caedaaadb2c0e47857ccf78">LaunchDataGetErrno</a> (const launch_data_t data)</td></tr>
<tr class="memdesc:a5637cdc78caedaaadb2c0e47857ccf78"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps the <code>&lt;launch.h&gt;</code> function of the same name. <a href="#a5637cdc78caedaaadb2c0e47857ccf78">More...</a><br /></td></tr>
<tr class="separator:a5637cdc78caedaaadb2c0e47857ccf78"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ae541f07925a67de751502b903af919b4"><td class="memItemLeft" align="right" valign="top">launch_data_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ae541f07925a67de751502b903af919b4">LaunchMsg</a> (const launch_data_t data)</td></tr>
<tr class="memdesc:ae541f07925a67de751502b903af919b4"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps the <code>&lt;launch.h&gt;</code> function of the same name. <a href="#ae541f07925a67de751502b903af919b4">More...</a><br /></td></tr>
<tr class="separator:ae541f07925a67de751502b903af919b4"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr><td colspan="2"><div class="groupHeader"></div></td></tr>
<tr class="memitem:ab269ab8edf326666ef7056a18f4a67c4"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ab269ab8edf326666ef7056a18f4a67c4">StringToNumber</a> (const base::StringPiece &amp;string, int *number)</td></tr>
<tr class="memdesc:ab269ab8edf326666ef7056a18f4a67c4"><td class="mdescLeft">&#160;</td><td class="mdescRight">Convert a string to a number. <a href="#ab269ab8edf326666ef7056a18f4a67c4">More...</a><br /></td></tr>
<tr class="separator:ab269ab8edf326666ef7056a18f4a67c4"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac76c5a4040c1f8e2878412dd368a4ea2"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ac76c5a4040c1f8e2878412dd368a4ea2">StringToNumber</a> (const base::StringPiece &amp;string, unsigned int *number)</td></tr>
<tr class="memdesc:ac76c5a4040c1f8e2878412dd368a4ea2"><td class="mdescLeft">&#160;</td><td class="mdescRight">Convert a string to a number. <a href="#ac76c5a4040c1f8e2878412dd368a4ea2">More...</a><br /></td></tr>
<tr class="separator:ac76c5a4040c1f8e2878412dd368a4ea2"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a0d7e404d4414f4a6dd7c00f3ac2920e9"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a0d7e404d4414f4a6dd7c00f3ac2920e9">StringToNumber</a> (const base::StringPiece &amp;string, uint64_t *number)</td></tr>
<tr class="memdesc:a0d7e404d4414f4a6dd7c00f3ac2920e9"><td class="mdescLeft">&#160;</td><td class="mdescRight">Convert a string to a number. <a href="#a0d7e404d4414f4a6dd7c00f3ac2920e9">More...</a><br /></td></tr>
<tr class="separator:a0d7e404d4414f4a6dd7c00f3ac2920e9"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="var-members"></a>
Variables</h2></td></tr>
<tr class="memitem:a77b69be523b4c70469e1d48e6c0bd3bc"><td class="memItemLeft" align="right" valign="top"><a id="a77b69be523b4c70469e1d48e6c0bd3bc"></a>
<a class="el" href="structcrashpad_1_1CrashpadInfo.html">CrashpadInfo</a>&#160;</td><td class="memItemRight" valign="bottom"><b>g_crashpad_info</b></td></tr>
<tr class="separator:a77b69be523b4c70469e1d48e6c0bd3bc"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a950cfdbaad26e28b48b48e211c15a43d"><td class="memItemLeft" align="right" valign="top"><a id="a950cfdbaad26e28b48b48e211c15a43d"></a>
return measured_size_in_kb_&#160;</td><td class="memItemRight" valign="bottom"><b>max_size_in_kb_</b></td></tr>
<tr class="separator:a950cfdbaad26e28b48b48e211c15a43d"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aec5ba90f34a36075fcc6e98e6293e1c1"><td class="memItemLeft" align="right" valign="top"><a id="aec5ba90f34a36075fcc6e98e6293e1c1"></a>
int *&#160;</td><td class="memItemRight" valign="bottom"><b>g_extra_memory_pointer</b></td></tr>
<tr class="separator:aec5ba90f34a36075fcc6e98e6293e1c1"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ad2a92286fc050a3c5c64aab6ebd2ac38"><td class="memItemLeft" align="right" valign="top"><a id="ad2a92286fc050a3c5c64aab6ebd2ac38"></a>
int *&#160;</td><td class="memItemRight" valign="bottom"><b>g_extra_memory_not_saved</b></td></tr>
<tr class="separator:ad2a92286fc050a3c5c64aab6ebd2ac38"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:add54baa0f53825b93f3aab2fcafce367"><td class="memItemLeft" align="right" valign="top"><a id="add54baa0f53825b93f3aab2fcafce367"></a>
const <a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#add54baa0f53825b93f3aab2fcafce367">kInvalidFileHandle</a> = -1</td></tr>
<tr class="memdesc:add54baa0f53825b93f3aab2fcafce367"><td class="mdescLeft">&#160;</td><td class="mdescRight">A value that can never be a valid FileHandle. <br /></td></tr>
<tr class="separator:add54baa0f53825b93f3aab2fcafce367"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a7c7b6c8b4f44c95c7f0fb70a56342277"><td class="memItemLeft" align="right" valign="top">const mach_port_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a7c7b6c8b4f44c95c7f0fb70a56342277">kMachPortNull</a> = MACH_PORT_NULL</td></tr>
<tr class="memdesc:a7c7b6c8b4f44c95c7f0fb70a56342277"><td class="mdescLeft">&#160;</td><td class="mdescRight"><code>MACH_PORT_NULL</code> with the correct type for a Mach port, <code>mach_port_t</code>. <a href="#a7c7b6c8b4f44c95c7f0fb70a56342277">More...</a><br /></td></tr>
<tr class="separator:a7c7b6c8b4f44c95c7f0fb70a56342277"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a7dbcba9449a5dd47d2911b1f85bc1a58"><td class="memItemLeft" align="right" valign="top">const exception_behavior_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a7dbcba9449a5dd47d2911b1f85bc1a58">kMachExceptionCodes</a> = MACH_EXCEPTION_CODES</td></tr>
<tr class="memdesc:a7dbcba9449a5dd47d2911b1f85bc1a58"><td class="mdescLeft">&#160;</td><td class="mdescRight"><code>MACH_EXCEPTION_CODES</code> with the correct type for a Mach exception behavior, <code>exception_behavior_t</code>. <a href="#a7dbcba9449a5dd47d2911b1f85bc1a58">More...</a><br /></td></tr>
<tr class="separator:a7dbcba9449a5dd47d2911b1f85bc1a58"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ad22bbde846a82173474ba002116c325c"><td class="memItemLeft" align="right" valign="top"><a id="ad22bbde846a82173474ba002116c325c"></a>
const exception_type_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ad22bbde846a82173474ba002116c325c">kMachExceptionSimulated</a> = 'CPsx'</td></tr>
<tr class="memdesc:ad22bbde846a82173474ba002116c325c"><td class="mdescLeft">&#160;</td><td class="mdescRight">An exception type to use for simulated exceptions. <br /></td></tr>
<tr class="separator:ad22bbde846a82173474ba002116c325c"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a2673983f0177685e048be73ee578eddb"><td class="memItemLeft" align="right" valign="top">const mach_msg_option_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a2673983f0177685e048be73ee578eddb">kMachMessageReceiveAuditTrailer</a></td></tr>
<tr class="memdesc:a2673983f0177685e048be73ee578eddb"><td class="mdescLeft">&#160;</td><td class="mdescRight">A Mach message option specifying that an audit trailer should be delivered during a receive operation. <a href="#a2673983f0177685e048be73ee578eddb">More...</a><br /></td></tr>
<tr class="separator:a2673983f0177685e048be73ee578eddb"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ae0af855b48de54cc50ef186da37cb769"><td class="memItemLeft" align="right" valign="top"><a id="ae0af855b48de54cc50ef186da37cb769"></a>
const char&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#ae0af855b48de54cc50ef186da37cb769">kContentType</a> [] = &quot;Content-Type&quot;</td></tr>
<tr class="memdesc:ae0af855b48de54cc50ef186da37cb769"><td class="mdescLeft">&#160;</td><td class="mdescRight">The header name <code>"Content-Type"</code>. <br /></td></tr>
<tr class="separator:ae0af855b48de54cc50ef186da37cb769"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a281b3c75cd8b0ae8ba3c9658a60bf2b3"><td class="memItemLeft" align="right" valign="top"><a id="a281b3c75cd8b0ae8ba3c9658a60bf2b3"></a>
const char&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespacecrashpad.html#a281b3c75cd8b0ae8ba3c9658a60bf2b3">kContentLength</a> [] = &quot;Content-Length&quot;</td></tr>
<tr class="memdesc:a281b3c75cd8b0ae8ba3c9658a60bf2b3"><td class="mdescLeft">&#160;</td><td class="mdescRight">The header name <code>"Content-Length"</code>. <br /></td></tr>
<tr class="separator:a281b3c75cd8b0ae8ba3c9658a60bf2b3"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table>
<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
<div class="textblock"><p>The main namespace. </p>
</div><h2 class="groupheader">Typedef Documentation</h2>
<a id="a86fa676850a73fb41a996c8fe256c175"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a86fa676850a73fb41a996c8fe256c175">&sect;&nbsp;</a></span>AlignedVector</h2>
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T , size_t Alignment = ALIGNOF(T)&gt; </div>
<table class="memname">
<tr>
<td class="memname">using <a class="el" href="namespacecrashpad.html#a86fa676850a73fb41a996c8fe256c175">crashpad::AlignedVector</a> = typedef std::vector&lt;T, <a class="el" href="structcrashpad_1_1AlignedAllocator.html">AlignedAllocator</a>&lt;T, Alignment&gt;&gt;</td>
</tr>
</table>
</div><div class="memdoc">
<p>A <code>std::vector</code> using <a class="el" href="structcrashpad_1_1AlignedAllocator.html" title="A standard allocator that aligns its allocations as requested, suitable for use as an allocator in st...">AlignedAllocator</a>. </p>
<p>This is similar to <code>std::vector&lt;T&gt;</code>, with the addition of an alignment guarantee. <em>Alignment</em> must be a power of 2. If <em>Alignment</em> is not specified, the default alignment for type <em>T</em> is used. </p>
</div>
</div>
<a id="a8d7f0170c573e59ca6b02e29735f4fad"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a8d7f0170c573e59ca6b02e29735f4fad">&sect;&nbsp;</a></span>CheckedMachAddressRange</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">using <a class="el" href="namespacecrashpad.html#a8d7f0170c573e59ca6b02e29735f4fad">crashpad::CheckedMachAddressRange</a> = typedef <a class="el" href="classcrashpad_1_1internal_1_1CheckedAddressRangeGeneric.html">internal::CheckedAddressRangeGeneric</a>&lt;mach_vm_address_t, mach_vm_size_t&gt;</td>
</tr>
</table>
</div><div class="memdoc">
<p>Ensures that a range, composed of a base and a size, does not overflow the pointer type of the process it describes a range in. </p>
<p>This class checks bases of type <code>mach_vm_address_t</code> and sizes of type <code>mach_vm_address_t</code> against a process whose pointer type is either 32 or 64 bits wide.</p>
<p>Aside from varying the overall range on the basis of a process pointer type width, this class functions very similarly to <a class="el" href="classcrashpad_1_1CheckedRange.html" title="Ensures that a range, composed of a base and size, does not overflow its data type. ">CheckedRange</a>. </p>
</div>
</div>
<a id="ad171ce8db60c84b2d875f7acd3b90f1e"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ad171ce8db60c84b2d875f7acd3b90f1e">&sect;&nbsp;</a></span>CheckedWinAddressRange</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">using <a class="el" href="namespacecrashpad.html#ad171ce8db60c84b2d875f7acd3b90f1e">crashpad::CheckedWinAddressRange</a> = typedef <a class="el" href="classcrashpad_1_1internal_1_1CheckedAddressRangeGeneric.html">internal::CheckedAddressRangeGeneric</a>&lt;<a class="el" href="namespacecrashpad.html#a368af6d88f68998b5c5eb80b8f6ebb76">WinVMAddress</a>, <a class="el" href="namespacecrashpad.html#a1bac9f2a189b24737e743d6690362239">WinVMSize</a>&gt;</td>
</tr>
</table>
</div><div class="memdoc">
<p>Ensures that a range, composed of a base and a size, does not overflow the pointer type of the process it describes a range in. </p>
<p>This class checks bases of type WinVMAddress and sizes of type WinVMSize against a process whose pointer type is either 32 or 64 bits wide.</p>
<p>Aside from varying the overall range on the basis of a process' pointer type width, this class functions very similarly to <a class="el" href="classcrashpad_1_1CheckedRange.html" title="Ensures that a range, composed of a base and size, does not overflow its data type. ">CheckedRange</a>. </p>
</div>
</div>
<a id="a72fa9ea632f7f1ec93ec3c1b1d300db6"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a72fa9ea632f7f1ec93ec3c1b1d300db6">&sect;&nbsp;</a></span>ConstThreadState</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">using <a class="el" href="namespacecrashpad.html#a72fa9ea632f7f1ec93ec3c1b1d300db6">crashpad::ConstThreadState</a> = typedef const natural_t*</td>
</tr>
</table>
</div><div class="memdoc">
<p>A const version of <code>thread_state_t</code>. </p>
<p>This is useful as the <em>old_state</em> parameter to exception handler functions. Normally, these parameters are of type <code>thread_state_t</code>, but this allows modification of the state, which is conceptually <code>const</code>. </p>
</div>
</div>
<a id="a34f36473e385b19eb229798ab2f7210c"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a34f36473e385b19eb229798ab2f7210c">&sect;&nbsp;</a></span>MachMessageDeadline</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">using <a class="el" href="namespacecrashpad.html#a34f36473e385b19eb229798ab2f7210c">crashpad::MachMessageDeadline</a> = typedef uint64_t</td>
</tr>
</table>
</div><div class="memdoc">
<p>The time before which a <a class="el" href="namespacecrashpad.html#a35293418a0b7637a00631807ac4b431e" title="Runs mach_msg() with a deadline, as opposed to a timeout. ">MachMessageWithDeadline()</a> call should complete. </p>
<p>A value of this type may be one of the special constants <a class="el" href="namespacecrashpad.html#a163a3ceac0adcb2419bb8d97e1425b94a6461bf9de012b5f2305fb3da6d0f82d5" title="MachMessageWithDeadline() should not block at all in its operation. ">kMachMessageDeadlineNonblocking</a> or <a class="el" href="namespacecrashpad.html#a163a3ceac0adcb2419bb8d97e1425b94a848a739b3c252f4565161a6bd3f070d6" title="MachMessageWithDeadline() should wait indefinitely for the requested operation to complete...">kMachMessageDeadlineWaitIndefinitely</a>. Any other values should be produced by calling <a class="el" href="namespacecrashpad.html#aa31f495c675536bcb30d1267c3a9b696" title="Computes the deadline for a specified timeout value. ">MachMessageDeadlineFromTimeout()</a>.</p>
<p>Internally, these are currently specified on the same time base as <a class="el" href="namespacecrashpad.html#aa93af751a4a09c316fb3de1a90e03fe8" title="Returns the value of the systems monotonic clock. ">ClockMonotonicNanoseconds()</a>, although this is an implementation detail. </p>
</div>
</div>
<a id="ae426d8c91f5448aaf543f91478d831da"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ae426d8c91f5448aaf543f91478d831da">&sect;&nbsp;</a></span>MinidumpThreadIDMap</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">using <a class="el" href="namespacecrashpad.html#ae426d8c91f5448aaf543f91478d831da">crashpad::MinidumpThreadIDMap</a> = typedef std::map&lt;uint64_t, uint32_t&gt;</td>
</tr>
</table>
</div><div class="memdoc">
<p>A map that connects 64-bit snapshot thread IDs to 32-bit minidump thread IDs. </p>
<p>64-bit snapshot thread IDs are obtained from <a class="el" href="classcrashpad_1_1ThreadSnapshot.html#a3c953575fadb934cd5f163560df149da" title="Returns the threads identifier. ">ThreadSnapshot::ThreadID()</a>. 32-bit minidump thread IDs are stored in <a class="el" href="structMINIDUMP__THREAD.html#a1d2508187af6c3ec09e5836badb56fd2" title="The threads ID. This may be referenced by MINIDUMP_EXCEPTION_STREAM::ThreadId. ">MINIDUMP_THREAD::ThreadId</a>.</p>
<p>A ThreadIDMap ensures that there are no collisions among the set of 32-bit minidump thread IDs. </p>
</div>
</div>
<a id="a9cae195b61eb9fe7cd4ae9a66e13f00f"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a9cae195b61eb9fe7cd4ae9a66e13f00f">&sect;&nbsp;</a></span>PointerVector</h2>
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T &gt; </div>
<table class="memname">
<tr>
<td class="memname">using <a class="el" href="namespacecrashpad.html#a9cae195b61eb9fe7cd4ae9a66e13f00f">crashpad::PointerVector</a> = typedef <a class="el" href="classcrashpad_1_1PointerContainer.html">PointerContainer</a>&lt;std::vector&lt;T*&gt;&gt;</td>
</tr>
</table>
</div><div class="memdoc">
<p>Allows a <code>std::vector</code> to “own” pointer elements stored in it. </p>
<p>When the vector is destroyed, <code>delete</code> will be called on its pointer elements.</p>
<dl class="section note"><dt>Note</dt><dd>No attempt is made to <code>delete</code> elements that are removed from the vector by other means, such as replacement or <code>clear()</code>. </dd></dl>
</div>
</div>
<a id="ac21afdb4f6e3c57ccf3bd34ea8410978"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ac21afdb4f6e3c57ccf3bd34ea8410978">&sect;&nbsp;</a></span>SimpleStringDictionary</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">using <a class="el" href="namespacecrashpad.html#ac21afdb4f6e3c57ccf3bd34ea8410978">crashpad::SimpleStringDictionary</a> = typedef <a class="el" href="classcrashpad_1_1TSimpleStringDictionary.html">TSimpleStringDictionary</a>&lt;256, 256, 64&gt;</td>
</tr>
</table>
</div><div class="memdoc">
<p>A <a class="el" href="classcrashpad_1_1TSimpleStringDictionary.html" title="A map/dictionary collection implementation using a fixed amount of storage, so that it does not perfo...">TSimpleStringDictionary</a> with default template parameters. </p>
<p>For historical reasons this specialized version is available with the same size factors as a previous implementation. </p>
</div>
</div>
<h2 class="groupheader">Enumeration Type Documentation</h2>
<a id="a29691961b22233f7519b41a78fd99449"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a29691961b22233f7519b41a78fd99449">&sect;&nbsp;</a></span>anonymous enum</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">anonymous enum</td>
</tr>
</table>
</div><div class="memdoc">
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a29691961b22233f7519b41a78fd99449ae4f1a3b637ac392d76826131e72ac832"></a>kXPProcessAllAccess&#160;</td><td class="fielddoc"><p>This is the XP-suitable value of <code>PROCESS_ALL_ACCESS</code>. </p>
<p>Requesting <code>PROCESS_ALL_ACCESS</code> with the value defined when building against a Vista+ SDK results in <code>ERROR_ACCESS_DENIED</code> when running on XP. See <a href="https://msdn.microsoft.com/en-ca/library/windows/desktop/ms684880.aspx">https://msdn.microsoft.com/en-ca/library/windows/desktop/ms684880.aspx</a> </p>
</td></tr>
<tr><td class="fieldname"><a id="a29691961b22233f7519b41a78fd99449af4736ae0e9abf32de684ad33895eec0e"></a>kXPThreadAllAccess&#160;</td><td class="fielddoc"><p>This is the XP-suitable value of <code>THREAD_ALL_ACCESS</code>. </p>
<p>Requesting <code>THREAD_ALL_ACCESS</code> with the value defined when building against a Vista+ SDK results in <code>ERROR_ACCESS_DENIED</code> when running on XP. See <a href="https://msdn.microsoft.com/en-us/library/windows/desktop/ms686769.aspx">https://msdn.microsoft.com/en-us/library/windows/desktop/ms686769.aspx</a> </p>
</td></tr>
</table>
</div>
</div>
<a id="a9c82d3742b041daf266c44df253ef02d"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a9c82d3742b041daf266c44df253ef02d">&sect;&nbsp;</a></span>anonymous enum</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">anonymous enum : mach_msg_timeout_t</td>
</tr>
</table>
</div><div class="memdoc">
<p>Special constants used as <code>mach_msg_timeout_t</code> values. </p>
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a9c82d3742b041daf266c44df253ef02da15aaf8991271871ab08493449c00a048"></a>kMachMessageTimeoutNonblocking&#160;</td><td class="fielddoc"><p>When passed to <a class="el" href="namespacecrashpad.html#aa31f495c675536bcb30d1267c3a9b696" title="Computes the deadline for a specified timeout value. ">MachMessageDeadlineFromTimeout()</a>, that function will return <a class="el" href="namespacecrashpad.html#a163a3ceac0adcb2419bb8d97e1425b94a6461bf9de012b5f2305fb3da6d0f82d5" title="MachMessageWithDeadline() should not block at all in its operation. ">kMachMessageDeadlineNonblocking</a>. </p>
</td></tr>
<tr><td class="fieldname"><a id="a9c82d3742b041daf266c44df253ef02daaf4f2c8a649ea6bcfe896e77c312315f"></a>kMachMessageTimeoutWaitIndefinitely&#160;</td><td class="fielddoc"><p>When passed to <a class="el" href="namespacecrashpad.html#aa31f495c675536bcb30d1267c3a9b696" title="Computes the deadline for a specified timeout value. ">MachMessageDeadlineFromTimeout()</a>, that function will return <a class="el" href="namespacecrashpad.html#a163a3ceac0adcb2419bb8d97e1425b94a848a739b3c252f4565161a6bd3f070d6" title="MachMessageWithDeadline() should wait indefinitely for the requested operation to complete...">kMachMessageDeadlineWaitIndefinitely</a>. </p>
</td></tr>
</table>
</div>
</div>
<a id="a163a3ceac0adcb2419bb8d97e1425b94"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a163a3ceac0adcb2419bb8d97e1425b94">&sect;&nbsp;</a></span>anonymous enum</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">anonymous enum : <a class="el" href="namespacecrashpad.html#a34f36473e385b19eb229798ab2f7210c">MachMessageDeadline</a></td>
</tr>
</table>
</div><div class="memdoc">
<p>Special constants used as <a class="el" href="namespacecrashpad.html#a34f36473e385b19eb229798ab2f7210c">MachMessageDeadline</a> values. </p>
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a163a3ceac0adcb2419bb8d97e1425b94a6461bf9de012b5f2305fb3da6d0f82d5"></a>kMachMessageDeadlineNonblocking&#160;</td><td class="fielddoc"><p><a class="el" href="namespacecrashpad.html#a35293418a0b7637a00631807ac4b431e" title="Runs mach_msg() with a deadline, as opposed to a timeout. ">MachMessageWithDeadline()</a> should not block at all in its operation. </p>
</td></tr>
<tr><td class="fieldname"><a id="a163a3ceac0adcb2419bb8d97e1425b94a848a739b3c252f4565161a6bd3f070d6"></a>kMachMessageDeadlineWaitIndefinitely&#160;</td><td class="fielddoc"><p><a class="el" href="namespacecrashpad.html#a35293418a0b7637a00631807ac4b431e" title="Runs mach_msg() with a deadline, as opposed to a timeout. ">MachMessageWithDeadline()</a> should wait indefinitely for the requested operation to complete. </p>
</td></tr>
</table>
</div>
</div>
<a id="a270e290ba558e948eb6690bd217cbb71"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a270e290ba558e948eb6690bd217cbb71">&sect;&nbsp;</a></span>CPUArchitecture</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">enum <a class="el" href="namespacecrashpad.html#a270e290ba558e948eb6690bd217cbb71">crashpad::CPUArchitecture</a></td>
</tr>
</table>
</div><div class="memdoc">
<p>A systems CPU architecture. </p>
<p>This can be used to represent the CPU architecture of an entire system as in SystemSnapshot::CPUArchitecture(). It can also be used to represent the architecture of a <a class="el" href="structcrashpad_1_1CPUContext.html" title="A context structure capable of carrying the context of any supported CPU architecture. ">CPUContext</a> structure in its <a class="el" href="structcrashpad_1_1CPUContext.html#af71f7a2e8478339d53fcb9d52ded6ae5" title="The CPU architecture of a context structure. This field controls the expression of the union...">CPUContext::architecture</a> field without reference to external data. </p>
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a270e290ba558e948eb6690bd217cbb71a4a3c395099ca8e31f9bd9511e058c73c"></a>kCPUArchitectureUnknown&#160;</td><td class="fielddoc"><p>The CPU architecture is unknown. </p>
</td></tr>
<tr><td class="fieldname"><a id="a270e290ba558e948eb6690bd217cbb71a35adbd1bc0b19ef37c520d078cf0df15"></a>kCPUArchitectureX86&#160;</td><td class="fielddoc"><p>32-bit x86. </p>
</td></tr>
<tr><td class="fieldname"><a id="a270e290ba558e948eb6690bd217cbb71addee685df867aea490719783e56baf0a"></a>kCPUArchitectureX86_64&#160;</td><td class="fielddoc"><p>x86_64. </p>
</td></tr>
</table>
</div>
</div>
<a id="a3753a95b02e5c96c6e20017e467cef07"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a3753a95b02e5c96c6e20017e467cef07">&sect;&nbsp;</a></span>FileLocking</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">enum <a class="el" href="namespacecrashpad.html#a3753a95b02e5c96c6e20017e467cef07">crashpad::FileLocking</a> : bool</td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">strong</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Determines the locking mode that <a class="el" href="namespacecrashpad.html#acd02263566d8c43fc7886f88a13b364f" title="Locks the given file using flock() on POSIX or LockFileEx() on Windows. ">LoggingLockFile()</a> uses. </p>
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a3753a95b02e5c96c6e20017e467cef07a767e1337acb2aa20d7ce4e903a75ca16"></a>kShared&#160;</td><td class="fielddoc"><p>Equivalent to <code>flock()</code> with <code>LOCK_SH</code>. </p>
</td></tr>
<tr><td class="fieldname"><a id="a3753a95b02e5c96c6e20017e467cef07a9d38b79e17ebc3239ca19ba517174b5b"></a>kExclusive&#160;</td><td class="fielddoc"><p>Equivalent to <code>flock()</code> with <code>LOCK_EX</code>. </p>
</td></tr>
</table>
</div>
</div>
<a id="a034ccc90eb0d1f587ee89275d822175d"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a034ccc90eb0d1f587ee89275d822175d">&sect;&nbsp;</a></span>FilePermissions</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">enum <a class="el" href="namespacecrashpad.html#a034ccc90eb0d1f587ee89275d822175d">crashpad::FilePermissions</a> : bool</td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">strong</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Determines the permissions bits for files created on POSIX systems. </p>
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a034ccc90eb0d1f587ee89275d822175dab73168a18962d7b0ed6b67f2e0ade611"></a>kOwnerOnly&#160;</td><td class="fielddoc"><p>Equivalent to <code>0600</code>. </p>
</td></tr>
<tr><td class="fieldname"><a id="a034ccc90eb0d1f587ee89275d822175da5368ce91b6c60534fe1187a23e98924d"></a>kWorldReadable&#160;</td><td class="fielddoc"><p>Equivalent to <code>0644</code>. </p>
</td></tr>
</table>
</div>
</div>
<a id="afa69b0967d9a6df659ff5d2a02ff3e51"></a>
<h2 class="memtitle"><span class="permalink"><a href="#afa69b0967d9a6df659ff5d2a02ff3e51">&sect;&nbsp;</a></span>FileWriteMode</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">enum <a class="el" href="namespacecrashpad.html#afa69b0967d9a6df659ff5d2a02ff3e51">crashpad::FileWriteMode</a></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">strong</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Determines the mode that <a class="el" href="namespacecrashpad.html#a62fc6876cc0c660f0ea8bd1dd0a07e82" title="Wraps OpenFileForWrite(), logging an error if the operation fails. ">LoggingOpenFileForWrite()</a> uses. </p>
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="afa69b0967d9a6df659ff5d2a02ff3e51aafde8ca07d267d05bcec5df8b0fc6c22"></a>kReuseOrFail&#160;</td><td class="fielddoc"><p>Opens the file if it exists, or fails if it does not. </p>
</td></tr>
<tr><td class="fieldname"><a id="afa69b0967d9a6df659ff5d2a02ff3e51ae32f90c7a8d4224749e4e99f11e5eee7"></a>kReuseOrCreate&#160;</td><td class="fielddoc"><p>Opens the file if it exists, or creates a new file. </p>
</td></tr>
<tr><td class="fieldname"><a id="afa69b0967d9a6df659ff5d2a02ff3e51a751805077642855501f572c876e1d907"></a>kTruncateOrCreate&#160;</td><td class="fielddoc"><p>Creates a new file. If the file already exists, it will be overwritten. </p>
</td></tr>
<tr><td class="fieldname"><a id="afa69b0967d9a6df659ff5d2a02ff3e51a4ece9fd054e01c35ba925186adcf0c71"></a>kCreateOrFail&#160;</td><td class="fielddoc"><p>Creates a new file. If the file already exists, the open will fail. </p>
</td></tr>
</table>
</div>
</div>
<a id="aa197c419950bae99f1ba663f10b1891c"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aa197c419950bae99f1ba663f10b1891c">&sect;&nbsp;</a></span>MinidumpContextAMD64Flags</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">enum <a class="el" href="namespacecrashpad.html#aa197c419950bae99f1ba663f10b1891c">crashpad::MinidumpContextAMD64Flags</a> : uint32_t</td>
</tr>
</table>
</div><div class="memdoc">
<p>x86_64-specific flags for <a class="el" href="structcrashpad_1_1MinidumpContextAMD64.html#a086c5c2655800e91e080241317aa3ace" title="A bitfield composed of values of MinidumpContextFlags and MinidumpContextAMD64Flags. ">MinidumpContextAMD64::context_flags</a>. </p>
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="aa197c419950bae99f1ba663f10b1891caaa3c47e2ec7565ce81b7cda3a4c101c6"></a>kMinidumpContextAMD64&#160;</td><td class="fielddoc"><p>Identifies the context structure as x86_64. This is the same as <code>CONTEXT_AMD64</code> on Windows for this architecture. </p>
</td></tr>
<tr><td class="fieldname"><a id="aa197c419950bae99f1ba663f10b1891ca7aaf3a9f32414c379444f75a341f61f6"></a>kMinidumpContextAMD64Control&#160;</td><td class="fielddoc"><p>Indicates the validity of control registers (<code>CONTEXT_CONTROL</code>). </p>
<p>The <code>cs</code>, <code>ss</code>, <code>eflags</code>, <code>rsp</code>, and <code>rip</code> fields are valid. </p>
</td></tr>
<tr><td class="fieldname"><a id="aa197c419950bae99f1ba663f10b1891ca3231a2e73f13021707e1dd5465124c94"></a>kMinidumpContextAMD64Integer&#160;</td><td class="fielddoc"><p>Indicates the validity of non-control integer registers (<code>CONTEXT_INTEGER</code>). </p>
<p>The <code>rax</code>, <code>rcx</code>, <code>rdx</code>, <code>rbx</code>, <code>rbp</code>, <code>rsi</code>, <code>rdi</code>, and <code>r8</code> through <code>r15</code> fields are valid. </p>
</td></tr>
<tr><td class="fieldname"><a id="aa197c419950bae99f1ba663f10b1891ca087fcb89147fcb03a42917257d7c95d8"></a>kMinidumpContextAMD64Segment&#160;</td><td class="fielddoc"><p>Indicates the validity of non-control segment registers (<code>CONTEXT_SEGMENTS</code>). </p>
<p>The <code>ds</code>, <code>es</code>, <code>fs</code>, and <code>gs</code> fields are valid. </p>
</td></tr>
<tr><td class="fieldname"><a id="aa197c419950bae99f1ba663f10b1891ca80855829a791a48417d0599bda56685c"></a>kMinidumpContextAMD64FloatingPoint&#160;</td><td class="fielddoc"><p>Indicates the validity of floating-point state (<code>CONTEXT_FLOATING_POINT</code>). </p>
<p>The <code>xmm0</code> through <code>xmm15</code> fields are valid. </p>
</td></tr>
<tr><td class="fieldname"><a id="aa197c419950bae99f1ba663f10b1891ca0a6187be426495350ac54f8eec044770"></a>kMinidumpContextAMD64Debug&#160;</td><td class="fielddoc"><p>Indicates the validity of debug registers (<code>CONTEXT_DEBUG_REGISTERS</code>). </p>
<p>The <code>dr0</code> through <code>dr3</code>, <code>dr6</code>, and <code>dr7</code> fields are valid. </p>
</td></tr>
<tr><td class="fieldname"><a id="aa197c419950bae99f1ba663f10b1891cae39eafc6efd87afc7c6977ae3cc0fc96"></a>kMinidumpContextAMD64Xstate&#160;</td><td class="fielddoc"><p>Indicates the validity of <code>xsave</code> data (<code>CONTEXT_XSTATE</code>). </p>
<p>The context contains <code>xsave</code> data. This is used with an extended context structure not currently defined here. </p>
</td></tr>
<tr><td class="fieldname"><a id="aa197c419950bae99f1ba663f10b1891ca7d67332dea79c652a93e592341ab5e51"></a>kMinidumpContextAMD64Full&#160;</td><td class="fielddoc"><p>Indicates the validity of control, integer, and floating-point registers (<code>CONTEXT_FULL</code>). </p>
</td></tr>
<tr><td class="fieldname"><a id="aa197c419950bae99f1ba663f10b1891cac84b1d90bf34dbb26631ca77d942abf8"></a>kMinidumpContextAMD64All&#160;</td><td class="fielddoc"><p>Indicates the validity of all registers except <code>xsave</code> data (<code>CONTEXT_ALL</code>). </p>
</td></tr>
</table>
</div>
</div>
<a id="a835e6bd6cb3f97c99c572596878c1573"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a835e6bd6cb3f97c99c572596878c1573">&sect;&nbsp;</a></span>MinidumpContextFlags</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">enum <a class="el" href="namespacecrashpad.html#a835e6bd6cb3f97c99c572596878c1573">crashpad::MinidumpContextFlags</a> : uint32_t</td>
</tr>
</table>
</div><div class="memdoc">
<p>Architecture-independent flags for <code>context_flags</code> fields in Minidump context structures. </p>
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a835e6bd6cb3f97c99c572596878c1573ac76899aed0f9a5f331fcdc9343a1bc68"></a>kMinidumpContextExceptionActive&#160;</td><td class="fielddoc"><p>The thread was executing a trap handler in kernel mode (<code>CONTEXT_EXCEPTION_ACTIVE</code>). </p>
<p>If this bit is set, it indicates that the context is from a thread that was executing a trap handler in the kernel. This bit is only valid when <a class="el" href="namespacecrashpad.html#a835e6bd6cb3f97c99c572596878c1573ae8cd92df6bc89b12ba3a4f7fe8529f10" title="Kernel-mode state reporting is provided (CONTEXT_EXCEPTION_REPORTING). ">kMinidumpContextExceptionReporting</a> is also set. This bit is only used on Windows. </p>
</td></tr>
<tr><td class="fieldname"><a id="a835e6bd6cb3f97c99c572596878c1573ac0a5b0f61a08eae36fc1ed26fa929ebb"></a>kMinidumpContextServiceActive&#160;</td><td class="fielddoc"><p>The thread was executing a system call in kernel mode (<code>CONTEXT_SERVICE_ACTIVE</code>). </p>
<p>If this bit is set, it indicates that the context is from a thread that was executing a system call in the kernel. This bit is only valid when <a class="el" href="namespacecrashpad.html#a835e6bd6cb3f97c99c572596878c1573ae8cd92df6bc89b12ba3a4f7fe8529f10" title="Kernel-mode state reporting is provided (CONTEXT_EXCEPTION_REPORTING). ">kMinidumpContextExceptionReporting</a> is also set. This bit is only used on Windows. </p>
</td></tr>
<tr><td class="fieldname"><a id="a835e6bd6cb3f97c99c572596878c1573a86fb4b3183b9ec5acb7798246f2de9e5"></a>kMinidumpContextExceptionRequest&#160;</td><td class="fielddoc"><p>Kernel-mode state reporting is desired (<code>CONTEXT_EXCEPTION_REQUEST</code>). </p>
<p>This bit is not used in context structures containing snapshots of thread CPU context. It used when calling <code>GetThreadContext()</code> on Windows to specify that kernel-mode state reporting (<a class="el" href="namespacecrashpad.html#a835e6bd6cb3f97c99c572596878c1573ae8cd92df6bc89b12ba3a4f7fe8529f10" title="Kernel-mode state reporting is provided (CONTEXT_EXCEPTION_REPORTING). ">kMinidumpContextExceptionReporting</a>) is desired in the returned context structure. </p>
</td></tr>
<tr><td class="fieldname"><a id="a835e6bd6cb3f97c99c572596878c1573ae8cd92df6bc89b12ba3a4f7fe8529f10"></a>kMinidumpContextExceptionReporting&#160;</td><td class="fielddoc"><p>Kernel-mode state reporting is provided (<code>CONTEXT_EXCEPTION_REPORTING</code>). </p>
<p>If this bit is set, it indicates that the bits indicating how the thread had entered kernel mode (<a class="el" href="namespacecrashpad.html#a835e6bd6cb3f97c99c572596878c1573ac76899aed0f9a5f331fcdc9343a1bc68" title="The thread was executing a trap handler in kernel mode (CONTEXT_EXCEPTION_ACTIVE). ">kMinidumpContextExceptionActive</a> and and <a class="el" href="namespacecrashpad.html#a835e6bd6cb3f97c99c572596878c1573ac0a5b0f61a08eae36fc1ed26fa929ebb" title="The thread was executing a system call in kernel mode (CONTEXT_SERVICE_ACTIVE). ">kMinidumpContextServiceActive</a>) are valid. This bit is only used on Windows. </p>
</td></tr>
</table>
</div>
</div>
<a id="a2a503f0a39ec98188b60178edbc1fc55"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a2a503f0a39ec98188b60178edbc1fc55">&sect;&nbsp;</a></span>MinidumpContextX86Flags</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">enum <a class="el" href="namespacecrashpad.html#a2a503f0a39ec98188b60178edbc1fc55">crashpad::MinidumpContextX86Flags</a> : uint32_t</td>
</tr>
</table>
</div><div class="memdoc">
<p>32-bit x86-specifc flags for <a class="el" href="structcrashpad_1_1MinidumpContextX86.html#a0b4f61874b6d7bf6bb750e270ceaad80" title="A bitfield composed of values of MinidumpContextFlags and MinidumpContextX86Flags. ">MinidumpContextX86::context_flags</a>. </p>
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a2a503f0a39ec98188b60178edbc1fc55a2f6918d087ba8042f2df2342e4fb3875"></a>kMinidumpContextX86&#160;</td><td class="fielddoc"><p>Identifies the context structure as 32-bit x86. This is the same as <code>CONTEXT_i386</code> and <code>CONTEXT_i486</code> on Windows for this architecture. </p>
</td></tr>
<tr><td class="fieldname"><a id="a2a503f0a39ec98188b60178edbc1fc55ada1e4c9c9232467b3f2d3784bceecb7b"></a>kMinidumpContextX86Control&#160;</td><td class="fielddoc"><p>Indicates the validity of control registers (<code>CONTEXT_CONTROL</code>). </p>
<p>The <code>ebp</code>, <code>eip</code>, <code>cs</code>, <code>eflags</code>, <code>esp</code>, and <code>ss</code> fields are valid. </p>
</td></tr>
<tr><td class="fieldname"><a id="a2a503f0a39ec98188b60178edbc1fc55a8cee96af57fd2f7e45350dadd97743ad"></a>kMinidumpContextX86Integer&#160;</td><td class="fielddoc"><p>Indicates the validity of non-control integer registers (<code>CONTEXT_INTEGER</code>). </p>
<p>The <code>edi</code>, <code>esi</code>, <code>ebx</code>, <code>edx</code>, <code>ecx, and</code>eax` fields are valid. </p>
</td></tr>
<tr><td class="fieldname"><a id="a2a503f0a39ec98188b60178edbc1fc55a351a40dfb28c1bed5d3efbaa5109f69e"></a>kMinidumpContextX86Segment&#160;</td><td class="fielddoc"><p>Indicates the validity of non-control segment registers (<code>CONTEXT_SEGMENTS</code>). </p>
<p>The <code>gs</code>, <code>fs</code>, <code>es</code>, and <code>ds</code> fields are valid. </p>
</td></tr>
<tr><td class="fieldname"><a id="a2a503f0a39ec98188b60178edbc1fc55aab6d4add027b8667770e914b21e22471"></a>kMinidumpContextX86FloatingPoint&#160;</td><td class="fielddoc"><p>Indicates the validity of floating-point state (<code>CONTEXT_FLOATING_POINT</code>). </p>
<p>The <code>float_save</code> field is valid. </p>
</td></tr>
<tr><td class="fieldname"><a id="a2a503f0a39ec98188b60178edbc1fc55a9cab86cf2d37ab8bc0f6ec0fa9a1442e"></a>kMinidumpContextX86Debug&#160;</td><td class="fielddoc"><p>Indicates the validity of debug registers (<code>CONTEXT_DEBUG_REGISTERS</code>). </p>
<p>The <code>dr0</code> through <code>dr3</code>, <code>dr6</code>, and <code>dr7</code> fields are valid. </p>
</td></tr>
<tr><td class="fieldname"><a id="a2a503f0a39ec98188b60178edbc1fc55afbe5d3708e41ca9b92a6d3acb6f6f322"></a>kMinidumpContextX86Extended&#160;</td><td class="fielddoc"><p>Indicates the validity of extended registers in <code>fxsave</code> format (<code>CONTEXT_EXTENDED_REGISTERS</code>). </p>
<p>The <code>extended_registers</code> field is valid and contains <code>fxsave</code> data. </p>
</td></tr>
<tr><td class="fieldname"><a id="a2a503f0a39ec98188b60178edbc1fc55a2e59094ad192c7388e85ca768d741dd4"></a>kMinidumpContextX86Xstate&#160;</td><td class="fielddoc"><p>Indicates the validity of <code>xsave</code> data (<code>CONTEXT_XSTATE</code>). </p>
<p>The context contains <code>xsave</code> data. This is used with an extended context structure not currently defined here. </p>
</td></tr>
<tr><td class="fieldname"><a id="a2a503f0a39ec98188b60178edbc1fc55a8dd8413af4852a4ca699b17a4d39d7bd"></a>kMinidumpContextX86Full&#160;</td><td class="fielddoc"><p>Indicates the validity of control, integer, and segment registers. (<code>CONTEXT_FULL</code>). </p>
</td></tr>
<tr><td class="fieldname"><a id="a2a503f0a39ec98188b60178edbc1fc55a49dd96e7cd1bb82c676a38eece63d63f"></a>kMinidumpContextX86All&#160;</td><td class="fielddoc"><p>Indicates the validity of all registers except <code>xsave</code> data. (<code>CONTEXT_ALL</code>). </p>
</td></tr>
</table>
</div>
</div>
<a id="a98e532bb06fc5ffdd93e0ceb6d789eb1"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a98e532bb06fc5ffdd93e0ceb6d789eb1">&sect;&nbsp;</a></span>MinidumpCPUArchitecture</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">enum <a class="el" href="namespacecrashpad.html#a98e532bb06fc5ffdd93e0ceb6d789eb1">crashpad::MinidumpCPUArchitecture</a> : uint16_t</td>
</tr>
</table>
</div><div class="memdoc">
<p>CPU type values for <a class="el" href="structMINIDUMP__SYSTEM__INFO.html#adc85b29d7df8943baf1a96af23051ca8" title="The systems CPU architecture. This may be a PROCESSOR_ARCHITECTURE_* value, or a member of crashpad...">MINIDUMP_SYSTEM_INFO::ProcessorArchitecture</a>. </p>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="winnt_8h.html#PROCESSOR_ARCHITECTURE_x">PROCESSOR_ARCHITECTURE_*</a> </dd></dl>
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a98e532bb06fc5ffdd93e0ceb6d789eb1a667f84537acd054ce17f527bcd41c885"></a>kMinidumpCPUArchitectureX86&#160;</td><td class="fielddoc"><p>32-bit x86. </p>
<p>These systems identify their CPUs generically as “x86” or “ia32”, or with more specific names such as “i386”, “i486”, “i586”, and “i686”. </p>
</td></tr>
<tr><td class="fieldname"><a id="a98e532bb06fc5ffdd93e0ceb6d789eb1a37feeb34e5df713f24a65f8687d23def"></a>kMinidumpCPUArchitecturePPC&#160;</td><td class="fielddoc"><p>32-bit PowerPC. </p>
<p>These systems identify their CPUs generically as “ppc”, or with more specific names such as “ppc6xx”, “ppc7xx”, and “ppc74xx”. </p>
</td></tr>
<tr><td class="fieldname"><a id="a98e532bb06fc5ffdd93e0ceb6d789eb1a8ab29cb3332c3c583c4d60b2c308361c"></a>kMinidumpCPUArchitectureARM&#160;</td><td class="fielddoc"><p>32-bit ARM. </p>
<p>These systems identify their CPUs generically as “arm”, or with more specific names such as “armv6” and “armv7”. </p>
</td></tr>
<tr><td class="fieldname"><a id="a98e532bb06fc5ffdd93e0ceb6d789eb1a74c0fcddcbf1502d7dedc7cd965550df"></a>kMinidumpCPUArchitectureAMD64&#160;</td><td class="fielddoc"><p>64-bit x86. </p>
<p>These systems identify their CPUs as “x86_64”, “amd64”, or “x64”. </p>
</td></tr>
<tr><td class="fieldname"><a id="a98e532bb06fc5ffdd93e0ceb6d789eb1a492f53b6303f91d08192bbfb9341e3cb"></a>kMinidumpCPUArchitectureX86Win64&#160;</td><td class="fielddoc"><p>A 32-bit x86 process running on IA-64 (Itanium). </p>
<dl class="section note"><dt>Note</dt><dd>This value is not used in minidump files for 32-bit x86 processes running on a 64-bit-capable x86 CPU and operating system. In that configuration, <a class="el" href="namespacecrashpad.html#a98e532bb06fc5ffdd93e0ceb6d789eb1a667f84537acd054ce17f527bcd41c885" title="32-bit x86. ">kMinidumpCPUArchitectureX86</a> is used instead. </dd></dl>
</td></tr>
<tr><td class="fieldname"><a id="a98e532bb06fc5ffdd93e0ceb6d789eb1aa58a9c127a74412bdcbce29f0ac6d9f5"></a>kMinidumpCPUArchitectureARM64&#160;</td><td class="fielddoc"><p>64-bit ARM. </p>
<p>These systems identify their CPUs generically as “arm64” or “aarch64”, or with more specific names such as “armv8”.</p>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="namespacecrashpad.html#a98e532bb06fc5ffdd93e0ceb6d789eb1af06c5024168bed0a96de94e665ba2e70" title="Used by Breakpad for 64-bit ARM. ">kMinidumpCPUArchitectureARM64Breakpad</a> </dd></dl>
</td></tr>
<tr><td class="fieldname"><a id="a98e532bb06fc5ffdd93e0ceb6d789eb1a96f1b70341467cfcaabaac225345716b"></a>kMinidumpCPUArchitecturePPC64&#160;</td><td class="fielddoc"><p>64-bit PowerPC. </p>
<p>These systems identify their CPUs generically as “ppc64”, or with more specific names such as “ppc970”. </p>
</td></tr>
<tr><td class="fieldname"><a id="a98e532bb06fc5ffdd93e0ceb6d789eb1af06c5024168bed0a96de94e665ba2e70"></a>kMinidumpCPUArchitectureARM64Breakpad&#160;</td><td class="fielddoc"><p>Used by Breakpad for 64-bit ARM. </p>
<dl class="deprecated"><dt><b><a class="el" href="deprecated.html#_deprecated000001">Deprecated:</a></b></dt><dd>Use <a class="el" href="namespacecrashpad.html#a98e532bb06fc5ffdd93e0ceb6d789eb1aa58a9c127a74412bdcbce29f0ac6d9f5" title="64-bit ARM. ">kMinidumpCPUArchitectureARM64</a> instead. </dd></dl>
</td></tr>
<tr><td class="fieldname"><a id="a98e532bb06fc5ffdd93e0ceb6d789eb1a1d0ecd96474945b642af3568bc43ab92"></a>kMinidumpCPUArchitectureUnknown&#160;</td><td class="fielddoc"><p>Unknown CPU architecture. </p>
</td></tr>
</table>
</div>
</div>
<a id="a9be77c6f7868f00c2f279006a1abe26a"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a9be77c6f7868f00c2f279006a1abe26a">&sect;&nbsp;</a></span>MinidumpOS</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">enum <a class="el" href="namespacecrashpad.html#a9be77c6f7868f00c2f279006a1abe26a">crashpad::MinidumpOS</a> : uint32_t</td>
</tr>
</table>
</div><div class="memdoc">
<p>Operating system family values for <a class="el" href="structMINIDUMP__SYSTEM__INFO.html#a214e7bd61a89343a80a3c9a265fbbe96" title="The systems operating system family. This may be a VER_PLATFORM_* value, or a member of crashpad::M...">MINIDUMP_SYSTEM_INFO::PlatformId</a>. </p>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="winnt_8h.html#VER_PLATFORM_x">VER_PLATFORM_*</a> </dd></dl>
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a9be77c6f7868f00c2f279006a1abe26aaca1cab5b93dabab4c83400fd74dc61f9"></a>kMinidumpOSWin32s&#160;</td><td class="fielddoc"><p>Windows 3.1. </p>
</td></tr>
<tr><td class="fieldname"><a id="a9be77c6f7868f00c2f279006a1abe26aa652417bb9221b48e7086f8b5e7055e72"></a>kMinidumpOSWin32Windows&#160;</td><td class="fielddoc"><p>Windows 95, Windows 98, and Windows Me. </p>
</td></tr>
<tr><td class="fieldname"><a id="a9be77c6f7868f00c2f279006a1abe26aa00fdfb21197a2b114e5ffeb51f53e3df"></a>kMinidumpOSWin32NT&#160;</td><td class="fielddoc"><p>Windows NT, Windows 2000, and later. </p>
</td></tr>
<tr><td class="fieldname"><a id="a9be77c6f7868f00c2f279006a1abe26aa03b20aa69a12cad7a9c08b3335b309d3"></a>kMinidumpOSMacOSX&#160;</td><td class="fielddoc"><p>macOS, Darwin for traditional systems. </p>
</td></tr>
<tr><td class="fieldname"><a id="a9be77c6f7868f00c2f279006a1abe26aa093968e4c9c7704732760e9ce2916115"></a>kMinidumpOSiOS&#160;</td><td class="fielddoc"><p>iOS, Darwin for mobile devices. </p>
</td></tr>
<tr><td class="fieldname"><a id="a9be77c6f7868f00c2f279006a1abe26aa126dc921b6c301f5ce7d111a29b72d4f"></a>kMinidumpOSLinux&#160;</td><td class="fielddoc"><p>Linux, not including Android. </p>
</td></tr>
<tr><td class="fieldname"><a id="a9be77c6f7868f00c2f279006a1abe26aa071bb71519a869fa5cf7004114b979d9"></a>kMinidumpOSAndroid&#160;</td><td class="fielddoc"><p>Android. </p>
</td></tr>
<tr><td class="fieldname"><a id="a9be77c6f7868f00c2f279006a1abe26aaf352d155051b508a5452a18e29f473bb"></a>kMinidumpOSNaCl&#160;</td><td class="fielddoc"><p>Native Client (NaCl). </p>
</td></tr>
<tr><td class="fieldname"><a id="a9be77c6f7868f00c2f279006a1abe26aa7f4f96b9f35fbad451bb4c09cedfba07"></a>kMinidumpOSUnknown&#160;</td><td class="fielddoc"><p>Unknown operating system. </p>
</td></tr>
</table>
</div>
</div>
<a id="a3bf5a6562c9ccee9b4ef3ae4d9ac0be7"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a3bf5a6562c9ccee9b4ef3ae4d9ac0be7">&sect;&nbsp;</a></span>MinidumpOSType</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">enum <a class="el" href="namespacecrashpad.html#a3bf5a6562c9ccee9b4ef3ae4d9ac0be7">crashpad::MinidumpOSType</a> : uint8_t</td>
</tr>
</table>
</div><div class="memdoc">
<p>Operating system type values for <a class="el" href="structMINIDUMP__SYSTEM__INFO.html#a9aac8ed4707ea43563fed1776454bad5" title="The systems operating system type, which distinguishes between “desktop” or “workstation” syste...">MINIDUMP_SYSTEM_INFO::ProductType</a>. </p>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="winnt_8h.html#VER_NT_x">VER_NT_*</a> </dd></dl>
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a3bf5a6562c9ccee9b4ef3ae4d9ac0be7a622c5cb563f37f8861f7c58e3ec64a05"></a>kMinidumpOSTypeWorkstation&#160;</td><td class="fielddoc"><p>A “desktop” or “workstation” system. </p>
</td></tr>
<tr><td class="fieldname"><a id="a3bf5a6562c9ccee9b4ef3ae4d9ac0be7a4d37fbae0e055c62b5bfe36797b8a592"></a>kMinidumpOSTypeDomainController&#160;</td><td class="fielddoc"><p>A “domain controller” system. Windows-specific. </p>
</td></tr>
<tr><td class="fieldname"><a id="a3bf5a6562c9ccee9b4ef3ae4d9ac0be7aaf31279bbe240bb77304d8d0f4a8f949"></a>kMinidumpOSTypeServer&#160;</td><td class="fielddoc"><p>A “server” system. </p>
</td></tr>
</table>
</div>
</div>
<a id="a88363a45a4af1a16f542a8c1ff522ab9"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a88363a45a4af1a16f542a8c1ff522ab9">&sect;&nbsp;</a></span>MinidumpStreamType</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">enum <a class="el" href="namespacecrashpad.html#a88363a45a4af1a16f542a8c1ff522ab9">crashpad::MinidumpStreamType</a> : uint32_t</td>
</tr>
</table>
</div><div class="memdoc">
<p>Minidump stream type values for <a class="el" href="structMINIDUMP__DIRECTORY.html#a425b8b68da6810a126c759c5f5a94f7d" title="The type of stream referenced, a value of MINIDUMP_STREAM_TYPE. ">MINIDUMP_DIRECTORY::StreamType</a>. Each stream structure has a corresponding stream type value to identify it. </p>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="dbghelp_8h.html#a64711234318a4a002f399dffb474ca08" title="Minidump stream type values for MINIDUMP_DIRECTORY::StreamType. Each stream structure has a correspon...">MINIDUMP_STREAM_TYPE</a> </dd></dl>
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a88363a45a4af1a16f542a8c1ff522ab9af87c478a3f2ce198936d817e98d87531"></a>kMinidumpStreamTypeThreadList&#160;</td><td class="fielddoc"><p>The stream type for <a class="el" href="structMINIDUMP__THREAD__LIST.html" title="Information about all threads within the process. ">MINIDUMP_THREAD_LIST</a>. </p>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="dbghelp_8h.html#a64711234318a4a002f399dffb474ca08a4dd234223e39c89f93aabce77e649d2c" title="The stream type for MINIDUMP_THREAD_LIST. ">ThreadListStream</a> </dd></dl>
</td></tr>
<tr><td class="fieldname"><a id="a88363a45a4af1a16f542a8c1ff522ab9a226cb7d075ec01c79f233d098e9a9e3f"></a>kMinidumpStreamTypeModuleList&#160;</td><td class="fielddoc"><p>The stream type for <a class="el" href="structMINIDUMP__MODULE__LIST.html" title="Information about all modules loaded within the process at the time the snapshot was taken...">MINIDUMP_MODULE_LIST</a>. </p>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="dbghelp_8h.html#a64711234318a4a002f399dffb474ca08ad404c18554f01aa57ac0af1a7674060b" title="The stream type for MINIDUMP_MODULE_LIST. ">ModuleListStream</a> </dd></dl>
</td></tr>
<tr><td class="fieldname"><a id="a88363a45a4af1a16f542a8c1ff522ab9ac9923e6a5c46946ba2cdc8ce4272c181"></a>kMinidumpStreamTypeMemoryList&#160;</td><td class="fielddoc"><p>The stream type for <a class="el" href="structMINIDUMP__MEMORY__LIST.html" title="Information about memory regions within the process. ">MINIDUMP_MEMORY_LIST</a>. </p>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="dbghelp_8h.html#a64711234318a4a002f399dffb474ca08a1511624630cd9150436de906ae033cbd" title="The stream type for MINIDUMP_MEMORY_LIST. ">MemoryListStream</a> </dd></dl>
</td></tr>
<tr><td class="fieldname"><a id="a88363a45a4af1a16f542a8c1ff522ab9a445b370a989c63b41f4080c2584912e7"></a>kMinidumpStreamTypeException&#160;</td><td class="fielddoc"><p>The stream type for <a class="el" href="structMINIDUMP__EXCEPTION__STREAM.html" title="Information about the exception that triggered a minidump files generation. ">MINIDUMP_EXCEPTION_STREAM</a>. </p>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="dbghelp_8h.html#a64711234318a4a002f399dffb474ca08a5ddc831e2440dfcfd112cb19401bbd60" title="The stream type for MINIDUMP_EXCEPTION_STREAM. ">ExceptionStream</a> </dd></dl>
</td></tr>
<tr><td class="fieldname"><a id="a88363a45a4af1a16f542a8c1ff522ab9a57ae6ef428bb48fdc877d92bc8046bd3"></a>kMinidumpStreamTypeSystemInfo&#160;</td><td class="fielddoc"><p>The stream type for <a class="el" href="structMINIDUMP__SYSTEM__INFO.html" title="Information about the system that hosted the process that the minidump file contains a snapshot of...">MINIDUMP_SYSTEM_INFO</a>. </p>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="dbghelp_8h.html#a64711234318a4a002f399dffb474ca08a36ca9398c8a42fa4ec2b4baf9c3d3474" title="The stream type for MINIDUMP_SYSTEM_INFO. ">SystemInfoStream</a> </dd></dl>
</td></tr>
<tr><td class="fieldname"><a id="a88363a45a4af1a16f542a8c1ff522ab9a956e21d34f0d97aa5b3b640b1676ef37"></a>kMinidumpStreamTypeHandleData&#160;</td><td class="fielddoc"><p>The stream type for MINIDUMP_HANDLE_DATA_STREAM. </p>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="dbghelp_8h.html#a64711234318a4a002f399dffb474ca08ad7775c9c100abafc1b864499acf84757" title="The stream contains information about active HANDLEs. ">HandleDataStream</a> </dd></dl>
</td></tr>
<tr><td class="fieldname"><a id="a88363a45a4af1a16f542a8c1ff522ab9afab92691d30e4386b008dab71fe359f6"></a>kMinidumpStreamTypeUnloadedModuleList&#160;</td><td class="fielddoc"><p>The stream type for <a class="el" href="structMINIDUMP__UNLOADED__MODULE__LIST.html" title="Information about all modules recorded as unloaded when the snapshot was taken. ">MINIDUMP_UNLOADED_MODULE_LIST</a>. </p>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="dbghelp_8h.html#a64711234318a4a002f399dffb474ca08ac9a369c7cfd7b0c05208e4af380c4bba" title="The stream type for MINIDUMP_UNLOADED_MODULE_LIST. ">UnloadedModuleListStream</a> </dd></dl>
</td></tr>
<tr><td class="fieldname"><a id="a88363a45a4af1a16f542a8c1ff522ab9a631532de9316c7cb41cf27b2df2f802f"></a>kMinidumpStreamTypeMiscInfo&#160;</td><td class="fielddoc"><p>The stream type for <a class="el" href="structMINIDUMP__MISC__INFO.html" title="Information about the process that the minidump file contains a snapshot of, as well as the system th...">MINIDUMP_MISC_INFO</a>, <a class="el" href="structMINIDUMP__MISC__INFO__2.html" title="Information about the process that the minidump file contains a snapshot of, as well as the system th...">MINIDUMP_MISC_INFO_2</a>, <a class="el" href="structMINIDUMP__MISC__INFO__3.html" title="Information about the process that the minidump file contains a snapshot of, as well as the system th...">MINIDUMP_MISC_INFO_3</a>, and <a class="el" href="structMINIDUMP__MISC__INFO__4.html" title="Information about the process that the minidump file contains a snapshot of, as well as the system th...">MINIDUMP_MISC_INFO_4</a>. </p>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="dbghelp_8h.html#a64711234318a4a002f399dffb474ca08a02e9fb2f037d09f1cdb4eb0c9f115b33" title="The stream type for MINIDUMP_MISC_INFO, MINIDUMP_MISC_INFO_2, MINIDUMP_MISC_INFO_3, and MINIDUMP_MISC_INFO_4. ">MiscInfoStream</a> </dd></dl>
</td></tr>
<tr><td class="fieldname"><a id="a88363a45a4af1a16f542a8c1ff522ab9ab6f692da21dc09fb3c17a186fdc3271b"></a>kMinidumpStreamTypeMemoryInfoList&#160;</td><td class="fielddoc"><p>The stream type for <a class="el" href="structMINIDUMP__MEMORY__INFO__LIST.html" title="Contains a list of memory regions. ">MINIDUMP_MEMORY_INFO_LIST</a>. </p>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="dbghelp_8h.html#a64711234318a4a002f399dffb474ca08ab3437fce4862d62ca22f4933cada4d43" title="The stream type for MINIDUMP_MEMORY_INFO_LIST. ">MemoryInfoListStream</a> </dd></dl>
</td></tr>
<tr><td class="fieldname"><a id="a88363a45a4af1a16f542a8c1ff522ab9af1056a1f748bba4c88fa8f4104771d00"></a>kMinidumpStreamTypeCrashpadInfo&#160;</td><td class="fielddoc"><p>The stream type for <a class="el" href="structcrashpad_1_1MinidumpCrashpadInfo.html" title="Additional Crashpad-specific information carried within a minidump file. ">MinidumpCrashpadInfo</a>. </p>
</td></tr>
</table>
</div>
</div>
<a id="ab96bb7edb42a2e1ce28eda205a18a17a"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ab96bb7edb42a2e1ce28eda205a18a17a">&sect;&nbsp;</a></span>ProcessSuspensionState</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">enum <a class="el" href="namespacecrashpad.html#ab96bb7edb42a2e1ce28eda205a18a17a">crashpad::ProcessSuspensionState</a> : bool</td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">strong</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>State of process being read by <a class="el" href="classcrashpad_1_1ProcessReaderWin.html" title="Accesses information about another process, identified by a HANDLE. ">ProcessReaderWin</a>. </p>
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="ab96bb7edb42a2e1ce28eda205a18a17aa2fc7fbf0d19294f85dd3880460dd3c0a"></a>kRunning&#160;</td><td class="fielddoc"><p>The process has not been suspended. </p>
</td></tr>
<tr><td class="fieldname"><a id="ab96bb7edb42a2e1ce28eda205a18a17aa6e09d95243f1f7bec7d0061e5831dc82"></a>kSuspended&#160;</td><td class="fielddoc"><p>The process is suspended. </p>
</td></tr>
</table>
</div>
</div>
<a id="a8387ad067a7e6a1735ab97a1af450d2b"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a8387ad067a7e6a1735ab97a1af450d2b">&sect;&nbsp;</a></span>StringToSymbolicConstantOptionBits</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">enum <a class="el" href="namespacecrashpad.html#a8387ad067a7e6a1735ab97a1af450d2b">crashpad::StringToSymbolicConstantOptionBits</a></td>
</tr>
</table>
</div><div class="memdoc">
<p>Options for various <code>StringTo*</code> functions in <code>symbolic_constants_*</code> files. </p>
<p>Not every <code>StringTo*</code> function will implement each of these options. See function-specific documentation for details.</p>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="symbolic__constants__common_8h.html#symbolic_constant_terminology">Symbolic constant terminology</a> </dd></dl>
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a8387ad067a7e6a1735ab97a1af450d2ba1ca8cfec5f4774db61b0359f6905cb49"></a>kAllowFullName&#160;</td><td class="fielddoc"><p>Allow conversion from a string containing a symbolic constant by its full name. </p>
</td></tr>
<tr><td class="fieldname"><a id="a8387ad067a7e6a1735ab97a1af450d2ba56cf2e379949ef54954bf3d23ca38e85"></a>kAllowShortName&#160;</td><td class="fielddoc"><p>Allow conversion from a string containing a symbolic constant by its short name. </p>
</td></tr>
<tr><td class="fieldname"><a id="a8387ad067a7e6a1735ab97a1af450d2ba9021a9f07e3e4eb819ac567dd4d28b6f"></a>kAllowNumber&#160;</td><td class="fielddoc"><p>Allow conversion from a numeric string. </p>
</td></tr>
<tr><td class="fieldname"><a id="a8387ad067a7e6a1735ab97a1af450d2ba060cbf403d47785a69b249e9c562f410"></a>kAllowOr&#160;</td><td class="fielddoc"><p>Allow <code>|</code> to combine values in a bitfield. </p>
<p>For families whose values may be constructed as bitfields, allow conversion of strings containing multiple individual components treated as being combined by a bitwise “or” operation. An example family of constants that behaves this way is the suite of Mach exception masks. For constants that are not constructed as bitfields, or constants that are only partially constructed as bitfields, this option has no effect. </p>
</td></tr>
</table>
</div>
</div>
<a id="a7856b82b71167792ea6103debb5105ed"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a7856b82b71167792ea6103debb5105ed">&sect;&nbsp;</a></span>SymbolicConstantToStringOptionBits</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">enum <a class="el" href="namespacecrashpad.html#a7856b82b71167792ea6103debb5105ed">crashpad::SymbolicConstantToStringOptionBits</a></td>
</tr>
</table>
</div><div class="memdoc">
<p>Options for various <code>*ToString</code> functions in <code>symbolic_constants_*</code> files. </p>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="symbolic__constants__common_8h.html#symbolic_constant_terminology">Symbolic constant terminology</a> </dd></dl>
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a7856b82b71167792ea6103debb5105edad497286630d39fe9b19c950a85c56db7"></a>kUseFullName&#160;</td><td class="fielddoc"><p>Return the full name for a given constant. </p>
<dl class="section attention"><dt>Attention</dt><dd>API consumers should provide this value when desired, but should provide only one of kUseFullName and <a class="el" href="namespacecrashpad.html#a7856b82b71167792ea6103debb5105eda127e077880ede5d2f87b87873d46ea55" title="Return the short name for a given constant. ">kUseShortName</a>. Because kUseFullName is valueless, implementers should check for the absence of <a class="el" href="namespacecrashpad.html#a7856b82b71167792ea6103debb5105eda127e077880ede5d2f87b87873d46ea55" title="Return the short name for a given constant. ">kUseShortName</a> instead. </dd></dl>
</td></tr>
<tr><td class="fieldname"><a id="a7856b82b71167792ea6103debb5105eda127e077880ede5d2f87b87873d46ea55"></a>kUseShortName&#160;</td><td class="fielddoc"><p>Return the short name for a given constant. </p>
</td></tr>
<tr><td class="fieldname"><a id="a7856b82b71167792ea6103debb5105eda6fd207e044b85ec202143881fcd5eb2e"></a>kUnknownIsEmpty&#160;</td><td class="fielddoc"><p>If no symbolic name is known for a given constant, return an empty string. </p>
<dl class="section attention"><dt>Attention</dt><dd>API consumers should provide this value when desired, but should provide only one of kUnknownIsEmpty and <a class="el" href="namespacecrashpad.html#a7856b82b71167792ea6103debb5105edaf9da07820c9857c86422b70c3cc33c12" title="If no symbolic name is known for a given constant, return a numeric string. ">kUnknownIsNumeric</a>. Because kUnknownIsEmpty is valueless, implementers should check for the absence of <a class="el" href="namespacecrashpad.html#a7856b82b71167792ea6103debb5105edaf9da07820c9857c86422b70c3cc33c12" title="If no symbolic name is known for a given constant, return a numeric string. ">kUnknownIsNumeric</a> instead. </dd></dl>
</td></tr>
<tr><td class="fieldname"><a id="a7856b82b71167792ea6103debb5105edaf9da07820c9857c86422b70c3cc33c12"></a>kUnknownIsNumeric&#160;</td><td class="fielddoc"><p>If no symbolic name is known for a given constant, return a numeric string. </p>
<p>The numeric format used will vary by family, but will be appropriate to the family. Families whose values are typically constructed as bitfields will generally use a hexadecimal format, and other families will generally use a signed or unsigned decimal format. </p>
</td></tr>
<tr><td class="fieldname"><a id="a7856b82b71167792ea6103debb5105eda18aa149c3471a5129274df2af6972f04"></a>kUseOr&#160;</td><td class="fielddoc"><p>Use <code>|</code> to combine values in a bitfield. </p>
<p>For families whose values may be constructed as bitfields, allow conversion to strings containing multiple individual components treated as being combined by a bitwise “or” operation. An example family of constants that behaves this way is the suite of Mach exception masks. For constants that are not constructed as bitfields, or constants that are only partially constructed as bitfields, this option has no effect. </p>
</td></tr>
</table>
</div>
</div>
<a id="acf909fcc58999f95ab1a2d485a3b884f"></a>
<h2 class="memtitle"><span class="permalink"><a href="#acf909fcc58999f95ab1a2d485a3b884f">&sect;&nbsp;</a></span>TerminationCodes</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">enum <a class="el" href="namespacecrashpad.html#acf909fcc58999f95ab1a2d485a3b884f">crashpad::TerminationCodes</a> : unsigned int</td>
</tr>
</table>
</div><div class="memdoc">
<p>Crashpad-specific codes that are used as arguments to <code>TerminateProcess()</code> in unusual circumstances. </p>
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="acf909fcc58999f95ab1a2d485a3b884fa80056c7b41974ff409381f83677977fb"></a>kTerminationCodeCrashNoDump&#160;</td><td class="fielddoc"><p>The crash handler did not respond, and the client self-terminated. </p>
</td></tr>
<tr><td class="fieldname"><a id="acf909fcc58999f95ab1a2d485a3b884fa360db709d75512a0e6b8a27b9b122910"></a>kTerminationCodeSnapshotFailed&#160;</td><td class="fielddoc"><p>The initial process snapshot failed, so the correct client termination code could not be retrieved. </p>
</td></tr>
<tr><td class="fieldname"><a id="acf909fcc58999f95ab1a2d485a3b884fa3110b7733dd8d446957e061cb8fb37d2"></a>kTerminationCodeNotConnectedToHandler&#160;</td><td class="fielddoc"><p>A dump was requested for a client that was never registered with the crash handler. </p>
</td></tr>
</table>
</div>
</div>
<a id="a3b405c19a5787fabcfba96001d49f292"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a3b405c19a5787fabcfba96001d49f292">&sect;&nbsp;</a></span>TriState</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">enum <a class="el" href="namespacecrashpad.html#a3b405c19a5787fabcfba96001d49f292">crashpad::TriState</a> : uint8_t</td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">strong</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>A tri-state value that can be unset, on, or off. </p>
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a3b405c19a5787fabcfba96001d49f292ac69d34d47bfd5244204004878441d53f"></a>kUnset&#160;</td><td class="fielddoc"><p>The value has not explicitly been set. </p>
<p>To allow a zero-initialized value to have this behavior, this must have the value <code>0</code>. </p>
</td></tr>
<tr><td class="fieldname"><a id="a3b405c19a5787fabcfba96001d49f292ade1ec1870756a80dffbdc4cda53153e0"></a>kEnabled&#160;</td><td class="fielddoc"><p>The value has explicitly been set to on, or a behavior has explicitly been enabled. </p>
</td></tr>
<tr><td class="fieldname"><a id="a3b405c19a5787fabcfba96001d49f292a7b04d8795f5fd03c761ce70dab985fee"></a>kDisabled&#160;</td><td class="fielddoc"><p>The value has explicitly been set to off, or a behavior has explicitly been disabled. </p>
</td></tr>
</table>
</div>
</div>
<a id="a589b4d9bd6f2233b67148ab6793c3c13"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a589b4d9bd6f2233b67148ab6793c3c13">&sect;&nbsp;</a></span>XattrStatus</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">enum <a class="el" href="namespacecrashpad.html#a589b4d9bd6f2233b67148ab6793c3c13">crashpad::XattrStatus</a></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">strong</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>The result code for a ReadXattr operation. </p>
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a589b4d9bd6f2233b67148ab6793c3c13ab8c5bbba307a5b38f6a1474fbf23dddd"></a>kOK&#160;</td><td class="fielddoc"><p>No error occured. No message is logged. </p>
</td></tr>
<tr><td class="fieldname"><a id="a589b4d9bd6f2233b67148ab6793c3c13a56b68c332155feb30564a8ebd779ba67"></a>kNoAttribute&#160;</td><td class="fielddoc"><p>The attribute does not exist. No message is logged. </p>
</td></tr>
<tr><td class="fieldname"><a id="a589b4d9bd6f2233b67148ab6793c3c13a298223b78cd88f4983fbc5ae093136ca"></a>kOtherError&#160;</td><td class="fielddoc"><p>An error occurred and an error message was logged. </p>
</td></tr>
</table>
</div>
</div>
<h2 class="groupheader">Function Documentation</h2>
<a id="a52a7dee343e392e5bf1794e8136df7f9"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a52a7dee343e392e5bf1794e8136df7f9">&sect;&nbsp;</a></span>AppendCommandLineArgument()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void crashpad::AppendCommandLineArgument </td>
<td>(</td>
<td class="paramtype">const std::wstring &amp;&#160;</td>
<td class="paramname"><em>argument</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">std::wstring *&#160;</td>
<td class="paramname"><em>command_line</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Utility function for building escaped command lines. </p>
<p>This builds a command line so that individual arguments can be reliably decoded by <code>CommandLineToArgvW()</code>.</p>
<p><em>argument</em> is appended to <em>command_line</em>. If necessary, it will be placed in quotation marks and escaped properly. If <em>command_line</em> is initially non-empty, a space will precede <em>argument</em>.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">argument</td><td>The argument to append to <em>command_line</em>. </td></tr>
<tr><td class="paramdir">[in,out]</td><td class="paramname">command_line</td><td>The command line being constructed. </td></tr>
</table>
</dd>
</dl>
</div>
</div>
<a id="aeb040202b4562c8c4087b9c9db2ce430"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aeb040202b4562c8c4087b9c9db2ce430">&sect;&nbsp;</a></span>AssignIfInRange()</h2>
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename Destination , typename Source &gt; </div>
<table class="memname">
<tr>
<td class="memname">bool crashpad::AssignIfInRange </td>
<td>(</td>
<td class="paramtype">Destination *&#160;</td>
<td class="paramname"><em>destination</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">Source&#160;</td>
<td class="paramname"><em>source</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Performs an assignment if it can be done safely, and signals if it cannot be done safely. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[out]</td><td class="paramname">destination</td><td>A pointer to the variable to be assigned to. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">source</td><td>The value to assign.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> if <em>source</em> is in the range supported by the type of <em>*destination</em>, with the assignment to <em>*destination</em> having been performed. <code>false</code> if the assignment cannot be completed safely because <em>source</em> is outside of this range. </dd></dl>
</div>
</div>
<a id="a2c18eae8148ec3304733581a28c2da3b"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a2c18eae8148ec3304733581a28c2da3b">&sect;&nbsp;</a></span>AuditPIDFromMachMessageTrailer()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">pid_t crashpad::AuditPIDFromMachMessageTrailer </td>
<td>(</td>
<td class="paramtype">const mach_msg_trailer_t *&#160;</td>
<td class="paramname"><em>trailer</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Returns the process ID of a Mach messages sender from its audit trailer. </p>
<p>For the audit trailer to be present, the message must have been received with <a class="el" href="namespacecrashpad.html#a2673983f0177685e048be73ee578eddb" title="A Mach message option specifying that an audit trailer should be delivered during a receive operation...">kMachMessageReceiveAuditTrailer</a> or its macro equivalent specified in the receive options.</p>
<p>If the kernel is the messages sender, a process ID of <code>0</code> will be returned.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">trailer</td><td>The trailer received with a Mach message.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The process ID of the messages sender, or <code>-1</code> on failure with a message logged. It is considered a failure for <em>trailer</em> to not contain audit information. </dd></dl>
</div>
</div>
<a id="af63980b36cac449785c26cee00c89205"></a>
<h2 class="memtitle"><span class="permalink"><a href="#af63980b36cac449785c26cee00c89205">&sect;&nbsp;</a></span>BootstrapCheckIn()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">base::mac::ScopedMachReceiveRight crashpad::BootstrapCheckIn </td>
<td>(</td>
<td class="paramtype">const std::string &amp;&#160;</td>
<td class="paramname"><em>service_name</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Makes a <code>boostrap_check_in()</code> call to the process bootstrap server. </p>
<p>This function is provided to make it easier to call <code>bootstrap_check_in()</code> while avoiding accidental leaks of the returned receive right.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">service_name</td><td>The service name to check in.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>On success, a receive right to the service port. On failure, <code>MACH_PORT_NULL</code> with a message logged. </dd></dl>
</div>
</div>
<a id="a32e6cb4455e49ede76dab41a256962ee"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a32e6cb4455e49ede76dab41a256962ee">&sect;&nbsp;</a></span>BootstrapLookUp()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">base::mac::ScopedMachSendRight crashpad::BootstrapLookUp </td>
<td>(</td>
<td class="paramtype">const std::string &amp;&#160;</td>
<td class="paramname"><em>service_name</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Makes a <code>boostrap_look_up()</code> call to the process bootstrap server. </p>
<p>This function is provided to make it easier to call <code>bootstrap_look_up()</code> while avoiding accidental leaks of the returned send right.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">service_name</td><td>The service name to look up.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>On success, a send right to the service port. On failure, <code>MACH_PORT_NULL</code> with a message logged. </dd></dl>
</div>
</div>
<a id="a58169a74e32daa2888614fcd2f2381ce"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a58169a74e32daa2888614fcd2f2381ce">&sect;&nbsp;</a></span>BuildMinidumpThreadIDMap()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void crashpad::BuildMinidumpThreadIDMap </td>
<td>(</td>
<td class="paramtype">const std::vector&lt; const <a class="el" href="classcrashpad_1_1ThreadSnapshot.html">ThreadSnapshot</a> * &gt; &amp;&#160;</td>
<td class="paramname"><em>thread_snapshots</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#ae426d8c91f5448aaf543f91478d831da">MinidumpThreadIDMap</a> *&#160;</td>
<td class="paramname"><em>thread_id_map</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Builds a MinidumpThreadIDMap for a group of <a class="el" href="classcrashpad_1_1ThreadSnapshot.html" title="An abstract interface to a snapshot representing a thread (lightweight process) present in a snapshot...">ThreadSnapshot</a> objects. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">thread_snapshots</td><td>The thread snapshots to use as source data. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">thread_id_map</td><td>A MinidumpThreadIDMap to be built by this method. This map must be empty when this function is called.</td></tr>
</table>
</dd>
</dl>
<p>The map ensures that for any unique 64-bit thread ID found in a <a class="el" href="classcrashpad_1_1ThreadSnapshot.html" title="An abstract interface to a snapshot representing a thread (lightweight process) present in a snapshot...">ThreadSnapshot</a>, the 32-bit thread ID used in a minidump file will also be unique. </p>
</div>
</div>
<a id="ab42fe62040bb628fb134573bb2131955"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ab42fe62040bb628fb134573bb2131955">&sect;&nbsp;</a></span>c16lcpy()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">size_t crashpad::c16lcpy </td>
<td>(</td>
<td class="paramtype">base::char16 *&#160;</td>
<td class="paramname"><em>destination</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const base::char16 *&#160;</td>
<td class="paramname"><em>source</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">size_t&#160;</td>
<td class="paramname"><em>length</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Copy a <code>NUL</code>-terminated char16-based string to a fixed-size buffer. </p>
<p>This function behaves identically to <code>strlcpy()</code>, but it operates on char16 data instead of <code>char</code> data. It copies the <code>NUL</code>-terminated string in the buffer beginning at <em>source</em> to the buffer of size <em>length</em> at <em>destination</em>, ensuring that the destination buffer is <code>NUL</code>-terminated. No data will be written outside of the <em>destination</em> buffer, but if <em>length</em> is smaller than the length of the string at <em>source</em>, the string will be truncated.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[out]</td><td class="paramname">destination</td><td>A pointer to a buffer of at least size <em>length</em> char16 units (not bytes). The string will be copied to this buffer, possibly with truncation, and <code>NUL</code>-terminated. Nothing will be written following the <code>NUL</code> terminator. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">source</td><td>A pointer to a <code>NUL</code>-terminated string of char16 data. The <code>NUL</code> terminator must be a <code>NUL</code> value in a char16 unit, not just a single <code>NUL</code> byte. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">length</td><td>The length of the <em>destination</em> buffer in char16 units, not bytes. A maximum of <em><code>length</em> - 1</code> char16 units from <em>source</em> will be copied to <em>destination</em>.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The length of the <em>source</em> string in char16 units, not including its <code>NUL</code> terminator. When truncation occurs, the return value will be equal to or greater than than the <em>length</em> parameter. </dd></dl>
</div>
</div>
<a id="adbc9204d047dd250fe5f6b4ce0dd27ae"></a>
<h2 class="memtitle"><span class="permalink"><a href="#adbc9204d047dd250fe5f6b4ce0dd27ae">&sect;&nbsp;</a></span>CaptureContext() <span class="overload">[1/2]</span></h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void crashpad::CaptureContext </td>
<td>(</td>
<td class="paramtype">CONTEXT *&#160;</td>
<td class="paramname"><em>context</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Saves the CPU context. </p>
<p>The CPU context will be captured as accurately and completely as possible, containing an atomic snapshot at the point of this functions return. This function does not modify any registers.</p>
<p>This function captures all integer registers as well as the floating-point and vector (SSE) state. It does not capture debug registers, which are inaccessible by user code.</p>
<p>This function is a replacement for <code>RtlCaptureContext()</code>, which contains bugs and limitations. On 32-bit x86, <code>RtlCaptureContext()</code> requires that <code>ebp</code> be used as a frame pointer, and returns <code>ebp</code>, <code>esp</code>, and <code>eip</code> out of sync with the other registers. Both the 32-bit x86 and 64-bit x86_64 versions of <code>RtlCaptureContext()</code> capture only the state of the integer registers, ignoring floating-point and vector state.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[out]</td><td class="paramname">context</td><td>The structure to store the context in.</td></tr>
</table>
</dd>
</dl>
<dl class="section note"><dt>Note</dt><dd>On x86_64, the value for <code>rcx</code> will be populated with the address of this functions argument, as mandated by the ABI. </dd></dl>
</div>
</div>
<a id="ac25486c6b4c38fc7c7868e978094edcf"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ac25486c6b4c38fc7c7868e978094edcf">&sect;&nbsp;</a></span>CaptureContext() <span class="overload">[2/2]</span></h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void crashpad::CaptureContext </td>
<td>(</td>
<td class="paramtype">NativeCPUContext *&#160;</td>
<td class="paramname"><em>cpu_context</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Saves the CPU context. </p>
<p>The CPU context will be captured as accurately and completely as possible, containing an atomic snapshot at the point of this functions return. This function does not modify any registers.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[out]</td><td class="paramname">cpu_context</td><td>The structure to store the context in.</td></tr>
</table>
</dd>
</dl>
<dl class="section note"><dt>Note</dt><dd>On x86_64, the value for <code>%rdi</code> will be populated with the address of this functions argument, as mandated by the ABI. If the value of <code>%rdi</code> prior to calling this function is needed, it must be obtained separately prior to calling this function. For example: <div class="fragment"><div class="line">uint64_t rdi;</div><div class="line"><span class="keyword">asm</span>(<span class="stringliteral">&quot;movq %%rdi, %0&quot;</span> : <span class="stringliteral">&quot;=m&quot;</span>(rdi));</div></div><!-- fragment --> </dd></dl>
</div>
</div>
<a id="a616ed0784021ecbd2f0f14b7e75c068c"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a616ed0784021ecbd2f0f14b7e75c068c">&sect;&nbsp;</a></span>CFPropertyToLaunchData()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">launch_data_t crashpad::CFPropertyToLaunchData </td>
<td>(</td>
<td class="paramtype">CFPropertyListRef&#160;</td>
<td class="paramname"><em>property_cf</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Converts a Core Foundation-type property list to a launchd-type <code>launch_data_t</code>. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">property_cf</td><td>The Core Foundation-type property list to convert.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The converted launchd-type <code>launch_data_t</code>. The caller takes ownership of the returned value. On error, returns <code>nullptr</code>.</dd></dl>
<dl class="section note"><dt>Note</dt><dd>This function handles all <code>CFPropertyListRef</code> types except for <code>CFDateRef</code>, because theres no <code>launch_data_type_t</code> analogue. Not all types supported in a launchd-type <code>launch_data_t</code> have <code>CFPropertyListRef</code> analogues. </dd></dl>
</div>
</div>
<a id="ac7cb2e4837a6fda169cbe92d1603460f"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ac7cb2e4837a6fda169cbe92d1603460f">&sect;&nbsp;</a></span>CheckedCloseFile()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void crashpad::CheckedCloseFile </td>
<td>(</td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a>&#160;</td>
<td class="paramname"><em>file</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps <code>close()</code> or <code>CloseHandle()</code>, ensuring that it succeeds. </p>
<p>If the underlying function fails, this function causes execution to terminate without returning. </p>
</div>
</div>
<a id="aee611c7116746b846a3cf79e65619f4d"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aee611c7116746b846a3cf79e65619f4d">&sect;&nbsp;</a></span>CheckedReadFile()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void crashpad::CheckedReadFile </td>
<td>(</td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a>&#160;</td>
<td class="paramname"><em>file</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">void *&#160;</td>
<td class="paramname"><em>buffer</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">size_t&#160;</td>
<td class="paramname"><em>size</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps <a class="el" href="namespacecrashpad.html#a8599600814a17d622766decd5f122a96" title="Reads from a file, retrying when interrupted on POSIX or following a short read. ">ReadFile()</a>, ensuring that exactly <em>size</em> bytes are read. </p>
<p>If <em>size</em> is out of the range of possible <a class="el" href="namespacecrashpad.html#a8599600814a17d622766decd5f122a96" title="Reads from a file, retrying when interrupted on POSIX or following a short read. ">ReadFile()</a> return values, if the underlying <a class="el" href="namespacecrashpad.html#a8599600814a17d622766decd5f122a96" title="Reads from a file, retrying when interrupted on POSIX or following a short read. ">ReadFile()</a> fails, or if other than <em>size</em> bytes were read, this function causes execution to terminate without returning.</p>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="namespacecrashpad.html#a74c74fefa3b1f5e0c1b885755c9f9cf6" title="Wraps WriteFile(), ensuring that exactly size bytes are written. ">CheckedWriteFile</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#a8599600814a17d622766decd5f122a96" title="Reads from a file, retrying when interrupted on POSIX or following a short read. ">ReadFile</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#abd2a51526c1f15e3f21a962457cbc53a" title="Wraps ReadFile(), ensuring that exactly size bytes are read. ">LoggingReadFile</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#ac8e7e1b1a4b89b489964ffee54d0d9df" title="Wraps ReadFile(), ensuring that it indicates end-of-file. ">CheckedReadFileAtEOF</a> </dd></dl>
</div>
</div>
<a id="ac8e7e1b1a4b89b489964ffee54d0d9df"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ac8e7e1b1a4b89b489964ffee54d0d9df">&sect;&nbsp;</a></span>CheckedReadFileAtEOF()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void crashpad::CheckedReadFileAtEOF </td>
<td>(</td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a>&#160;</td>
<td class="paramname"><em>file</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps <a class="el" href="namespacecrashpad.html#a8599600814a17d622766decd5f122a96" title="Reads from a file, retrying when interrupted on POSIX or following a short read. ">ReadFile()</a>, ensuring that it indicates end-of-file. </p>
<p>Attempts to read a single byte from <em>file</em>, expecting no data to be read. If the underlying <a class="el" href="namespacecrashpad.html#a8599600814a17d622766decd5f122a96" title="Reads from a file, retrying when interrupted on POSIX or following a short read. ">ReadFile()</a> fails, or if a byte actually is read, this function causes execution to terminate without returning.</p>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="namespacecrashpad.html#aee611c7116746b846a3cf79e65619f4d" title="Wraps ReadFile(), ensuring that exactly size bytes are read. ">CheckedReadFile</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#a8599600814a17d622766decd5f122a96" title="Reads from a file, retrying when interrupted on POSIX or following a short read. ">ReadFile</a> </dd></dl>
</div>
</div>
<a id="a74c74fefa3b1f5e0c1b885755c9f9cf6"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a74c74fefa3b1f5e0c1b885755c9f9cf6">&sect;&nbsp;</a></span>CheckedWriteFile()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void crashpad::CheckedWriteFile </td>
<td>(</td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a>&#160;</td>
<td class="paramname"><em>file</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const void *&#160;</td>
<td class="paramname"><em>buffer</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">size_t&#160;</td>
<td class="paramname"><em>size</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps <a class="el" href="namespacecrashpad.html#ab9dded3137add283f6cf32facb86641a" title="Writes to a file, retrying when interrupted or following a short write on POSIX. ">WriteFile()</a>, ensuring that exactly <em>size</em> bytes are written. </p>
<p>If <em>size</em> is out of the range of possible <a class="el" href="namespacecrashpad.html#ab9dded3137add283f6cf32facb86641a" title="Writes to a file, retrying when interrupted or following a short write on POSIX. ">WriteFile()</a> return values, if the underlying <a class="el" href="namespacecrashpad.html#ab9dded3137add283f6cf32facb86641a" title="Writes to a file, retrying when interrupted or following a short write on POSIX. ">WriteFile()</a> fails, or if other than <em>size</em> bytes were written, this function causes execution to terminate without returning.</p>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="namespacecrashpad.html#aee611c7116746b846a3cf79e65619f4d" title="Wraps ReadFile(), ensuring that exactly size bytes are read. ">CheckedReadFile</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#ab9dded3137add283f6cf32facb86641a" title="Writes to a file, retrying when interrupted or following a short write on POSIX. ">WriteFile</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#a8a91af9c690d2a280c463596bf82070b" title="Wraps WriteFile(), ensuring that exactly size bytes are written. ">LoggingWriteFile</a> </dd></dl>
</div>
</div>
<a id="aa93af751a4a09c316fb3de1a90e03fe8"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aa93af751a4a09c316fb3de1a90e03fe8">&sect;&nbsp;</a></span>ClockMonotonicNanoseconds()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">uint64_t crashpad::ClockMonotonicNanoseconds </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Returns the value of the systems monotonic clock. </p>
<p>The monotonic clock is a tick counter whose epoch is unspecified. It is a monotonically-increasing clock that cannot be set, and never jumps backwards on a running system. The monotonic clock may stop while the system is sleeping, and it may be reset when the system starts up. This clock is suitable for computing durations of events. Subject to the underlying clocks resolution, successive calls to this function will result in a series of increasing values.</p>
<dl class="section return"><dt>Returns</dt><dd>The value of the systems monotonic clock, in nanoseconds. </dd></dl>
</div>
</div>
<a id="a003f563ef0fe26081b4520012e0c1ef8"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a003f563ef0fe26081b4520012e0c1ef8">&sect;&nbsp;</a></span>CloseMultipleNowOrOnExec()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void crashpad::CloseMultipleNowOrOnExec </td>
<td>(</td>
<td class="paramtype">int&#160;</td>
<td class="paramname"><em>fd</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">int&#160;</td>
<td class="paramname"><em>preserve_fd</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Close multiple file descriptors or mark them close-on-exec. </p>
<p>This is similar to the BSD/Solaris-style <code>closefrom()</code> routine, which closes all open file descriptors equal to or higher than its <em>fd</em> argument. This function must not be called while other threads are active. It is intended to be used in a child process created by <code>fork()</code>, prior to calling an <code>exec()</code>-family function. This guarantees that a (possibly untrustworthy) child process does not inherit file descriptors that it has no need for.</p>
<p>Unlike the BSD function, this function may not close file descriptors immediately, but may instead mark them as close-on-exec. The actual behavior chosen is specific to the operating system. On macOS, file descriptors are marked close-on-exec instead of being closed outright in order to avoid raising <code>EXC_GUARD</code> exceptions for guarded file descriptors that are protected against <code>close()</code>.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">fd</td><td>The lowest file descriptor to close or set as close-on-exec. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">preserve_fd</td><td>A file descriptor to preserve and not close (or set as close-on-exec), even if it is open and its value is greater than <em>fd</em>. To not preserve any file descriptor, pass <code>-1</code> for this parameter. </td></tr>
</table>
</dd>
</dl>
</div>
</div>
<a id="aa8a3145ce95463d1638428b2547cde4d"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aa8a3145ce95463d1638428b2547cde4d">&sect;&nbsp;</a></span>CloseStdinAndStdout()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void crashpad::CloseStdinAndStdout </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Closes <code>stdin</code> and <code>stdout</code> by opening <code>/dev/null</code> over them. </p>
<p>It is normally inadvisable to <code>close()</code> the three standard input/output streams, because they occupy special file descriptors. Closing them outright could result in their file descriptors being reused. This causes problems for library code (including the standard library) that expects these file descriptors to have special meaning.</p>
<p>This function discards the standard input and standard output streams by opening <code>/dev/null</code> and assigning it to their file descriptors, closing whatever had been at those file descriptors previously.</p>
<p><code>stderr</code>, the standard error stream, is not closed. It is often useful to retain the ability to send diagnostic messages to the standard error stream.</p>
<dl class="section note"><dt>Note</dt><dd>This function can only maintain its guarantees in a single-threaded process, or in situations where the caller has control of all threads in the process. </dd></dl>
</div>
</div>
<a id="a1bb7596acd0c7d75d0608ffafc6028e8"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a1bb7596acd0c7d75d0608ffafc6028e8">&sect;&nbsp;</a></span>CreateNamedPipeInstance()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">HANDLE crashpad::CreateNamedPipeInstance </td>
<td>(</td>
<td class="paramtype">const std::wstring &amp;&#160;</td>
<td class="paramname"><em>pipe_name</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">bool&#160;</td>
<td class="paramname"><em>first_instance</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps CreateNamedPipe() to create a single named pipe instance. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">pipe_name</td><td>The name to use for the pipe. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">first_instance</td><td>If <code>true</code>, the named pipe instance will be created with <code>FILE_FLAG_FIRST_PIPE_INSTANCE</code>. This ensures that the the pipe name is not already in use when created. The first instance will be created with an untrusted integrity SACL so instances of this pipe can be connected to by processes of any integrity level. </td></tr>
</table>
</dd>
</dl>
</div>
</div>
<a id="a5e5ee7c62768446ceb8fa8a76db99952"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a5e5ee7c62768446ceb8fa8a76db99952">&sect;&nbsp;</a></span>DropPrivileges()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void crashpad::DropPrivileges </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Permanently drops privileges conferred by being a setuid or setgid executable. </p>
<p>The effective user ID and saved set-user ID are set to the real user ID, negating any effects of being a setuid executable. The effective group ID and saved set-group ID are set to the real group ID, negating any effects of being a setgid executable. Because the saved set-user ID and saved set-group ID are reset, there is no way to restore the prior privileges, and the drop is permanent.</p>
<p>This function drops privileges correctly when running setuid root and in other circumstances, including when running setuid non-root. If the program is not a setuid or setgid executable, this function has no effect.</p>
<p>No changes are made to the supplementary group list, which is normally not altered for setuid or setgid executables. </p>
</div>
</div>
<a id="a830c754edaa401f7d866e69369f76ae1"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a830c754edaa401f7d866e69369f76ae1">&sect;&nbsp;</a></span>ExcCrashRecoverOriginalException()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">exception_type_t crashpad::ExcCrashRecoverOriginalException </td>
<td>(</td>
<td class="paramtype">mach_exception_code_t&#160;</td>
<td class="paramname"><em>code_0</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">mach_exception_code_t *&#160;</td>
<td class="paramname"><em>original_code_0</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">int *&#160;</td>
<td class="paramname"><em>signal</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Recovers the original exception, first exception code, and signal from the encoded form of the first exception code delivered with <code>EXC_CRASH</code> exceptions. </p>
<p><code>EXC_CRASH</code> exceptions are generated when the kernel has committed to terminating a process as a result of a core-generating POSIX signal and, for hardware exceptions, an earlier Mach exception. Information about this earlier exception and signal is made available to the <code>EXC_CRASH</code> handler via its <code>code[0]</code> parameter. This function recovers the original exception, the value of <code>code[0]</code> from the original exception, and the value of the signal responsible for process termination.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">code_0</td><td>The first exception code (<code>code[0]</code>) passed to a Mach exception handler in an <code>EXC_CRASH</code> exception. It is invalid to call this function with an exception code from any exception other than <code>EXC_CRASH</code>. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">original_code_0</td><td>The first exception code (<code>code[0]</code>) passed to the Mach exception handler for a hardware exception that resulted in the generation of a POSIX signal that caused process termination. If the signal that caused termination was not sent as a result of a hardware exception, this will be <code>0</code>. Callers that do not need this value may pass <code>nullptr</code>. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">signal</td><td>The POSIX signal that caused process termination. Callers that do not need this value may pass <code>nullptr</code>.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The original exception for a hardware exception that resulted in the generation of a POSIX signal that caused process termination. If the signal that caused termination was not sent as a result of a hardware exception, this will be <code>0</code>. </dd></dl>
</div>
</div>
<a id="a2e26b5b9a8355ab15063b1c07fa6dff7"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a2e26b5b9a8355ab15063b1c07fa6dff7">&sect;&nbsp;</a></span>ExceptionBehaviorBasic()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">exception_behavior_t crashpad::ExceptionBehaviorBasic </td>
<td>(</td>
<td class="paramtype">exception_behavior_t&#160;</td>
<td class="paramname"><em>behavior</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Returns the basic behavior value of <em>behavior</em>, its value without <code>MACH_EXCEPTION_CODES</code> set. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">behavior</td><td>An exception behavior value.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>EXCEPTION_DEFAULT</code>, <code>EXCEPTION_STATE</code>, or <code>EXCEPTION_STATE_IDENTITY</code>, assuming <em>behavior</em> was a correct exception behavior value. </dd></dl>
</div>
</div>
<a id="a5d424769dc3683b809a9783f9319d4ab"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a5d424769dc3683b809a9783f9319d4ab">&sect;&nbsp;</a></span>ExceptionBehaviorHasIdentity()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::ExceptionBehaviorHasIdentity </td>
<td>(</td>
<td class="paramtype">exception_behavior_t&#160;</td>
<td class="paramname"><em>behavior</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Determines whether <em>behavior</em> indicates an exception behavior that carries thread and task identities. </p>
<p>When this function returns <code>true</code>, an exception message of <em>behavior</em> will carry thread and task identities in the form of send rights to the thread and task ports. Its <em>thread</em> and <em>task</em> fields will be valid. When this function returns <code>false</code>, these fields will not be valid.</p>
<p>Exception behaviors that carry thread and task identity information are <code>EXCEPTION_DEFAULT</code> and <code>EXCEPTION_STATE_IDENTITY</code>. <code>MACH_EXCEPTION_CODES</code> may also be set. These behaviors correspond to <code>exception_raise()</code>, <code>exception_raise_state_identity()</code>, <code>mach_exception_raise()</code>, and <code>mach_exception_raise_state_identity()</code>.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">behavior</td><td>An exception behavior value.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> if <em>behavior</em> is <code>EXCEPTION_DEFAULT</code> or <code>EXCEPTION_STATE_IDENTITY</code>, possibly with <code>MACH_EXCEPTION_CODES</code> also set. </dd></dl>
</div>
</div>
<a id="a6cd35f65144317021b4ea09a2b779bfb"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a6cd35f65144317021b4ea09a2b779bfb">&sect;&nbsp;</a></span>ExceptionBehaviorHasMachExceptionCodes()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::ExceptionBehaviorHasMachExceptionCodes </td>
<td>(</td>
<td class="paramtype">exception_behavior_t&#160;</td>
<td class="paramname"><em>behavior</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Determines whether <em>behavior</em> indicates an exception behavior that carries 64-bit exception codes (“Mach exception codes”). </p>
<p>When this function returns <code>true</code>, an exception message of <em>behavior</em> will carry 64-bit exception codes of type <code>mach_exception_code_t</code> in its <em>code</em> field. When this function returns <code>false</code>, the exception message will carry 32-bit exception codes of type <code>exception_data_type_t</code> in its <em>code</em> field.</p>
<p>Exception behaviors that carry 64-bit exception codes are those that have <code>MACH_EXCEPTION_CODES</code> set. These behaviors correspond to <code>mach_exception_raise()</code>, <code>mach_exception_raise_state()</code>, and <code>mach_exception_raise_state_identity()</code>.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">behavior</td><td>An exception behavior value.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> if <code>MACH_EXCEPTION_CODES</code> is set in <em>behavior</em>. </dd></dl>
</div>
</div>
<a id="acea6434eb784ccde471620e9d79ba8c1"></a>
<h2 class="memtitle"><span class="permalink"><a href="#acea6434eb784ccde471620e9d79ba8c1">&sect;&nbsp;</a></span>ExceptionBehaviorHasState()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::ExceptionBehaviorHasState </td>
<td>(</td>
<td class="paramtype">exception_behavior_t&#160;</td>
<td class="paramname"><em>behavior</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Determines whether <em>behavior</em> indicates an exception behavior that carries thread state information. </p>
<p>When this function returns <code>true</code>, an exception message of <em>behavior</em> will carry thread state information. Its <em>flavor</em>, <em>old_state</em>, <em>old_state_count</em>, <em>new_state</em>, and <em>new_state_count</em> fields will be valid. When this function returns <code>false</code>, these fields will not be valid.</p>
<p>Exception behaviors that carry thread state information are <code>EXCEPTION_STATE</code> and <code>EXCEPTION_STATE_IDENTITY</code>. <code>MACH_EXCEPTION_CODES</code> may also be set. These behaviors correspond to <code>exception_raise_state()</code>, <code>exception_raise_state_identity()</code>, <code>mach_exception_raise_state()</code>, and <code>mach_exception_raise_state_identity()</code>.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">behavior</td><td>An exception behavior value.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> if <em>behavior</em> is <code>EXCEPTION_STATE</code> or <code>EXCEPTION_STATE_IDENTITY</code>, possibly with <code>MACH_EXCEPTION_CODES</code> also set. </dd></dl>
</div>
</div>
<a id="a53fd131112ba6eba0d81467733a7643a"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a53fd131112ba6eba0d81467733a7643a">&sect;&nbsp;</a></span>ExceptionBehaviorToString()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">std::string crashpad::ExceptionBehaviorToString </td>
<td>(</td>
<td class="paramtype">exception_behavior_t&#160;</td>
<td class="paramname"><em>behavior</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a0f13feba965ef7750b3d49064936e5ee">SymbolicConstantToStringOptions</a>&#160;</td>
<td class="paramname"><em>options</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Converts a Mach exception behavior value to a textual representation. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">behavior</td><td>The Mach exception behavior value to convert. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">options</td><td>Options affecting the conversion. <a class="el" href="namespacecrashpad.html#a7856b82b71167792ea6103debb5105eda18aa149c3471a5129274df2af6972f04" title="Use | to combine values in a bitfield. ">kUseOr</a> is ignored. <code>MACH_EXCEPTION_CODES</code> can always be ORed in, but no other values can be ORed with each other. For <a class="el" href="namespacecrashpad.html#a7856b82b71167792ea6103debb5105edaf9da07820c9857c86422b70c3cc33c12" title="If no symbolic name is known for a given constant, return a numeric string. ">kUnknownIsNumeric</a>, the format is <code>"%#x"</code>.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The converted string. </dd></dl>
</div>
</div>
<a id="a8ee31102507c0f75d82496dcd6f6b53b"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a8ee31102507c0f75d82496dcd6f6b53b">&sect;&nbsp;</a></span>ExceptionMaskToString()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">std::string crashpad::ExceptionMaskToString </td>
<td>(</td>
<td class="paramtype">exception_mask_t&#160;</td>
<td class="paramname"><em>exception_mask</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a0f13feba965ef7750b3d49064936e5ee">SymbolicConstantToStringOptions</a>&#160;</td>
<td class="paramname"><em>options</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Converts a Mach exception mask value to a textual representation. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">exception_mask</td><td>The Mach exception mask value to convert. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">options</td><td>Options affecting the conversion. <a class="el" href="namespacecrashpad.html#a7856b82b71167792ea6103debb5105eda18aa149c3471a5129274df2af6972f04" title="Use | to combine values in a bitfield. ">kUseOr</a> is honored. For <a class="el" href="namespacecrashpad.html#a7856b82b71167792ea6103debb5105edaf9da07820c9857c86422b70c3cc33c12" title="If no symbolic name is known for a given constant, return a numeric string. ">kUnknownIsNumeric</a>, the format is <code>"%#x"</code>.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The converted string. </dd></dl>
</div>
</div>
<a id="a05296bfd23550f42639067355410811e"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a05296bfd23550f42639067355410811e">&sect;&nbsp;</a></span>ExceptionToString()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">std::string crashpad::ExceptionToString </td>
<td>(</td>
<td class="paramtype">exception_type_t&#160;</td>
<td class="paramname"><em>exception</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a0f13feba965ef7750b3d49064936e5ee">SymbolicConstantToStringOptions</a>&#160;</td>
<td class="paramname"><em>options</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Converts a Mach exception value to a textual representation. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">exception</td><td>The Mach exception value to convert. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">options</td><td>Options affecting the conversion. <a class="el" href="namespacecrashpad.html#a7856b82b71167792ea6103debb5105eda18aa149c3471a5129274df2af6972f04" title="Use | to combine values in a bitfield. ">kUseOr</a> is ignored. For <a class="el" href="namespacecrashpad.html#a7856b82b71167792ea6103debb5105edaf9da07820c9857c86422b70c3cc33c12" title="If no symbolic name is known for a given constant, return a numeric string. ">kUnknownIsNumeric</a>, the format is <code>"%d"</code>.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The converted string. </dd></dl>
</div>
</div>
<a id="a194e0575e09db56e4107e1c41b27c941"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a194e0575e09db56e4107e1c41b27c941">&sect;&nbsp;</a></span>ExcMaskAll()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">exception_mask_t crashpad::ExcMaskAll </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>The value for <code>EXC_MASK_ALL</code> appropriate for the operating system at run time. </p>
<p>The SDKs definition of <code>EXC_MASK_ALL</code> has changed over time, with later versions containing more bits set than earlier versions. However, older kernels will reject exception masks that contain bits set that they dont recognize. Calling this function will return a value for <code>EXC_MASK_ALL</code> appropriate for the system at run time.</p>
<dl class="section note"><dt>Note</dt><dd><code>EXC_MASK_ALL</code> does not include the value of <code>EXC_MASK_CRASH</code> or <code>EXC_MASK_CORPSE_NOTIFY</code>. Consumers that want <code>EXC_MASK_ALL</code> along with <code>EXC_MASK_CRASH</code> may use <a class="el" href="namespacecrashpad.html#a194e0575e09db56e4107e1c41b27c941" title="The value for EXC_MASK_ALL appropriate for the operating system at run time. ">ExcMaskAll()</a> <code>| EXC_MASK_CRASH</code>. Consumers may use <a class="el" href="namespacecrashpad.html#a18e47623f33e0c86fef1d08a82b28cc9" title="An exception mask containing every possible exception understood by the operating system at run time...">ExcMaskValid()</a> for <code>EXC_MASK_ALL</code> along with <code>EXC_MASK_CRASH</code>, <code>EXC_MASK_CORPSE_NOTIFY</code>, and any values that come into existence in the future. </dd></dl>
</div>
</div>
<a id="a18e47623f33e0c86fef1d08a82b28cc9"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a18e47623f33e0c86fef1d08a82b28cc9">&sect;&nbsp;</a></span>ExcMaskValid()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">exception_mask_t crashpad::ExcMaskValid </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>An exception mask containing every possible exception understood by the operating system at run time. </p>
<p><code>EXC_MASK_ALL</code>, and thus <a class="el" href="namespacecrashpad.html#a194e0575e09db56e4107e1c41b27c941" title="The value for EXC_MASK_ALL appropriate for the operating system at run time. ">ExcMaskAll()</a>, never includes the value of <code>EXC_MASK_CRASH</code> or <code>EXC_MASK_CORPSE_NOTIFY</code>. For situations where an exception mask corresponding to every possible exception understood by the running kernel is desired, use this function instead.</p>
<p>Should new exception types be introduced in the future, this function will be updated to include their bits in the returned mask value when run time support is present. </p>
</div>
</div>
<a id="ac192440e1d208f5dd348f0cba652d93a"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ac192440e1d208f5dd348f0cba652d93a">&sect;&nbsp;</a></span>ExcServerCopyState()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void crashpad::ExcServerCopyState </td>
<td>(</td>
<td class="paramtype">exception_behavior_t&#160;</td>
<td class="paramname"><em>behavior</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a72fa9ea632f7f1ec93ec3c1b1d300db6">ConstThreadState</a>&#160;</td>
<td class="paramname"><em>old_state</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">mach_msg_type_number_t&#160;</td>
<td class="paramname"><em>old_state_count</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">thread_state_t&#160;</td>
<td class="paramname"><em>new_state</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">mach_msg_type_number_t *&#160;</td>
<td class="paramname"><em>new_state_count</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Copies the old state to the new state for state-carrying exceptions. </p>
<p>When the kernel sends a state-carrying exception request and the response is successful (<code>MACH_MSG_SUCCESS</code>, a synonym for <code>KERN_SUCCESS</code>), it will set a new thread state based on <em>new_state</em> and <em>new_state_count</em>. To ease initialization of the new state, this function copies <em>old_state</em> and <em>old_state_count</em>. This is only done if <em>behavior</em> indicates a state-carrying exception.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">behavior</td><td>The behavior of the exception handler as invoked. This may be taken directly from the <em>behavior</em> parameter of internal::SimplifiedExcServer::Interface::CatchException(), for example. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">old_state</td><td>The original state value. This may be taken directly from the <em>old_state</em> parameter of internal::SimplifiedExcServer::Interface::CatchException(), for example. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">old_state_count</td><td>The number of significant <code>natural_t</code> words in <em>old_state</em>. This may be taken directly from the <em>old_state_count</em> parameter of internal::SimplifiedExcServer::Interface::CatchException(), for example. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">new_state</td><td>The state value to be set. This may be taken directly from the <em>new_state</em> parameter of internal::SimplifiedExcServer::Interface::CatchException(), for example. This parameter is untouched if <em>behavior</em> is not state-carrying. </td></tr>
<tr><td class="paramdir">[in,out]</td><td class="paramname">new_state_count</td><td>On entry, the number of <code>natural_t</code> words available to be written to in <em>new_state</em>. On return, the number of significant <code>natural_t</code> words in <em>new_state</em>. This may be taken directly from the <em>new_state_count</em> parameter of internal::SimplifiedExcServer::Interface::CatchException(), for example. This parameter is untouched if <em>behavior</em> is not state-carrying. If <em><em>behavior</em> is</em> state-carrying, this parameter should be at least as large as <em>old_state_count</em>. </td></tr>
</table>
</dd>
</dl>
</div>
</div>
<a id="a2112e7fcb6a2fc7f9b6b0ff8856e8466"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a2112e7fcb6a2fc7f9b6b0ff8856e8466">&sect;&nbsp;</a></span>ExcServerSuccessfulReturnValue()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">kern_return_t crashpad::ExcServerSuccessfulReturnValue </td>
<td>(</td>
<td class="paramtype">exception_type_t&#160;</td>
<td class="paramname"><em>exception</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">exception_behavior_t&#160;</td>
<td class="paramname"><em>behavior</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">bool&#160;</td>
<td class="paramname"><em>set_thread_state</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Computes an approriate successful return value for an exception handler function. </p>
<p>For exception handlers that respond to state-carrying behaviors, when the handler is called by the kernel (as it is normally), the kernel will attempt to set a new thread state when the exception handler returns successfully. Other code that mimics the kernels exception-delivery semantics may implement the same or similar behavior. In some situations, it is undesirable to set a new thread state. If the exception handler were to return unsuccessfully, however, the kernel would continue searching for an exception handler at a wider (task or host) scope. This may also be undesirable.</p>
<p>If such exception handlers return <code>MACH_RCV_PORT_DIED</code>, the kernel will not set a new thread state and will also not search for another exception handler. See 10.9.4 <code>xnu-2422.110.17/osfmk/kern/exception.c</code>. <code>exception_deliver()</code> will only set a new thread state if the handlers return code was <code>MACH_MSG_SUCCESS</code> (a synonym for <code>KERN_SUCCESS</code>), and subsequently, <code>exception_triage()</code> will not search for a new handler if the handlers return code was <code>KERN_SUCCESS</code> or <code>MACH_RCV_PORT_DIED</code>.</p>
<p>This function allows exception handlers to compute an appropriate return code to influence their caller (the kernel) in the desired way with respect to setting a new thread state while suppressing the callers subsequent search for other exception handlers. An exception handler should return the value returned by this function.</p>
<p>This function is useful even for <code>EXC_CRASH</code> handlers, where returning <code>KERN_SUCCESS</code> and allowing the kernel to set a new thread state has been observed to cause a perceptible and unnecessary waste of time. The victim task in an <code>EXC_CRASH</code> handler is already being terminated and is no longer schedulable, so there is no point in setting the states of any of its threads.</p>
<p>On OS X 10.11, the <code>MACH_RCV_PORT_DIED</code> mechanism cannot be used with an <code>EXC_CRASH</code> handler without triggering an undesirable <code>EXC_CORPSE_NOTIFY</code> exception. In that case, <code>KERN_SUCCESS</code> is always returned. Because this function may return <code>KERN_SUCCESS</code> for a state-carrying exception, it is important to ensure that the state returned by a state-carrying exception handler is valid, because it will be passed to <code>thread_set_status()</code>. <a class="el" href="namespacecrashpad.html#ac192440e1d208f5dd348f0cba652d93a" title="Copies the old state to the new state for state-carrying exceptions. ">ExcServerCopyState()</a> may be used to achieve this.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">exception</td><td>The exception type passed to the exception handler. This may be taken directly from the <em>exception</em> parameter of internal::SimplifiedExcServer::Interface::CatchException(), for example. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">behavior</td><td>The behavior of the exception handler as invoked. This may be taken directly from the <em>behavior</em> parameter of internal::SimplifiedExcServer::Interface::CatchException(), for example. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">set_thread_state</td><td><code>true</code> if the handler would like its caller to set the new thread state using the <em>flavor</em>, <em>new_state</em>, and <em>new_state_count</em> out parameters. This can only happen when <em>behavior</em> is a state-carrying behavior.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>KERN_SUCCESS</code> or <code>MACH_RCV_PORT_DIED</code>. <code>KERN_SUCCESS</code> is used when <em>behavior</em> is not a state-carrying behavior, or when it is a state-carrying behavior and <em>set_thread_state</em> is <code>true</code>, or for <code>EXC_CRASH</code> exceptions on OS X 10.11 and later. Otherwise, <code>MACH_RCV_PORT_DIED</code> is used. </dd></dl>
</div>
</div>
<a id="af5f4414be804bdcd71f57053d7147eff"></a>
<h2 class="memtitle"><span class="permalink"><a href="#af5f4414be804bdcd71f57053d7147eff">&sect;&nbsp;</a></span>GetModuleVersionAndType()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::GetModuleVersionAndType </td>
<td>(</td>
<td class="paramtype">const base::FilePath &amp;&#160;</td>
<td class="paramname"><em>path</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="structVS__FIXEDFILEINFO.html">VS_FIXEDFILEINFO</a> *&#160;</td>
<td class="paramname"><em>vs_fixedfileinfo</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Retrieve the type and version information from a given module (exe, dll, etc.) </p>
<p>This function calls <code>GetFileVersionInfo()</code>, which can implicitly call <code>LoadLibrary()</code> to load <em>path</em> into the calling process. Do not call this function on an untrusted module, because there is a risk of executing the modules code.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">path</td><td>The path to the module to be inspected. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">vs_fixedfileinfo</td><td>The <a class="el" href="structVS__FIXEDFILEINFO.html" title="Version information for a file. ">VS_FIXEDFILEINFO</a> on success. <a class="el" href="structVS__FIXEDFILEINFO.html#a1ecf0351f90806354f987321c4d1ce0e" title="A bitmask of VS_FF_* values identifying attributes of the file. Only bits present in dwFileFlagsMask ...">VS_FIXEDFILEINFO::dwFileFlags</a> will have been masked with <a class="el" href="structVS__FIXEDFILEINFO.html#a1523cf64b0b010ecf5a8c3b02866041c" title="A bitmask of VS_FF_* values indicating which bits in dwFileFlags are valid. ">VS_FIXEDFILEINFO::dwFileFlagsMask</a> already.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> on success, or <code>false</code> on failure with a message logged. If the module has no <code>VERSIONINFO</code> resource, <code>false</code> will be returned without any messages logged. </dd></dl>
</div>
</div>
<a id="a794c1a44de599deb3e261eab0bd6c03b"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a794c1a44de599deb3e261eab0bd6c03b">&sect;&nbsp;</a></span>GetReadableRangesOfMemoryMap()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">std::vector&lt; <a class="el" href="classcrashpad_1_1CheckedRange.html">CheckedRange</a>&lt; <a class="el" href="namespacecrashpad.html#a368af6d88f68998b5c5eb80b8f6ebb76">WinVMAddress</a>, <a class="el" href="namespacecrashpad.html#a1bac9f2a189b24737e743d6690362239">WinVMSize</a> &gt; &gt; crashpad::GetReadableRangesOfMemoryMap </td>
<td>(</td>
<td class="paramtype">const <a class="el" href="classcrashpad_1_1CheckedRange.html">CheckedRange</a>&lt; <a class="el" href="namespacecrashpad.html#a368af6d88f68998b5c5eb80b8f6ebb76">WinVMAddress</a>, <a class="el" href="namespacecrashpad.html#a1bac9f2a189b24737e743d6690362239">WinVMSize</a> &gt; &amp;&#160;</td>
<td class="paramname"><em>range</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const <a class="el" href="classcrashpad_1_1ProcessInfo.html#a9b1bd70d4a58ec0afe0ce742f0e3fea8">ProcessInfo::MemoryBasicInformation64Vector</a> &amp;&#160;</td>
<td class="paramname"><em>memory_info</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Given a memory map of a process, and a range to be read from the target process, returns a vector of ranges, representing the readable portions of the original range. </p>
<p>This is a free function for testing, but prefer <a class="el" href="classcrashpad_1_1ProcessInfo.html#a96ddc54651cdea815f8f88a5ae00f0ab" title="Given a range to be read from the target process, returns a vector of ranges, representing the readab...">ProcessInfo::GetReadableRanges()</a>. </p>
</div>
</div>
<a id="aaad18d253c543d4f003b5803fd295f91"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aaad18d253c543d4f003b5803fd295f91">&sect;&nbsp;</a></span>HandlerMain()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">int crashpad::HandlerMain </td>
<td>(</td>
<td class="paramtype">int&#160;</td>
<td class="paramname"><em>argc</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">char *&#160;</td>
<td class="paramname"><em>argv</em>[]&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>The <code>main()</code> of the <code>crashpad_handler</code> binary. </p>
<p>This is exposed so that <code>crashpad_handler</code> can be embedded into another binary, but called and used as if it were a standalone executable. </p>
</div>
</div>
<a id="ae643b5c6bce4e11a0f51eb2f4d5fa1de"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ae643b5c6bce4e11a0f51eb2f4d5fa1de">&sect;&nbsp;</a></span>HandleToInt()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">int crashpad::HandleToInt </td>
<td>(</td>
<td class="paramtype">HANDLE&#160;</td>
<td class="paramname"><em>handle</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Converts a <code>HANDLE</code> to an <code>int</code>. </p>
<p><code>HANDLE</code> is a <code>typedef</code> for <code>void *</code>, but kernel <code>HANDLE</code> values arent pointers to anything. Only 32 bits of kernel <code>HANDLE</code>s are significant, even in 64-bit processes on 64-bit operating systems. See <a href="https://msdn.microsoft.com/en-us/library/windows/desktop/aa384203">Interprocess Communication Between 32-bit and 64-bit Applications</a>.</p>
<p>This function safely converts a kernel <code>HANDLE</code> to an <code>int</code> similarly to a cast operation. It checks that the operation can be performed safely, and aborts execution if it cannot.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">handle</td><td>The kernel <code>HANDLE</code> to convert.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>An equivalent <code>int</code>, truncated (if necessary) from <em>handle</em>. If truncation would have resulted in an <code>int</code> that could not be converted back to <em>handle</em>, aborts execution.</dd></dl>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="namespacecrashpad.html#a83df06f1e4dc470676c1f86e93b6bc63" title="Converts an int to an HANDLE. ">IntToHandle()</a> </dd></dl>
</div>
</div>
<a id="af8340c24a2983e788d2a3ba90d1d4846"></a>
<h2 class="memtitle"><span class="permalink"><a href="#af8340c24a2983e788d2a3ba90d1d4846">&sect;&nbsp;</a></span>InitializeCriticalSectionWithDebugInfoIfPossible()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::InitializeCriticalSectionWithDebugInfoIfPossible </td>
<td>(</td>
<td class="paramtype">CRITICAL_SECTION *&#160;</td>
<td class="paramname"><em>critical_section</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Equivalent to <code>InitializeCritialSection()</code>, but attempts to allocate with a valid <code>.DebugInfo</code> field on versions of Windows where it's possible to do so. </p>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> on success, or <code>false</code> on failure with a message logged. Success means that the critical section was successfully initialized, but it does not necessarily have a valid <code>.DebugInfo</code> field. </dd></dl>
</div>
</div>
<a id="a6e1b1c536af301cd418dad62348b1d29"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a6e1b1c536af301cd418dad62348b1d29">&sect;&nbsp;</a></span>InRangeCast()</h2>
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename Destination , typename Source &gt; </div>
<table class="memname">
<tr>
<td class="memname">Destination crashpad::InRangeCast </td>
<td>(</td>
<td class="paramtype">Source&#160;</td>
<td class="paramname"><em>source</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">Destination&#160;</td>
<td class="paramname"><em>default_value</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Casts to a different type if it can be done without data loss, logging a warning message and returing a default value otherwise. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">source</td><td>The value to convert and return. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">default_value</td><td>The default value to return, in the event that <em>source</em> cannot be represented in the destination type.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><em>source</em> if it can be represented in the destination type, otherwise <em>default_value</em>. </dd></dl>
</div>
</div>
<a id="a83df06f1e4dc470676c1f86e93b6bc63"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a83df06f1e4dc470676c1f86e93b6bc63">&sect;&nbsp;</a></span>IntToHandle()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">HANDLE crashpad::IntToHandle </td>
<td>(</td>
<td class="paramtype">int&#160;</td>
<td class="paramname"><em>handle_int</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Converts an <code>int</code> to an <code>HANDLE</code>. </p>
<p><code>HANDLE</code> is a <code>typedef</code> for <code>void *</code>, but kernel <code>HANDLE</code> values arent pointers to anything. Only 32 bits of kernel <code>HANDLE</code>s are significant, even in 64-bit processes on 64-bit operating systems. See <a href="https://msdn.microsoft.com/en-us/library/windows/desktop/aa384203">Interprocess Communication Between 32-bit and 64-bit Applications</a>.</p>
<p>This function safely convert an <code>int</code> to a kernel <code>HANDLE</code> similarly to a cast operation.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">handle_int</td><td>The <code>int</code> to convert. This must have been produced by <a class="el" href="namespacecrashpad.html#ae643b5c6bce4e11a0f51eb2f4d5fa1de" title="Converts a HANDLE to an int. ">HandleToInt()</a>, possibly in a different process.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>An equivalent kernel <code>HANDLE</code>, sign-extended (if necessary) from <em>handle_int</em>.</dd></dl>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="namespacecrashpad.html#ae643b5c6bce4e11a0f51eb2f4d5fa1de" title="Converts a HANDLE to an int. ">HandleToInt()</a> </dd></dl>
</div>
</div>
<a id="ad2ac0b9fe2a066fecac5e8d9b977e892"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ad2ac0b9fe2a066fecac5e8d9b977e892">&sect;&nbsp;</a></span>IsExceptionNonfatalResource()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::IsExceptionNonfatalResource </td>
<td>(</td>
<td class="paramtype">exception_type_t&#160;</td>
<td class="paramname"><em>exception</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">mach_exception_code_t&#160;</td>
<td class="paramname"><em>code_0</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">pid_t&#160;</td>
<td class="paramname"><em>pid</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Determines whether an exception is a non-fatal <code>EXC_RESOURCE</code>. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">exception</td><td>The exception type as received by a Mach exception handler. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">code_0</td><td>The first exception code (<code>code[0]</code>) as received by a Mach exception handler. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">pid</td><td>The process ID that the exception occurred in. In some cases, process may need to be queried to determine whether an <code>EXC_RESOURCE</code> exception is fatal.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> if the exception is a non-fatal <code>EXC_RESOURCE</code>. <code>false</code> otherwise. If the exception is <code>EXC_RESOURCE</code> of a recognized type but it is not possible to determine whether it is fatal, returns <code>true</code> under the assumption that all known <code>EXC_RESOURCE</code> exceptions are non-fatal by default. If the exception is not <code>EXC_RESOURCE</code> or is an unknown <code>EXC_RESOURCE</code> type, returns <code>false</code>. </dd></dl>
</div>
</div>
<a id="aec89d58359f33bb2ba3671feea0c15f4"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aec89d58359f33bb2ba3671feea0c15f4">&sect;&nbsp;</a></span>LaunchDataAlloc()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">launch_data_t crashpad::LaunchDataAlloc </td>
<td>(</td>
<td class="paramtype">launch_data_type_t&#160;</td>
<td class="paramname"><em>type</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps the <code>&lt;launch.h&gt;</code> function of the same name. </p>
<p>The OS X 10.10 SDK deprecates <code>&lt;launch.h&gt;</code>, although the functionality it provides is still useful. These wrappers allow the deprecated functions to be called without triggering deprecated-declaration warnings. </p>
</div>
</div>
<a id="abeb060347d9343e720856380234cd6ff"></a>
<h2 class="memtitle"><span class="permalink"><a href="#abeb060347d9343e720856380234cd6ff">&sect;&nbsp;</a></span>LaunchDataArrayGetCount()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">size_t crashpad::LaunchDataArrayGetCount </td>
<td>(</td>
<td class="paramtype">launch_data_t&#160;</td>
<td class="paramname"><em>array</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps the <code>&lt;launch.h&gt;</code> function of the same name. </p>
<p>The OS X 10.10 SDK deprecates <code>&lt;launch.h&gt;</code>, although the functionality it provides is still useful. These wrappers allow the deprecated functions to be called without triggering deprecated-declaration warnings. </p>
</div>
</div>
<a id="a46e5304477aab0ad1d165869557eb3b5"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a46e5304477aab0ad1d165869557eb3b5">&sect;&nbsp;</a></span>LaunchDataArrayGetIndex()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">launch_data_t crashpad::LaunchDataArrayGetIndex </td>
<td>(</td>
<td class="paramtype">launch_data_t&#160;</td>
<td class="paramname"><em>array</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">size_t&#160;</td>
<td class="paramname"><em>index</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps the <code>&lt;launch.h&gt;</code> function of the same name. </p>
<p>The OS X 10.10 SDK deprecates <code>&lt;launch.h&gt;</code>, although the functionality it provides is still useful. These wrappers allow the deprecated functions to be called without triggering deprecated-declaration warnings. </p>
</div>
</div>
<a id="a075be3843e4294e446c40022ba6661c4"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a075be3843e4294e446c40022ba6661c4">&sect;&nbsp;</a></span>LaunchDataArraySetIndex()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">bool crashpad::LaunchDataArraySetIndex </td>
<td>(</td>
<td class="paramtype">launch_data_t&#160;</td>
<td class="paramname"><em>array</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const launch_data_t&#160;</td>
<td class="paramname"><em>value</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">size_t&#160;</td>
<td class="paramname"><em>index</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps the <code>&lt;launch.h&gt;</code> function of the same name. </p>
<p>The OS X 10.10 SDK deprecates <code>&lt;launch.h&gt;</code>, although the functionality it provides is still useful. These wrappers allow the deprecated functions to be called without triggering deprecated-declaration warnings. </p>
</div>
</div>
<a id="aedb99d12b989d048f972d843a2aea013"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aedb99d12b989d048f972d843a2aea013">&sect;&nbsp;</a></span>LaunchDataDictGetCount()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">size_t crashpad::LaunchDataDictGetCount </td>
<td>(</td>
<td class="paramtype">launch_data_t&#160;</td>
<td class="paramname"><em>dict</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps the <code>&lt;launch.h&gt;</code> function of the same name. </p>
<p>The OS X 10.10 SDK deprecates <code>&lt;launch.h&gt;</code>, although the functionality it provides is still useful. These wrappers allow the deprecated functions to be called without triggering deprecated-declaration warnings. </p>
</div>
</div>
<a id="a5637f13db21865305a5d09b123647ee0"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a5637f13db21865305a5d09b123647ee0">&sect;&nbsp;</a></span>LaunchDataDictInsert()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">bool crashpad::LaunchDataDictInsert </td>
<td>(</td>
<td class="paramtype">launch_data_t&#160;</td>
<td class="paramname"><em>dict</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const launch_data_t&#160;</td>
<td class="paramname"><em>value</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const char *&#160;</td>
<td class="paramname"><em>key</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps the <code>&lt;launch.h&gt;</code> function of the same name. </p>
<p>The OS X 10.10 SDK deprecates <code>&lt;launch.h&gt;</code>, although the functionality it provides is still useful. These wrappers allow the deprecated functions to be called without triggering deprecated-declaration warnings. </p>
</div>
</div>
<a id="a7d4549b38faef80da81a53b88b1a27ac"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a7d4549b38faef80da81a53b88b1a27ac">&sect;&nbsp;</a></span>LaunchDataDictLookup()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">launch_data_t crashpad::LaunchDataDictLookup </td>
<td>(</td>
<td class="paramtype">const launch_data_t&#160;</td>
<td class="paramname"><em>dict</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const char *&#160;</td>
<td class="paramname"><em>key</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps the <code>&lt;launch.h&gt;</code> function of the same name. </p>
<p>The OS X 10.10 SDK deprecates <code>&lt;launch.h&gt;</code>, although the functionality it provides is still useful. These wrappers allow the deprecated functions to be called without triggering deprecated-declaration warnings. </p>
</div>
</div>
<a id="a6075a91ef08754a4f6f1d1cc4f4243d2"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a6075a91ef08754a4f6f1d1cc4f4243d2">&sect;&nbsp;</a></span>LaunchDataFree()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">void crashpad::LaunchDataFree </td>
<td>(</td>
<td class="paramtype">launch_data_t&#160;</td>
<td class="paramname"><em>data</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps the <code>&lt;launch.h&gt;</code> function of the same name. </p>
<p>The OS X 10.10 SDK deprecates <code>&lt;launch.h&gt;</code>, although the functionality it provides is still useful. These wrappers allow the deprecated functions to be called without triggering deprecated-declaration warnings. </p>
</div>
</div>
<a id="a6fd262daa89e57ffd897e4b583d44d44"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a6fd262daa89e57ffd897e4b583d44d44">&sect;&nbsp;</a></span>LaunchDataGetBool()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">bool crashpad::LaunchDataGetBool </td>
<td>(</td>
<td class="paramtype">const launch_data_t&#160;</td>
<td class="paramname"><em>data</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps the <code>&lt;launch.h&gt;</code> function of the same name. </p>
<p>The OS X 10.10 SDK deprecates <code>&lt;launch.h&gt;</code>, although the functionality it provides is still useful. These wrappers allow the deprecated functions to be called without triggering deprecated-declaration warnings. </p>
</div>
</div>
<a id="a5637cdc78caedaaadb2c0e47857ccf78"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a5637cdc78caedaaadb2c0e47857ccf78">&sect;&nbsp;</a></span>LaunchDataGetErrno()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">int crashpad::LaunchDataGetErrno </td>
<td>(</td>
<td class="paramtype">const launch_data_t&#160;</td>
<td class="paramname"><em>data</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps the <code>&lt;launch.h&gt;</code> function of the same name. </p>
<p>The OS X 10.10 SDK deprecates <code>&lt;launch.h&gt;</code>, although the functionality it provides is still useful. These wrappers allow the deprecated functions to be called without triggering deprecated-declaration warnings. </p>
</div>
</div>
<a id="a54549da20f78530f300712625fc0ba5a"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a54549da20f78530f300712625fc0ba5a">&sect;&nbsp;</a></span>LaunchDataGetInteger()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">long long crashpad::LaunchDataGetInteger </td>
<td>(</td>
<td class="paramtype">const launch_data_t&#160;</td>
<td class="paramname"><em>data</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps the <code>&lt;launch.h&gt;</code> function of the same name. </p>
<p>The OS X 10.10 SDK deprecates <code>&lt;launch.h&gt;</code>, although the functionality it provides is still useful. These wrappers allow the deprecated functions to be called without triggering deprecated-declaration warnings. </p>
</div>
</div>
<a id="aaf2fbe2de028de73c9013d6c0759bc2b"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aaf2fbe2de028de73c9013d6c0759bc2b">&sect;&nbsp;</a></span>LaunchDataGetOpaque()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">void* crashpad::LaunchDataGetOpaque </td>
<td>(</td>
<td class="paramtype">const launch_data_t&#160;</td>
<td class="paramname"><em>data</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps the <code>&lt;launch.h&gt;</code> function of the same name. </p>
<p>The OS X 10.10 SDK deprecates <code>&lt;launch.h&gt;</code>, although the functionality it provides is still useful. These wrappers allow the deprecated functions to be called without triggering deprecated-declaration warnings. </p>
</div>
</div>
<a id="a6ed0f2e24befe2e6faa94445bb03e054"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a6ed0f2e24befe2e6faa94445bb03e054">&sect;&nbsp;</a></span>LaunchDataGetOpaqueSize()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">size_t crashpad::LaunchDataGetOpaqueSize </td>
<td>(</td>
<td class="paramtype">const launch_data_t&#160;</td>
<td class="paramname"><em>data</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps the <code>&lt;launch.h&gt;</code> function of the same name. </p>
<p>The OS X 10.10 SDK deprecates <code>&lt;launch.h&gt;</code>, although the functionality it provides is still useful. These wrappers allow the deprecated functions to be called without triggering deprecated-declaration warnings. </p>
</div>
</div>
<a id="a21114f1a9f28bfb065033f569d466a09"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a21114f1a9f28bfb065033f569d466a09">&sect;&nbsp;</a></span>LaunchDataGetReal()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">double crashpad::LaunchDataGetReal </td>
<td>(</td>
<td class="paramtype">const launch_data_t&#160;</td>
<td class="paramname"><em>data</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps the <code>&lt;launch.h&gt;</code> function of the same name. </p>
<p>The OS X 10.10 SDK deprecates <code>&lt;launch.h&gt;</code>, although the functionality it provides is still useful. These wrappers allow the deprecated functions to be called without triggering deprecated-declaration warnings. </p>
</div>
</div>
<a id="a30a24e225530ab7feeb3e12df480f5c5"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a30a24e225530ab7feeb3e12df480f5c5">&sect;&nbsp;</a></span>LaunchDataGetString()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">const char* crashpad::LaunchDataGetString </td>
<td>(</td>
<td class="paramtype">const launch_data_t&#160;</td>
<td class="paramname"><em>data</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps the <code>&lt;launch.h&gt;</code> function of the same name. </p>
<p>The OS X 10.10 SDK deprecates <code>&lt;launch.h&gt;</code>, although the functionality it provides is still useful. These wrappers allow the deprecated functions to be called without triggering deprecated-declaration warnings. </p>
</div>
</div>
<a id="a765503fd97e9e3d622d3b30bff543fb9"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a765503fd97e9e3d622d3b30bff543fb9">&sect;&nbsp;</a></span>LaunchDataGetType()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">launch_data_type_t crashpad::LaunchDataGetType </td>
<td>(</td>
<td class="paramtype">const launch_data_t&#160;</td>
<td class="paramname"><em>data</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps the <code>&lt;launch.h&gt;</code> function of the same name. </p>
<p>The OS X 10.10 SDK deprecates <code>&lt;launch.h&gt;</code>, although the functionality it provides is still useful. These wrappers allow the deprecated functions to be called without triggering deprecated-declaration warnings. </p>
</div>
</div>
<a id="a19e679e954d2d8ca88ace03ccab5c4df"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a19e679e954d2d8ca88ace03ccab5c4df">&sect;&nbsp;</a></span>LaunchDataNewBool()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">launch_data_t crashpad::LaunchDataNewBool </td>
<td>(</td>
<td class="paramtype">bool&#160;</td>
<td class="paramname"><em>boolean</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps the <code>&lt;launch.h&gt;</code> function of the same name. </p>
<p>The OS X 10.10 SDK deprecates <code>&lt;launch.h&gt;</code>, although the functionality it provides is still useful. These wrappers allow the deprecated functions to be called without triggering deprecated-declaration warnings. </p>
</div>
</div>
<a id="a7b4bfcaae95ef3a81e3ec2d27f059bab"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a7b4bfcaae95ef3a81e3ec2d27f059bab">&sect;&nbsp;</a></span>LaunchDataNewInteger()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">launch_data_t crashpad::LaunchDataNewInteger </td>
<td>(</td>
<td class="paramtype">long long&#160;</td>
<td class="paramname"><em>integer</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps the <code>&lt;launch.h&gt;</code> function of the same name. </p>
<p>The OS X 10.10 SDK deprecates <code>&lt;launch.h&gt;</code>, although the functionality it provides is still useful. These wrappers allow the deprecated functions to be called without triggering deprecated-declaration warnings. </p>
</div>
</div>
<a id="a5af22dade75539fd9e5032acf799c945"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a5af22dade75539fd9e5032acf799c945">&sect;&nbsp;</a></span>LaunchDataNewOpaque()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">launch_data_t crashpad::LaunchDataNewOpaque </td>
<td>(</td>
<td class="paramtype">const void *&#160;</td>
<td class="paramname"><em>opaque</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">size_t&#160;</td>
<td class="paramname"><em>size</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps the <code>&lt;launch.h&gt;</code> function of the same name. </p>
<p>The OS X 10.10 SDK deprecates <code>&lt;launch.h&gt;</code>, although the functionality it provides is still useful. These wrappers allow the deprecated functions to be called without triggering deprecated-declaration warnings. </p>
</div>
</div>
<a id="aa78698056108819fe4bd268cc55801c3"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aa78698056108819fe4bd268cc55801c3">&sect;&nbsp;</a></span>LaunchDataNewReal()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">launch_data_t crashpad::LaunchDataNewReal </td>
<td>(</td>
<td class="paramtype">double&#160;</td>
<td class="paramname"><em>real</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps the <code>&lt;launch.h&gt;</code> function of the same name. </p>
<p>The OS X 10.10 SDK deprecates <code>&lt;launch.h&gt;</code>, although the functionality it provides is still useful. These wrappers allow the deprecated functions to be called without triggering deprecated-declaration warnings. </p>
</div>
</div>
<a id="a7ae48002caa906acb164114bc290b048"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a7ae48002caa906acb164114bc290b048">&sect;&nbsp;</a></span>LaunchDataNewString()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">launch_data_t crashpad::LaunchDataNewString </td>
<td>(</td>
<td class="paramtype">const char *&#160;</td>
<td class="paramname"><em>string</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps the <code>&lt;launch.h&gt;</code> function of the same name. </p>
<p>The OS X 10.10 SDK deprecates <code>&lt;launch.h&gt;</code>, although the functionality it provides is still useful. These wrappers allow the deprecated functions to be called without triggering deprecated-declaration warnings. </p>
</div>
</div>
<a id="ae541f07925a67de751502b903af919b4"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ae541f07925a67de751502b903af919b4">&sect;&nbsp;</a></span>LaunchMsg()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">launch_data_t crashpad::LaunchMsg </td>
<td>(</td>
<td class="paramtype">const launch_data_t&#160;</td>
<td class="paramname"><em>data</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps the <code>&lt;launch.h&gt;</code> function of the same name. </p>
<p>The OS X 10.10 SDK deprecates <code>&lt;launch.h&gt;</code>, although the functionality it provides is still useful. These wrappers allow the deprecated functions to be called without triggering deprecated-declaration warnings. </p>
</div>
</div>
<a id="ab9db00544fd57cfde0bb03d32b989221"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ab9db00544fd57cfde0bb03d32b989221">&sect;&nbsp;</a></span>LoggingCloseFile()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::LoggingCloseFile </td>
<td>(</td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a>&#160;</td>
<td class="paramname"><em>file</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps <code>close()</code> or <code>CloseHandle()</code>, logging an error if the operation fails. </p>
<dl class="section return"><dt>Returns</dt><dd>On success, <code>true</code> is returned. On failure, an error is logged and <code>false</code> is returned. </dd></dl>
</div>
</div>
<a id="a0224d5a689cdb8c2315c255fd6ea6b5c"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a0224d5a689cdb8c2315c255fd6ea6b5c">&sect;&nbsp;</a></span>LoggingFileSizeByHandle()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="namespacecrashpad.html#a1e53a1957d9edcba8b406ea632b6daf2">FileOffset</a> crashpad::LoggingFileSizeByHandle </td>
<td>(</td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a>&#160;</td>
<td class="paramname"><em>file</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Determines the size of a file. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">file</td><td>The handle to the file for which the size should be retrived.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The size of the file. If an error occurs when attempting to determine its size, returns <code>-1</code> with an error logged. </dd></dl>
</div>
</div>
<a id="acd02263566d8c43fc7886f88a13b364f"></a>
<h2 class="memtitle"><span class="permalink"><a href="#acd02263566d8c43fc7886f88a13b364f">&sect;&nbsp;</a></span>LoggingLockFile()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::LoggingLockFile </td>
<td>(</td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a>&#160;</td>
<td class="paramname"><em>file</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a3753a95b02e5c96c6e20017e467cef07">FileLocking</a>&#160;</td>
<td class="paramname"><em>locking</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Locks the given <em>file</em> using <code>flock()</code> on POSIX or <code>LockFileEx()</code> on Windows. </p>
<p>It is an error to attempt to lock a file in a different mode when it is already locked. This call will block until the lock is acquired. The entire file is locked.</p>
<p>If <em>locking</em> is <a class="el" href="namespacecrashpad.html#a3753a95b02e5c96c6e20017e467cef07a767e1337acb2aa20d7ce4e903a75ca16" title="Equivalent to flock() with LOCK_SH. ">FileLocking::kShared</a>, <em>file</em> must have been opened for reading, and if it's <a class="el" href="namespacecrashpad.html#a3753a95b02e5c96c6e20017e467cef07a9d38b79e17ebc3239ca19ba517174b5b" title="Equivalent to flock() with LOCK_EX. ">FileLocking::kExclusive</a>, <em>file</em> must have been opened for writing.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">file</td><td>The open file handle to be locked. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">locking</td><td>Controls whether the lock is a shared reader lock, or an exclusive writer lock.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> on success, or <code>false</code> and a message will be logged. </dd></dl>
</div>
</div>
<a id="ab3712d59104f641109b170c78a912b4d"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ab3712d59104f641109b170c78a912b4d">&sect;&nbsp;</a></span>LoggingOpenFileForRead()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a> crashpad::LoggingOpenFileForRead </td>
<td>(</td>
<td class="paramtype">const base::FilePath &amp;&#160;</td>
<td class="paramname"><em>path</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps <a class="el" href="namespacecrashpad.html#a7987df05e1260e6d8d93ee3a21e9b0eb" title="Wraps open() or CreateFile(), opening an existing file for reading. ">OpenFileForRead()</a>, logging an error if the operation fails. </p>
<dl class="section return"><dt>Returns</dt><dd>The newly opened FileHandle, or an invalid FileHandle on failure.</dd></dl>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="namespacecrashpad.html#a9daa1b956487883acd9f43d13cc77339" title="Scoped wrapper of a FileHandle. ">ScopedFileHandle</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#a62fc6876cc0c660f0ea8bd1dd0a07e82" title="Wraps OpenFileForWrite(), logging an error if the operation fails. ">LoggingOpenFileForWrite</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#aab3e964bdba04aaf74e7a27a36efe108" title="Wraps OpenFileForReadAndWrite(), logging an error if the operation fails. ">LoggingOpenFileForReadAndWrite</a> </dd></dl>
</div>
</div>
<a id="aab3e964bdba04aaf74e7a27a36efe108"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aab3e964bdba04aaf74e7a27a36efe108">&sect;&nbsp;</a></span>LoggingOpenFileForReadAndWrite()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a> crashpad::LoggingOpenFileForReadAndWrite </td>
<td>(</td>
<td class="paramtype">const base::FilePath &amp;&#160;</td>
<td class="paramname"><em>path</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#afa69b0967d9a6df659ff5d2a02ff3e51">FileWriteMode</a>&#160;</td>
<td class="paramname"><em>mode</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a034ccc90eb0d1f587ee89275d822175d">FilePermissions</a>&#160;</td>
<td class="paramname"><em>permissions</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps <a class="el" href="namespacecrashpad.html#abe6238b18be49921772c14dd25a624de" title="Wraps open() or CreateFile(), creating a file for both input and output. ">OpenFileForReadAndWrite()</a>, logging an error if the operation fails. </p>
<dl class="section return"><dt>Returns</dt><dd>The newly opened FileHandle, or an invalid FileHandle on failure.</dd></dl>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="namespacecrashpad.html#a9daa1b956487883acd9f43d13cc77339" title="Scoped wrapper of a FileHandle. ">ScopedFileHandle</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#ab3712d59104f641109b170c78a912b4d" title="Wraps OpenFileForRead(), logging an error if the operation fails. ">LoggingOpenFileForRead</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#a62fc6876cc0c660f0ea8bd1dd0a07e82" title="Wraps OpenFileForWrite(), logging an error if the operation fails. ">LoggingOpenFileForWrite</a> </dd></dl>
</div>
</div>
<a id="a62fc6876cc0c660f0ea8bd1dd0a07e82"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a62fc6876cc0c660f0ea8bd1dd0a07e82">&sect;&nbsp;</a></span>LoggingOpenFileForWrite()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a> crashpad::LoggingOpenFileForWrite </td>
<td>(</td>
<td class="paramtype">const base::FilePath &amp;&#160;</td>
<td class="paramname"><em>path</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#afa69b0967d9a6df659ff5d2a02ff3e51">FileWriteMode</a>&#160;</td>
<td class="paramname"><em>mode</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a034ccc90eb0d1f587ee89275d822175d">FilePermissions</a>&#160;</td>
<td class="paramname"><em>permissions</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps <a class="el" href="namespacecrashpad.html#ad8e8848af82384f7757108c8c445f18d" title="Wraps open() or CreateFile(), creating a file for output. ">OpenFileForWrite()</a>, logging an error if the operation fails. </p>
<dl class="section return"><dt>Returns</dt><dd>The newly opened FileHandle, or an invalid FileHandle on failure.</dd></dl>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="namespacecrashpad.html#a9daa1b956487883acd9f43d13cc77339" title="Scoped wrapper of a FileHandle. ">ScopedFileHandle</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#ab3712d59104f641109b170c78a912b4d" title="Wraps OpenFileForRead(), logging an error if the operation fails. ">LoggingOpenFileForRead</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#aab3e964bdba04aaf74e7a27a36efe108" title="Wraps OpenFileForReadAndWrite(), logging an error if the operation fails. ">LoggingOpenFileForReadAndWrite</a> </dd></dl>
</div>
</div>
<a id="abd2a51526c1f15e3f21a962457cbc53a"></a>
<h2 class="memtitle"><span class="permalink"><a href="#abd2a51526c1f15e3f21a962457cbc53a">&sect;&nbsp;</a></span>LoggingReadFile()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::LoggingReadFile </td>
<td>(</td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a>&#160;</td>
<td class="paramname"><em>file</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">void *&#160;</td>
<td class="paramname"><em>buffer</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">size_t&#160;</td>
<td class="paramname"><em>size</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps <a class="el" href="namespacecrashpad.html#a8599600814a17d622766decd5f122a96" title="Reads from a file, retrying when interrupted on POSIX or following a short read. ">ReadFile()</a>, ensuring that exactly <em>size</em> bytes are read. </p>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> on success. If <em>size</em> is out of the range of possible <a class="el" href="namespacecrashpad.html#a8599600814a17d622766decd5f122a96" title="Reads from a file, retrying when interrupted on POSIX or following a short read. ">ReadFile()</a> return values, if the underlying <a class="el" href="namespacecrashpad.html#a8599600814a17d622766decd5f122a96" title="Reads from a file, retrying when interrupted on POSIX or following a short read. ">ReadFile()</a> fails, or if other than <em>size</em> bytes were read, this function logs a message and returns <code>false</code>.</dd></dl>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="namespacecrashpad.html#a8a91af9c690d2a280c463596bf82070b" title="Wraps WriteFile(), ensuring that exactly size bytes are written. ">LoggingWriteFile</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#a8599600814a17d622766decd5f122a96" title="Reads from a file, retrying when interrupted on POSIX or following a short read. ">ReadFile</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#aee611c7116746b846a3cf79e65619f4d" title="Wraps ReadFile(), ensuring that exactly size bytes are read. ">CheckedReadFile</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#ac8e7e1b1a4b89b489964ffee54d0d9df" title="Wraps ReadFile(), ensuring that it indicates end-of-file. ">CheckedReadFileAtEOF</a> </dd></dl>
</div>
</div>
<a id="a3d6cedc10e24145d4a0c1000c33f8a10"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a3d6cedc10e24145d4a0c1000c33f8a10">&sect;&nbsp;</a></span>LoggingSeekFile()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="namespacecrashpad.html#a1e53a1957d9edcba8b406ea632b6daf2">FileOffset</a> crashpad::LoggingSeekFile </td>
<td>(</td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a>&#160;</td>
<td class="paramname"><em>file</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a1e53a1957d9edcba8b406ea632b6daf2">FileOffset</a>&#160;</td>
<td class="paramname"><em>offset</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">int&#160;</td>
<td class="paramname"><em>whence</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps <code>lseek()</code> or <code>SetFilePointerEx()</code>. Logs an error if the operation fails. </p>
<p>Repositions the offset of the open <em>file</em> to the specified <em>offset</em>, relative to <em>whence</em>. <em>whence</em> must be one of <code>SEEK_SET</code>, <code>SEEK_CUR</code>, or <code>SEEK_END</code>, and is interpreted in the usual way.</p>
<dl class="section return"><dt>Returns</dt><dd>The resulting offset in bytes from the beginning of the file, or <code>-1</code> on failure. </dd></dl>
</div>
</div>
<a id="a06ba30c1a4b2974f1d4ea842db55b068"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a06ba30c1a4b2974f1d4ea842db55b068">&sect;&nbsp;</a></span>LoggingTruncateFile()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::LoggingTruncateFile </td>
<td>(</td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a>&#160;</td>
<td class="paramname"><em>file</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Truncates the given <em>file</em> to zero bytes in length. </p>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> on success, or <code>false</code>, and a message will be logged. </dd></dl>
</div>
</div>
<a id="a15c1f3a2c6f04e944fdca12e22b0cb6e"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a15c1f3a2c6f04e944fdca12e22b0cb6e">&sect;&nbsp;</a></span>LoggingUnlockFile()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::LoggingUnlockFile </td>
<td>(</td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a>&#160;</td>
<td class="paramname"><em>file</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Unlocks a file previously locked with <a class="el" href="namespacecrashpad.html#acd02263566d8c43fc7886f88a13b364f" title="Locks the given file using flock() on POSIX or LockFileEx() on Windows. ">LoggingLockFile()</a>. </p>
<p>It is an error to attempt to unlock a file that was not previously locked. A previously-locked file should be unlocked before closing the file handle, otherwise on some OSs the lock may not be released immediately.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">file</td><td>The open locked file handle to be unlocked.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> on success, or <code>false</code> and a message will be logged. </dd></dl>
</div>
</div>
<a id="a8a91af9c690d2a280c463596bf82070b"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a8a91af9c690d2a280c463596bf82070b">&sect;&nbsp;</a></span>LoggingWriteFile()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::LoggingWriteFile </td>
<td>(</td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a>&#160;</td>
<td class="paramname"><em>file</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const void *&#160;</td>
<td class="paramname"><em>buffer</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">size_t&#160;</td>
<td class="paramname"><em>size</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps <a class="el" href="namespacecrashpad.html#ab9dded3137add283f6cf32facb86641a" title="Writes to a file, retrying when interrupted or following a short write on POSIX. ">WriteFile()</a>, ensuring that exactly <em>size</em> bytes are written. </p>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> on success. If <em>size</em> is out of the range of possible <a class="el" href="namespacecrashpad.html#ab9dded3137add283f6cf32facb86641a" title="Writes to a file, retrying when interrupted or following a short write on POSIX. ">WriteFile()</a> return values, if the underlying <a class="el" href="namespacecrashpad.html#ab9dded3137add283f6cf32facb86641a" title="Writes to a file, retrying when interrupted or following a short write on POSIX. ">WriteFile()</a> fails, or if other than <em>size</em> bytes were written, this function logs a message and returns <code>false</code>.</dd></dl>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="namespacecrashpad.html#abd2a51526c1f15e3f21a962457cbc53a" title="Wraps ReadFile(), ensuring that exactly size bytes are read. ">LoggingReadFile</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#ab9dded3137add283f6cf32facb86641a" title="Writes to a file, retrying when interrupted or following a short write on POSIX. ">WriteFile</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#a74c74fefa3b1f5e0c1b885755c9f9cf6" title="Wraps WriteFile(), ensuring that exactly size bytes are written. ">CheckedWriteFile</a> </dd></dl>
</div>
</div>
<a id="aa31f495c675536bcb30d1267c3a9b696"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aa31f495c675536bcb30d1267c3a9b696">&sect;&nbsp;</a></span>MachMessageDeadlineFromTimeout()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="namespacecrashpad.html#a34f36473e385b19eb229798ab2f7210c">MachMessageDeadline</a> crashpad::MachMessageDeadlineFromTimeout </td>
<td>(</td>
<td class="paramtype">mach_msg_timeout_t&#160;</td>
<td class="paramname"><em>timeout_ms</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Computes the deadline for a specified timeout value. </p>
<p>While deadlines exist on an absolute time scale, timeouts are relative. This function calculates the deadline as <em>timeout_ms</em> milliseconds after it executes.</p>
<p>If <em>timeout_ms</em> is <a class="el" href="namespacecrashpad.html#a163a3ceac0adcb2419bb8d97e1425b94a6461bf9de012b5f2305fb3da6d0f82d5" title="MachMessageWithDeadline() should not block at all in its operation. ">kMachMessageDeadlineNonblocking</a>, this function will return <a class="el" href="namespacecrashpad.html#a163a3ceac0adcb2419bb8d97e1425b94a6461bf9de012b5f2305fb3da6d0f82d5" title="MachMessageWithDeadline() should not block at all in its operation. ">kMachMessageDeadlineNonblocking</a>. If <em>timeout_ms</em> is <a class="el" href="namespacecrashpad.html#a9c82d3742b041daf266c44df253ef02daaf4f2c8a649ea6bcfe896e77c312315f" title="When passed to MachMessageDeadlineFromTimeout(), that function will return kMachMessageDeadlineWaitIn...">kMachMessageTimeoutWaitIndefinitely</a>, this function will return <a class="el" href="namespacecrashpad.html#a163a3ceac0adcb2419bb8d97e1425b94a848a739b3c252f4565161a6bd3f070d6" title="MachMessageWithDeadline() should wait indefinitely for the requested operation to complete...">kMachMessageDeadlineWaitIndefinitely</a>. </p>
</div>
</div>
<a id="a2670a96d46f33b0e88db50a6222c0b47"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a2670a96d46f33b0e88db50a6222c0b47">&sect;&nbsp;</a></span>MachMessageDestroyReceivedPort()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::MachMessageDestroyReceivedPort </td>
<td>(</td>
<td class="paramtype">mach_port_t&#160;</td>
<td class="paramname"><em>port</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">mach_msg_type_name_t&#160;</td>
<td class="paramname"><em>port_right_type</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Destroys or deallocates a Mach port received in a Mach message. </p>
<p>This function disposes of port rights received in a Mach message. Receive rights will be destroyed with <code>mach_port_mod_refs()</code>. Send and send-once rights will be deallocated with <code>mach_port_deallocate()</code>.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">port</td><td>The port to destroy or deallocate. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">port_right_type</td><td>The right type held for <em>port:</em> <code>MACH_MSG_TYPE_PORT_RECEIVE</code>, <code>MACH_MSG_TYPE_PORT_SEND</code>, or <code>MACH_MSG_TYPE_PORT_SEND_ONCE</code>.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> on success, or <code>false</code> on failure with a message logged. </dd></dl>
</div>
</div>
<a id="a979ca1d327dcf56488d3304efa9680eb"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a979ca1d327dcf56488d3304efa9680eb">&sect;&nbsp;</a></span>MachMessageTrailerFromHeader()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">const mach_msg_trailer_t * crashpad::MachMessageTrailerFromHeader </td>
<td>(</td>
<td class="paramtype">const mach_msg_header_t *&#160;</td>
<td class="paramname"><em>header</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Returns a Mach message trailer for a message that has been received. </p>
<p>This function must only be called on Mach messages that have been received via the Mach messaging interface, such as <code>mach_msg()</code>. Messages constructed for sending do not contain trailers.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">header</td><td>A pointer to a received Mach message.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>A pointer to the trailer following the received Mach messages body. The contents of the trailer depend on the options provided to <code>mach_msg()</code> or a similar function when the message was received. </dd></dl>
</div>
</div>
<a id="a35293418a0b7637a00631807ac4b431e"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a35293418a0b7637a00631807ac4b431e">&sect;&nbsp;</a></span>MachMessageWithDeadline()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">mach_msg_return_t crashpad::MachMessageWithDeadline </td>
<td>(</td>
<td class="paramtype">mach_msg_header_t *&#160;</td>
<td class="paramname"><em>message</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">mach_msg_option_t&#160;</td>
<td class="paramname"><em>options</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">mach_msg_size_t&#160;</td>
<td class="paramname"><em>receive_size</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">mach_port_name_t&#160;</td>
<td class="paramname"><em>receive_port</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a34f36473e385b19eb229798ab2f7210c">MachMessageDeadline</a>&#160;</td>
<td class="paramname"><em>deadline</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">mach_port_name_t&#160;</td>
<td class="paramname"><em>notify_port</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">bool&#160;</td>
<td class="paramname"><em>run_even_if_expired</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Runs <code>mach_msg()</code> with a deadline, as opposed to a timeout. </p>
<p>This function is similar to <code>mach_msg()</code>, with the following differences:</p><ul>
<li>The <code>timeout</code> parameter has been replaced by <em>deadline</em>. The deadline applies uniformly to a call that is requested to both send and receive a message.</li>
<li>The <code>MACH_SEND_TIMEOUT</code> and <code>MACH_RCV_TIMEOUT</code> bits in <em>options</em> are not used. Timeouts are specified by the <em>deadline</em> argument.</li>
<li>The <code>send_size</code> parameter has been removed. Its value is implied by <em>message</em> when <em>options</em> contains <code>MACH_SEND_MSG</code>.</li>
<li>The <em>run_even_if_expired</em> parameter has been added.</li>
</ul>
<p>Like the <code>mach_msg()</code> wrapper in <code>libsyscall</code>, this function will retry operations when experiencing <code>MACH_SEND_INTERRUPTED</code> and <code>MACH_RCV_INTERRUPTED</code>, unless <em>options</em> contains <code>MACH_SEND_INTERRUPT</code> or <code>MACH_RCV_INTERRUPT</code>. Unlike <code>mach_msg()</code>, which restarts the call with the full timeout when this occurs, this function continues enforcing the user-specified <em>deadline</em>.</p>
<p>Except as noted, the parameters and return value are identical to those of <code>mach_msg()</code>.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in,out]</td><td class="paramname">message</td><td></td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">options</td><td></td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">receive_size</td><td></td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">receive_port</td><td></td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">deadline</td><td>The time by which this call should complete. If the deadline is exceeded, this call will return <code>MACH_SEND_TIMED_OUT</code> or <code>MACH_RCV_TIMED_OUT</code>. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">notify_port</td><td></td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">run_even_if_expired</td><td>If <code>true</code>, a deadline that is expired when this function is called will be treated as though a deadline of <a class="el" href="namespacecrashpad.html#a163a3ceac0adcb2419bb8d97e1425b94a6461bf9de012b5f2305fb3da6d0f82d5" title="MachMessageWithDeadline() should not block at all in its operation. ">kMachMessageDeadlineNonblocking</a> had been specified. When <code>false</code>, an expired deadline will result in a <code>MACH_SEND_TIMED_OUT</code> or <code>MACH_RCV_TIMED_OUT</code> return value, even if the deadline is already expired when the function is called.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The return value of <code>mach_msg()</code> </dd></dl>
</div>
</div>
<a id="a79ee9764b34c0267b58f54404946275a"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a79ee9764b34c0267b58f54404946275a">&sect;&nbsp;</a></span>MachThreadSelf()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">thread_t crashpad::MachThreadSelf </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Like <code>mach_thread_self()</code>, but without the obligation to release the send right. </p>
<p><code>mach_thread_self()</code> returns a send right to the current thread port, incrementing its reference count. This burdens the caller with maintaining this send right, and calling <code>mach_port_deallocate()</code> when it is no longer needed. This is burdensome, and is at odds with the normal operation of <code>mach_task_self()</code>, which does not increment the task ports reference count whose result must not be deallocated.</p>
<p>Callers can use this function in preference to <code>mach_thread_self()</code>. This function returns an extant reference to the current threads port without incrementing its reference count.</p>
<dl class="section return"><dt>Returns</dt><dd>The value of <code>mach_thread_self()</code> without incrementing its reference count. The returned port must not be deallocated by <code>mach_port_deallocate()</code>. The returned value is valid as long as the thread continues to exist as a <code>pthread_t</code>. </dd></dl>
</div>
</div>
<a id="a71c79500b827d06b190e30b7cc016c35"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a71c79500b827d06b190e30b7cc016c35">&sect;&nbsp;</a></span>MacModelAndBoard()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void crashpad::MacModelAndBoard </td>
<td>(</td>
<td class="paramtype">std::string *&#160;</td>
<td class="paramname"><em>model</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">std::string *&#160;</td>
<td class="paramname"><em>board_id</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Returns the model name and board ID of the running system. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[out]</td><td class="paramname">model</td><td>The systems model name. A mid-2012 15" MacBook Pro would report “MacBookPro10,1”. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">board_id</td><td>The systems board ID. A mid-2012 15" MacBook Pro would report “Mac-C3EC7CD22292981F”.</td></tr>
</table>
</dd>
</dl>
<p>If a value cannot be determined, its string is cleared. </p>
</div>
</div>
<a id="ab05052e02f3c3605fd7bae0f006d2cba"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ab05052e02f3c3605fd7bae0f006d2cba">&sect;&nbsp;</a></span>MacOSXMinorVersion()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">int crashpad::MacOSXMinorVersion </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Returns the version of the running operating system. </p>
<dl class="section return"><dt>Returns</dt><dd>The minor version of the operating system, such as <code>12</code> for macOS 10.12.1.</dd></dl>
<dl class="section note"><dt>Note</dt><dd>This is similar to the base::mac::IsOS*() family of functions, but is provided for situations where the caller needs to obtain version information beyond what is provided by Chromiums base, or for when the caller needs the actual minor version value. </dd></dl>
</div>
</div>
<a id="a99a833f0c39ce203b49862367494a923"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a99a833f0c39ce203b49862367494a923">&sect;&nbsp;</a></span>MacOSXVersion()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::MacOSXVersion </td>
<td>(</td>
<td class="paramtype">int *&#160;</td>
<td class="paramname"><em>major</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">int *&#160;</td>
<td class="paramname"><em>minor</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">int *&#160;</td>
<td class="paramname"><em>bugfix</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">std::string *&#160;</td>
<td class="paramname"><em>build</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">bool *&#160;</td>
<td class="paramname"><em>server</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">std::string *&#160;</td>
<td class="paramname"><em>version_string</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Returns the version of the running operating system. </p>
<p>All parameters are required. No parameter may be <code>nullptr</code>.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[out]</td><td class="paramname">major</td><td>The major version of the operating system, such as <code>10</code> for macOS 10.12.1. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">minor</td><td>The major version of the operating system, such as <code>12</code> for macOS 10.12.1. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">bugfix</td><td>The bugfix version of the operating system, such as <code>1</code> for macOS 10.12.1. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">build</td><td>The operating systems build string, such as <code>"16B2657"</code> for macOS 10.12.1. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">server</td><td><code>true</code> for a macOS Server installation, <code>false</code> otherwise (for a desktop/laptop, client, or workstation system). </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">version_string</td><td>A string representing the full operating system version, such as <code>"macOS 10.12.1 (16B2657)"</code>.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> on success, <code>false</code> on failure, with an error message logged. A failure is considered to have occurred if any element could not be determined. When this happens, their values will be untouched, but other values that could be determined will still be set properly. </dd></dl>
</div>
</div>
<a id="a0486df983d8e9cecbe1e46e0059806df"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a0486df983d8e9cecbe1e46e0059806df">&sect;&nbsp;</a></span>MapInsertOrReplace()</h2>
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T &gt; </div>
<table class="memname">
<tr>
<td class="memname">bool crashpad::MapInsertOrReplace </td>
<td>(</td>
<td class="paramtype">T *&#160;</td>
<td class="paramname"><em>map</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const typename T::key_type &amp;&#160;</td>
<td class="paramname"><em>key</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const typename T::mapped_type &amp;&#160;</td>
<td class="paramname"><em>value</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">typename T::mapped_type *&#160;</td>
<td class="paramname"><em>old_value</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Inserts a mapping from <em>key</em> to <em>value</em> into <em>map</em>, or replaces an existing mapping so that <em>key</em> maps to <em>value</em>. </p>
<p>This behaves similarly to <code>std::map&lt;&gt;::insert_or_assign()</code> proposed for C++17, except that the <em>old_value</em> parameter is added.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in,out]</td><td class="paramname">map</td><td>The map to operate on. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">key</td><td>The key that should be mapped to <em>value</em>. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">value</td><td>The value that <em>key</em> should map to. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">old_value</td><td>If <em>key</em> was previously present in <em>map</em>, this will be set to its previous value. This parameter is optional and may be <code>nullptr</code> if this information is not required.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>false</code> if <em>key</em> was previously present in <em>map</em>. If <em>old_value</em> is not <code>nullptr</code>, it will be set to the previous value. <code>true</code> if <em>key</em> was not present in the map and was inserted. </dd></dl>
</div>
</div>
<a id="a9c9bc6ad9973f794c425707617b63278"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a9c9bc6ad9973f794c425707617b63278">&sect;&nbsp;</a></span>NewMachPort()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">mach_port_t crashpad::NewMachPort </td>
<td>(</td>
<td class="paramtype">mach_port_right_t&#160;</td>
<td class="paramname"><em>right</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Creates a new Mach port in the current task. </p>
<p>This function wraps the <code>mach_port_allocate()</code> providing a simpler interface.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">right</td><td>The type of right to create.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The new Mach port. On failure, <code>MACH_PORT_NULL</code> with a message logged. </dd></dl>
</div>
</div>
<a id="a7987df05e1260e6d8d93ee3a21e9b0eb"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a7987df05e1260e6d8d93ee3a21e9b0eb">&sect;&nbsp;</a></span>OpenFileForRead()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a> crashpad::OpenFileForRead </td>
<td>(</td>
<td class="paramtype">const base::FilePath &amp;&#160;</td>
<td class="paramname"><em>path</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps <code>open()</code> or <code>CreateFile()</code>, opening an existing file for reading. </p>
<dl class="section return"><dt>Returns</dt><dd>The newly opened FileHandle, or an invalid FileHandle on failure.</dd></dl>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="namespacecrashpad.html#a9daa1b956487883acd9f43d13cc77339" title="Scoped wrapper of a FileHandle. ">ScopedFileHandle</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#ad8e8848af82384f7757108c8c445f18d" title="Wraps open() or CreateFile(), creating a file for output. ">OpenFileForWrite</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#abe6238b18be49921772c14dd25a624de" title="Wraps open() or CreateFile(), creating a file for both input and output. ">OpenFileForReadAndWrite</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#ab3712d59104f641109b170c78a912b4d" title="Wraps OpenFileForRead(), logging an error if the operation fails. ">LoggingOpenFileForRead</a> </dd></dl>
</div>
</div>
<a id="abe6238b18be49921772c14dd25a624de"></a>
<h2 class="memtitle"><span class="permalink"><a href="#abe6238b18be49921772c14dd25a624de">&sect;&nbsp;</a></span>OpenFileForReadAndWrite()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a> crashpad::OpenFileForReadAndWrite </td>
<td>(</td>
<td class="paramtype">const base::FilePath &amp;&#160;</td>
<td class="paramname"><em>path</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#afa69b0967d9a6df659ff5d2a02ff3e51">FileWriteMode</a>&#160;</td>
<td class="paramname"><em>mode</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a034ccc90eb0d1f587ee89275d822175d">FilePermissions</a>&#160;</td>
<td class="paramname"><em>permissions</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps <code>open()</code> or <code>CreateFile()</code>, creating a file for both input and output. </p>
<p><em>mode</em> determines the style (truncate, reuse, etc.) that is used to open the file. On POSIX, <em>permissions</em> determines the value that is passed as <code>mode</code> to <code>open()</code>. On Windows, the file is always opened in binary mode (that is, no CRLF translation). On Windows, the file is opened for sharing, see <a class="el" href="namespacecrashpad.html#acd02263566d8c43fc7886f88a13b364f" title="Locks the given file using flock() on POSIX or LockFileEx() on Windows. ">LoggingLockFile()</a> and <a class="el" href="namespacecrashpad.html#a15c1f3a2c6f04e944fdca12e22b0cb6e" title="Unlocks a file previously locked with LoggingLockFile(). ">LoggingUnlockFile()</a> to control concurrent access.</p>
<dl class="section return"><dt>Returns</dt><dd>The newly opened FileHandle, or an invalid FileHandle on failure.</dd></dl>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="namespacecrashpad.html#a9daa1b956487883acd9f43d13cc77339" title="Scoped wrapper of a FileHandle. ">ScopedFileHandle</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#a7987df05e1260e6d8d93ee3a21e9b0eb" title="Wraps open() or CreateFile(), opening an existing file for reading. ">OpenFileForRead</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#ad8e8848af82384f7757108c8c445f18d" title="Wraps open() or CreateFile(), creating a file for output. ">OpenFileForWrite</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#aab3e964bdba04aaf74e7a27a36efe108" title="Wraps OpenFileForReadAndWrite(), logging an error if the operation fails. ">LoggingOpenFileForReadAndWrite</a> </dd></dl>
</div>
</div>
<a id="ad8e8848af82384f7757108c8c445f18d"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ad8e8848af82384f7757108c8c445f18d">&sect;&nbsp;</a></span>OpenFileForWrite()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a> crashpad::OpenFileForWrite </td>
<td>(</td>
<td class="paramtype">const base::FilePath &amp;&#160;</td>
<td class="paramname"><em>path</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#afa69b0967d9a6df659ff5d2a02ff3e51">FileWriteMode</a>&#160;</td>
<td class="paramname"><em>mode</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a034ccc90eb0d1f587ee89275d822175d">FilePermissions</a>&#160;</td>
<td class="paramname"><em>permissions</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps <code>open()</code> or <code>CreateFile()</code>, creating a file for output. </p>
<p><em>mode</em> determines the style (truncate, reuse, etc.) that is used to open the file. On POSIX, <em>permissions</em> determines the value that is passed as <code>mode</code> to <code>open()</code>. On Windows, the file is always opened in binary mode (that is, no CRLF translation). On Windows, the file is opened for sharing, see <a class="el" href="namespacecrashpad.html#acd02263566d8c43fc7886f88a13b364f" title="Locks the given file using flock() on POSIX or LockFileEx() on Windows. ">LoggingLockFile()</a> and <a class="el" href="namespacecrashpad.html#a15c1f3a2c6f04e944fdca12e22b0cb6e" title="Unlocks a file previously locked with LoggingLockFile(). ">LoggingUnlockFile()</a> to control concurrent access.</p>
<dl class="section return"><dt>Returns</dt><dd>The newly opened FileHandle, or an invalid FileHandle on failure.</dd></dl>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="namespacecrashpad.html#a9daa1b956487883acd9f43d13cc77339" title="Scoped wrapper of a FileHandle. ">ScopedFileHandle</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#a7987df05e1260e6d8d93ee3a21e9b0eb" title="Wraps open() or CreateFile(), opening an existing file for reading. ">OpenFileForRead</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#abe6238b18be49921772c14dd25a624de" title="Wraps open() or CreateFile(), creating a file for both input and output. ">OpenFileForReadAndWrite</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#a62fc6876cc0c660f0ea8bd1dd0a07e82" title="Wraps OpenFileForWrite(), logging an error if the operation fails. ">LoggingOpenFileForWrite</a> </dd></dl>
</div>
</div>
<a id="a2274adc0459f68b93ffe51d8f975f14e"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a2274adc0459f68b93ffe51d8f975f14e">&sect;&nbsp;</a></span>PrepareMIGReplyFromRequest()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void crashpad::PrepareMIGReplyFromRequest </td>
<td>(</td>
<td class="paramtype">const mach_msg_header_t *&#160;</td>
<td class="paramname"><em>in_header</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">mach_msg_header_t *&#160;</td>
<td class="paramname"><em>out_header</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Initializes a reply message for a MIG server routine based on its corresponding request. </p>
<p>If a request is handled by a server routine, it may be necessary to revise some of the fields set by this function, such as <code>msgh_size</code> and any fields defined in a routines reply structure type.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">in_header</td><td>The request message to base the reply on. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">out_header</td><td>The reply message to initialize. <em>out_header</em> will be treated as a <code>mig_reply_error_t*</code> and all of its fields will be set except for <code>RetCode</code>, which must be set by <a class="el" href="namespacecrashpad.html#aa023691aedd4f3e6faa923e8d2095947" title="Sets the error code in a reply message for a MIG server routine. ">SetMIGReplyError()</a>. This argument is accepted as a <code>mach_msg_header_t*</code> instead of a <code>mig_reply_error_t*</code> because that is the type that callers are expected to possess in the C API. </td></tr>
</table>
</dd>
</dl>
</div>
</div>
<a id="a87aa3a36a41939af1166c336db41ec11"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a87aa3a36a41939af1166c336db41ec11">&sect;&nbsp;</a></span>PruneCrashReportDatabase()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void crashpad::PruneCrashReportDatabase </td>
<td>(</td>
<td class="paramtype"><a class="el" href="classcrashpad_1_1CrashReportDatabase.html">CrashReportDatabase</a> *&#160;</td>
<td class="paramname"><em>database</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="classcrashpad_1_1PruneCondition.html">PruneCondition</a> *&#160;</td>
<td class="paramname"><em>condition</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Deletes crash reports from <em>database</em> that match <em>condition</em>. </p>
<p>This function can be used to remove old or large reports from the database. The <em>condition</em> will be evaluated against each report in the <em>database</em>, sorted in descending order by <a class="el" href="structcrashpad_1_1CrashReportDatabase_1_1Report.html#a8011cd1a4b4fcd84ecbc21e5c5fd80b8" title="The time at which the report was generated. ">CrashReportDatabase::Report::creation_time</a>. This guarantee allows conditions to be stateful.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">database</td><td>The database from which crash reports will be deleted. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">condition</td><td>The condition against which all reports in the database will be evaluated. </td></tr>
</table>
</dd>
</dl>
</div>
</div>
<a id="ab15d0aff86a0aafe6f33cbd8913441c7"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ab15d0aff86a0aafe6f33cbd8913441c7">&sect;&nbsp;</a></span>RandomString()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">std::string crashpad::RandomString </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Returns a random string. </p>
<p>The string consists of 16 uppercase characters chosen at random. The returned string has over 75 bits of randomness (26<sup>16</sup> &gt; 2<sup>75</sup>). </p>
</div>
</div>
<a id="a8599600814a17d622766decd5f122a96"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a8599600814a17d622766decd5f122a96">&sect;&nbsp;</a></span>ReadFile()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">FileOperationResult crashpad::ReadFile </td>
<td>(</td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a>&#160;</td>
<td class="paramname"><em>file</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">void *&#160;</td>
<td class="paramname"><em>buffer</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">size_t&#160;</td>
<td class="paramname"><em>size</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Reads from a file, retrying when interrupted on POSIX or following a short read. </p>
<p>This function reads into <em>buffer</em>, stopping only when <em>size</em> bytes have been read or when end-of-file has been reached. On Windows, reading from sockets is not currently supported.</p>
<dl class="section return"><dt>Returns</dt><dd>The number of bytes read and placed into <em>buffer</em>, or <code>-1</code> on error, with <code>errno</code> or <code>GetLastError()</code> set appropriately. On error, a portion of <em>file</em> may have been read into <em>buffer</em>.</dd></dl>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="namespacecrashpad.html#ab9dded3137add283f6cf32facb86641a" title="Writes to a file, retrying when interrupted or following a short write on POSIX. ">WriteFile</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#abd2a51526c1f15e3f21a962457cbc53a" title="Wraps ReadFile(), ensuring that exactly size bytes are read. ">LoggingReadFile</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#aee611c7116746b846a3cf79e65619f4d" title="Wraps ReadFile(), ensuring that exactly size bytes are read. ">CheckedReadFile</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#ac8e7e1b1a4b89b489964ffee54d0d9df" title="Wraps ReadFile(), ensuring that it indicates end-of-file. ">CheckedReadFileAtEOF</a> </dd></dl>
</div>
</div>
<a id="aaccce94b8a0b7b0ada3391216706e599"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aaccce94b8a0b7b0ada3391216706e599">&sect;&nbsp;</a></span>ReadModuleAnnotations()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::ReadModuleAnnotations </td>
<td>(</td>
<td class="paramtype">HANDLE&#160;</td>
<td class="paramname"><em>process</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">HMODULE&#160;</td>
<td class="paramname"><em>module</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">std::map&lt; std::string, std::string &gt; *&#160;</td>
<td class="paramname"><em>annotations</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Reads the module annotations from another process. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">process</td><td>The handle to the process that hosts the <em>module</em>. Requires PROCESS_QUERY_INFORMATION and PROCESS_VM_READ accesses. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">module</td><td>The handle to the module from which the <em>annotations</em> will be read. This module should be loaded in the target process. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">annotations</td><td>The map that will be filled with the annotations. Remains unchanged if the function returns 'false'.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> if the annotations could be read succesfully, even if the module doesn't contain any annotations. </dd></dl>
</div>
</div>
<a id="ac86f028e5f175cccfcab418346d7bcfe"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ac86f028e5f175cccfcab418346d7bcfe">&sect;&nbsp;</a></span>ReadXattr()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="namespacecrashpad.html#a589b4d9bd6f2233b67148ab6793c3c13">XattrStatus</a> crashpad::ReadXattr </td>
<td>(</td>
<td class="paramtype">const base::FilePath &amp;&#160;</td>
<td class="paramname"><em>file</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const base::StringPiece &amp;&#160;</td>
<td class="paramname"><em>name</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">std::string *&#160;</td>
<td class="paramname"><em>value</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Reads an extended attribute on a file. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">file</td><td>The path to the file. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">name</td><td>The name of the extended attribute to read. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">value</td><td>The value of the attribute.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>XattrStatus </dd></dl>
</div>
</div>
<a id="ab8c682ff6d5f00ca828640a72436e196"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ab8c682ff6d5f00ca828640a72436e196">&sect;&nbsp;</a></span>ReadXattrBool()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="namespacecrashpad.html#a589b4d9bd6f2233b67148ab6793c3c13">XattrStatus</a> crashpad::ReadXattrBool </td>
<td>(</td>
<td class="paramtype">const base::FilePath &amp;&#160;</td>
<td class="paramname"><em>file</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const base::StringPiece &amp;&#160;</td>
<td class="paramname"><em>name</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">bool *&#160;</td>
<td class="paramname"><em>value</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Reads an extended attribute on a file. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">file</td><td>The path to the file. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">name</td><td>The name of the extended attribute to read. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">value</td><td>The value of the attribute.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>XattrStatus</dd></dl>
<p>Only the values <code>"0"</code> and <code>"1"</code>, for <code>false</code> and <code>true</code> respectively, are valid conversions. </p>
</div>
</div>
<a id="a0c28700ce2629c13b5b8bb1392625ef4"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a0c28700ce2629c13b5b8bb1392625ef4">&sect;&nbsp;</a></span>ReadXattrInt()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="namespacecrashpad.html#a589b4d9bd6f2233b67148ab6793c3c13">XattrStatus</a> crashpad::ReadXattrInt </td>
<td>(</td>
<td class="paramtype">const base::FilePath &amp;&#160;</td>
<td class="paramname"><em>file</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const base::StringPiece &amp;&#160;</td>
<td class="paramname"><em>name</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">int *&#160;</td>
<td class="paramname"><em>value</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Reads an extended attribute on a file. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">file</td><td>The path to the file. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">name</td><td>The name of the extended attribute to read. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">value</td><td>The value of the attribute.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>XattrStatus </dd></dl>
</div>
</div>
<a id="a71572c94f27aba3f34938d3a0d9030a3"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a71572c94f27aba3f34938d3a0d9030a3">&sect;&nbsp;</a></span>ReadXattrTimeT()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="namespacecrashpad.html#a589b4d9bd6f2233b67148ab6793c3c13">XattrStatus</a> crashpad::ReadXattrTimeT </td>
<td>(</td>
<td class="paramtype">const base::FilePath &amp;&#160;</td>
<td class="paramname"><em>file</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const base::StringPiece &amp;&#160;</td>
<td class="paramname"><em>name</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">time_t *&#160;</td>
<td class="paramname"><em>value</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Reads an extended attribute on a file. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">file</td><td>The path to the file. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">name</td><td>The name of the extended attribute to read. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">value</td><td>The value of the attribute.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>XattrStatus </dd></dl>
</div>
</div>
<a id="a354d84b9ce60fa7d437c2ee6f58ea05f"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a354d84b9ce60fa7d437c2ee6f58ea05f">&sect;&nbsp;</a></span>RemoveXattr()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="namespacecrashpad.html#a589b4d9bd6f2233b67148ab6793c3c13">XattrStatus</a> crashpad::RemoveXattr </td>
<td>(</td>
<td class="paramtype">const base::FilePath &amp;&#160;</td>
<td class="paramname"><em>file</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const base::StringPiece &amp;&#160;</td>
<td class="paramname"><em>name</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Removes an extended attribute from a file. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">file</td><td>The path to the file. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">name</td><td>The name of the extended attribute to remove.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>XattrStatus </dd></dl>
</div>
</div>
<a id="a638d7916642f81df8063d300f08ff2ca"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a638d7916642f81df8063d300f08ff2ca">&sect;&nbsp;</a></span>SendToCrashHandlerServer()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::SendToCrashHandlerServer </td>
<td>(</td>
<td class="paramtype">const base::string16 &amp;&#160;</td>
<td class="paramname"><em>pipe_name</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const <a class="el" href="structcrashpad_1_1ClientToServerMessage.html">ClientToServerMessage</a> &amp;&#160;</td>
<td class="paramname"><em>message</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="unioncrashpad_1_1ServerToClientMessage.html">ServerToClientMessage</a> *&#160;</td>
<td class="paramname"><em>response</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Connect over the given <em>pipe_name</em>, passing <em>message</em> to the server, storing the server's reply into <em>response</em>. </p>
<p>Typically clients will not use this directly, instead using CrashpadClient::SetHandler().</p>
<dl class="section see"><dt>See also</dt><dd>CrashpadClient::SetHandler() </dd></dl>
</div>
</div>
<a id="aead5f04bd94549956a7f2826aeccf495"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aead5f04bd94549956a7f2826aeccf495">&sect;&nbsp;</a></span>ServiceManagementIsJobLoaded()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::ServiceManagementIsJobLoaded </td>
<td>(</td>
<td class="paramtype">const std::string &amp;&#160;</td>
<td class="paramname"><em>label</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Determines whether a specified job is loaded in the user launchd domain. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">label</td><td>The label for the job to look up.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> if the job is loaded, otherwise <code>false</code>.</dd></dl>
<dl class="section note"><dt>Note</dt><dd>A loaded job is not necessarily presently running, nor has it necessarily ever run in the past. </dd>
<dd>
This function is provided because <code>SMJobCopyDictionary()</code> is deprecated in OS X 10.10. It may or may not be implemented using <code>SMJobCopyDictionary()</code> from <code>ServiceManagement.framework</code>. </dd></dl>
</div>
</div>
<a id="a3bc3a94386dd27968d48619f42154463"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a3bc3a94386dd27968d48619f42154463">&sect;&nbsp;</a></span>ServiceManagementIsJobRunning()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">pid_t crashpad::ServiceManagementIsJobRunning </td>
<td>(</td>
<td class="paramtype">const std::string &amp;&#160;</td>
<td class="paramname"><em>label</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Determines whether a specified job is running in the user launchd domain. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">label</td><td>The label for the job to look up.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The jobs process ID if running, otherwise <code>0</code>.</dd></dl>
<dl class="section note"><dt>Note</dt><dd>This function is provided because <code>SMJobCopyDictionary()</code> is deprecated in OS X 10.10. It may or may not be implemented using <code>SMJobCopyDictionary()</code> from <code>ServiceManagement.framework</code>. </dd></dl>
</div>
</div>
<a id="a8cc130fecf996b7d7c76a56200afccb1"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a8cc130fecf996b7d7c76a56200afccb1">&sect;&nbsp;</a></span>ServiceManagementRemoveJob()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::ServiceManagementRemoveJob </td>
<td>(</td>
<td class="paramtype">const std::string &amp;&#160;</td>
<td class="paramname"><em>label</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">bool&#160;</td>
<td class="paramname"><em>wait</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Removes a job from the user launchd domain as in <code>SMJobRemove()</code>. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">label</td><td>The label for the job to remove. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">wait</td><td><code>true</code> if this function should block, waiting for the job to be removed. <code>false</code> if the job may be removed asynchronously.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> if the job was removed successfully or if an asynchronous attempt to remove the job was started successfully, otherwise <code>false</code>.</dd></dl>
<dl class="section note"><dt>Note</dt><dd>This function is provided because <code>SMJobRemove()</code> is deprecated in OS X 10.10. On OS X 10.10, observed in DP8 14A361c, it also blocks for far too long (<code>_block_until_job_exits()</code> contains a one-second <code>sleep()</code>, filed as radar 18398683) and does not signal failure via its return value when asked to remove a nonexistent job (filed as radar 18268941). </dd></dl>
</div>
</div>
<a id="a97ebbbac4c7f27e2e3ba2b9c080ed0f3"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a97ebbbac4c7f27e2e3ba2b9c080ed0f3">&sect;&nbsp;</a></span>ServiceManagementSubmitJob()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::ServiceManagementSubmitJob </td>
<td>(</td>
<td class="paramtype">CFDictionaryRef&#160;</td>
<td class="paramname"><em>job_cf</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Submits a job to the user launchd domain as in <code>SMJobSubmit()</code>. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">job_cf</td><td>A dictionary describing a job.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> if the job was submitted successfully, otherwise <code>false</code>.</dd></dl>
<dl class="section note"><dt>Note</dt><dd>This function is provided because <code>SMJobSubmit()</code> is deprecated in OS X 10.10. It may or may not be implemented using <code>SMJobSubmit()</code> from <code>ServiceManagement.framework</code>. </dd></dl>
</div>
</div>
<a id="aa023691aedd4f3e6faa923e8d2095947"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aa023691aedd4f3e6faa923e8d2095947">&sect;&nbsp;</a></span>SetMIGReplyError()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void crashpad::SetMIGReplyError </td>
<td>(</td>
<td class="paramtype">mach_msg_header_t *&#160;</td>
<td class="paramname"><em>out_header</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">kern_return_t&#160;</td>
<td class="paramname"><em>error</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Sets the error code in a reply message for a MIG server routine. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in,out]</td><td class="paramname">out_header</td><td>The reply message to operate on. <em>out_header</em> will be treated as a <code>mig_reply_error_t*</code> and its <code>RetCode</code> field will be set. This argument is accepted as a <code>mach_msg_header_t*</code> instead of a <code>mig_reply_error_t*</code> because that is the type that callers are expected to possess in the C API. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">error</td><td>The error code to store in <em>out_header</em>.</td></tr>
</table>
</dd>
</dl>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="namespacecrashpad.html#a2274adc0459f68b93ffe51d8f975f14e" title="Initializes a reply message for a MIG server routine based on its corresponding request. ">PrepareMIGReplyFromRequest()</a> </dd></dl>
</div>
</div>
<a id="a97b946d80de148d1fd2452af38b220f4"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a97b946d80de148d1fd2452af38b220f4">&sect;&nbsp;</a></span>SignalToString()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">std::string crashpad::SignalToString </td>
<td>(</td>
<td class="paramtype">int&#160;</td>
<td class="paramname"><em>signal</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a0f13feba965ef7750b3d49064936e5ee">SymbolicConstantToStringOptions</a>&#160;</td>
<td class="paramname"><em>options</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Converts a POSIX signal value to a textual representation. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">signal</td><td>The signal value to convert. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">options</td><td>Options affecting the conversion. <a class="el" href="namespacecrashpad.html#a7856b82b71167792ea6103debb5105eda18aa149c3471a5129274df2af6972f04" title="Use | to combine values in a bitfield. ">kUseOr</a> is ignored. For <a class="el" href="namespacecrashpad.html#a7856b82b71167792ea6103debb5105edaf9da07820c9857c86422b70c3cc33c12" title="If no symbolic name is known for a given constant, return a numeric string. ">kUnknownIsNumeric</a>, the format is <code>"%d"</code>.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The converted string. </dd></dl>
</div>
</div>
<a id="a45a44a5552e00ceaf0917f94433ac104"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a45a44a5552e00ceaf0917f94433ac104">&sect;&nbsp;</a></span>SimulateCrash()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void crashpad::SimulateCrash </td>
<td>(</td>
<td class="paramtype">const NativeCPUContext &amp;&#160;</td>
<td class="paramname"><em>cpu_context</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Simulates a exception without crashing. </p>
<p>This function searches for an <code>EXC_CRASH</code> handler in the same manner that the kernel does, and sends it an exception message to that handler in the format that the handler expects, considering the behavior and thread state flavor that are registered for it. The exception sent to the handler will be <a class="el" href="namespacecrashpad.html#ad22bbde846a82173474ba002116c325c" title="An exception type to use for simulated exceptions. ">kMachExceptionSimulated</a>, not <code>EXC_CRASH</code>.</p>
<p>Typically, the <a class="el" href="simulate__crash__mac_8h.html#a0ac6f4df5ed356f04dd12be3f07f9ed2" title="Captures the CPU context and simulates an exception without crashing. ">CRASHPAD_SIMULATE_CRASH()</a> macro will be used in preference to this function, because it combines the context-capture operation with the raising of a simulated exception.</p>
<p>This function returns normally after the exception message is processed. If no valid handler was found, or no handler processed the exception successfully, a warning will be logged, but these conditions are not considered fatal.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">cpu_context</td><td>The thread state to pass to the exception handler as the exception context, provided that it is compatible with the thread state flavor that the exception handler accepts. If it is not compatible, the correct thread state for the handler will be obtained by calling <code>thread_get_state()</code>. </td></tr>
</table>
</dd>
</dl>
</div>
</div>
<a id="a8f1db976c6e43d3731c26df569368592"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a8f1db976c6e43d3731c26df569368592">&sect;&nbsp;</a></span>SleepNanoseconds()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void crashpad::SleepNanoseconds </td>
<td>(</td>
<td class="paramtype">uint64_t&#160;</td>
<td class="paramname"><em>nanoseconds</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Sleeps for the specified duration. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">nanoseconds</td><td>The number of nanoseconds to sleep. The actual sleep may be slightly longer due to latencies and timer resolution.</td></tr>
</table>
</dd>
</dl>
<p>This function is resilient against the underlying <code>nanosleep()</code> system call being interrupted by a signal. </p>
</div>
</div>
<a id="abb5d05de37d3f1a92ce36c3ce37842b7"></a>
<h2 class="memtitle"><span class="permalink"><a href="#abb5d05de37d3f1a92ce36c3ce37842b7">&sect;&nbsp;</a></span>SplitString()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">std::vector&lt; std::string &gt; crashpad::SplitString </td>
<td>(</td>
<td class="paramtype">const std::string &amp;&#160;</td>
<td class="paramname"><em>string</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">char&#160;</td>
<td class="paramname"><em>delimiter</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Splits a string into multiple parts on the given delimiter. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">string</td><td>The string to split. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">delimiter</td><td>The delimiter to split at.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The individual parts of the string. </dd></dl>
</div>
</div>
<a id="a1b3aaf00fdc6fef366afb2a00062c97f"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a1b3aaf00fdc6fef366afb2a00062c97f">&sect;&nbsp;</a></span>SplitStringFirst()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::SplitStringFirst </td>
<td>(</td>
<td class="paramtype">const std::string &amp;&#160;</td>
<td class="paramname"><em>string</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">char&#160;</td>
<td class="paramname"><em>delimiter</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">std::string *&#160;</td>
<td class="paramname"><em>left</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">std::string *&#160;</td>
<td class="paramname"><em>right</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Splits a string into two parts at the first delimiter found. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">string</td><td>The string to split. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">delimiter</td><td>The delimiter to split at. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">left</td><td>The portion of <em>string</em> up to, but not including, the first <em>delimiter</em> character. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">right</td><td>The portion of <em>string</em> after the first <em>delimiter</em> character.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> if <em>string</em> was split successfully. <code>false</code> if <em>string</em> did not contain a <em>delimiter</em> character or began with a <em>delimiter</em> character. </dd></dl>
</div>
</div>
<a id="a229a9b5ddd24c6722e413e6132d0acf0"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a229a9b5ddd24c6722e413e6132d0acf0">&sect;&nbsp;</a></span>StringToException()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::StringToException </td>
<td>(</td>
<td class="paramtype">const base::StringPiece &amp;&#160;</td>
<td class="paramname"><em>string</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a14f1de509869f929122998a2f88f08a6">StringToSymbolicConstantOptions</a>&#160;</td>
<td class="paramname"><em>options</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">exception_type_t *&#160;</td>
<td class="paramname"><em>exception</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Converts a string to its corresponding Mach exception value. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">string</td><td>The string to convert. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">options</td><td>Options affecting the conversion. <a class="el" href="namespacecrashpad.html#a8387ad067a7e6a1735ab97a1af450d2ba060cbf403d47785a69b249e9c562f410" title="Allow | to combine values in a bitfield. ">kAllowOr</a> is ignored. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">exception</td><td>The converted Mach exception value.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> on success, <code>false</code> if <em>string</em> could not be converted as requested. </dd></dl>
</div>
</div>
<a id="a957c7de6eb716bf1662c08333b1f7e21"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a957c7de6eb716bf1662c08333b1f7e21">&sect;&nbsp;</a></span>StringToExceptionBehavior()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::StringToExceptionBehavior </td>
<td>(</td>
<td class="paramtype">const base::StringPiece &amp;&#160;</td>
<td class="paramname"><em>string</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a14f1de509869f929122998a2f88f08a6">StringToSymbolicConstantOptions</a>&#160;</td>
<td class="paramname"><em>options</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">exception_behavior_t *&#160;</td>
<td class="paramname"><em>behavior</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Converts a string to its corresponding Mach exception behavior value. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">string</td><td>The string to convert. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">options</td><td>Options affecting the conversion. <a class="el" href="namespacecrashpad.html#a8387ad067a7e6a1735ab97a1af450d2ba060cbf403d47785a69b249e9c562f410" title="Allow | to combine values in a bitfield. ">kAllowOr</a> is ignored. <code>MACH_EXCEPTION_CODES</code> can always be ORed in, but no other values can be ORed with each other. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">behavior</td><td>The converted Mach exception behavior value.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> on success, <code>false</code> if <em>string</em> could not be converted as requested. </dd></dl>
</div>
</div>
<a id="a7ab63868a738f3bfd4d2449e60607dec"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a7ab63868a738f3bfd4d2449e60607dec">&sect;&nbsp;</a></span>StringToExceptionMask()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::StringToExceptionMask </td>
<td>(</td>
<td class="paramtype">const base::StringPiece &amp;&#160;</td>
<td class="paramname"><em>string</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a14f1de509869f929122998a2f88f08a6">StringToSymbolicConstantOptions</a>&#160;</td>
<td class="paramname"><em>options</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">exception_mask_t *&#160;</td>
<td class="paramname"><em>exception_mask</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Converts a string to its corresponding Mach exception mask value. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">string</td><td>The string to convert. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">options</td><td>Options affecting the conversion. <a class="el" href="namespacecrashpad.html#a8387ad067a7e6a1735ab97a1af450d2ba060cbf403d47785a69b249e9c562f410" title="Allow | to combine values in a bitfield. ">kAllowOr</a> is honored. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">exception_mask</td><td>The converted Mach exception mask value.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> on success, <code>false</code> if <em>string</em> could not be converted as requested. </dd></dl>
</div>
</div>
<a id="ab269ab8edf326666ef7056a18f4a67c4"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ab269ab8edf326666ef7056a18f4a67c4">&sect;&nbsp;</a></span>StringToNumber() <span class="overload">[1/3]</span></h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::StringToNumber </td>
<td>(</td>
<td class="paramtype">const base::StringPiece &amp;&#160;</td>
<td class="paramname"><em>string</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">int *&#160;</td>
<td class="paramname"><em>number</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Convert a string to a number. </p>
<p>A conversion will only be performed if it can be done perfectly: if <em>string</em> contains no leading or trailing characters (including whitespace) other than the number to convert, and does not overflow the targeted data type.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">string</td><td>The string to convert to a number. As in <code>strtol()</code> with a <code>base</code> parameter of <code>0</code>, the string is treated as decimal unless it begins with a <code>"0x"</code> or <code>"0X"</code> prefix, in which case it is treated as hexadecimal, or a <code>"0"</code> prefix, in which case it is treated as octal. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">number</td><td>The converted number. This will only be set if a perfect conversion can be performed.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> if a perfect conversion could be performed, with <em>number</em> set appropriately. <code>false</code> if a perfect conversion was not possible.</dd></dl>
<dl class="section note"><dt>Note</dt><dd>The interface in <code>base/strings/string_number_conversions.h</code> doesnt allow arbitrary bases based on whether the string begins with a prefix indicating its base. The functions here are provided for situations where such prefix recognition is desirable. </dd></dl>
</div>
</div>
<a id="ac76c5a4040c1f8e2878412dd368a4ea2"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ac76c5a4040c1f8e2878412dd368a4ea2">&sect;&nbsp;</a></span>StringToNumber() <span class="overload">[2/3]</span></h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::StringToNumber </td>
<td>(</td>
<td class="paramtype">const base::StringPiece &amp;&#160;</td>
<td class="paramname"><em>string</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">unsigned int *&#160;</td>
<td class="paramname"><em>number</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Convert a string to a number. </p>
<p>A conversion will only be performed if it can be done perfectly: if <em>string</em> contains no leading or trailing characters (including whitespace) other than the number to convert, and does not overflow the targeted data type.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">string</td><td>The string to convert to a number. As in <code>strtol()</code> with a <code>base</code> parameter of <code>0</code>, the string is treated as decimal unless it begins with a <code>"0x"</code> or <code>"0X"</code> prefix, in which case it is treated as hexadecimal, or a <code>"0"</code> prefix, in which case it is treated as octal. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">number</td><td>The converted number. This will only be set if a perfect conversion can be performed.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> if a perfect conversion could be performed, with <em>number</em> set appropriately. <code>false</code> if a perfect conversion was not possible.</dd></dl>
<dl class="section note"><dt>Note</dt><dd>The interface in <code>base/strings/string_number_conversions.h</code> doesnt allow arbitrary bases based on whether the string begins with a prefix indicating its base. The functions here are provided for situations where such prefix recognition is desirable. </dd></dl>
</div>
</div>
<a id="a0d7e404d4414f4a6dd7c00f3ac2920e9"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a0d7e404d4414f4a6dd7c00f3ac2920e9">&sect;&nbsp;</a></span>StringToNumber() <span class="overload">[3/3]</span></h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::StringToNumber </td>
<td>(</td>
<td class="paramtype">const base::StringPiece &amp;&#160;</td>
<td class="paramname"><em>string</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">uint64_t *&#160;</td>
<td class="paramname"><em>number</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Convert a string to a number. </p>
<p>A conversion will only be performed if it can be done perfectly: if <em>string</em> contains no leading or trailing characters (including whitespace) other than the number to convert, and does not overflow the targeted data type.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">string</td><td>The string to convert to a number. As in <code>strtol()</code> with a <code>base</code> parameter of <code>0</code>, the string is treated as decimal unless it begins with a <code>"0x"</code> or <code>"0X"</code> prefix, in which case it is treated as hexadecimal, or a <code>"0"</code> prefix, in which case it is treated as octal. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">number</td><td>The converted number. This will only be set if a perfect conversion can be performed.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> if a perfect conversion could be performed, with <em>number</em> set appropriately. <code>false</code> if a perfect conversion was not possible.</dd></dl>
<dl class="section note"><dt>Note</dt><dd>The interface in <code>base/strings/string_number_conversions.h</code> doesnt allow arbitrary bases based on whether the string begins with a prefix indicating its base. The functions here are provided for situations where such prefix recognition is desirable. </dd></dl>
</div>
</div>
<a id="a6249dd58c6a81b300d64b25a943fa25c"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a6249dd58c6a81b300d64b25a943fa25c">&sect;&nbsp;</a></span>StringToSignal()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::StringToSignal </td>
<td>(</td>
<td class="paramtype">const base::StringPiece &amp;&#160;</td>
<td class="paramname"><em>string</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a14f1de509869f929122998a2f88f08a6">StringToSymbolicConstantOptions</a>&#160;</td>
<td class="paramname"><em>options</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">int *&#160;</td>
<td class="paramname"><em>signal</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Converts a string to its corresponding POSIX signal value. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">string</td><td>The string to convert. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">options</td><td>Options affecting the conversion. <a class="el" href="namespacecrashpad.html#a8387ad067a7e6a1735ab97a1af450d2ba060cbf403d47785a69b249e9c562f410" title="Allow | to combine values in a bitfield. ">kAllowOr</a> is ignored. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">signal</td><td>The converted POSIX signal value.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> on success, <code>false</code> if <em>string</em> could not be converted as requested. </dd></dl>
</div>
</div>
<a id="a2fdb1f659a2813e80d5b644020a44208"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a2fdb1f659a2813e80d5b644020a44208">&sect;&nbsp;</a></span>StringToThreadStateFlavor()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::StringToThreadStateFlavor </td>
<td>(</td>
<td class="paramtype">const base::StringPiece &amp;&#160;</td>
<td class="paramname"><em>string</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a14f1de509869f929122998a2f88f08a6">StringToSymbolicConstantOptions</a>&#160;</td>
<td class="paramname"><em>options</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">thread_state_flavor_t *&#160;</td>
<td class="paramname"><em>flavor</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Converts a string to its corresponding thread state flavor value. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">string</td><td>The string to convert. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">options</td><td>Options affecting the conversion. <a class="el" href="namespacecrashpad.html#a8387ad067a7e6a1735ab97a1af450d2ba060cbf403d47785a69b249e9c562f410" title="Allow | to combine values in a bitfield. ">kAllowOr</a> is ignored. </td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">flavor</td><td>The converted thread state flavor value.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> on success, <code>false</code> if <em>string</em> could not be converted as requested. </dd></dl>
</div>
</div>
<a id="ac8605dea4710c2630ccdd21439e05999"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ac8605dea4710c2630ccdd21439e05999">&sect;&nbsp;</a></span>strnlen()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">size_t crashpad::strnlen </td>
<td>(</td>
<td class="paramtype">const char *&#160;</td>
<td class="paramname"><em>string</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">size_t&#160;</td>
<td class="paramname"><em>max_length</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Returns the length of a string, not to exceed a maximum. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">string</td><td>The string whose length is to be calculated. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">max_length</td><td>The maximum length to return.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The length of <em>string</em>, determined as the index of the first <code>NUL</code> byte found, not exceeding <em>max_length</em>.</dd></dl>
<dl class="section note"><dt>Note</dt><dd>This function is provided because it was introduced in POSIX.1-2008, and not all systems standard libraries provide an implementation. </dd></dl>
</div>
</div>
<a id="a47204f3a62646651e8f393cac2a6316b"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a47204f3a62646651e8f393cac2a6316b">&sect;&nbsp;</a></span>SystemCrashReporterHandler()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">base::mac::ScopedMachSendRight crashpad::SystemCrashReporterHandler </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Obtains the systems default Mach exception handler for crash-type exceptions. </p>
<p>This is obtained by looking up <code>"com.apple.ReportCrash"</code> with the bootstrap server. The service name comes from the first launch agent loaded by <code>launchd</code> with a <code>MachServices</code> entry having <code>ExceptionServer</code> set. This launch agent is normally loaded from <code>/System/Library/LaunchAgents/com.apple.ReportCrash.plist</code>.</p>
<dl class="section return"><dt>Returns</dt><dd>On success, a send right to an <code>exception_handler_t</code> corresponding to the systems default crash reporter. On failure, <code>MACH_PORT_NULL</code>, with a message logged. </dd></dl>
</div>
</div>
<a id="aeff94a266a84248b3ff0defae01efd8d"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aeff94a266a84248b3ff0defae01efd8d">&sect;&nbsp;</a></span>TaskForPID()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">task_t crashpad::TaskForPID </td>
<td>(</td>
<td class="paramtype">pid_t&#160;</td>
<td class="paramname"><em>pid</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Wraps <code>task_for_pid()</code>. </p>
<p>This function exists to support <code>task_for_pid()</code> access checks in a setuid environment. Normally, <code>task_for_pid()</code> can only return an arbitrary tasks port when running as root or when taskgated(8) approves. When not running as root, a series of access checks are perfomed to ensure that the running process has permission to obtain the other process task port.</p>
<p>It is possible to make an executable setuid root to give it broader <code>task_for_pid()</code> access by bypassing taskgated(8) checks, but this also has the effect of bypassing the access checks, allowing any process task port to be obtained. In most situations, these access checks are desirable to prevent security and privacy breaches.</p>
<p>When running as setuid root, this function wraps <code>task_for_pid()</code>, reimplementing those access checks. A process whose effective user ID is 0 and whose real user ID is nonzero is understood to be running setuid root. In this case, the requested tasks real, effective, and saved set-user IDs must all equal the running process real user ID, the requested task must not have changed privileges, and the requested tasks set of all group IDs (including its real, effective, and saved set-group IDs and supplementary group list) must be a subset of the running process set of all group IDs. These access checks mimic those that the kernel performs.</p>
<p>When not running as setuid root, <code>task_for_pid()</code> is called directly, without imposing any additional checks beyond what the kernel does.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">pid</td><td>The process ID of the task whose task port is desired.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>A send right to the task port if it could be obtained, or <code>TASK_NULL</code> otherwise, with an error message logged. If a send right is returned, the caller takes ownership of it. </dd></dl>
</div>
</div>
<a id="a857f6b2f39cb21b22891242df26757e0"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a857f6b2f39cb21b22891242df26757e0">&sect;&nbsp;</a></span>ThreadStateFlavorToString()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">std::string crashpad::ThreadStateFlavorToString </td>
<td>(</td>
<td class="paramtype">thread_state_flavor_t&#160;</td>
<td class="paramname"><em>flavor</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a0f13feba965ef7750b3d49064936e5ee">SymbolicConstantToStringOptions</a>&#160;</td>
<td class="paramname"><em>options</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Converts a thread state flavor value to a textual representation. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">flavor</td><td>The thread state flavor value to convert. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">options</td><td>Options affecting the conversion. <a class="el" href="namespacecrashpad.html#a7856b82b71167792ea6103debb5105eda18aa149c3471a5129274df2af6972f04" title="Use | to combine values in a bitfield. ">kUseOr</a> is ignored. For <a class="el" href="namespacecrashpad.html#a7856b82b71167792ea6103debb5105edaf9da07820c9857c86422b70c3cc33c12" title="If no symbolic name is known for a given constant, return a numeric string. ">kUnknownIsNumeric</a>, the format is <code>"%d"</code>.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The converted string. </dd></dl>
</div>
</div>
<a id="a34001ec0bfa5e0815fa478a8cf025c61"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a34001ec0bfa5e0815fa478a8cf025c61">&sect;&nbsp;</a></span>UniversalExceptionRaise()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">kern_return_t crashpad::UniversalExceptionRaise </td>
<td>(</td>
<td class="paramtype">exception_behavior_t&#160;</td>
<td class="paramname"><em>behavior</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">exception_handler_t&#160;</td>
<td class="paramname"><em>exception_port</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">thread_t&#160;</td>
<td class="paramname"><em>thread</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">task_t&#160;</td>
<td class="paramname"><em>task</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">exception_type_t&#160;</td>
<td class="paramname"><em>exception</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const mach_exception_data_type_t *&#160;</td>
<td class="paramname"><em>code</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">mach_msg_type_number_t&#160;</td>
<td class="paramname"><em>code_count</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">thread_state_flavor_t *&#160;</td>
<td class="paramname"><em>flavor</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a72fa9ea632f7f1ec93ec3c1b1d300db6">ConstThreadState</a>&#160;</td>
<td class="paramname"><em>old_state</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">mach_msg_type_number_t&#160;</td>
<td class="paramname"><em>old_state_count</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">thread_state_t&#160;</td>
<td class="paramname"><em>new_state</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">mach_msg_type_number_t *&#160;</td>
<td class="paramname"><em>new_state_count</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Calls the appropriate <code>*exception_raise*()</code> function for the specified <em>behavior</em>. </p>
<p>The function called will be <code>exception_raise()</code> for <code>EXCEPTION_DEFAULT</code>, <code>exception_raise_state()</code> for <code>EXCEPTION_STATE</code>, or <code>exception_raise_state_identity()</code> for <code>EXCEPTION_STATE_IDENTITY</code>. If <code>MACH_EXCEPTION_CODES</code> is also set, the function called will instead be <code>mach_exception_raise()</code>, <code>mach_exception_raise_state()</code> or <code>mach_exception_raise_state_identity()</code>, respectively.</p>
<p>This function does not fetch the existing thread state for <em>behavior</em> values that require a thread state. The caller must provide the existing thread state in the <em>flavor</em>, <em>old_state</em>, and <em>old_state_count</em> parameters for <em>behavior</em> values that require a thread state. <a class="el" href="classcrashpad_1_1Thread.html" title="Basic thread abstraction. Users should derive from this class and implement ThreadMain(). ">Thread</a> states may be obtained by calling <code>thread_get_state()</code> if needed. Similarly, this function does not do anything with the new thread state returned for these <em>behavior</em> values. Callers that wish to make use of the new thread state may do so by using the returned <em>flavor</em>, <em>new_state</em>, and <em>new_state_count</em> values. <a class="el" href="classcrashpad_1_1Thread.html" title="Basic thread abstraction. Users should derive from this class and implement ThreadMain(). ">Thread</a> states may be set by calling <code>thread_set_state()</code> if needed.</p>
<p><em>thread</em> and <em>task</em> are only used when <em>behavior</em> indicates that the exception message will carry identity information, when it has the value value <code>EXCEPTION_DEFAULT</code> or <code>EXCEPTION_STATE_IDENTITY</code>, possibly with <code>MACH_EXCEPTION_CODES</code> also set. In other cases, these parameters are unused and may be set to <code>THREAD_NULL</code> and <code>TASK_NULL</code>, respectively.</p>
<p><em>flavor</em>, <em>old_state</em>, <em>old_state_count</em>, <em>new_state</em>, and <em>new_state_count</em> are only used when <em>behavior</em> indicates that the exception message will carry thread state information, when it has the value <code>EXCEPTION_STATE</code> or <code>EXCEPTION_STATE_IDENTITY</code>, possibly with <code>MACH_EXCEPTION_CODES</code> also set. In other cases, these parameters are unused and may be set to <code>0</code> (<em>old_state_count</em>) or <code>nullptr</code> (the remaining parameters).</p>
<p>Except as noted, the parameters and return value are equivalent to those of the <code>*exception_raise*()</code> family of functions.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">behavior</td><td>The exception behavior, which dictates which function will be called. It is an error to call this function with an invalid value for <em>behavior</em>. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">exception_port</td><td></td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">thread</td><td></td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">task</td><td></td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">exception</td><td></td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">code</td><td>If <em>behavior</em> indicates a behavior without <code>MACH_EXCEPTION_CODES</code>, the elements of <em>code</em> will be truncated in order to be passed to the appropriate exception handler. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">code_count</td><td></td></tr>
<tr><td class="paramdir">[in,out]</td><td class="paramname">flavor</td><td></td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">old_state</td><td></td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">old_state_count</td><td></td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">new_state</td><td></td></tr>
<tr><td class="paramdir">[out]</td><td class="paramname">new_state_count</td><td></td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The return value of the function called. </dd></dl>
</div>
</div>
<a id="ab9dded3137add283f6cf32facb86641a"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ab9dded3137add283f6cf32facb86641a">&sect;&nbsp;</a></span>WriteFile()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">FileOperationResult crashpad::WriteFile </td>
<td>(</td>
<td class="paramtype"><a class="el" href="namespacecrashpad.html#a07f8e33c4fdeba3783277f9f2563e48a">FileHandle</a>&#160;</td>
<td class="paramname"><em>file</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const void *&#160;</td>
<td class="paramname"><em>buffer</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">size_t&#160;</td>
<td class="paramname"><em>size</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Writes to a file, retrying when interrupted or following a short write on POSIX. </p>
<p>This function writes to <em>file</em>, stopping only when <em>size</em> bytes have been written.</p>
<dl class="section return"><dt>Returns</dt><dd>The number of bytes written from <em>buffer</em>, or <code>-1</code> on error, with <code>errno</code> or <code>GetLastError()</code> set appropriately. On error, a portion of <em>buffer</em> may have been written to <em>file</em>.</dd></dl>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="namespacecrashpad.html#a8599600814a17d622766decd5f122a96" title="Reads from a file, retrying when interrupted on POSIX or following a short read. ">ReadFile</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#a8a91af9c690d2a280c463596bf82070b" title="Wraps WriteFile(), ensuring that exactly size bytes are written. ">LoggingWriteFile</a> </dd>
<dd>
<a class="el" href="namespacecrashpad.html#a74c74fefa3b1f5e0c1b885755c9f9cf6" title="Wraps WriteFile(), ensuring that exactly size bytes are written. ">CheckedWriteFile</a> </dd></dl>
</div>
</div>
<a id="a6842e0ae3110f04477765c771c04dc60"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a6842e0ae3110f04477765c771c04dc60">&sect;&nbsp;</a></span>WriteXattr()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::WriteXattr </td>
<td>(</td>
<td class="paramtype">const base::FilePath &amp;&#160;</td>
<td class="paramname"><em>file</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const base::StringPiece &amp;&#160;</td>
<td class="paramname"><em>name</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const std::string &amp;&#160;</td>
<td class="paramname"><em>value</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Writes an extended attribute on a file. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">file</td><td>The path to the file. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">name</td><td>The name of the extended attribute to write. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">value</td><td>The value of the attribute.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> if the write was successful. <code>false</code> on error, with a message logged. </dd></dl>
</div>
</div>
<a id="ae086861e350e7225e4ea065d941e664f"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ae086861e350e7225e4ea065d941e664f">&sect;&nbsp;</a></span>WriteXattrBool()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::WriteXattrBool </td>
<td>(</td>
<td class="paramtype">const base::FilePath &amp;&#160;</td>
<td class="paramname"><em>file</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const base::StringPiece &amp;&#160;</td>
<td class="paramname"><em>name</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">bool&#160;</td>
<td class="paramname"><em>value</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Writes an extended attribute on a file. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">file</td><td>The path to the file. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">name</td><td>The name of the extended attribute to write. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">value</td><td>The value of the attribute.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> if the write was successful. <code>false</code> on error, with a message logged. </dd></dl>
</div>
</div>
<a id="a85a3551184d900a1d970bd8fa0be0ec3"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a85a3551184d900a1d970bd8fa0be0ec3">&sect;&nbsp;</a></span>WriteXattrInt()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::WriteXattrInt </td>
<td>(</td>
<td class="paramtype">const base::FilePath &amp;&#160;</td>
<td class="paramname"><em>file</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const base::StringPiece &amp;&#160;</td>
<td class="paramname"><em>name</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">int&#160;</td>
<td class="paramname"><em>value</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Writes an extended attribute on a file. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">file</td><td>The path to the file. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">name</td><td>The name of the extended attribute to write. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">value</td><td>The value of the attribute.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> if the write was successful. <code>false</code> on error, with a message logged. </dd></dl>
</div>
</div>
<a id="ae63f9a1eeeec00b78c216f72b1ca1327"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ae63f9a1eeeec00b78c216f72b1ca1327">&sect;&nbsp;</a></span>WriteXattrTimeT()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool crashpad::WriteXattrTimeT </td>
<td>(</td>
<td class="paramtype">const base::FilePath &amp;&#160;</td>
<td class="paramname"><em>file</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const base::StringPiece &amp;&#160;</td>
<td class="paramname"><em>name</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">time_t&#160;</td>
<td class="paramname"><em>value</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Writes an extended attribute on a file. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramdir">[in]</td><td class="paramname">file</td><td>The path to the file. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">name</td><td>The name of the extended attribute to write. </td></tr>
<tr><td class="paramdir">[in]</td><td class="paramname">value</td><td>The value of the attribute.</td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><code>true</code> if the write was successful. <code>false</code> on error, with a message logged. </dd></dl>
</div>
</div>
<h2 class="groupheader">Variable Documentation</h2>
<a id="a7dbcba9449a5dd47d2911b1f85bc1a58"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a7dbcba9449a5dd47d2911b1f85bc1a58">&sect;&nbsp;</a></span>kMachExceptionCodes</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">const exception_behavior_t crashpad::kMachExceptionCodes = MACH_EXCEPTION_CODES</td>
</tr>
</table>
</div><div class="memdoc">
<p><code>MACH_EXCEPTION_CODES</code> with the correct type for a Mach exception behavior, <code>exception_behavior_t</code>. </p>
<p>Signedness problems can occur when ORing <code>MACH_EXCEPTION_CODES</code> as a signed integer, because a signed integer overflow results. This constant can be used instead of <code>MACH_EXCEPTION_CODES</code> in such cases. </p>
</div>
</div>
<a id="a2673983f0177685e048be73ee578eddb"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a2673983f0177685e048be73ee578eddb">&sect;&nbsp;</a></span>kMachMessageReceiveAuditTrailer</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">const mach_msg_option_t crashpad::kMachMessageReceiveAuditTrailer</td>
</tr>
</table>
</div><div class="memdoc">
<b>Initial value:</b><div class="fragment"><div class="line">=</div><div class="line"> MACH_RCV_TRAILER_TYPE(MACH_MSG_TRAILER_FORMAT_0) |</div><div class="line"> MACH_RCV_TRAILER_ELEMENTS(MACH_RCV_TRAILER_AUDIT)</div></div><!-- fragment -->
<p>A Mach message option specifying that an audit trailer should be delivered during a receive operation. </p>
<p>This constant is provided because the macros normally used to request this behavior are cumbersome. </p>
</div>
</div>
<a id="a7c7b6c8b4f44c95c7f0fb70a56342277"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a7c7b6c8b4f44c95c7f0fb70a56342277">&sect;&nbsp;</a></span>kMachPortNull</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">const mach_port_t crashpad::kMachPortNull = MACH_PORT_NULL</td>
</tr>
</table>
</div><div class="memdoc">
<p><code>MACH_PORT_NULL</code> with the correct type for a Mach port, <code>mach_port_t</code>. </p>
<p>For situations where implicit conversions between signed and unsigned types are not performed, use kMachPortNull instead of an explicit <code>implicit_cast</code> of <code>MACH_PORT_NULL</code> to <code>mach_port_t</code>. This is useful for logging and testing assertions. </p>
</div>
</div>
</div><!-- contents -->
<!-- start footer part -->
<hr class="footer"/><address class="footer"><small>
Generated by &#160;<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/>
</a> 1.8.12
</small></address>
</body>
</html>