|  | <!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.6"/> | 
|  | <title>Impala: impala::SimpleMetric< T, metric_kind > Class Template 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="navtree.css" rel="stylesheet" type="text/css"/> | 
|  | <script type="text/javascript" src="resize.js"></script> | 
|  | <script type="text/javascript" src="navtree.js"></script> | 
|  | <script type="text/javascript"> | 
|  | $(document).ready(initResizable); | 
|  | $(window).load(resizeHeight); | 
|  | </script> | 
|  | <link href="search/search.css" rel="stylesheet" type="text/css"/> | 
|  | <script type="text/javascript" src="search/search.js"></script> | 
|  | <script type="text/javascript"> | 
|  | $(document).ready(function() { searchBox.OnSelectItem(0); }); | 
|  | </script> | 
|  | <link href="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 style="padding-left: 0.5em;"> | 
|  | <div id="projectname">Impala | 
|  | </div> | 
|  | <div id="projectbrief">Impalaistheopensource,nativeanalyticdatabaseforApacheHadoop.</div> | 
|  | </td> | 
|  | </tr> | 
|  | </tbody> | 
|  | </table> | 
|  | </div> | 
|  | <!-- end header part --> | 
|  | <!-- Generated by Doxygen 1.8.6 --> | 
|  | <script type="text/javascript"> | 
|  | var searchBox = new SearchBox("searchBox", "search",false,'Search'); | 
|  | </script> | 
|  | <div id="navrow1" class="tabs"> | 
|  | <ul class="tablist"> | 
|  | <li><a href="index.html"><span>Main Page</span></a></li> | 
|  | <li><a href="namespaces.html"><span>Namespaces</span></a></li> | 
|  | <li class="current"><a href="annotated.html"><span>Classes</span></a></li> | 
|  | <li><a href="files.html"><span>Files</span></a></li> | 
|  | <li> | 
|  | <div id="MSearchBox" class="MSearchBoxInactive"> | 
|  | <span class="left"> | 
|  | <img id="MSearchSelect" src="search/mag_sel.png" | 
|  | onmouseover="return searchBox.OnSearchSelectShow()" | 
|  | onmouseout="return searchBox.OnSearchSelectHide()" | 
|  | alt=""/> | 
|  | <input type="text" id="MSearchField" value="Search" accesskey="S" | 
|  | onfocus="searchBox.OnSearchFieldFocus(true)" | 
|  | onblur="searchBox.OnSearchFieldFocus(false)" | 
|  | onkeyup="searchBox.OnSearchFieldChange(event)"/> | 
|  | </span><span class="right"> | 
|  | <a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a> | 
|  | </span> | 
|  | </div> | 
|  | </li> | 
|  | </ul> | 
|  | </div> | 
|  | <div id="navrow2" class="tabs2"> | 
|  | <ul class="tablist"> | 
|  | <li><a href="annotated.html"><span>Class List</span></a></li> | 
|  | <li><a href="classes.html"><span>Class Index</span></a></li> | 
|  | <li><a href="inherits.html"><span>Class Hierarchy</span></a></li> | 
|  | <li><a href="functions.html"><span>Class Members</span></a></li> | 
|  | </ul> | 
|  | </div> | 
|  | </div><!-- top --> | 
|  | <div id="side-nav" class="ui-resizable side-nav-resizable"> | 
|  | <div id="nav-tree"> | 
|  | <div id="nav-tree-contents"> | 
|  | <div id="nav-sync" class="sync"></div> | 
|  | </div> | 
|  | </div> | 
|  | <div id="splitbar" style="-moz-user-select:none;" | 
|  | class="ui-resizable-handle"> | 
|  | </div> | 
|  | </div> | 
|  | <script type="text/javascript"> | 
|  | $(document).ready(function(){initNavTree('classimpala_1_1SimpleMetric.html','');}); | 
|  | </script> | 
|  | <div id="doc-content"> | 
|  | <!-- window showing the filter options --> | 
|  | <div id="MSearchSelectWindow" | 
|  | onmouseover="return searchBox.OnSearchSelectShow()" | 
|  | onmouseout="return searchBox.OnSearchSelectHide()" | 
|  | onkeydown="return searchBox.OnSearchSelectKey(event)"> | 
|  | <a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(0)"><span class="SelectionMark"> </span>All</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(1)"><span class="SelectionMark"> </span>Classes</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(2)"><span class="SelectionMark"> </span>Namespaces</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(3)"><span class="SelectionMark"> </span>Files</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(4)"><span class="SelectionMark"> </span>Functions</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(5)"><span class="SelectionMark"> </span>Variables</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(6)"><span class="SelectionMark"> </span>Typedefs</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(7)"><span class="SelectionMark"> </span>Enumerations</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(8)"><span class="SelectionMark"> </span>Enumerator</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(9)"><span class="SelectionMark"> </span>Friends</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(10)"><span class="SelectionMark"> </span>Macros</a></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 class="header"> | 
|  | <div class="summary"> | 
|  | <a href="#pub-methods">Public Member Functions</a> | | 
|  | <a href="#pro-methods">Protected Member Functions</a> | | 
|  | <a href="#pro-attribs">Protected Attributes</a> | | 
|  | <a href="classimpala_1_1SimpleMetric-members.html">List of all members</a>  </div> | 
|  | <div class="headertitle"> | 
|  | <div class="title">impala::SimpleMetric< T, metric_kind > Class Template Reference</div>  </div> | 
|  | </div><!--header--> | 
|  | <div class="contents"> | 
|  |  | 
|  | <p><code>#include <<a class="el" href="metrics_8h_source.html">metrics.h</a>></code></p> | 
|  | <div class="dynheader"> | 
|  | Inheritance diagram for impala::SimpleMetric< T, metric_kind >:</div> | 
|  | <div class="dyncontent"> | 
|  | <div class="center"><iframe scrolling="no" frameborder="0" src="classimpala_1_1SimpleMetric__inherit__graph.svg" width="163" height="536"><p><b>This browser is not able to show SVG: try Firefox, Chrome, Safari, or Opera instead.</b></p></iframe></div> | 
|  | </div> | 
|  | <div class="dynheader"> | 
|  | Collaboration diagram for impala::SimpleMetric< T, metric_kind >:</div> | 
|  | <div class="dyncontent"> | 
|  | <div class="center"><div class="zoom"><iframe scrolling="no" frameborder="0" src="classimpala_1_1SimpleMetric__coll__graph.svg" width="100%" height="600"><p><b>This browser is not able to show SVG: try Firefox, Chrome, Safari, or Opera instead.</b></p></iframe></div></div> | 
|  | </div> | 
|  | <table class="memberdecls"> | 
|  | <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-methods"></a> | 
|  | Public Member Functions</h2></td></tr> | 
|  | <tr class="memitem:a69a7f8c8b70024ba4ab4292087c327ac"><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="classimpala_1_1SimpleMetric.html#a69a7f8c8b70024ba4ab4292087c327ac">SimpleMetric</a> (const std::string &<a class="el" href="classimpala_1_1Metric.html#a56211a0cc08bb2e10a0c89ebe5b152d9">key</a>, const TUnit::type <a class="el" href="classimpala_1_1SimpleMetric.html#aca0380a54d8c42df8a6fd6d9bf9bf452">unit</a>, const T &initial_value, const std::string &<a class="el" href="classimpala_1_1Metric.html#a80682167db8743e5c8e38e73ad55f0c3">description</a>="")</td></tr> | 
|  | <tr class="separator:a69a7f8c8b70024ba4ab4292087c327ac"><td class="memSeparator" colspan="2"> </td></tr> | 
|  | <tr class="memitem:af5438dfceffb45c462fbaaa6f195fa0f"><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="classimpala_1_1SimpleMetric.html#af5438dfceffb45c462fbaaa6f195fa0f">SimpleMetric</a> (const std::string &<a class="el" href="classimpala_1_1Metric.html#a56211a0cc08bb2e10a0c89ebe5b152d9">key</a>, const TUnit::type <a class="el" href="classimpala_1_1SimpleMetric.html#aca0380a54d8c42df8a6fd6d9bf9bf452">unit</a>, const std::string &<a class="el" href="classimpala_1_1Metric.html#a80682167db8743e5c8e38e73ad55f0c3">description</a>="")</td></tr> | 
|  | <tr class="separator:af5438dfceffb45c462fbaaa6f195fa0f"><td class="memSeparator" colspan="2"> </td></tr> | 
|  | <tr class="memitem:a98684f965400150dbb3c8f78a7bac45e"><td class="memItemLeft" align="right" valign="top">virtual </td><td class="memItemRight" valign="bottom"><a class="el" href="classimpala_1_1SimpleMetric.html#a98684f965400150dbb3c8f78a7bac45e">~SimpleMetric</a> ()</td></tr> | 
|  | <tr class="separator:a98684f965400150dbb3c8f78a7bac45e"><td class="memSeparator" colspan="2"> </td></tr> | 
|  | <tr class="memitem:aee1b3c3e9b4d8f5bd9c8e199cf742572"><td class="memItemLeft" align="right" valign="top">T </td><td class="memItemRight" valign="bottom"><a class="el" href="classimpala_1_1SimpleMetric.html#aee1b3c3e9b4d8f5bd9c8e199cf742572">value</a> ()</td></tr> | 
|  | <tr class="memdesc:aee1b3c3e9b4d8f5bd9c8e199cf742572"><td class="mdescLeft"> </td><td class="mdescRight">Returns the current value, updating it if necessary. Thread-safe.  <a href="#aee1b3c3e9b4d8f5bd9c8e199cf742572">More...</a><br/></td></tr> | 
|  | <tr class="separator:aee1b3c3e9b4d8f5bd9c8e199cf742572"><td class="memSeparator" colspan="2"> </td></tr> | 
|  | <tr class="memitem:a19937427c8bdf7967ffc181f31316763"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classimpala_1_1SimpleMetric.html#a19937427c8bdf7967ffc181f31316763">set_value</a> (const T &<a class="el" href="classimpala_1_1SimpleMetric.html#aee1b3c3e9b4d8f5bd9c8e199cf742572">value</a>)</td></tr> | 
|  | <tr class="memdesc:a19937427c8bdf7967ffc181f31316763"><td class="mdescLeft"> </td><td class="mdescRight">Sets the current value. Thread-safe.  <a href="#a19937427c8bdf7967ffc181f31316763">More...</a><br/></td></tr> | 
|  | <tr class="separator:a19937427c8bdf7967ffc181f31316763"><td class="memSeparator" colspan="2"> </td></tr> | 
|  | <tr class="memitem:acc1207a7d680280aa6bde04c6e7a3fc4"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classimpala_1_1SimpleMetric.html#acc1207a7d680280aa6bde04c6e7a3fc4">Increment</a> (const T &delta)</td></tr> | 
|  | <tr class="memdesc:acc1207a7d680280aa6bde04c6e7a3fc4"><td class="mdescLeft"> </td><td class="mdescRight">Adds 'delta' to the current value atomically.  <a href="#acc1207a7d680280aa6bde04c6e7a3fc4">More...</a><br/></td></tr> | 
|  | <tr class="separator:acc1207a7d680280aa6bde04c6e7a3fc4"><td class="memSeparator" colspan="2"> </td></tr> | 
|  | <tr class="memitem:aa50443609a6867817cede75fd2d936da"><td class="memItemLeft" align="right" valign="top">virtual void </td><td class="memItemRight" valign="bottom"><a class="el" href="classimpala_1_1SimpleMetric.html#aa50443609a6867817cede75fd2d936da">ToJson</a> (rapidjson::Document *document, rapidjson::Value *val)</td></tr> | 
|  | <tr class="memdesc:aa50443609a6867817cede75fd2d936da"><td class="mdescLeft"> </td><td class="mdescRight">name, value, human_readable, description  <a href="#aa50443609a6867817cede75fd2d936da">More...</a><br/></td></tr> | 
|  | <tr class="separator:aa50443609a6867817cede75fd2d936da"><td class="memSeparator" colspan="2"> </td></tr> | 
|  | <tr class="memitem:a37bc0809743e6448ff026ed379de3d78"><td class="memItemLeft" align="right" valign="top">virtual std::string </td><td class="memItemRight" valign="bottom"><a class="el" href="classimpala_1_1SimpleMetric.html#a37bc0809743e6448ff026ed379de3d78">ToHumanReadable</a> ()</td></tr> | 
|  | <tr class="separator:a37bc0809743e6448ff026ed379de3d78"><td class="memSeparator" colspan="2"> </td></tr> | 
|  | <tr class="memitem:a6555da07dbd5674a3b69a36ec0f7323e"><td class="memItemLeft" align="right" valign="top">virtual void </td><td class="memItemRight" valign="bottom"><a class="el" href="classimpala_1_1SimpleMetric.html#a6555da07dbd5674a3b69a36ec0f7323e">ToLegacyJson</a> (rapidjson::Document *document)</td></tr> | 
|  | <tr class="memdesc:a6555da07dbd5674a3b69a36ec0f7323e"><td class="mdescLeft"> </td><td class="mdescRight">This method is kept for backwards-compatibility with CM5.0.  <a href="#a6555da07dbd5674a3b69a36ec0f7323e">More...</a><br/></td></tr> | 
|  | <tr class="separator:a6555da07dbd5674a3b69a36ec0f7323e"><td class="memSeparator" colspan="2"> </td></tr> | 
|  | <tr class="memitem:aca0380a54d8c42df8a6fd6d9bf9bf452"><td class="memItemLeft" align="right" valign="top">const TUnit::type </td><td class="memItemRight" valign="bottom"><a class="el" href="classimpala_1_1SimpleMetric.html#aca0380a54d8c42df8a6fd6d9bf9bf452">unit</a> () const </td></tr> | 
|  | <tr class="separator:aca0380a54d8c42df8a6fd6d9bf9bf452"><td class="memSeparator" colspan="2"> </td></tr> | 
|  | <tr class="memitem:ac14b5c3b6778acb0de85b297e8bba2aa"><td class="memItemLeft" align="right" valign="top">const TMetricKind::type </td><td class="memItemRight" valign="bottom"><a class="el" href="classimpala_1_1SimpleMetric.html#ac14b5c3b6778acb0de85b297e8bba2aa">kind</a> () const </td></tr> | 
|  | <tr class="separator:ac14b5c3b6778acb0de85b297e8bba2aa"><td class="memSeparator" colspan="2"> </td></tr> | 
|  | <tr class="memitem:a56211a0cc08bb2e10a0c89ebe5b152d9"><td class="memItemLeft" align="right" valign="top">const std::string & </td><td class="memItemRight" valign="bottom"><a class="el" href="classimpala_1_1Metric.html#a56211a0cc08bb2e10a0c89ebe5b152d9">key</a> () const </td></tr> | 
|  | <tr class="separator:a56211a0cc08bb2e10a0c89ebe5b152d9"><td class="memSeparator" colspan="2"> </td></tr> | 
|  | <tr class="memitem:a80682167db8743e5c8e38e73ad55f0c3"><td class="memItemLeft" align="right" valign="top">const std::string & </td><td class="memItemRight" valign="bottom"><a class="el" href="classimpala_1_1Metric.html#a80682167db8743e5c8e38e73ad55f0c3">description</a> () const </td></tr> | 
|  | <tr class="separator:a80682167db8743e5c8e38e73ad55f0c3"><td class="memSeparator" colspan="2"> </td></tr> | 
|  | </table><table class="memberdecls"> | 
|  | <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pro-methods"></a> | 
|  | Protected Member Functions</h2></td></tr> | 
|  | <tr class="memitem:ab1253cbe7f6132765b7abcad558e4e06"><td class="memItemLeft" align="right" valign="top">virtual void </td><td class="memItemRight" valign="bottom"><a class="el" href="classimpala_1_1SimpleMetric.html#ab1253cbe7f6132765b7abcad558e4e06">CalculateValue</a> ()</td></tr> | 
|  | <tr class="separator:ab1253cbe7f6132765b7abcad558e4e06"><td class="memSeparator" colspan="2"> </td></tr> | 
|  | <tr class="memitem:a05010f15c634161716da4e8451dba06d"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classimpala_1_1Metric.html#a05010f15c634161716da4e8451dba06d">AddStandardFields</a> (rapidjson::Document *document, rapidjson::Value *val)</td></tr> | 
|  | <tr class="separator:a05010f15c634161716da4e8451dba06d"><td class="memSeparator" colspan="2"> </td></tr> | 
|  | </table><table class="memberdecls"> | 
|  | <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pro-attribs"></a> | 
|  | Protected Attributes</h2></td></tr> | 
|  | <tr class="memitem:a29fa15d10a26cf152194302e76d3f83a"><td class="memItemLeft" align="right" valign="top">const TUnit::type </td><td class="memItemRight" valign="bottom"><a class="el" href="classimpala_1_1SimpleMetric.html#a29fa15d10a26cf152194302e76d3f83a">unit_</a></td></tr> | 
|  | <tr class="memdesc:a29fa15d10a26cf152194302e76d3f83a"><td class="mdescLeft"> </td><td class="mdescRight">Units of this metric.  <a href="#a29fa15d10a26cf152194302e76d3f83a">More...</a><br/></td></tr> | 
|  | <tr class="separator:a29fa15d10a26cf152194302e76d3f83a"><td class="memSeparator" colspan="2"> </td></tr> | 
|  | <tr class="memitem:a59533b22fc8f4ddca90dd16e8be2c29f"><td class="memItemLeft" align="right" valign="top">boost::mutex </td><td class="memItemRight" valign="bottom"><a class="el" href="classimpala_1_1SimpleMetric.html#a59533b22fc8f4ddca90dd16e8be2c29f">lock_</a></td></tr> | 
|  | <tr class="memdesc:a59533b22fc8f4ddca90dd16e8be2c29f"><td class="mdescLeft"> </td><td class="mdescRight">Guards access to value_.  <a href="#a59533b22fc8f4ddca90dd16e8be2c29f">More...</a><br/></td></tr> | 
|  | <tr class="separator:a59533b22fc8f4ddca90dd16e8be2c29f"><td class="memSeparator" colspan="2"> </td></tr> | 
|  | <tr class="memitem:a602d3a314922a977a85fea236bb27399"><td class="memItemLeft" align="right" valign="top">T </td><td class="memItemRight" valign="bottom"><a class="el" href="classimpala_1_1SimpleMetric.html#a602d3a314922a977a85fea236bb27399">value_</a></td></tr> | 
|  | <tr class="memdesc:a602d3a314922a977a85fea236bb27399"><td class="mdescLeft"> </td><td class="mdescRight">The current value of the metric.  <a href="#a602d3a314922a977a85fea236bb27399">More...</a><br/></td></tr> | 
|  | <tr class="separator:a602d3a314922a977a85fea236bb27399"><td class="memSeparator" colspan="2"> </td></tr> | 
|  | <tr class="memitem:abfaeffb213edb0d448f5b07638ee6963"><td class="memItemLeft" align="right" valign="top">const std::string </td><td class="memItemRight" valign="bottom"><a class="el" href="classimpala_1_1Metric.html#abfaeffb213edb0d448f5b07638ee6963">key_</a></td></tr> | 
|  | <tr class="memdesc:abfaeffb213edb0d448f5b07638ee6963"><td class="mdescLeft"> </td><td class="mdescRight">Unique key identifying this metric.  <a href="#abfaeffb213edb0d448f5b07638ee6963">More...</a><br/></td></tr> | 
|  | <tr class="separator:abfaeffb213edb0d448f5b07638ee6963"><td class="memSeparator" colspan="2"> </td></tr> | 
|  | <tr class="memitem:a27ca97f61ec3c3ea2608bb51b78c33ae"><td class="memItemLeft" align="right" valign="top">const std::string </td><td class="memItemRight" valign="bottom"><a class="el" href="classimpala_1_1Metric.html#a27ca97f61ec3c3ea2608bb51b78c33ae">description_</a></td></tr> | 
|  | <tr class="separator:a27ca97f61ec3c3ea2608bb51b78c33ae"><td class="memSeparator" colspan="2"> </td></tr> | 
|  | </table> | 
|  | <a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> | 
|  | <div class="textblock"><h3>template<typename T, TMetricKind::type metric_kind = TMetricKind::GAUGE><br/> | 
|  | class impala::SimpleMetric< T, metric_kind ></h3> | 
|  |  | 
|  | <p>A <a class="el" href="classimpala_1_1SimpleMetric.html">SimpleMetric</a> has a value which is a simple primitive type: e.g. integers, strings and floats. It is parameterised not only by the type of its value, but by both the unit (e.g. bytes/s), drawn from TUnit and the 'kind' of the metric itself. The kind can be one of: 'gauge', which may increase or decrease over time, a 'counter' which is increasing only over time, or a 'property' which is not numeric. SimpleMetrics return their current value through the <a class="el" href="classimpala_1_1SimpleMetric.html#aee1b3c3e9b4d8f5bd9c8e199cf742572" title="Returns the current value, updating it if necessary. Thread-safe. ">value()</a> method. Access to <a class="el" href="classimpala_1_1SimpleMetric.html#aee1b3c3e9b4d8f5bd9c8e199cf742572" title="Returns the current value, updating it if necessary. Thread-safe. ">value()</a> is thread-safe. TODO: We can use type traits to select a more efficient lock-free implementation of <a class="el" href="classimpala_1_1SimpleMetric.html#aee1b3c3e9b4d8f5bd9c8e199cf742572" title="Returns the current value, updating it if necessary. Thread-safe. ">value()</a> etc. where it is safe to do so. </p> | 
|  |  | 
|  | <p>Definition at line <a class="el" href="metrics_8h_source.html#l00104">104</a> of file <a class="el" href="metrics_8h_source.html">metrics.h</a>.</p> | 
|  | </div><h2 class="groupheader">Constructor & Destructor Documentation</h2> | 
|  | <a class="anchor" id="a69a7f8c8b70024ba4ab4292087c327ac"></a> | 
|  | <div class="memitem"> | 
|  | <div class="memproto"> | 
|  | <div class="memtemplate"> | 
|  | template<typename T , TMetricKind::type metric_kind = TMetricKind::GAUGE> </div> | 
|  | <table class="mlabels"> | 
|  | <tr> | 
|  | <td class="mlabels-left"> | 
|  | <table class="memname"> | 
|  | <tr> | 
|  | <td class="memname"><a class="el" href="classimpala_1_1SimpleMetric.html">impala::SimpleMetric</a>< T, metric_kind >::<a class="el" href="classimpala_1_1SimpleMetric.html">SimpleMetric</a> </td> | 
|  | <td>(</td> | 
|  | <td class="paramtype">const std::string & </td> | 
|  | <td class="paramname"><em>key</em>, </td> | 
|  | </tr> | 
|  | <tr> | 
|  | <td class="paramkey"></td> | 
|  | <td></td> | 
|  | <td class="paramtype">const TUnit::type </td> | 
|  | <td class="paramname"><em>unit</em>, </td> | 
|  | </tr> | 
|  | <tr> | 
|  | <td class="paramkey"></td> | 
|  | <td></td> | 
|  | <td class="paramtype">const T & </td> | 
|  | <td class="paramname"><em>initial_value</em>, </td> | 
|  | </tr> | 
|  | <tr> | 
|  | <td class="paramkey"></td> | 
|  | <td></td> | 
|  | <td class="paramtype">const std::string & </td> | 
|  | <td class="paramname"><em>description</em> = <code>""</code> </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>Definition at line <a class="el" href="metrics_8h_source.html#l00106">106</a> of file <a class="el" href="metrics_8h_source.html">metrics.h</a>.</p> | 
|  |  | 
|  | </div> | 
|  | </div> | 
|  | <a class="anchor" id="af5438dfceffb45c462fbaaa6f195fa0f"></a> | 
|  | <div class="memitem"> | 
|  | <div class="memproto"> | 
|  | <div class="memtemplate"> | 
|  | template<typename T , TMetricKind::type metric_kind = TMetricKind::GAUGE> </div> | 
|  | <table class="mlabels"> | 
|  | <tr> | 
|  | <td class="mlabels-left"> | 
|  | <table class="memname"> | 
|  | <tr> | 
|  | <td class="memname"><a class="el" href="classimpala_1_1SimpleMetric.html">impala::SimpleMetric</a>< T, metric_kind >::<a class="el" href="classimpala_1_1SimpleMetric.html">SimpleMetric</a> </td> | 
|  | <td>(</td> | 
|  | <td class="paramtype">const std::string & </td> | 
|  | <td class="paramname"><em>key</em>, </td> | 
|  | </tr> | 
|  | <tr> | 
|  | <td class="paramkey"></td> | 
|  | <td></td> | 
|  | <td class="paramtype">const TUnit::type </td> | 
|  | <td class="paramname"><em>unit</em>, </td> | 
|  | </tr> | 
|  | <tr> | 
|  | <td class="paramkey"></td> | 
|  | <td></td> | 
|  | <td class="paramtype">const std::string & </td> | 
|  | <td class="paramname"><em>description</em> = <code>""</code> </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>Definition at line <a class="el" href="metrics_8h_source.html#l00111">111</a> of file <a class="el" href="metrics_8h_source.html">metrics.h</a>.</p> | 
|  |  | 
|  | </div> | 
|  | </div> | 
|  | <a class="anchor" id="a98684f965400150dbb3c8f78a7bac45e"></a> | 
|  | <div class="memitem"> | 
|  | <div class="memproto"> | 
|  | <div class="memtemplate"> | 
|  | template<typename T , TMetricKind::type metric_kind = TMetricKind::GAUGE> </div> | 
|  | <table class="mlabels"> | 
|  | <tr> | 
|  | <td class="mlabels-left"> | 
|  | <table class="memname"> | 
|  | <tr> | 
|  | <td class="memname">virtual <a class="el" href="classimpala_1_1SimpleMetric.html">impala::SimpleMetric</a>< T, metric_kind >::~<a class="el" href="classimpala_1_1SimpleMetric.html">SimpleMetric</a> </td> | 
|  | <td>(</td> | 
|  | <td class="paramname"></td><td>)</td> | 
|  | <td></td> | 
|  | </tr> | 
|  | </table> | 
|  | </td> | 
|  | <td class="mlabels-right"> | 
|  | <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span>  </td> | 
|  | </tr> | 
|  | </table> | 
|  | </div><div class="memdoc"> | 
|  |  | 
|  | <p>Definition at line <a class="el" href="metrics_8h_source.html#l00115">115</a> of file <a class="el" href="metrics_8h_source.html">metrics.h</a>.</p> | 
|  |  | 
|  | </div> | 
|  | </div> | 
|  | <h2 class="groupheader">Member Function Documentation</h2> | 
|  | <a class="anchor" id="a05010f15c634161716da4e8451dba06d"></a> | 
|  | <div class="memitem"> | 
|  | <div class="memproto"> | 
|  | <table class="mlabels"> | 
|  | <tr> | 
|  | <td class="mlabels-left"> | 
|  | <table class="memname"> | 
|  | <tr> | 
|  | <td class="memname">void Metric::AddStandardFields </td> | 
|  | <td>(</td> | 
|  | <td class="paramtype">rapidjson::Document * </td> | 
|  | <td class="paramname"><em>document</em>, </td> | 
|  | </tr> | 
|  | <tr> | 
|  | <td class="paramkey"></td> | 
|  | <td></td> | 
|  | <td class="paramtype">rapidjson::Value * </td> | 
|  | <td class="paramname"><em>val</em> </td> | 
|  | </tr> | 
|  | <tr> | 
|  | <td></td> | 
|  | <td>)</td> | 
|  | <td></td><td></td> | 
|  | </tr> | 
|  | </table> | 
|  | </td> | 
|  | <td class="mlabels-right"> | 
|  | <span class="mlabels"><span class="mlabel">protected</span><span class="mlabel">inherited</span></span>  </td> | 
|  | </tr> | 
|  | </table> | 
|  | </div><div class="memdoc"> | 
|  | <p>Convenience method to add standard fields (name, description, human readable string) to 'val'. </p> | 
|  |  | 
|  | <p>Definition at line <a class="el" href="metrics_8cc_source.html#l00046">46</a> of file <a class="el" href="metrics_8cc_source.html">metrics.cc</a>.</p> | 
|  |  | 
|  | <p>References <a class="el" href="cpu-info_8cc_source.html#l00050">impala::name</a>.</p> | 
|  |  | 
|  | <p>Referenced by <a class="el" href="collection-metrics_8h_source.html#l00062">impala::SetMetric< std::string >::ToJson()</a>, <a class="el" href="collection-metrics_8h_source.html#l00123">impala::StatsMetric< double >::ToJson()</a>, and <a class="el" href="metrics_8h_source.html#l00140">impala::SimpleMetric< T, metric_kind >::ToJson()</a>.</p> | 
|  |  | 
|  | </div> | 
|  | </div> | 
|  | <a class="anchor" id="ab1253cbe7f6132765b7abcad558e4e06"></a> | 
|  | <div class="memitem"> | 
|  | <div class="memproto"> | 
|  | <div class="memtemplate"> | 
|  | template<typename T , TMetricKind::type metric_kind = TMetricKind::GAUGE> </div> | 
|  | <table class="mlabels"> | 
|  | <tr> | 
|  | <td class="mlabels-left"> | 
|  | <table class="memname"> | 
|  | <tr> | 
|  | <td class="memname">virtual void <a class="el" href="classimpala_1_1SimpleMetric.html">impala::SimpleMetric</a>< T, metric_kind >::CalculateValue </td> | 
|  | <td>(</td> | 
|  | <td class="paramname"></td><td>)</td> | 
|  | <td></td> | 
|  | </tr> | 
|  | </table> | 
|  | </td> | 
|  | <td class="mlabels-right"> | 
|  | <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">protected</span><span class="mlabel">virtual</span></span>  </td> | 
|  | </tr> | 
|  | </table> | 
|  | </div><div class="memdoc"> | 
|  | <p>Called to compute value_ if necessary during calls to <a class="el" href="classimpala_1_1SimpleMetric.html#aee1b3c3e9b4d8f5bd9c8e199cf742572" title="Returns the current value, updating it if necessary. Thread-safe. ">value()</a>. The more natural approach would be to have virtual T <a class="el" href="classimpala_1_1SimpleMetric.html#aee1b3c3e9b4d8f5bd9c8e199cf742572" title="Returns the current value, updating it if necessary. Thread-safe. ">value()</a>, but that's not possible in C++. TODO: Should be cheap to have a blank implementation, but if required we can cause the compiler to avoid calling this entirely through a compile-time constant. </p> | 
|  |  | 
|  | <p>Definition at line <a class="el" href="metrics_8h_source.html#l00175">175</a> of file <a class="el" href="metrics_8h_source.html">metrics.h</a>.</p> | 
|  |  | 
|  | <p>Referenced by <a class="el" href="metrics_8h_source.html#l00118">impala::SimpleMetric< T, metric_kind >::value()</a>.</p> | 
|  |  | 
|  | </div> | 
|  | </div> | 
|  | <a class="anchor" id="a80682167db8743e5c8e38e73ad55f0c3"></a> | 
|  | <div class="memitem"> | 
|  | <div class="memproto"> | 
|  | <table class="mlabels"> | 
|  | <tr> | 
|  | <td class="mlabels-left"> | 
|  | <table class="memname"> | 
|  | <tr> | 
|  | <td class="memname">const std::string& impala::Metric::description </td> | 
|  | <td>(</td> | 
|  | <td class="paramname"></td><td>)</td> | 
|  | <td> const</td> | 
|  | </tr> | 
|  | </table> | 
|  | </td> | 
|  | <td class="mlabels-right"> | 
|  | <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">inherited</span></span>  </td> | 
|  | </tr> | 
|  | </table> | 
|  | </div><div class="memdoc"> | 
|  |  | 
|  | <p>Definition at line <a class="el" href="metrics_8h_source.html#l00072">72</a> of file <a class="el" href="metrics_8h_source.html">metrics.h</a>.</p> | 
|  |  | 
|  | <p>References <a class="el" href="metrics_8h_source.html#l00080">impala::Metric::description_</a>.</p> | 
|  |  | 
|  | </div> | 
|  | </div> | 
|  | <a class="anchor" id="acc1207a7d680280aa6bde04c6e7a3fc4"></a> | 
|  | <div class="memitem"> | 
|  | <div class="memproto"> | 
|  | <div class="memtemplate"> | 
|  | template<typename T , TMetricKind::type metric_kind = TMetricKind::GAUGE> </div> | 
|  | <table class="mlabels"> | 
|  | <tr> | 
|  | <td class="mlabels-left"> | 
|  | <table class="memname"> | 
|  | <tr> | 
|  | <td class="memname">void <a class="el" href="classimpala_1_1SimpleMetric.html">impala::SimpleMetric</a>< T, metric_kind >::Increment </td> | 
|  | <td>(</td> | 
|  | <td class="paramtype">const T & </td> | 
|  | <td class="paramname"><em>delta</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>Adds 'delta' to the current value atomically. </p> | 
|  |  | 
|  | <p>Definition at line <a class="el" href="metrics_8h_source.html#l00131">131</a> of file <a class="el" href="metrics_8h_source.html">metrics.h</a>.</p> | 
|  |  | 
|  | <p>References <a class="el" href="metrics_8h_source.html#l00071">impala::Metric::key()</a>, <a class="el" href="metrics_8h_source.html#l00167">impala::SimpleMetric< T, metric_kind >::kind()</a>, <a class="el" href="metrics_8h_source.html#l00181">impala::SimpleMetric< T, metric_kind >::lock_</a>, and <a class="el" href="metrics_8h_source.html#l00184">impala::SimpleMetric< T, metric_kind >::value_</a>.</p> | 
|  |  | 
|  | </div> | 
|  | </div> | 
|  | <a class="anchor" id="a56211a0cc08bb2e10a0c89ebe5b152d9"></a> | 
|  | <div class="memitem"> | 
|  | <div class="memproto"> | 
|  | <table class="mlabels"> | 
|  | <tr> | 
|  | <td class="mlabels-left"> | 
|  | <table class="memname"> | 
|  | <tr> | 
|  | <td class="memname">const std::string& impala::Metric::key </td> | 
|  | <td>(</td> | 
|  | <td class="paramname"></td><td>)</td> | 
|  | <td> const</td> | 
|  | </tr> | 
|  | </table> | 
|  | </td> | 
|  | <td class="mlabels-right"> | 
|  | <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">inherited</span></span>  </td> | 
|  | </tr> | 
|  | </table> | 
|  | </div><div class="memdoc"> | 
|  |  | 
|  | <p>Definition at line <a class="el" href="metrics_8h_source.html#l00071">71</a> of file <a class="el" href="metrics_8h_source.html">metrics.h</a>.</p> | 
|  |  | 
|  | <p>References <a class="el" href="metrics_8h_source.html#l00076">impala::Metric::key_</a>.</p> | 
|  |  | 
|  | <p>Referenced by <a class="el" href="metrics_8h_source.html#l00131">impala::SimpleMetric< T, metric_kind >::Increment()</a>.</p> | 
|  |  | 
|  | </div> | 
|  | </div> | 
|  | <a class="anchor" id="ac14b5c3b6778acb0de85b297e8bba2aa"></a> | 
|  | <div class="memitem"> | 
|  | <div class="memproto"> | 
|  | <div class="memtemplate"> | 
|  | template<typename T , TMetricKind::type metric_kind = TMetricKind::GAUGE> </div> | 
|  | <table class="mlabels"> | 
|  | <tr> | 
|  | <td class="mlabels-left"> | 
|  | <table class="memname"> | 
|  | <tr> | 
|  | <td class="memname">const TMetricKind::type <a class="el" href="classimpala_1_1SimpleMetric.html">impala::SimpleMetric</a>< T, metric_kind >::kind </td> | 
|  | <td>(</td> | 
|  | <td class="paramname"></td><td>)</td> | 
|  | <td> const</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>Definition at line <a class="el" href="metrics_8h_source.html#l00167">167</a> of file <a class="el" href="metrics_8h_source.html">metrics.h</a>.</p> | 
|  |  | 
|  | <p>Referenced by <a class="el" href="metrics_8h_source.html#l00131">impala::SimpleMetric< T, metric_kind >::Increment()</a>, and <a class="el" href="metrics_8h_source.html#l00140">impala::SimpleMetric< T, metric_kind >::ToJson()</a>.</p> | 
|  |  | 
|  | </div> | 
|  | </div> | 
|  | <a class="anchor" id="a19937427c8bdf7967ffc181f31316763"></a> | 
|  | <div class="memitem"> | 
|  | <div class="memproto"> | 
|  | <div class="memtemplate"> | 
|  | template<typename T , TMetricKind::type metric_kind = TMetricKind::GAUGE> </div> | 
|  | <table class="mlabels"> | 
|  | <tr> | 
|  | <td class="mlabels-left"> | 
|  | <table class="memname"> | 
|  | <tr> | 
|  | <td class="memname">void <a class="el" href="classimpala_1_1SimpleMetric.html">impala::SimpleMetric</a>< T, metric_kind >::set_value </td> | 
|  | <td>(</td> | 
|  | <td class="paramtype">const T & </td> | 
|  | <td class="paramname"><em>value</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>Sets the current value. Thread-safe. </p> | 
|  |  | 
|  | <p>Definition at line <a class="el" href="metrics_8h_source.html#l00125">125</a> of file <a class="el" href="metrics_8h_source.html">metrics.h</a>.</p> | 
|  |  | 
|  | <p>References <a class="el" href="metrics_8h_source.html#l00181">impala::SimpleMetric< T, metric_kind >::lock_</a>, <a class="el" href="metrics_8h_source.html#l00118">impala::SimpleMetric< T, metric_kind >::value()</a>, and <a class="el" href="metrics_8h_source.html#l00184">impala::SimpleMetric< T, metric_kind >::value_</a>.</p> | 
|  |  | 
|  | </div> | 
|  | </div> | 
|  | <a class="anchor" id="a37bc0809743e6448ff026ed379de3d78"></a> | 
|  | <div class="memitem"> | 
|  | <div class="memproto"> | 
|  | <div class="memtemplate"> | 
|  | template<typename T , TMetricKind::type metric_kind = TMetricKind::GAUGE> </div> | 
|  | <table class="mlabels"> | 
|  | <tr> | 
|  | <td class="mlabels-left"> | 
|  | <table class="memname"> | 
|  | <tr> | 
|  | <td class="memname">virtual std::string <a class="el" href="classimpala_1_1SimpleMetric.html">impala::SimpleMetric</a>< T, metric_kind >::ToHumanReadable </td> | 
|  | <td>(</td> | 
|  | <td class="paramname"></td><td>)</td> | 
|  | <td></td> | 
|  | </tr> | 
|  | </table> | 
|  | </td> | 
|  | <td class="mlabels-right"> | 
|  | <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span>  </td> | 
|  | </tr> | 
|  | </table> | 
|  | </div><div class="memdoc"> | 
|  | <p>Writes a human-readable representation of this metric to 'out'. This is the representation that is often displayed in webpages etc. </p> | 
|  |  | 
|  | <p>Implements <a class="el" href="classimpala_1_1Metric.html#a0927716b77c734cdda1c72b8f7314230">impala::Metric</a>.</p> | 
|  |  | 
|  | <p>Definition at line <a class="el" href="metrics_8h_source.html#l00156">156</a> of file <a class="el" href="metrics_8h_source.html">metrics.h</a>.</p> | 
|  |  | 
|  | <p>References <a class="el" href="pretty-printer_8h_source.html#l00033">impala::PrettyPrinter::Print()</a>, <a class="el" href="metrics_8h_source.html#l00166">impala::SimpleMetric< T, metric_kind >::unit()</a>, and <a class="el" href="metrics_8h_source.html#l00118">impala::SimpleMetric< T, metric_kind >::value()</a>.</p> | 
|  |  | 
|  | </div> | 
|  | </div> | 
|  | <a class="anchor" id="aa50443609a6867817cede75fd2d936da"></a> | 
|  | <div class="memitem"> | 
|  | <div class="memproto"> | 
|  | <div class="memtemplate"> | 
|  | template<typename T , TMetricKind::type metric_kind = TMetricKind::GAUGE> </div> | 
|  | <table class="mlabels"> | 
|  | <tr> | 
|  | <td class="mlabels-left"> | 
|  | <table class="memname"> | 
|  | <tr> | 
|  | <td class="memname">virtual void <a class="el" href="classimpala_1_1SimpleMetric.html">impala::SimpleMetric</a>< T, metric_kind >::ToJson </td> | 
|  | <td>(</td> | 
|  | <td class="paramtype">rapidjson::Document * </td> | 
|  | <td class="paramname"><em>document</em>, </td> | 
|  | </tr> | 
|  | <tr> | 
|  | <td class="paramkey"></td> | 
|  | <td></td> | 
|  | <td class="paramtype">rapidjson::Value * </td> | 
|  | <td class="paramname"><em>val</em> </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 class="mlabel">virtual</span></span>  </td> | 
|  | </tr> | 
|  | </table> | 
|  | </div><div class="memdoc"> | 
|  |  | 
|  | <p>name, value, human_readable, description </p> | 
|  | <p>Builds a new Value into 'val', using (if required) the allocator from 'document'. Should set the following fields where appropriate: </p> | 
|  |  | 
|  | <p>Implements <a class="el" href="classimpala_1_1Metric.html#a9ffe6624e9683bf07561246655347285">impala::Metric</a>.</p> | 
|  |  | 
|  | <p>Definition at line <a class="el" href="metrics_8h_source.html#l00140">140</a> of file <a class="el" href="metrics_8h_source.html">metrics.h</a>.</p> | 
|  |  | 
|  | <p>References <a class="el" href="metrics_8cc_source.html#l00046">impala::Metric::AddStandardFields()</a>, <a class="el" href="metrics_8h_source.html#l00167">impala::SimpleMetric< T, metric_kind >::kind()</a>, <a class="el" href="namespaceimpala.html#a7754809f09bebd3e8316443140ce5a2e">impala::PrintTMetricKind()</a>, <a class="el" href="namespaceimpala.html#ad2f4584b415189a2f961e909fb53b570">impala::PrintTUnit()</a>, <a class="el" href="json-util_8h_source.html#l00033">impala::ToJsonValue()</a>, <a class="el" href="metrics_8h_source.html#l00166">impala::SimpleMetric< T, metric_kind >::unit()</a>, and <a class="el" href="metrics_8h_source.html#l00118">impala::SimpleMetric< T, metric_kind >::value()</a>.</p> | 
|  |  | 
|  | </div> | 
|  | </div> | 
|  | <a class="anchor" id="a6555da07dbd5674a3b69a36ec0f7323e"></a> | 
|  | <div class="memitem"> | 
|  | <div class="memproto"> | 
|  | <div class="memtemplate"> | 
|  | template<typename T , TMetricKind::type metric_kind = TMetricKind::GAUGE> </div> | 
|  | <table class="mlabels"> | 
|  | <tr> | 
|  | <td class="mlabels-left"> | 
|  | <table class="memname"> | 
|  | <tr> | 
|  | <td class="memname">virtual void <a class="el" href="classimpala_1_1SimpleMetric.html">impala::SimpleMetric</a>< T, metric_kind >::ToLegacyJson </td> | 
|  | <td>(</td> | 
|  | <td class="paramtype">rapidjson::Document * </td> | 
|  | <td class="paramname"><em>document</em></td><td>)</td> | 
|  | <td></td> | 
|  | </tr> | 
|  | </table> | 
|  | </td> | 
|  | <td class="mlabels-right"> | 
|  | <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span>  </td> | 
|  | </tr> | 
|  | </table> | 
|  | </div><div class="memdoc"> | 
|  |  | 
|  | <p>This method is kept for backwards-compatibility with CM5.0. </p> | 
|  | <p>Adds a new json value directly to 'document' of the form: "name" : "human-readable-string" </p> | 
|  |  | 
|  | <p>Implements <a class="el" href="classimpala_1_1Metric.html#a192ffba4fa4b4f5fb797af1cd7adcce1">impala::Metric</a>.</p> | 
|  |  | 
|  | <p>Definition at line <a class="el" href="metrics_8h_source.html#l00160">160</a> of file <a class="el" href="metrics_8h_source.html">metrics.h</a>.</p> | 
|  |  | 
|  | <p>References <a class="el" href="metrics_8h_source.html#l00076">impala::Metric::key_</a>, <a class="el" href="json-util_8h_source.html#l00033">impala::ToJsonValue()</a>, and <a class="el" href="metrics_8h_source.html#l00118">impala::SimpleMetric< T, metric_kind >::value()</a>.</p> | 
|  |  | 
|  | </div> | 
|  | </div> | 
|  | <a class="anchor" id="aca0380a54d8c42df8a6fd6d9bf9bf452"></a> | 
|  | <div class="memitem"> | 
|  | <div class="memproto"> | 
|  | <div class="memtemplate"> | 
|  | template<typename T , TMetricKind::type metric_kind = TMetricKind::GAUGE> </div> | 
|  | <table class="mlabels"> | 
|  | <tr> | 
|  | <td class="mlabels-left"> | 
|  | <table class="memname"> | 
|  | <tr> | 
|  | <td class="memname">const TUnit::type <a class="el" href="classimpala_1_1SimpleMetric.html">impala::SimpleMetric</a>< T, metric_kind >::unit </td> | 
|  | <td>(</td> | 
|  | <td class="paramname"></td><td>)</td> | 
|  | <td> const</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>Definition at line <a class="el" href="metrics_8h_source.html#l00166">166</a> of file <a class="el" href="metrics_8h_source.html">metrics.h</a>.</p> | 
|  |  | 
|  | <p>References <a class="el" href="metrics_8h_source.html#l00178">impala::SimpleMetric< T, metric_kind >::unit_</a>.</p> | 
|  |  | 
|  | <p>Referenced by <a class="el" href="metrics_8h_source.html#l00156">impala::SimpleMetric< T, metric_kind >::ToHumanReadable()</a>, and <a class="el" href="metrics_8h_source.html#l00140">impala::SimpleMetric< T, metric_kind >::ToJson()</a>.</p> | 
|  |  | 
|  | </div> | 
|  | </div> | 
|  | <a class="anchor" id="aee1b3c3e9b4d8f5bd9c8e199cf742572"></a> | 
|  | <div class="memitem"> | 
|  | <div class="memproto"> | 
|  | <div class="memtemplate"> | 
|  | template<typename T , TMetricKind::type metric_kind = TMetricKind::GAUGE> </div> | 
|  | <table class="mlabels"> | 
|  | <tr> | 
|  | <td class="mlabels-left"> | 
|  | <table class="memname"> | 
|  | <tr> | 
|  | <td class="memname">T <a class="el" href="classimpala_1_1SimpleMetric.html">impala::SimpleMetric</a>< T, metric_kind >::value </td> | 
|  | <td>(</td> | 
|  | <td class="paramname"></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 current value, updating it if necessary. Thread-safe. </p> | 
|  |  | 
|  | <p>Definition at line <a class="el" href="metrics_8h_source.html#l00118">118</a> of file <a class="el" href="metrics_8h_source.html">metrics.h</a>.</p> | 
|  |  | 
|  | <p>References <a class="el" href="metrics_8h_source.html#l00175">impala::SimpleMetric< T, metric_kind >::CalculateValue()</a>, <a class="el" href="metrics_8h_source.html#l00181">impala::SimpleMetric< T, metric_kind >::lock_</a>, and <a class="el" href="metrics_8h_source.html#l00184">impala::SimpleMetric< T, metric_kind >::value_</a>.</p> | 
|  |  | 
|  | <p>Referenced by <a class="el" href="metrics_8h_source.html#l00125">impala::SimpleMetric< T, metric_kind >::set_value()</a>, <a class="el" href="metrics_8h_source.html#l00156">impala::SimpleMetric< T, metric_kind >::ToHumanReadable()</a>, <a class="el" href="metrics_8h_source.html#l00140">impala::SimpleMetric< T, metric_kind >::ToJson()</a>, and <a class="el" href="metrics_8h_source.html#l00160">impala::SimpleMetric< T, metric_kind >::ToLegacyJson()</a>.</p> | 
|  |  | 
|  | </div> | 
|  | </div> | 
|  | <h2 class="groupheader">Member Data Documentation</h2> | 
|  | <a class="anchor" id="a27ca97f61ec3c3ea2608bb51b78c33ae"></a> | 
|  | <div class="memitem"> | 
|  | <div class="memproto"> | 
|  | <table class="mlabels"> | 
|  | <tr> | 
|  | <td class="mlabels-left"> | 
|  | <table class="memname"> | 
|  | <tr> | 
|  | <td class="memname">const std::string impala::Metric::description_</td> | 
|  | </tr> | 
|  | </table> | 
|  | </td> | 
|  | <td class="mlabels-right"> | 
|  | <span class="mlabels"><span class="mlabel">protected</span><span class="mlabel">inherited</span></span>  </td> | 
|  | </tr> | 
|  | </table> | 
|  | </div><div class="memdoc"> | 
|  | <p>Description of this metric. TODO: share one copy amongst metrics with the same description. </p> | 
|  |  | 
|  | <p>Definition at line <a class="el" href="metrics_8h_source.html#l00080">80</a> of file <a class="el" href="metrics_8h_source.html">metrics.h</a>.</p> | 
|  |  | 
|  | <p>Referenced by <a class="el" href="metrics_8h_source.html#l00072">impala::Metric::description()</a>.</p> | 
|  |  | 
|  | </div> | 
|  | </div> | 
|  | <a class="anchor" id="abfaeffb213edb0d448f5b07638ee6963"></a> | 
|  | <div class="memitem"> | 
|  | <div class="memproto"> | 
|  | <table class="mlabels"> | 
|  | <tr> | 
|  | <td class="mlabels-left"> | 
|  | <table class="memname"> | 
|  | <tr> | 
|  | <td class="memname">const std::string impala::Metric::key_</td> | 
|  | </tr> | 
|  | </table> | 
|  | </td> | 
|  | <td class="mlabels-right"> | 
|  | <span class="mlabels"><span class="mlabel">protected</span><span class="mlabel">inherited</span></span>  </td> | 
|  | </tr> | 
|  | </table> | 
|  | </div><div class="memdoc"> | 
|  |  | 
|  | <p>Unique key identifying this metric. </p> | 
|  |  | 
|  | <p>Definition at line <a class="el" href="metrics_8h_source.html#l00076">76</a> of file <a class="el" href="metrics_8h_source.html">metrics.h</a>.</p> | 
|  |  | 
|  | <p>Referenced by <a class="el" href="metrics_8h_source.html#l00071">impala::Metric::key()</a>, <a class="el" href="collection-metrics_8h_source.html#l00075">impala::SetMetric< std::string >::ToLegacyJson()</a>, <a class="el" href="collection-metrics_8h_source.html#l00147">impala::StatsMetric< double >::ToLegacyJson()</a>, and <a class="el" href="metrics_8h_source.html#l00160">impala::SimpleMetric< T, metric_kind >::ToLegacyJson()</a>.</p> | 
|  |  | 
|  | </div> | 
|  | </div> | 
|  | <a class="anchor" id="a59533b22fc8f4ddca90dd16e8be2c29f"></a> | 
|  | <div class="memitem"> | 
|  | <div class="memproto"> | 
|  | <div class="memtemplate"> | 
|  | template<typename T , TMetricKind::type metric_kind = TMetricKind::GAUGE> </div> | 
|  | <table class="mlabels"> | 
|  | <tr> | 
|  | <td class="mlabels-left"> | 
|  | <table class="memname"> | 
|  | <tr> | 
|  | <td class="memname">boost::mutex <a class="el" href="classimpala_1_1SimpleMetric.html">impala::SimpleMetric</a>< T, metric_kind >::lock_</td> | 
|  | </tr> | 
|  | </table> | 
|  | </td> | 
|  | <td class="mlabels-right"> | 
|  | <span class="mlabels"><span class="mlabel">protected</span></span>  </td> | 
|  | </tr> | 
|  | </table> | 
|  | </div><div class="memdoc"> | 
|  |  | 
|  | <p>Guards access to value_. </p> | 
|  |  | 
|  | <p>Definition at line <a class="el" href="metrics_8h_source.html#l00181">181</a> of file <a class="el" href="metrics_8h_source.html">metrics.h</a>.</p> | 
|  |  | 
|  | <p>Referenced by <a class="el" href="metrics_8h_source.html#l00131">impala::SimpleMetric< T, metric_kind >::Increment()</a>, <a class="el" href="metrics_8h_source.html#l00125">impala::SimpleMetric< T, metric_kind >::set_value()</a>, and <a class="el" href="metrics_8h_source.html#l00118">impala::SimpleMetric< T, metric_kind >::value()</a>.</p> | 
|  |  | 
|  | </div> | 
|  | </div> | 
|  | <a class="anchor" id="a29fa15d10a26cf152194302e76d3f83a"></a> | 
|  | <div class="memitem"> | 
|  | <div class="memproto"> | 
|  | <div class="memtemplate"> | 
|  | template<typename T , TMetricKind::type metric_kind = TMetricKind::GAUGE> </div> | 
|  | <table class="mlabels"> | 
|  | <tr> | 
|  | <td class="mlabels-left"> | 
|  | <table class="memname"> | 
|  | <tr> | 
|  | <td class="memname">const TUnit::type <a class="el" href="classimpala_1_1SimpleMetric.html">impala::SimpleMetric</a>< T, metric_kind >::unit_</td> | 
|  | </tr> | 
|  | </table> | 
|  | </td> | 
|  | <td class="mlabels-right"> | 
|  | <span class="mlabels"><span class="mlabel">protected</span></span>  </td> | 
|  | </tr> | 
|  | </table> | 
|  | </div><div class="memdoc"> | 
|  |  | 
|  | <p>Units of this metric. </p> | 
|  |  | 
|  | <p>Definition at line <a class="el" href="metrics_8h_source.html#l00178">178</a> of file <a class="el" href="metrics_8h_source.html">metrics.h</a>.</p> | 
|  |  | 
|  | <p>Referenced by <a class="el" href="metrics_8h_source.html#l00166">impala::SimpleMetric< T, metric_kind >::unit()</a>.</p> | 
|  |  | 
|  | </div> | 
|  | </div> | 
|  | <a class="anchor" id="a602d3a314922a977a85fea236bb27399"></a> | 
|  | <div class="memitem"> | 
|  | <div class="memproto"> | 
|  | <div class="memtemplate"> | 
|  | template<typename T , TMetricKind::type metric_kind = TMetricKind::GAUGE> </div> | 
|  | <table class="mlabels"> | 
|  | <tr> | 
|  | <td class="mlabels-left"> | 
|  | <table class="memname"> | 
|  | <tr> | 
|  | <td class="memname">T <a class="el" href="classimpala_1_1SimpleMetric.html">impala::SimpleMetric</a>< T, metric_kind >::value_</td> | 
|  | </tr> | 
|  | </table> | 
|  | </td> | 
|  | <td class="mlabels-right"> | 
|  | <span class="mlabels"><span class="mlabel">protected</span></span>  </td> | 
|  | </tr> | 
|  | </table> | 
|  | </div><div class="memdoc"> | 
|  |  | 
|  | <p>The current value of the metric. </p> | 
|  |  | 
|  | <p>Definition at line <a class="el" href="metrics_8h_source.html#l00184">184</a> of file <a class="el" href="metrics_8h_source.html">metrics.h</a>.</p> | 
|  |  | 
|  | <p>Referenced by <a class="el" href="metrics_8h_source.html#l00131">impala::SimpleMetric< T, metric_kind >::Increment()</a>, <a class="el" href="metrics_8h_source.html#l00125">impala::SimpleMetric< T, metric_kind >::set_value()</a>, and <a class="el" href="metrics_8h_source.html#l00118">impala::SimpleMetric< T, metric_kind >::value()</a>.</p> | 
|  |  | 
|  | </div> | 
|  | </div> | 
|  | <hr/>The documentation for this class was generated from the following file:<ul> | 
|  | <li>be/src/util/<a class="el" href="metrics_8h_source.html">metrics.h</a></li> | 
|  | </ul> | 
|  | </div><!-- contents --> | 
|  | </div><!-- doc-content --> | 
|  | <!-- start footer part --> | 
|  | <div id="nav-path" class="navpath"><!-- id is needed for treeview function! --> | 
|  | <ul> | 
|  | <li class="navelem"><a class="el" href="namespaceimpala.html">impala</a></li><li class="navelem"><a class="el" href="classimpala_1_1SimpleMetric.html">SimpleMetric</a></li> | 
|  | <li class="footer">Generated on Thu May 7 2015 16:10:50 for Impala by | 
|  | <a href="http://www.doxygen.org/index.html"> | 
|  | <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.6 </li> | 
|  | </ul> | 
|  | </div> | 
|  | </body> | 
|  | </html> |