nytprof run results of /variantgraph/<ID> and /relation/<ID>/relationships
[scpubgit/stemmatology.git] / stemmaweb / nytprof-runs / relation-uuid-relationships / Moose-pm-62-block.html
diff --git a/stemmaweb/nytprof-runs/relation-uuid-relationships/Moose-pm-62-block.html b/stemmaweb/nytprof-runs/relation-uuid-relationships/Moose-pm-62-block.html
new file mode 100644 (file)
index 0000000..7599b44
--- /dev/null
@@ -0,0 +1,1967 @@
+    <!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">
+<!--
+This file was generated by Devel::NYTProf version 4.06
+-->
+<head>
+    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
+    <meta http-equiv="Content-Language" content="en-us" />
+    <title>Profile of Moose.pm</title>
+<link rel="stylesheet" type="text/css" href="style.css" />
+    <script type="text/javascript" src="js/jquery-min.js"></script> 
+
+    <script type="text/javascript" src="js/jquery-tablesorter-min.js"></script> 
+    <link rel="stylesheet" type="text/css" href="js/style-tablesorter.css" />
+    <script type="text/javascript">
+    // when a column is first clicked on to sort it, use descending order
+    // XXX doesn't seem to work (and not just because the tablesorter formatSortingOrder() is broken)
+    $.tablesorter.defaults.sortInitialOrder = "desc";
+    // add parser through the tablesorter addParser method 
+    $.tablesorter.addParser({
+        id: 'fmt_time',   // name of this parser
+        is: function(s) { 
+            return false; // return false so this parser is not auto detected 
+        }, 
+        format: function(orig) { // format data for normalization 
+            // console.log(orig);
+            val = orig.replace(/ns/,'');
+            if (val != orig) { return val / (1000*1000*1000); } 
+            val = orig.replace(/µs/,''); /* XXX use &micro; ? */
+            if (val != orig) { return val / (1000*1000); } 
+            var val = orig.replace(/ms/,'');
+            if (val != orig) { return val / (1000); }
+            var val = orig.replace(/s/,'');
+            if (val != orig) { return val; }
+            if (orig == '0') { return orig; } 
+            console.log('no match for fmt_time of '.concat(orig));
+            return orig;
+        },
+        type: 'numeric' // set type, either numeric or text 
+    }); 
+    </script> 
+</head>
+
+<body > 
+<div class="header" style="position: relative; overflow-x: hidden; overflow-y: hidden; z-index: 0; ">
+<div class="header_back">
+            <a href="index.html">&larr; Index</a>
+        </div>
+<div class="headerForeground" style="float: left">
+    <span class="siteTitle">NYTProf Performance Profile</span>
+    <span class="siteSubtitle">&emsp;&emsp;<span>&laquo;&emsp;<span class="mode_btn mode_btn_selected">block view</span>&emsp;&bull;&emsp;<span class="mode_btn"><a href="Moose-pm-62-line.html">line view</a></span>&emsp;&bull;&emsp;<span class="mode_btn"><a href="Moose-pm-62-sub.html">sub view</a></span>&emsp;&raquo;</span><br />
+            For script/nytprof.pl
+        </span>
+</div>
+<div class="headerForeground" style="float: right; text-align: right">
+    <span class="siteTitle">&nbsp;</span>
+    <span class="siteSubtitle">Run on Thu May 31 16:49:15 2012<br />Reported on Thu May 31 16:51:04 2012</span>
+</div>
+<div style="position: absolute; left: 0px; top: 0%; width: 100%; height: 101%; z-index: -1; background-color: rgb(17, 136, 255); "></div>
+<div style="position: absolute; left: 0px; top: 2%; width: 100%; height: 99%; z-index: -1; background-color: rgb(16, 134, 253); "></div>
+<div style="position: absolute; left: 0px; top: 4%; width: 100%; height: 97%; z-index: -1; background-color: rgb(16, 133, 252); "></div>
+<div style="position: absolute; left: 0px; top: 6%; width: 100%; height: 95%; z-index: -1; background-color: rgb(15, 131, 250); "></div>
+<div style="position: absolute; left: 0px; top: 8%; width: 100%; height: 93%; z-index: -1; background-color: rgb(15, 130, 249); "></div>
+<div style="position: absolute; left: 0px; top: 10%; width: 100%; height: 91%; z-index: -1; background-color: rgb(15, 129, 248); "></div>
+<div style="position: absolute; left: 0px; top: 12%; width: 100%; height: 89%; z-index: -1; background-color: rgb(14, 127, 246); "></div>
+<div style="position: absolute; left: 0px; top: 14%; width: 100%; height: 87%; z-index: -1; background-color: rgb(14, 126, 245); "></div>
+<div style="position: absolute; left: 0px; top: 16%; width: 100%; height: 85%; z-index: -1; background-color: rgb(14, 125, 244); "></div>
+<div style="position: absolute; left: 0px; top: 18%; width: 100%; height: 83%; z-index: -1; background-color: rgb(13, 123, 242); "></div>
+<div style="position: absolute; left: 0px; top: 20%; width: 100%; height: 81%; z-index: -1; background-color: rgb(13, 122, 241); "></div>
+<div style="position: absolute; left: 0px; top: 22%; width: 100%; height: 79%; z-index: -1; background-color: rgb(13, 121, 240); "></div>
+<div style="position: absolute; left: 0px; top: 24%; width: 100%; height: 77%; z-index: -1; background-color: rgb(12, 119, 238); "></div>
+<div style="position: absolute; left: 0px; top: 26%; width: 100%; height: 75%; z-index: -1; background-color: rgb(12, 118, 237); "></div>
+<div style="position: absolute; left: 0px; top: 28%; width: 100%; height: 73%; z-index: -1; background-color: rgb(12, 116, 235); "></div>
+<div style="position: absolute; left: 0px; top: 30%; width: 100%; height: 71%; z-index: -1; background-color: rgb(11, 115, 234); "></div>
+<div style="position: absolute; left: 0px; top: 32%; width: 100%; height: 69%; z-index: -1; background-color: rgb(11, 114, 233); "></div>
+<div style="position: absolute; left: 0px; top: 34%; width: 100%; height: 67%; z-index: -1; background-color: rgb(11, 112, 231); "></div>
+<div style="position: absolute; left: 0px; top: 36%; width: 100%; height: 65%; z-index: -1; background-color: rgb(10, 111, 230); "></div>
+<div style="position: absolute; left: 0px; top: 38%; width: 100%; height: 63%; z-index: -1; background-color: rgb(10, 110, 229); "></div>
+<div style="position: absolute; left: 0px; top: 40%; width: 100%; height: 61%; z-index: -1; background-color: rgb(10, 108, 227); "></div>
+<div style="position: absolute; left: 0px; top: 42%; width: 100%; height: 59%; z-index: -1; background-color: rgb(9, 107, 226); "></div>
+<div style="position: absolute; left: 0px; top: 44%; width: 100%; height: 57%; z-index: -1; background-color: rgb(9, 106, 225); "></div>
+<div style="position: absolute; left: 0px; top: 46%; width: 100%; height: 55%; z-index: -1; background-color: rgb(9, 104, 223); "></div>
+<div style="position: absolute; left: 0px; top: 48%; width: 100%; height: 53%; z-index: -1; background-color: rgb(8, 103, 222); "></div>
+<div style="position: absolute; left: 0px; top: 50%; width: 100%; height: 51%; z-index: -1; background-color: rgb(8, 102, 221); "></div>
+<div style="position: absolute; left: 0px; top: 52%; width: 100%; height: 49%; z-index: -1; background-color: rgb(8, 100, 219); "></div>
+<div style="position: absolute; left: 0px; top: 54%; width: 100%; height: 47%; z-index: -1; background-color: rgb(7, 99, 218); "></div>
+<div style="position: absolute; left: 0px; top: 56%; width: 100%; height: 45%; z-index: -1; background-color: rgb(7, 97, 216); "></div>
+<div style="position: absolute; left: 0px; top: 58%; width: 100%; height: 43%; z-index: -1; background-color: rgb(7, 96, 215); "></div>
+<div style="position: absolute; left: 0px; top: 60%; width: 100%; height: 41%; z-index: -1; background-color: rgb(6, 95, 214); "></div>
+<div style="position: absolute; left: 0px; top: 62%; width: 100%; height: 39%; z-index: -1; background-color: rgb(6, 93, 212); "></div>
+<div style="position: absolute; left: 0px; top: 64%; width: 100%; height: 37%; z-index: -1; background-color: rgb(6, 92, 211); "></div>
+<div style="position: absolute; left: 0px; top: 66%; width: 100%; height: 35%; z-index: -1; background-color: rgb(5, 91, 210); "></div>
+<div style="position: absolute; left: 0px; top: 68%; width: 100%; height: 33%; z-index: -1; background-color: rgb(5, 89, 208); "></div>
+<div style="position: absolute; left: 0px; top: 70%; width: 100%; height: 31%; z-index: -1; background-color: rgb(5, 88, 207); "></div>
+<div style="position: absolute; left: 0px; top: 72%; width: 100%; height: 29%; z-index: -1; background-color: rgb(4, 87, 206); "></div>
+<div style="position: absolute; left: 0px; top: 74%; width: 100%; height: 27%; z-index: -1; background-color: rgb(4, 85, 204); "></div>
+<div style="position: absolute; left: 0px; top: 76%; width: 100%; height: 25%; z-index: -1; background-color: rgb(4, 84, 203); "></div>
+<div style="position: absolute; left: 0px; top: 78%; width: 100%; height: 23%; z-index: -1; background-color: rgb(3, 82, 201); "></div>
+<div style="position: absolute; left: 0px; top: 80%; width: 100%; height: 21%; z-index: -1; background-color: rgb(3, 81, 200); "></div>
+<div style="position: absolute; left: 0px; top: 82%; width: 100%; height: 19%; z-index: -1; background-color: rgb(3, 80, 199); "></div>
+<div style="position: absolute; left: 0px; top: 84%; width: 100%; height: 17%; z-index: -1; background-color: rgb(2, 78, 197); "></div>
+<div style="position: absolute; left: 0px; top: 86%; width: 100%; height: 15%; z-index: -1; background-color: rgb(2, 77, 196); "></div>
+<div style="position: absolute; left: 0px; top: 88%; width: 100%; height: 13%; z-index: -1; background-color: rgb(2, 76, 195); "></div>
+<div style="position: absolute; left: 0px; top: 90%; width: 100%; height: 11%; z-index: -1; background-color: rgb(1, 74, 193); "></div>
+<div style="position: absolute; left: 0px; top: 92%; width: 100%; height: 9%; z-index: -1; background-color: rgb(1, 73, 192); "></div>
+<div style="position: absolute; left: 0px; top: 94%; width: 100%; height: 7%; z-index: -1; background-color: rgb(1, 72, 191); "></div>
+<div style="position: absolute; left: 0px; top: 96%; width: 100%; height: 5%; z-index: -1; background-color: rgb(0, 70, 189); "></div>
+<div style="position: absolute; left: 0px; top: 98%; width: 100%; height: 3%; z-index: -1; background-color: rgb(0, 69, 188); "></div>
+<div style="position: absolute; left: 0px; top: 100%; width: 100%; height: 1%; z-index: -1; background-color: rgb(0, 68, 187); "></div>
+</div>
+
+<div class="body_content"><br />
+<table class="file_summary"><tr><td class="h">Filename</td><td align="left"><a href="file:///Users/edenc/perl5/lib/perl5/darwin-multi-2level/Moose.pm">/Users/edenc/perl5/lib/perl5/darwin-multi-2level/Moose.pm</a></td></tr>
+<tr><td class="h">Statements</td><td align="left">Executed 5066 statements in 24.0ms</td></tr></table>
+        
+        <table id="subs_table" border="1" cellpadding="0" class="tablesorter">
+        <caption>Subroutines</caption>
+        <thead>
+        <tr>
+        <th>Calls</th>
+        <th><span title="Number of Places sub is called from">P</span></th>
+        <th><span title="Number of Files sub is called from">F</span></th>
+        <th>Exclusive<br />Time</th>
+        <th>Inclusive<br />Time</th>
+        <th>Subroutine</th>
+        </tr>
+        </thead>
+    <tbody>
+<tr><td class="c0">754</td><td class="c0">377</td><td class="c0">82</td><td class="c0"><span title="0.0%">13.9ms</span></td><td class="c0"><span title="9.0%">4.33s</span></td><td class="sub_name"><span style="display: none;">Moose::::has</span>Moose::<a href="Moose-pm-62-block.html#70">has</a></span></td></tr>
+<tr><td class="c0">123</td><td class="c3">1</td><td class="c3">1</td><td class="c0"><span title="0.0%">7.77ms</span></td><td class="c0"><span title="0.9%">449ms</span></td><td class="sub_name"><span style="display: none;">Moose::::init_meta</span>Moose::<a href="Moose-pm-62-block.html#142">init_meta</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c0"><span title="0.0%">5.10ms</span></td><td class="c0"><span title="0.1%">28.4ms</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@28</span>Moose::<a href="Moose-pm-62-block.html#28">BEGIN@28</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c0"><span title="0.0%">4.88ms</span></td><td class="c0"><span title="0.1%">30.5ms</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@36</span>Moose::<a href="Moose-pm-62-block.html#36">BEGIN@36</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c0"><span title="0.0%">3.83ms</span></td><td class="c0"><span title="0.3%">123ms</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@19</span>Moose::<a href="Moose-pm-62-block.html#19">BEGIN@19</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c0"><span title="0.0%">2.75ms</span></td><td class="c0"><span title="0.0%">11.7ms</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@29</span>Moose::<a href="Moose-pm-62-block.html#29">BEGIN@29</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c0"><span title="0.0%">2.27ms</span></td><td class="c3"><span title="0.0%">4.12ms</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@39</span>Moose::<a href="Moose-pm-62-block.html#39">BEGIN@39</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c0"><span title="0.0%">2.23ms</span></td><td class="c2"><span title="0.0%">5.48ms</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@40</span>Moose::<a href="Moose-pm-62-block.html#40">BEGIN@40</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c1"><span title="0.0%">1.73ms</span></td><td class="c3"><span title="0.0%">3.04ms</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@41</span>Moose::<a href="Moose-pm-62-block.html#41">BEGIN@41</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c1"><span title="0.0%">1.72ms</span></td><td class="c1"><span title="0.0%">7.05ms</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@34</span>Moose::<a href="Moose-pm-62-block.html#34">BEGIN@34</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c1"><span title="0.0%">1.38ms</span></td><td class="c0"><span title="0.3%">164ms</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@30</span>Moose::<a href="Moose-pm-62-block.html#30">BEGIN@30</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c2"><span title="0.0%">1.29ms</span></td><td class="c3"><span title="0.0%">4.06ms</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@38</span>Moose::<a href="Moose-pm-62-block.html#38">BEGIN@38</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c2"><span title="0.0%">1.28ms</span></td><td class="c0"><span title="0.0%">14.1ms</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@15</span>Moose::<a href="Moose-pm-62-block.html#15">BEGIN@15</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c2"><span title="0.0%">1.07ms</span></td><td class="c3"><span title="0.0%">3.42ms</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@37</span>Moose::<a href="Moose-pm-62-block.html#37">BEGIN@37</a></span></td></tr>
+<tr><td class="c0">114</td><td class="c0">58</td><td class="c0">57</td><td class="c2"><span title="0.0%">1.01ms</span></td><td class="c0"><span title="5.9%">2.84s</span></td><td class="sub_name"><span style="display: none;">Moose::::with</span>Moose::<a href="Moose-pm-62-block.html#66">with</a>&nbsp;(recurses: max depth 1, inclusive time 157ms)</span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c3"><span title="0.0%">886&micro;s</span></td><td class="c3"><span title="0.0%">3.14ms</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@42</span>Moose::<a href="Moose-pm-62-block.html#42">BEGIN@42</a></span></td></tr>
+<tr><td class="c0">70</td><td class="c0">36</td><td class="c0">36</td><td class="c3"><span title="0.0%">671&micro;s</span></td><td class="c0"><span title="5.9%">2.82s</span></td><td class="sub_name"><span style="display: none;">Moose::::extends</span>Moose::<a href="Moose-pm-62-block.html#55">extends</a>&nbsp;(recurses: max depth 2, inclusive time 15.1ms)</span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c3"><span title="0.0%">669&micro;s</span></td><td class="c3"><span title="0.0%">1.09ms</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@13</span>Moose::<a href="Moose-pm-62-block.html#13">BEGIN@13</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c3"><span title="0.0%">630&micro;s</span></td><td class="c3"><span title="0.0%">3.11ms</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@47</span>Moose::<a href="Moose-pm-62-block.html#47">BEGIN@47</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c3"><span title="0.0%">559&micro;s</span></td><td class="c3"><span title="0.0%">3.07ms</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@32</span>Moose::<a href="Moose-pm-62-block.html#32">BEGIN@32</a></span></td></tr>
+<tr><td class="c0">54</td><td class="c0">28</td><td class="c0">18</td><td class="c3"><span title="0.0%">433&micro;s</span></td><td class="c0"><span title="0.1%">26.4ms</span></td><td class="sub_name"><span style="display: none;">Moose::::around</span>Moose::<a href="Moose-pm-62-block.html#90">around</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c3"><span title="0.0%">318&micro;s</span></td><td class="c3"><span title="0.0%">3.21ms</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@18</span>Moose::<a href="Moose-pm-62-block.html#18">BEGIN@18</a></span></td></tr>
+<tr><td class="c0">10</td><td class="c0">6</td><td class="c0">4</td><td class="c3"><span title="0.0%">90&micro;s</span></td><td class="c3"><span title="0.0%">4.61ms</span></td><td class="sub_name"><span style="display: none;">Moose::::override</span>Moose::<a href="Moose-pm-62-block.html#105">override</a></span></td></tr>
+<tr><td class="c0">8</td><td class="c3">1</td><td class="c3">1</td><td class="c3"><span title="0.0%">56&micro;s</span></td><td class="c3"><span title="0.0%">102&micro;s</span></td><td class="sub_name"><span style="display: none;">Moose::::super</span>Moose::<a href="Moose-pm-62-block.html#98">super</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c3"><span title="0.0%">45&micro;s</span></td><td class="c3"><span title="0.0%">45&micro;s</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@11</span>Moose::<a href="Moose-pm-62-block.html#11">BEGIN@11</a></span></td></tr>
+<tr><td class="c0">4</td><td class="c0">3</td><td class="c0">3</td><td class="c3"><span title="0.0%">28&micro;s</span></td><td class="c3"><span title="0.0%">2.36ms</span></td><td class="sub_name"><span style="display: none;">Moose::::before</span>Moose::<a href="Moose-pm-62-block.html#82">before</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c3"><span title="0.0%">16&micro;s</span></td><td class="c3"><span title="0.0%">2.06ms</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@44</span>Moose::<a href="Moose-pm-62-block.html#44">BEGIN@44</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c3"><span title="0.0%">13&micro;s</span></td><td class="c3"><span title="0.0%">19&micro;s</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@8</span>Moose::<a href="Moose-pm-62-block.html#8">BEGIN@8</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c3"><span title="0.0%">12&micro;s</span></td><td class="c3"><span title="0.0%">22&micro;s</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@9</span>Moose::<a href="Moose-pm-62-block.html#9">BEGIN@9</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c3"><span title="0.0%">11&micro;s</span></td><td class="c3"><span title="0.0%">11&micro;s</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@21</span>Moose::<a href="Moose-pm-62-block.html#21">BEGIN@21</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c3"><span title="0.0%">11&micro;s</span></td><td class="c3"><span title="0.0%">52&micro;s</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@14</span>Moose::<a href="Moose-pm-62-block.html#14">BEGIN@14</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c3"><span title="0.0%">10&micro;s</span></td><td class="c3"><span title="0.0%">10&micro;s</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@2</span>Moose::<a href="Moose-pm-62-block.html#2">BEGIN@2</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c3"><span title="0.0%">8&micro;s</span></td><td class="c3"><span title="0.0%">8&micro;s</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@23</span>Moose::<a href="Moose-pm-62-block.html#23">BEGIN@23</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c3"><span title="0.0%">8&micro;s</span></td><td class="c3"><span title="0.0%">8&micro;s</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@31</span>Moose::<a href="Moose-pm-62-block.html#31">BEGIN@31</a></span></td></tr>
+<tr><td class="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c3"><span title="0.0%">7&micro;s</span></td><td class="c3"><span title="0.0%">7&micro;s</span></td><td class="sub_name"><span style="display: none;">Moose::::BEGIN@45</span>Moose::<a href="Moose-pm-62-block.html#45">BEGIN@45</a></span></td></tr>
+<tr><td class="c3">0</td><td class="c3">0</td><td class="c3">0</td><td class="c3"><span title="0.0%">0s</span></td><td class="c3"><span title="0.0%">0s</span></td><td class="sub_name"><span style="display: none;">Moose::::_get_caller</span>Moose::<a href="Moose-pm-62-block.html#222">_get_caller</a></span></td></tr>
+<tr><td class="c3">0</td><td class="c3">0</td><td class="c3">0</td><td class="c3"><span title="0.0%">0s</span></td><td class="c3"><span title="0.0%">0s</span></td><td class="sub_name"><span style="display: none;">Moose::::after</span>Moose::<a href="Moose-pm-62-block.html#86">after</a></span></td></tr>
+<tr><td class="c3">0</td><td class="c3">0</td><td class="c3">0</td><td class="c3"><span title="0.0%">0s</span></td><td class="c3"><span title="0.0%">0s</span></td><td class="sub_name"><span style="display: none;">Moose::::augment</span>Moose::<a href="Moose-pm-62-block.html#125">augment</a></span></td></tr>
+<tr><td class="c3">0</td><td class="c3">0</td><td class="c3">0</td><td class="c3"><span title="0.0%">0s</span></td><td class="c3"><span title="0.0%">0s</span></td><td class="sub_name"><span style="display: none;">Moose::::inner</span>Moose::<a href="Moose-pm-62-block.html#111">inner</a></span></td></tr>
+<tr><td class="c3">0</td><td class="c3">0</td><td class="c3">0</td><td class="c3"><span title="0.0%">0s</span></td><td class="c3"><span title="0.0%">0s</span></td><td class="sub_name"><span style="display: none;">Moose::::throw_error</span>Moose::<a href="Moose-pm-62-block.html#49">throw_error</a></span></td></tr>
+</tbody></table>
+                Call graph for these subroutines as a
+                <a href="http://en.wikipedia.org/wiki/Graphviz">Graphviz</a>
+                <a href="Users-edenc-perl5-lib-perl5-darwin-multi-2level-Moose-pm.dot">dot language file</a>.
+            
+      <table border="1" cellpadding="0">
+      <thead>
+      <tr><th>Line</th>
+      <th><span title="Number of statements executed">State<br />ments</span></th>
+      <th><span title="Time spend executing statements on the line,
+        excluding time spent executing statements in any called subroutines">Time<br />on line</span></th>
+      <th><span title="Number of subroutines calls">Calls</span></th>
+      <th><span title="Time spent in subroutines called (inclusive)">Time<br />in subs</span></th>
+      <th class="left_indent_header">Code</th>
+      </tr>
+
+      </thead>
+      <tbody>
+    <tr><td class="h"><a name="1"></a>1</td><td></td><td></td><td></td><td></td><td class="s">package Moose;</td></tr>
+<tr><td class="h"><a name="2"></a>2</td><td></td><td></td><td></td><td></td><td class="s"><div class="calls"><div class="calls_in"># spent 10&micro;s within Moose::BEGIN@2 which was called:
+#    once (10&micro;s+0s) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#4">line 4</a></div></div>BEGIN {</td></tr>
+<tr><td class="h"><a name="3"></a>3</td><td class="c3">1</td><td class="c3"><span title="Avg 5&micro;s">5&micro;s</span></td><td></td><td></td><td class="s">  $Moose::AUTHORITY = 'cpan:STEVAN';</td></tr>
+<tr><td class="h"><a name="4"></a>4</td><td class="c3">1</td><td class="c3"><span title="Avg 28&micro;s">28&micro;s</span></td><td class="c3">1</td><td class="c3">10&micro;s</td><td class="s">}<div class="calls"><div class="calls_out"># spent    10&micro;s making 1 call to <a href="Moose-pm-62-block.html#2">Moose::BEGIN@2</a></div></div></td></tr>
+<tr><td class="h"><a name="5"></a>5</td><td></td><td></td><td></td><td></td><td class="s">{</td></tr>
+<tr><td class="h"><a name="6"></a>6</td><td class="c3">2</td><td class="c3"><span title="Avg 2&micro;s">3&micro;s</span></td><td></td><td></td><td class="s">  $Moose::VERSION = '2.0602';</td></tr>
+<tr><td class="h"><a name="7"></a>7</td><td></td><td></td><td></td><td></td><td class="s">}</td></tr>
+<tr><td class="h"><a name="8"></a>8</td><td class="c3">2</td><td class="c3"><span title="Avg 14&micro;s">28&micro;s</span></td><td class="c3">2</td><td class="c3">24&micro;s</td><td class="s"><div class="calls"><div class="calls_in"># spent 19&micro;s (13+5) within Moose::BEGIN@8 which was called:
+#    once (13&micro;s+5&micro;s) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#8">line 8</a></div></div>use strict;<div class="calls"><div class="calls_out"># spent    19&micro;s making 1 call to <a href="Moose-pm-62-block.html#8">Moose::BEGIN@8</a>
+# spent     5&micro;s making 1 call to <a href="strict-pm-3-block.html#34">strict::import</a></div></div></td></tr>
+<tr><td class="h"><a name="9"></a>9</td><td class="c3">2</td><td class="c3"><span title="Avg 14&micro;s">28&micro;s</span></td><td class="c3">2</td><td class="c3">31&micro;s</td><td class="s"><div class="calls"><div class="calls_in"># spent 22&micro;s (12+10) within Moose::BEGIN@9 which was called:
+#    once (12&micro;s+10&micro;s) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#9">line 9</a></div></div>use warnings;<div class="calls"><div class="calls_out"># spent    22&micro;s making 1 call to <a href="Moose-pm-62-block.html#9">Moose::BEGIN@9</a>
+# spent    10&micro;s making 1 call to <a href="warnings-pm-2-block.html#386">warnings::import</a></div></div></td></tr>
+<tr><td class="h"><a name="10"></a>10</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="11"></a>11</td><td class="c3">2</td><td class="c3"><span title="Avg 39&micro;s">78&micro;s</span></td><td class="c3">1</td><td class="c3">45&micro;s</td><td class="s"><div class="calls"><div class="calls_in"># spent 45&micro;s within Moose::BEGIN@11 which was called:
+#    once (45&micro;s+0s) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#11">line 11</a></div></div>use 5.008;<div class="calls"><div class="calls_out"># spent    45&micro;s making 1 call to <a href="Moose-pm-62-block.html#11">Moose::BEGIN@11</a></div></div></td></tr>
+<tr><td class="h"><a name="12"></a>12</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="13"></a>13</td><td class="c3">2</td><td class="c3"><span title="Avg 76&micro;s">152&micro;s</span></td><td class="c3">2</td><td class="c3">1.17ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 1.09ms (669&micro;s+420&micro;s) within Moose::BEGIN@13 which was called:
+#    once (669&micro;s+420&micro;s) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#13">line 13</a></div></div>use Scalar::Util 'blessed';<div class="calls"><div class="calls_out"># spent  1.09ms making 1 call to <a href="Moose-pm-62-block.html#13">Moose::BEGIN@13</a>
+# spent    77&micro;s making 1 call to <a href="Exporter-pm-8-block.html#28">Exporter::import</a></div></div></td></tr>
+<tr><td class="h"><a name="14"></a>14</td><td class="c3">2</td><td class="c3"><span title="Avg 14&micro;s">29&micro;s</span></td><td class="c3">2</td><td class="c3">94&micro;s</td><td class="s"><div class="calls"><div class="calls_in"># spent 52&micro;s (11+42) within Moose::BEGIN@14 which was called:
+#    once (11&micro;s+42&micro;s) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#14">line 14</a></div></div>use Carp         'confess';<div class="calls"><div class="calls_out"># spent    52&micro;s making 1 call to <a href="Moose-pm-62-block.html#14">Moose::BEGIN@14</a>
+# spent    42&micro;s making 1 call to <a href="Exporter-pm-8-block.html#28">Exporter::import</a></div></div></td></tr>
+<tr><td class="h"><a name="15"></a>15</td><td class="c3">2</td><td class="c2"><span title="Avg 104&micro;s">207&micro;s</span></td><td class="c3">2</td><td class="c0">14.1ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 14.1ms (1.28+12.8) within Moose::BEGIN@15 which was called:
+#    once (1.28ms+12.8ms) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#15">line 15</a></div></div>use Class::Load  'is_class_loaded';<div class="calls"><div class="calls_out"># spent  14.1ms making 1 call to <a href="Moose-pm-62-block.html#15">Moose::BEGIN@15</a>
+# spent    53&micro;s making 1 call to <a href="Exporter-pm-8-block.html#28">Exporter::import</a></div></div></td></tr>
+<tr><td class="h"><a name="16"></a>16</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="17"></a>17</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="18"></a>18</td><td class="c3">2</td><td class="c3"><span title="Avg 71&micro;s">142&micro;s</span></td><td class="c3">2</td><td class="c3">3.22ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 3.21ms (318&micro;s+2.90) within Moose::BEGIN@18 which was called:
+#    once (318&micro;s+2.90ms) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#18">line 18</a></div></div>use Moose::Deprecated;<div class="calls"><div class="calls_out"># spent  3.21ms making 1 call to <a href="Moose-pm-62-block.html#18">Moose::BEGIN@18</a>
+# spent     9&micro;s making 1 call to <a href="Package-DeprecationManager-pm-80-block.html#51">Package::DeprecationManager::__ANON__[Package/DeprecationManager.pm:61]</a></div></div></td></tr>
+<tr><td class="h"><a name="19"></a>19</td><td class="c3">2</td><td class="c3"><span title="Avg 78&micro;s">155&micro;s</span></td><td class="c3">2</td><td class="c0">123ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 123ms (3.83+119) within Moose::BEGIN@19 which was called:
+#    once (3.83ms+119ms) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#19">line 19</a></div></div>use Moose::Exporter;<div class="calls"><div class="calls_out"># spent   123ms making 1 call to <a href="Moose-pm-62-block.html#19">Moose::BEGIN@19</a>
+# spent    37&micro;s making 1 call to <a href="Moose-Exporter-pm-82-block.html#753">Moose::Exporter::import</a></div></div></td></tr>
+<tr><td class="h"><a name="20"></a>20</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="21"></a>21</td><td class="c3">2</td><td class="c3"><span title="Avg 44&micro;s">88&micro;s</span></td><td class="c3">1</td><td class="c3">11&micro;s</td><td class="s"><div class="calls"><div class="calls_in"># spent 11&micro;s within Moose::BEGIN@21 which was called:
+#    once (11&micro;s+0s) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#21">line 21</a></div></div>use Class::MOP;<div class="calls"><div class="calls_out"># spent    11&micro;s making 1 call to <a href="Moose-pm-62-block.html#21">Moose::BEGIN@21</a></div></div></td></tr>
+<tr><td class="h"><a name="22"></a>22</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="23"></a>23</td><td></td><td></td><td></td><td></td><td class="s"><div class="calls"><div class="calls_in"># spent 8&micro;s within Moose::BEGIN@23 which was called:
+#    once (8&micro;s+0s) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#26">line 26</a></div></div>BEGIN {</td></tr>
+<tr><td class="h"><a name="24"></a>24</td><td class="c3">1</td><td class="c3"><span title="Avg 7&micro;s">7&micro;s</span></td><td></td><td></td><td class="s">    die &quot;Class::MOP version $Moose::VERSION required--this is version $Class::MOP::VERSION&quot;</td></tr>
+<tr><td class="h"><a name="25"></a>25</td><td></td><td></td><td></td><td></td><td class="s">        if $Moose::VERSION &amp;&amp; $Class::MOP::VERSION ne $Moose::VERSION;</td></tr>
+<tr><td class="h"><a name="26"></a>26</td><td class="c3">1</td><td class="c3"><span title="Avg 36&micro;s">36&micro;s</span></td><td class="c3">1</td><td class="c3">8&micro;s</td><td class="s">}<div class="calls"><div class="calls_out"># spent     8&micro;s making 1 call to <a href="Moose-pm-62-block.html#23">Moose::BEGIN@23</a></div></div></td></tr>
+<tr><td class="h"><a name="27"></a>27</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="28"></a>28</td><td class="c3">2</td><td class="c2"><span title="Avg 122&micro;s">244&micro;s</span></td><td class="c3">1</td><td class="c0">28.4ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 28.4ms (5.10+23.3) within Moose::BEGIN@28 which was called:
+#    once (5.10ms+23.3ms) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#28">line 28</a></div></div>use Moose::Meta::Class;<div class="calls"><div class="calls_out"># spent  28.4ms making 1 call to <a href="Moose-pm-62-block.html#28">Moose::BEGIN@28</a></div></div></td></tr>
+<tr><td class="h"><a name="29"></a>29</td><td class="c3">2</td><td class="c2"><span title="Avg 110&micro;s">221&micro;s</span></td><td class="c3">1</td><td class="c0">11.7ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 11.7ms (2.75+8.97) within Moose::BEGIN@29 which was called:
+#    once (2.75ms+8.97ms) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#29">line 29</a></div></div>use Moose::Meta::TypeConstraint;<div class="calls"><div class="calls_out"># spent  11.7ms making 1 call to <a href="Moose-pm-62-block.html#29">Moose::BEGIN@29</a></div></div></td></tr>
+<tr><td class="h"><a name="30"></a>30</td><td class="c3">2</td><td class="c3"><span title="Avg 93&micro;s">186&micro;s</span></td><td class="c3">1</td><td class="c0">164ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 164ms (1.38+162) within Moose::BEGIN@30 which was called:
+#    once (1.38ms+162ms) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#30">line 30</a></div></div>use Moose::Meta::TypeCoercion;<div class="calls"><div class="calls_out"># spent   164ms making 1 call to <a href="Moose-pm-62-block.html#30">Moose::BEGIN@30</a></div></div></td></tr>
+<tr><td class="h"><a name="31"></a>31</td><td class="c3">2</td><td class="c3"><span title="Avg 22&micro;s">44&micro;s</span></td><td class="c3">1</td><td class="c3">8&micro;s</td><td class="s"><div class="calls"><div class="calls_in"># spent 8&micro;s within Moose::BEGIN@31 which was called:
+#    once (8&micro;s+0s) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#31">line 31</a></div></div>use Moose::Meta::Attribute;<div class="calls"><div class="calls_out"># spent     8&micro;s making 1 call to <a href="Moose-pm-62-block.html#31">Moose::BEGIN@31</a></div></div></td></tr>
+<tr><td class="h"><a name="32"></a>32</td><td class="c3">2</td><td class="c1"><span title="Avg 156&micro;s">311&micro;s</span></td><td class="c3">1</td><td class="c3">3.07ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 3.07ms (559&micro;s+2.51) within Moose::BEGIN@32 which was called:
+#    once (559&micro;s+2.51ms) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#32">line 32</a></div></div>use Moose::Meta::Instance;<div class="calls"><div class="calls_out"># spent  3.07ms making 1 call to <a href="Moose-pm-62-block.html#32">Moose::BEGIN@32</a></div></div></td></tr>
+<tr><td class="h"><a name="33"></a>33</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="34"></a>34</td><td class="c3">2</td><td class="c2"><span title="Avg 111&micro;s">222&micro;s</span></td><td class="c3">1</td><td class="c1">7.05ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 7.05ms (1.72+5.33) within Moose::BEGIN@34 which was called:
+#    once (1.72ms+5.33ms) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#34">line 34</a></div></div>use Moose::Object;<div class="calls"><div class="calls_out"># spent  7.05ms making 1 call to <a href="Moose-pm-62-block.html#34">Moose::BEGIN@34</a></div></div></td></tr>
+<tr><td class="h"><a name="35"></a>35</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="36"></a>36</td><td class="c3">2</td><td class="c2"><span title="Avg 111&micro;s">222&micro;s</span></td><td class="c3">1</td><td class="c0">30.5ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 30.5ms (4.88+25.7) within Moose::BEGIN@36 which was called:
+#    once (4.88ms+25.7ms) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#36">line 36</a></div></div>use Moose::Meta::Role;<div class="calls"><div class="calls_out"># spent  30.5ms making 1 call to <a href="Moose-pm-62-block.html#36">Moose::BEGIN@36</a></div></div></td></tr>
+<tr><td class="h"><a name="37"></a>37</td><td class="c3">2</td><td class="c2"><span title="Avg 115&micro;s">229&micro;s</span></td><td class="c3">1</td><td class="c3">3.42ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 3.42ms (1.07+2.34) within Moose::BEGIN@37 which was called:
+#    once (1.07ms+2.34ms) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#37">line 37</a></div></div>use Moose::Meta::Role::Composite;<div class="calls"><div class="calls_out"># spent  3.42ms making 1 call to <a href="Moose-pm-62-block.html#37">Moose::BEGIN@37</a></div></div></td></tr>
+<tr><td class="h"><a name="38"></a>38</td><td class="c3">2</td><td class="c1"><span title="Avg 127&micro;s">254&micro;s</span></td><td class="c3">1</td><td class="c3">4.06ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 4.06ms (1.29+2.77) within Moose::BEGIN@38 which was called:
+#    once (1.29ms+2.77ms) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#38">line 38</a></div></div>use Moose::Meta::Role::Application;<div class="calls"><div class="calls_out"># spent  4.06ms making 1 call to <a href="Moose-pm-62-block.html#38">Moose::BEGIN@38</a></div></div></td></tr>
+<tr><td class="h"><a name="39"></a>39</td><td class="c3">2</td><td class="c2"><span title="Avg 119&micro;s">238&micro;s</span></td><td class="c3">1</td><td class="c3">4.12ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 4.12ms (2.27+1.86) within Moose::BEGIN@39 which was called:
+#    once (2.27ms+1.86ms) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#39">line 39</a></div></div>use Moose::Meta::Role::Application::RoleSummation;<div class="calls"><div class="calls_out"># spent  4.12ms making 1 call to <a href="Moose-pm-62-block.html#39">Moose::BEGIN@39</a></div></div></td></tr>
+<tr><td class="h"><a name="40"></a>40</td><td class="c3">2</td><td class="c3"><span title="Avg 93&micro;s">187&micro;s</span></td><td class="c3">1</td><td class="c2">5.48ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 5.48ms (2.23+3.25) within Moose::BEGIN@40 which was called:
+#    once (2.23ms+3.25ms) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#40">line 40</a></div></div>use Moose::Meta::Role::Application::ToClass;<div class="calls"><div class="calls_out"># spent  5.48ms making 1 call to <a href="Moose-pm-62-block.html#40">Moose::BEGIN@40</a></div></div></td></tr>
+<tr><td class="h"><a name="41"></a>41</td><td class="c3">2</td><td class="c2"><span title="Avg 120&micro;s">241&micro;s</span></td><td class="c3">1</td><td class="c3">3.04ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 3.04ms (1.73+1.32) within Moose::BEGIN@41 which was called:
+#    once (1.73ms+1.32ms) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#41">line 41</a></div></div>use Moose::Meta::Role::Application::ToRole;<div class="calls"><div class="calls_out"># spent  3.04ms making 1 call to <a href="Moose-pm-62-block.html#41">Moose::BEGIN@41</a></div></div></td></tr>
+<tr><td class="h"><a name="42"></a>42</td><td class="c3">2</td><td class="c2"><span title="Avg 121&micro;s">241&micro;s</span></td><td class="c3">1</td><td class="c3">3.14ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 3.14ms (886&micro;s+2.25) within Moose::BEGIN@42 which was called:
+#    once (886&micro;s+2.25ms) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#42">line 42</a></div></div>use Moose::Meta::Role::Application::ToInstance;<div class="calls"><div class="calls_out"># spent  3.14ms making 1 call to <a href="Moose-pm-62-block.html#42">Moose::BEGIN@42</a></div></div></td></tr>
+<tr><td class="h"><a name="43"></a>43</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="44"></a>44</td><td class="c3">2</td><td class="c3"><span title="Avg 31&micro;s">62&micro;s</span></td><td class="c3">2</td><td class="c3">4.10ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 2.06ms (16&micro;s+2.04) within Moose::BEGIN@44 which was called:
+#    once (16&micro;s+2.04ms) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#44">line 44</a></div></div>use Moose::Util::TypeConstraints;<div class="calls"><div class="calls_out"># spent  2.06ms making 1 call to <a href="Moose-pm-62-block.html#44">Moose::BEGIN@44</a>
+# spent  2.04ms making 1 call to <a href="Moose-Exporter-pm-82-block.html#402">Moose::Exporter::__ANON__[Moose/Exporter.pm:492]</a></div></div></td></tr>
+<tr><td class="h"><a name="45"></a>45</td><td class="c3">2</td><td class="c3"><span title="Avg 13&micro;s">27&micro;s</span></td><td class="c3">1</td><td class="c3">7&micro;s</td><td class="s"><div class="calls"><div class="calls_in"># spent 7&micro;s within Moose::BEGIN@45 which was called:
+#    once (7&micro;s+0s) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#45">line 45</a></div></div>use Moose::Util ();<div class="calls"><div class="calls_out"># spent     7&micro;s making 1 call to <a href="Moose-pm-62-block.html#45">Moose::BEGIN@45</a></div></div></td></tr>
+<tr><td class="h"><a name="46"></a>46</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="47"></a>47</td><td class="c3">2</td><td class="c0"><span title="Avg 822&micro;s">1.64ms</span></td><td class="c3">1</td><td class="c3">3.11ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 3.11ms (630&micro;s+2.48) within Moose::BEGIN@47 which was called:
+#    once (630&micro;s+2.48ms) by stemmaweb::BEGIN@2 at <a href="Moose-pm-62-block.html#47">line 47</a></div></div>use Moose::Meta::Attribute::Native;<div class="calls"><div class="calls_out"># spent  3.11ms making 1 call to <a href="Moose-pm-62-block.html#47">Moose::BEGIN@47</a></div></div></td></tr>
+<tr><td class="h"><a name="48"></a>48</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="49"></a>49</td><td></td><td></td><td></td><td></td><td class="s">sub throw_error {</td></tr>
+<tr><td class="h"><a name="50"></a>50</td><td></td><td></td><td></td><td></td><td class="s">    # FIXME This</td></tr>
+<tr><td class="h"><a name="51"></a>51</td><td></td><td></td><td></td><td></td><td class="s">    shift;</td></tr>
+<tr><td class="h"><a name="52"></a>52</td><td></td><td></td><td></td><td></td><td class="s">    goto \&amp;confess</td></tr>
+<tr><td class="h"><a name="53"></a>53</td><td></td><td></td><td></td><td></td><td class="s">}</td></tr>
+<tr><td class="h"><a name="54"></a>54</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="55"></a>55</td><td></td><td></td><td></td><td></td><td class="s"><div class="calls"><div class="calls_in"># spent 2.82s (671&micro;s+2.82) within Moose::extends which was called 70 times, avg 40.3ms/call:
+# 35 times (266&micro;s+1.40s) by Moose::extends at <a href="Moose-Exporter-pm-82-block.html#382">line 382 of Moose/Exporter.pm</a>, avg 40.1ms/call
+#     once (17&micro;s+1.13s) by main::BEGIN@11 at <a href="lib-Text-Tradition-Directory-pm-1356-block.html#13">line 13 of lib/Text/Tradition/Directory.pm</a>
+#     once (10&micro;s+120ms) by Catalyst::Controller::BEGIN@8 at <a href="Catalyst-Controller-pm-576-block.html#8">line 8 of Catalyst/Controller.pm</a>
+#     once (10&micro;s+59.8ms) by Catalyst::Utils::ensure_class_loaded at <a href="lib-stemmaweb-Model-Directory-pm-2052-block.html#7">line 7 of lib/stemmaweb/Model/Directory.pm</a>
+#     once (10&micro;s+21.5ms) by KiokuDB::Backend::DBI::BEGIN@26 at <a href="KiokuDB-Backend-DBI-Schema-pm-2164-block.html#14">line 14 of KiokuDB/Backend/DBI/Schema.pm</a>
+#     once (10&micro;s+12.6ms) by Module::Runtime::require_module at <a href="Catalyst-Model-KiokuDB-pm-2055-block.html#17">line 17 of Catalyst/Model/KiokuDB.pm</a>
+#     once (10&micro;s+9.74ms) by Catalyst::Dispatcher::BEGIN@11 at <a href="Catalyst-DispatchType-Default-pm-1899-block.html#4">line 4 of Catalyst/DispatchType/Default.pm</a>
+#     once (8&micro;s+8.51ms) by KiokuDB::TypeMap::Entry::Set::BEGIN@8 at <a href="KiokuDB-Set-Stored-pm-2568-block.html#8">line 8 of KiokuDB/Set/Stored.pm</a>
+#     once (9&micro;s+6.75ms) by stemmaweb::Controller::Stexaminer::BEGIN@8 at <a href="lib-stemmaweb-Controller-Stexaminer-pm-2108-block.html#8">line 8 of lib/stemmaweb/Controller/Stexaminer.pm</a>
+#     once (12&micro;s+6.64ms) by stemmaweb::Controller::Root::BEGIN@7 at <a href="lib-stemmaweb-Controller-Root-pm-2077-block.html#7">line 7 of lib/stemmaweb/Controller/Root.pm</a>
+#     once (14&micro;s+5.55ms) by Catalyst::BEGIN@32 at <a href="Catalyst-EngineLoader-pm-643-block.html#7">line 7 of Catalyst/EngineLoader.pm</a>
+#     once (9&micro;s+5.48ms) by stemmaweb::Controller::Relation::BEGIN@6 at <a href="lib-stemmaweb-Controller-Relation-pm-2093-block.html#6">line 6 of lib/stemmaweb/Controller/Relation.pm</a>
+#     once (8&micro;s+5.28ms) by stemmaweb::Controller::Microservice::BEGIN@11 at <a href="lib-stemmaweb-Controller-Microservice-pm-2113-block.html#11">line 11 of lib/stemmaweb/Controller/Microservice.pm</a>
+#     once (21&micro;s+1.58ms) by MooseX::Types::Structured::BEGIN@13 at <a href="MooseX-Meta-TypeConstraint-Structured-pm-1203-block.html#9">line 9 of MooseX/Meta/TypeConstraint/Structured.pm</a>
+#     once (15&micro;s+1.54ms) by MooseX::Emulate::Class::Accessor::Fast::BEGIN@7 at <a href="MooseX-Accessor-pm-476-block.html#5">line 5 of MooseX/Emulate/Class/Accessor/Fast/Meta/Accessor.pm</a>
+#     once (16&micro;s+1.49ms) by MooseX::Role::Parameterized::Meta::Role::Parameterizable::BEGIN@7 at <a href="MooseX-Parameterized-pm-833-block.html#3">line 3 of MooseX/Role/Parameterized/Meta/Role/Parameterized.pm</a>
+#     once (13&micro;s+1.43ms) by Module::Runtime::require_module at <a href="Catalyst-Model-pm-2058-block.html#4">line 4 of Catalyst/Model.pm</a>
+#     once (14&micro;s+1.41ms) by MooseX::Types::Structured::BEGIN@14 at <a href="MooseX-Meta-TypeConstraint-Structured-Optional-pm-1229-block.html#7">line 7 of MooseX/Meta/TypeConstraint/Structured/Optional.pm</a>
+#     once (15&micro;s+1.41ms) by main::BEGIN@9 at <a href="lib-stemmaweb-pm-61-block.html#25">line 25 of lib/stemmaweb.pm</a>
+#     once (12&micro;s+1.33ms) by MooseX::Meta::TypeConstraint::Structured::BEGIN@8 at <a href="MooseX-Meta-TypeCoercion-Structured-pm-1221-block.html#6">line 6 of MooseX/Meta/TypeCoercion/Structured.pm</a>
+#     once (23&micro;s+1.25ms) by Catalyst::Exception::BEGIN@63 at <a href="Catalyst-Exception-pm-384-block.html#64">line 64 of Catalyst/Exception.pm</a>
+#     once (12&micro;s+1.24ms) by MooseX::Meta::TypeConstraint::Structured::Optional::BEGIN@5 at <a href="MooseX-Meta-TypeCoercion-Structured-Optional-pm-1232-block.html#5">line 5 of MooseX/Meta/TypeCoercion/Structured/Optional.pm</a>
+#     once (13&micro;s+1.24ms) by Module::Runtime::require_module at <a href="Catalyst-DispatchType-Regex-pm-2487-block.html#4">line 4 of Catalyst/DispatchType/Regex.pm</a>
+#     once (13&micro;s+1.16ms) by KiokuDB::BEGIN@11 at <a href="KiokuDB-Collapser-pm-1524-block.html#26">line 26 of KiokuDB/Collapser.pm</a>
+#     once (9&micro;s+1.13ms) by base::import at <a href="Catalyst-View-pm-2019-block.html#4">line 4 of Catalyst/View.pm</a>
+#     once (11&micro;s+1.05ms) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#5">line 5 of Catalyst.pm</a>
+#     once (10&micro;s+1.03ms) by Catalyst::Plugin::ConfigLoader::BEGIN@8 at <a href="Data-Visitor-Callback-pm-1863-block.html#23">line 23 of Data/Visitor/Callback.pm</a>
+#     once (10&micro;s+1.01ms) by MooseX::Role::Parameterized::BEGIN@7 at <a href="MooseX-Parameterizable-pm-830-block.html#3">line 3 of MooseX/Role/Parameterized/Meta/Role/Parameterizable.pm</a>
+#     once (9&micro;s+986&micro;s) by KiokuDB::TypeMap::Entry::Set::BEGIN@9 at <a href="KiokuDB-Set-Deferred-pm-2579-block.html#16">line 16 of KiokuDB/Set/Deferred.pm</a>
+#     once (9&micro;s+982&micro;s) by Module::Runtime::require_module at <a href="Catalyst-DispatchType-Chained-pm-2498-block.html#4">line 4 of Catalyst/DispatchType/Chained.pm</a>
+#     once (11&micro;s+904&micro;s) by Module::Runtime::require_module at <a href="Catalyst-DispatchType-Path-pm-2481-block.html#4">line 4 of Catalyst/DispatchType/Path.pm</a>
+#     once (9&micro;s+877&micro;s) by KiokuDB::Set::Deferred::BEGIN@8 at <a href="KiokuDB-Set-Loaded-pm-2582-block.html#12">line 12 of KiokuDB/Set/Loaded.pm</a>
+#     once (9&micro;s+846&micro;s) by KiokuDB::Backend::DBI::BEGIN@30 at <a href="KiokuDB-TypeMap-Entry-DBIC-ResultSet-pm-2222-block.html#15">line 15 of KiokuDB/TypeMap/Entry/DBIC/ResultSet.pm</a>
+#     once (9&micro;s+820&micro;s) by KiokuDB::Backend::TypeMap::Default::JSON::BEGIN@6 at <a href="KiokuDB-TypeMap-Default-JSON-pm-2384-block.html#8">line 8 of KiokuDB/TypeMap/Default/JSON.pm</a>
+#     once (9&micro;s+818&micro;s) by Catalyst::DispatchType::Chained::BEGIN@7 at <a href="Catalyst-ActionChain-pm-2501-block.html#4">line 4 of Catalyst/ActionChain.pm</a>
+#     once (8&micro;s+814&micro;s) by Catalyst::Dispatcher::BEGIN@12 at <a href="Catalyst-DispatchType-Index-pm-1909-block.html#4">line 4 of Catalyst/DispatchType/Index.pm</a></div></div>sub extends {</td></tr>
+<tr><td class="h"><a name="56"></a>56</td><td class="c0">105</td><td class="c2"><span title="Avg 2&micro;s">242&micro;s</span></td><td></td><td></td><td class="s">    my $meta = shift;</td></tr>
+<tr><td class="h"><a name="57"></a>57</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="58"></a>58</td><td></td><td></td><td></td><td></td><td class="s">    Moose-&gt;throw_error(&quot;Must derive at least one class&quot;) unless @_;</td></tr>
+<tr><td class="h"><a name="59"></a>59</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="60"></a>60</td><td></td><td></td><td></td><td></td><td class="s">    # this checks the metaclass to make sure</td></tr>
+<tr><td class="h"><a name="61"></a>61</td><td></td><td></td><td></td><td></td><td class="s">    # it is correct, sometimes it can get out</td></tr>
+<tr><td class="h"><a name="62"></a>62</td><td></td><td></td><td></td><td></td><td class="s">    # of sync when the classes are being built</td></tr>
+<tr><td class="h"><a name="63"></a>63</td><td></td><td></td><td class="c0">35</td><td class="c0">1.40s</td><td class="s">    $meta-&gt;superclasses(@_);<div class="calls"><div class="calls_out">    # spent  1.42s making 35 calls to <a href="Moose-Meta-Class-pm-136-block.html#549">Moose::Meta::Class::superclasses</a>, avg 40.5ms/call, recursion: max depth 2, sum of overlapping time 15.1ms</div></div></td></tr>
+<tr><td class="h"><a name="64"></a>64</td><td></td><td></td><td></td><td></td><td class="s">}</td></tr>
+<tr><td class="h"><a name="65"></a>65</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="66"></a>66</td><td></td><td></td><td></td><td></td><td class="s"><div class="calls"><div class="calls_in"># spent 2.84s (1.01ms+2.84) within Moose::with which was called 114 times, avg 24.9ms/call:
+# 57 times (342&micro;s+1.34s) by Moose::with at <a href="Moose-Exporter-pm-82-block.html#382">line 382 of Moose/Exporter.pm</a>, avg 23.5ms/call
+#     once (9&micro;s+296ms) by Module::Runtime::require_module at <a href="KiokuDB-Serializer-JSON-pm-2327-block.html#8">line 8 of KiokuDB/Serializer/JSON.pm</a>
+#     once (14&micro;s+213ms) by Catalyst::BEGIN@8 at <a href="Catalyst-Exception-pm-384-block.html#50">line 50 of Catalyst/Exception.pm</a>
+#     once (11&micro;s+111ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#35">line 35 of KiokuDB/Backend/DBI.pm</a>
+#     once (16&micro;s+97.9ms) by Text::Tradition::Directory::BEGIN@10 at <a href="KiokuDB-TypeMap-Entry-Naive-pm-1474-block.html#10">line 10 of KiokuDB/TypeMap/Entry/Naive.pm</a>
+#     once (9&micro;s+92.8ms) by KiokuDB::BEGIN@17 at <a href="KiokuDB-Stream-Objects-pm-1765-block.html#56">line 56 of KiokuDB/Stream/Objects.pm</a>
+#     once (8&micro;s+78.4ms) by KiokuDB::Backend::TypeMap::Default::JSON::BEGIN@6 at <a href="KiokuDB-TypeMap-Default-JSON-pm-2384-block.html#10">line 10 of KiokuDB/TypeMap/Default/JSON.pm</a>
+#     once (14&micro;s+69.1ms) by KiokuDB::GC::Naive::BEGIN@6 at <a href="KiokuDB-GC-Naive-Mark-pm-1363-block.html#8">line 8 of KiokuDB/GC/Naive/Mark.pm</a>
+#     once (16&micro;s+65.7ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#10">line 10 of KiokuDB/Entry.pm</a>
+#     once (9&micro;s+55.3ms) by Text::Tradition::Collation::RelationshipStore::BEGIN@5 at <a href="lib-Text-Tradition-Error-pm-812-block.html#8">line 8 of lib/Text/Tradition/Error.pm</a>
+#     once (12&micro;s+39.3ms) by KiokuDB::GC::Naive::BEGIN@7 at <a href="KiokuDB-GC-Naive-Sweep-pm-1400-block.html#8">line 8 of KiokuDB/GC/Naive/Sweep.pm</a>
+#     once (9&micro;s+30.5ms) by KiokuDB::Backend::Serialize::JSPON::BEGIN@6 at <a href="KiokuDB-Backend-Serialize-JSPON-Expander-pm-2336-block.html#14">line 14 of KiokuDB/Backend/Serialize/JSPON/Expander.pm</a>
+#     once (15&micro;s+24.1ms) by KiokuDB::TypeMap::Resolver::BEGIN@9 at <a href="KiokuDB-TypeMap-Entry-MOP-pm-1731-block.html#21">line 21 of KiokuDB/TypeMap/Entry/MOP.pm</a>
+#     once (10&micro;s+23.9ms) by KiokuDB::Backend::Serialize::JSPON::BEGIN@7 at <a href="KiokuDB-Backend-Serialize-JSPON-Collapser-pm-2360-block.html#12">line 12 of KiokuDB/Backend/Serialize/JSPON/Collapser.pm</a>
+#     once (13&micro;s+23.6ms) by Catalyst::BEGIN@11 at <a href="Catalyst-Log-pm-469-block.html#4">line 4 of Catalyst/Log.pm</a>
+#     once (11&micro;s+23.1ms) by KiokuDB::Set::Deferred::BEGIN@8 at <a href="KiokuDB-Set-Loaded-pm-2582-block.html#10">line 10 of KiokuDB/Set/Loaded.pm</a>
+#     once (13&micro;s+21.9ms) by MooseX::Role::Parameterized::Meta::Role::Parameterizable::BEGIN@7 at <a href="MooseX-Parameterized-pm-833-block.html#4">line 4 of MooseX/Role/Parameterized/Meta/Role/Parameterized.pm</a>
+#     once (12&micro;s+17.1ms) by Module::Runtime::require_module at <a href="Data-Stream-Bulk-Chunked-pm-1787-block.html#13">line 13 of Data/Stream/Bulk/Chunked.pm</a>
+#     once (16&micro;s+16.9ms) by Module::Runtime::require_module at <a href="MooseX-MethodAttributes-Inheritable-pm-591-block.html#18">line 18 of MooseX/MethodAttributes/Inheritable.pm</a>
+#     once (11&micro;s+15.9ms) by KiokuDB::BEGIN@11 at <a href="KiokuDB-Collapser-pm-1524-block.html#28">line 28 of KiokuDB/Collapser.pm</a>
+#     once (16&micro;s+13.2ms) by Module::Runtime::require_module at <a href="Parse-Method-Signatures-Param-pm-1199-block.html#9">line 9 of Parse/Method/Signatures/Param.pm</a>
+#     once (13&micro;s+12.2ms) by Catalyst::BEGIN@16 at <a href="Catalyst-Controller-pm-576-block.html#14">line 14 of Catalyst/Controller.pm</a>
+#     once (13&micro;s+11.9ms) by KiokuDB::Collapser::BEGIN@18 at <a href="KiokuDB-Error-UnknownObjects-pm-1626-block.html#8">line 8 of KiokuDB/Error/UnknownObjects.pm</a>
+#     once (14&micro;s+10.7ms) by Catalyst::BEGIN@10 at <a href="Catalyst-Exception-Go-pm-462-block.html#6">line 6 of Catalyst/Exception/Go.pm</a>
+#     once (15&micro;s+10.5ms) by Catalyst::BEGIN@9 at <a href="Catalyst-Exception-Detach-pm-455-block.html#6">line 6 of Catalyst/Exception/Detach.pm</a>
+#     once (10&micro;s+10.1ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#248">line 248 of KiokuDB.pm</a>
+#     once (15&micro;s+8.91ms) by Text::Tradition::Directory::BEGIN@9 at <a href="KiokuDB-TypeMap-pm-1440-block.html#14">line 14 of KiokuDB/TypeMap.pm</a>
+#     once (15&micro;s+8.39ms) by Text::Tradition::Directory::BEGIN@154 at <a href="lib-Text-Tradition-TypeMap-Entry-pm-1500-block.html#8">line 8 of lib/Text/Tradition/TypeMap/Entry.pm</a>
+#     once (10&micro;s+8.08ms) by Module::Runtime::require_module at <a href="KiokuDB-TypeMap-Entry-StorableHook-pm-2539-block.html#18">line 18 of KiokuDB/TypeMap/Entry/StorableHook.pm</a>
+#     once (14&micro;s+7.44ms) by KiokuDB::TypeMap::Entry::Set::BEGIN@9 at <a href="KiokuDB-Set-Deferred-pm-2579-block.html#14">line 14 of KiokuDB/Set/Deferred.pm</a>
+#     once (10&micro;s+7.08ms) by Module::Runtime::require_module at <a href="KiokuDB-TypeMap-Entry-Set-pm-2565-block.html#14">line 14 of KiokuDB/TypeMap/Entry/Set.pm</a>
+#     once (11&micro;s+6.74ms) by Module::Runtime::require_module at <a href="Catalyst-Component-pm-579-block.html#15">line 15 of Catalyst/Component.pm</a>
+#     once (9&micro;s+5.33ms) by KiokuDB::Backend::DBI::BEGIN@21 at <a href="Data-Stream-Bulk-DBI-pm-2152-block.html#13">line 13 of Data/Stream/Bulk/DBI.pm</a>
+#     once (9&micro;s+4.73ms) by Module::Runtime::require_module at <a href="KiokuDB-TypeMap-Entry-JSON-Scalar-pm-2558-block.html#8">line 8 of KiokuDB/TypeMap/Entry/JSON/Scalar.pm</a>
+#     once (8&micro;s+4.67ms) by Module::Runtime::require_module at <a href="KiokuDB-TypeMap-Entry-Callback-pm-2528-block.html#12">line 12 of KiokuDB/TypeMap/Entry/Callback.pm</a>
+#     once (8&micro;s+4.55ms) by Module::Runtime::require_module at <a href="KiokuDB-TypeMap-Entry-Closure-pm-2546-block.html#11">line 11 of KiokuDB/TypeMap/Entry/Closure.pm</a>
+#     once (17&micro;s+4.23ms) by Catalyst::BEGIN@14 at <a href="Catalyst-Response-pm-553-block.html#8">line 8 of Catalyst/Response.pm</a>
+#     once (13&micro;s+4.03ms) by Text::Tradition::Directory::BEGIN@8 at <a href="KiokuDB-GC-Naive-pm-1360-block.html#11">line 11 of KiokuDB/GC/Naive.pm</a>
+#     once (13&micro;s+3.92ms) by Catalyst::BEGIN@13 at <a href="Catalyst-Request-Upload-pm-537-block.html#4">line 4 of Catalyst/Request/Upload.pm</a>
+#     once (10&micro;s+3.49ms) by KiokuDB::Linker::BEGIN@18 at <a href="KiokuDB-Error-MissingObjects-pm-1665-block.html#8">line 8 of KiokuDB/Error/MissingObjects.pm</a>
+#     once (13&micro;s+3.10ms) by Catalyst::Dispatcher::BEGIN@9 at <a href="Catalyst-Action-pm-1880-block.html#24">line 24 of Catalyst/Action.pm</a>
+#     once (9&micro;s+3.10ms) by Module::Runtime::require_module at <a href="KiokuDB-TypeMap-Entry-Ref-pm-2553-block.html#8">line 8 of KiokuDB/TypeMap/Entry/Ref.pm</a>
+#     once (11&micro;s+2.78ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#15">line 15 of Catalyst/Request.pm</a>
+#     once (11&micro;s+2.56ms) by Module::Runtime::require_module at <a href="Data-Stream-Bulk-Cat-pm-1780-block.html#13">line 13 of Data/Stream/Bulk/Cat.pm</a>
+#     once (9&micro;s+2.48ms) by Catalyst::Dispatcher::BEGIN@10 at <a href="Catalyst-ActionContainer-pm-1892-block.html#19">line 19 of Catalyst/ActionContainer.pm</a>
+#     once (11&micro;s+2.47ms) by Module::Runtime::require_module at <a href="Catalyst-Component-pm-579-block.html#14">line 14 of Catalyst/Component.pm</a>
+#     once (10&micro;s+2.43ms) by Module::Runtime::require_module at <a href="Catalyst-Engine-pm-1927-block.html#4">line 4 of Catalyst/Engine.pm</a>
+#     once (8&micro;s+2.33ms) by Module::Runtime::require_module at <a href="Catalyst-Dispatcher-pm-1877-block.html#5">line 5 of Catalyst/Dispatcher.pm</a>
+#     once (8&micro;s+2.17ms) by Module::Runtime::require_module at <a href="Catalyst-DispatchType-pm-1902-block.html#4">line 4 of Catalyst/DispatchType.pm</a>
+#     once (15&micro;s+2.10ms) by Module::Runtime::require_module at <a href="Data-Stream-Bulk-Nil-pm-1798-block.html#13">line 13 of Data/Stream/Bulk/Nil.pm</a>
+#     once (25&micro;s+1.55ms) by KiokuDB::Backend::DBI::BEGIN@29 at <a href="KiokuDB-TypeMap-Entry-DBIC-ResultSource-pm-2217-block.html#20">line 20 of KiokuDB/TypeMap/Entry/DBIC/ResultSource.pm</a>
+#     once (8&micro;s+1.52ms) by Data::Stream::Bulk::Util::BEGIN@14 at <a href="Data-Stream-Bulk-Array-pm-2252-block.html#13">line 13 of Data/Stream/Bulk/Array.pm</a>
+#     once (9&micro;s+1.47ms) by Module::Runtime::require_module at <a href="Data-Stream-Bulk-Filter-pm-1803-block.html#28">line 28 of Data/Stream/Bulk/Filter.pm</a>
+#     once (13&micro;s+1.45ms) by KiokuDB::Collapser::BEGIN@16 at <a href="KiokuDB-Reference-pm-1599-block.html#8">line 8 of KiokuDB/Reference.pm</a>
+#     once (12&micro;s+865&micro;s) by KiokuDB::BEGIN@15 at <a href="KiokuDB-TypeMap-Shadow-pm-1723-block.html#8">line 8 of KiokuDB/TypeMap/Shadow.pm</a>
+#     once (11&micro;s+733&micro;s) by KiokuDB::Backend::DBI::BEGIN@28 at <a href="KiokuDB-TypeMap-Entry-DBIC-Row-pm-2211-block.html#15">line 15 of KiokuDB/TypeMap/Entry/DBIC/Row.pm</a>
+#     once (8&micro;s+708&micro;s) by Module::Runtime::require_module at <a href="KiokuDB-TypeMap-Entry-Passthrough-pm-2609-block.html#14">line 14 of KiokuDB/TypeMap/Entry/Passthrough.pm</a>
+#     once (9&micro;s+636&micro;s) by KiokuDB::Backend::DBI::BEGIN@31 at <a href="KiokuDB-TypeMap-Entry-DBIC-Schema-pm-2227-block.html#14">line 14 of KiokuDB/TypeMap/Entry/DBIC/Schema.pm</a></div></div>sub with {</td></tr>
+<tr><td class="h"><a name="67"></a>67</td><td class="c0">57</td><td class="c1"><span title="Avg 6&micro;s">343&micro;s</span></td><td class="c0">57</td><td class="c0">1.32s</td><td class="s">    Moose::Util::apply_all_roles(shift, @_);<div class="calls"><div class="calls_out">    # spent  1.50s making 57 calls to <a href="Moose-Util-pm-158-block.html#97">Moose::Util::apply_all_roles</a>, avg 26.3ms/call, recursion: max depth 3, sum of overlapping time 179ms</div></div></td></tr>
+<tr><td class="h"><a name="68"></a>68</td><td></td><td></td><td></td><td></td><td class="s">}</td></tr>
+<tr><td class="h"><a name="69"></a>69</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="70"></a>70</td><td></td><td></td><td></td><td></td><td class="s"><div class="calls"><div class="calls_in"># spent 4.33s (13.9ms+4.32) within Moose::has which was called 754 times, avg 5.75ms/call:
+# 377 times (9.62ms+2.15s) by Moose::has at <a href="Moose-Exporter-pm-82-block.html#382">line 382 of Moose/Exporter.pm</a>, avg 5.74ms/call
+#   2 times (16&micro;s+12.0ms) by Module::Runtime::require_module at <a href="Catalyst-Dispatcher-pm-1877-block.html#42">line 42 of Catalyst/Dispatcher.pm</a>, avg 6.00ms/call
+#      once (11&micro;s+193ms) by Text::Tradition::Collation::BEGIN@9 at <a href="lib-Text-Tradition-Collation-Reading-pm-747-block.html#152">line 152 of lib/Text/Tradition/Collation/Reading.pm</a>
+#      once (14&micro;s+176ms) by Text::Tradition::Collation::BEGIN@10 at <a href="lib-Text-Tradition-Collation-RelationshipStore-pm-811-block.html#102">line 102 of lib/Text/Tradition/Collation/RelationshipStore.pm</a>
+#      once (12&micro;s+88.5ms) by MooseX::Types::Structured::BEGIN@16 at <a href="MooseX-Types-Structured-MessageStack-pm-1241-block.html#7">line 7 of MooseX/Types/Structured/MessageStack.pm</a>
+#      once (15&micro;s+65.7ms) by Text::Tradition::BEGIN@6 at <a href="lib-Text-Tradition-Collation-pm-686-block.html#58">line 58 of lib/Text/Tradition/Collation.pm</a>
+#      once (14&micro;s+43.8ms) by main::BEGIN@10 at <a href="lib-Text-Tradition-pm-673-block.html#55">line 55 of lib/Text/Tradition.pm</a>
+#      once (12&micro;s+27.5ms) by KiokuDB::Collapser::BEGIN@17 at <a href="KiokuDB-Collapser-Buffer-pm-1606-block.html#61">line 61 of KiokuDB/Collapser/Buffer.pm</a>
+#      once (15&micro;s+18.3ms) by MooseX::Types::Structured::BEGIN@16 at <a href="MooseX-Types-Structured-MessageStack-pm-1241-block.html#26">line 26 of MooseX/Types/Structured/MessageStack.pm</a>
+#      once (15&micro;s+14.4ms) by KiokuDB::TypeMap::Entry::Std::BEGIN@6 at <a href="KiokuDB-TypeMap-Entry-Compiled-pm-1479-block.html#8">line 8 of KiokuDB/TypeMap/Entry/Compiled.pm</a>
+#      once (12&micro;s+14.3ms) by Text::Tradition::Collation::BEGIN@10 at <a href="lib-Text-Tradition-Collation-RelationshipStore-pm-811-block.html#112">line 112 of lib/Text/Tradition/Collation/RelationshipStore.pm</a>
+#      once (17&micro;s+14.0ms) by Text::Tradition::Directory::BEGIN@9 at <a href="KiokuDB-TypeMap-pm-1440-block.html#16">line 16 of KiokuDB/TypeMap.pm</a>
+#      once (13&micro;s+13.8ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#100">line 100 of KiokuDB/Entry.pm</a>
+#      once (15&micro;s+13.5ms) by Text::Tradition::Directory::BEGIN@9 at <a href="KiokuDB-TypeMap-pm-1440-block.html#25">line 25 of KiokuDB/TypeMap.pm</a>
+#      once (15&micro;s+13.0ms) by Text::Tradition::Collation::BEGIN@10 at <a href="lib-Text-Tradition-Collation-RelationshipStore-pm-811-block.html#75">line 75 of lib/Text/Tradition/Collation/RelationshipStore.pm</a>
+#      once (10&micro;s+12.9ms) by Module::Runtime::require_module at <a href="Parse-Method-Signatures-Sig-pm-1184-block.html#38">line 38 of Parse/Method/Signatures/Sig.pm</a>
+#      once (11&micro;s+12.7ms) by KiokuDB::LiveObjects::BEGIN@13 at <a href="KiokuDB-LiveObjects-Scope-pm-1683-block.html#12">line 12 of KiokuDB/LiveObjects/Scope.pm</a>
+#      once (9&micro;s+12.6ms) by main::BEGIN@10 at <a href="lib-Text-Tradition-pm-673-block.html#30">line 30 of lib/Text/Tradition.pm</a>
+#      once (14&micro;s+11.4ms) by KiokuDB::TypeMap::Resolver::BEGIN@9 at <a href="KiokuDB-TypeMap-Entry-MOP-pm-1731-block.html#44">line 44 of KiokuDB/TypeMap/Entry/MOP.pm</a>
+#      once (10&micro;s+11.4ms) by Module::Runtime::require_module at <a href="Parse-Method-Signatures-Param-pm-1199-block.html#45">line 45 of Parse/Method/Signatures/Param.pm</a>
+#      once (13&micro;s+10.9ms) by Text::Tradition::Directory::BEGIN@8 at <a href="KiokuDB-GC-Naive-pm-1360-block.html#62">line 62 of KiokuDB/GC/Naive.pm</a>
+#      once (15&micro;s+10.8ms) by Text::Tradition::Directory::BEGIN@9 at <a href="KiokuDB-TypeMap-pm-1440-block.html#37">line 37 of KiokuDB/TypeMap.pm</a>
+#      once (11&micro;s+10.8ms) by Text::Tradition::Directory::BEGIN@8 at <a href="KiokuDB-GC-Naive-pm-1360-block.html#19">line 19 of KiokuDB/GC/Naive.pm</a>
+#      once (15&micro;s+10.5ms) by Module::Runtime::require_module at <a href="Parse-Method-Signatures-Param-pm-1199-block.html#38">line 38 of Parse/Method/Signatures/Param.pm</a>
+#      once (14&micro;s+10.3ms) by KiokuDB::BEGIN@13 at <a href="KiokuDB-LiveObjects-pm-1680-block.html#49">line 49 of KiokuDB/LiveObjects.pm</a>
+#      once (8&micro;s+10.2ms) by Text::Tradition::BEGIN@8 at <a href="lib-Text-Tradition-Witness-pm-1180-block.html#287">line 287 of lib/Text/Tradition/Witness.pm</a>
+#      once (10&micro;s+9.74ms) by Module::Runtime::require_module at <a href="Catalyst-Model-KiokuDB-pm-2055-block.html#59">line 59 of Catalyst/Model/KiokuDB.pm</a>
+#      once (12&micro;s+9.55ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#65">line 65 of Catalyst/Request.pm</a>
+#      once (8&micro;s+9.48ms) by Module::Runtime::require_module at <a href="KiokuX-Model-pm-1511-block.html#36">line 36 of KiokuX/Model.pm</a>
+#      once (15&micro;s+9.28ms) by Text::Tradition::Directory::BEGIN@9 at <a href="KiokuDB-TypeMap-pm-1440-block.html#31">line 31 of KiokuDB/TypeMap.pm</a>
+#      once (12&micro;s+9.28ms) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#65">line 65 of Parse/Method/Signatures.pm</a>
+#      once (16&micro;s+9.11ms) by Catalyst::BEGIN@14 at <a href="Catalyst-Response-pm-553-block.html#10">line 10 of Catalyst/Response.pm</a>
+#      once (13&micro;s+9.07ms) by KiokuDB::Backend::TypeMap::Default::JSON::BEGIN@6 at <a href="KiokuDB-TypeMap-Default-JSON-pm-2384-block.html#14">line 14 of KiokuDB/TypeMap/Default/JSON.pm</a>
+#      once (13&micro;s+8.71ms) by Text::Tradition::Directory::BEGIN@8 at <a href="KiokuDB-GC-Naive-pm-1360-block.html#47">line 47 of KiokuDB/GC/Naive.pm</a>
+#      once (14&micro;s+8.54ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#12">line 12 of KiokuDB/Entry.pm</a>
+#      once (9&micro;s+8.35ms) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#79">line 79 of Parse/Method/Signatures.pm</a>
+#      once (14&micro;s+8.34ms) by Catalyst::BEGIN@14 at <a href="Catalyst-Response-pm-553-block.html#21">line 21 of Catalyst/Response.pm</a>
+#      once (15&micro;s+8.16ms) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#59">line 59 of Parse/Method/Signatures.pm</a>
+#      once (16&micro;s+7.82ms) by KiokuDB::GC::Naive::BEGIN@7 at <a href="KiokuDB-GC-Naive-Sweep-pm-1400-block.html#27">line 27 of KiokuDB/GC/Naive/Sweep.pm</a>
+#      once (9&micro;s+7.73ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#172">line 172 of KiokuDB/Entry.pm</a>
+#      once (14&micro;s+7.64ms) by KiokuDB::TypeMap::Resolver::BEGIN@9 at <a href="KiokuDB-TypeMap-Entry-MOP-pm-1731-block.html#38">line 38 of KiokuDB/TypeMap/Entry/MOP.pm</a>
+#      once (16&micro;s+7.56ms) by Module::Runtime::require_module at <a href="Parse-Method-Signatures-Param-pm-1199-block.html#23">line 23 of Parse/Method/Signatures/Param.pm</a>
+#      once (8&micro;s+7.50ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#252">line 252 of KiokuDB/Backend/DBI.pm</a>
+#      once (13&micro;s+7.44ms) by KiokuDB::BEGIN@17 at <a href="KiokuDB-Stream-Objects-pm-1765-block.html#21">line 21 of KiokuDB/Stream/Objects.pm</a>
+#      once (10&micro;s+7.44ms) by Module::Runtime::require_module at <a href="Parse-Method-Signatures-TypeConstraint-pm-1283-block.html#27">line 27 of Parse/Method/Signatures/TypeConstraint.pm</a>
+#      once (10&micro;s+7.44ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#129">line 129 of KiokuDB/Entry.pm</a>
+#      once (13&micro;s+7.39ms) by Module::Runtime::require_module at <a href="Parse-Method-Signatures-Param-pm-1199-block.html#32">line 32 of Parse/Method/Signatures/Param.pm</a>
+#      once (16&micro;s+7.38ms) by Text::Tradition::BEGIN@6 at <a href="lib-Text-Tradition-Collation-pm-686-block.html#111">line 111 of lib/Text/Tradition/Collation.pm</a>
+#      once (15&micro;s+7.32ms) by Text::Tradition::BEGIN@8 at <a href="lib-Text-Tradition-Witness-pm-1180-block.html#211">line 211 of lib/Text/Tradition/Witness.pm</a>
+#      once (8&micro;s+7.25ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#165">line 165 of KiokuDB/Backend/DBI.pm</a>
+#      once (14&micro;s+7.22ms) by KiokuDB::BEGIN@13 at <a href="KiokuDB-LiveObjects-pm-1680-block.html#240">line 240 of KiokuDB/LiveObjects.pm</a>
+#      once (12&micro;s+7.17ms) by KiokuDB::GC::Naive::BEGIN@6 at <a href="KiokuDB-GC-Naive-Mark-pm-1363-block.html#20">line 20 of KiokuDB/GC/Naive/Mark.pm</a>
+#      once (16&micro;s+7.12ms) by Catalyst::BEGIN@13 at <a href="Catalyst-Request-Upload-pm-537-block.html#17">line 17 of Catalyst/Request/Upload.pm</a>
+#      once (13&micro;s+7.06ms) by Text::Tradition::BEGIN@6 at <a href="lib-Text-Tradition-Collation-pm-686-block.html#26">line 26 of lib/Text/Tradition/Collation.pm</a>
+#      once (15&micro;s+7.05ms) by KiokuDB::BEGIN@13 at <a href="KiokuDB-LiveObjects-pm-1680-block.html#155">line 155 of KiokuDB/LiveObjects.pm</a>
+#      once (13&micro;s+7.03ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#74">line 74 of KiokuDB.pm</a>
+#      once (8&micro;s+7.00ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#154">line 154 of KiokuDB.pm</a>
+#      once (12&micro;s+6.80ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#48">line 48 of KiokuDB/Entry.pm</a>
+#      once (15&micro;s+6.72ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#290">line 290 of Catalyst/Request.pm</a>
+#      once (14&micro;s+6.71ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#268">line 268 of Catalyst/Request.pm</a>
+#      once (12&micro;s+6.65ms) by KiokuDB::BEGIN@17 at <a href="KiokuDB-Stream-Objects-pm-1765-block.html#33">line 33 of KiokuDB/Stream/Objects.pm</a>
+#      once (14&micro;s+6.60ms) by Text::Tradition::BEGIN@6 at <a href="lib-Text-Tradition-Collation-pm-686-block.html#104">line 104 of lib/Text/Tradition/Collation.pm</a>
+#      once (12&micro;s+6.54ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#223">line 223 of KiokuDB.pm</a>
+#      once (10&micro;s+6.48ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#20">line 20 of KiokuDB/Entry.pm</a>
+#      once (10&micro;s+6.42ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#62">line 62 of KiokuDB/Entry.pm</a>
+#      once (13&micro;s+6.37ms) by Parse::Method::Signatures::BEGIN@10 at <a href="Parse-Method-Signatures-ParamCollection-pm-1006-block.html#9">line 9 of Parse/Method/Signatures/ParamCollection.pm</a>
+#      once (10&micro;s+6.36ms) by KiokuDB::TypeMap::Entry::MOP::BEGIN@9 at <a href="KiokuDB-Thunk-pm-1734-block.html#24">line 24 of KiokuDB/Thunk.pm</a>
+#      once (12&micro;s+6.31ms) by Catalyst::BEGIN@9 at <a href="Catalyst-Exception-Detach-pm-455-block.html#8">line 8 of Catalyst/Exception/Detach.pm</a>
+#      once (11&micro;s+6.28ms) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#71">line 71 of Parse/Method/Signatures.pm</a>
+#      once (15&micro;s+6.23ms) by Text::Tradition::Collation::BEGIN@10 at <a href="lib-Text-Tradition-Collation-RelationshipStore-pm-811-block.html#81">line 81 of lib/Text/Tradition/Collation/RelationshipStore.pm</a>
+#      once (17&micro;s+6.12ms) by KiokuDB::BEGIN@13 at <a href="KiokuDB-LiveObjects-pm-1680-block.html#32">line 32 of KiokuDB/LiveObjects.pm</a>
+#      once (15&micro;s+6.06ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#63">line 63 of Catalyst/Request.pm</a>
+#      once (11&micro;s+6.02ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#194">line 194 of KiokuDB.pm</a>
+#      once (14&micro;s+5.91ms) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#35">line 35 of Parse/Method/Signatures.pm</a>
+#      once (13&micro;s+5.88ms) by Catalyst::BEGIN@10 at <a href="Catalyst-Exception-Go-pm-462-block.html#8">line 8 of Catalyst/Exception/Go.pm</a>
+#      once (14&micro;s+5.83ms) by MooseX::Meta::TypeConstraint::Structured::BEGIN@6 at <a href="Devel-PartialDump-pm-1206-block.html#52">line 52 of Devel/PartialDump.pm</a>
+#      once (10&micro;s+5.74ms) by Module::Runtime::require_module at <a href="Parse-Method-Signatures-Sig-pm-1184-block.html#16">line 16 of Parse/Method/Signatures/Sig.pm</a>
+#      once (11&micro;s+5.65ms) by Text::Tradition::BEGIN@6 at <a href="lib-Text-Tradition-Collation-pm-686-block.html#40">line 40 of lib/Text/Tradition/Collation.pm</a>
+#      once (13&micro;s+5.61ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#215">line 215 of KiokuDB/Backend/DBI.pm</a>
+#      once (12&micro;s+5.54ms) by Text::Tradition::BEGIN@6 at <a href="lib-Text-Tradition-Collation-pm-686-block.html#97">line 97 of lib/Text/Tradition/Collation.pm</a>
+#      once (9&micro;s+5.51ms) by Data::Stream::Bulk::Util::BEGIN@14 at <a href="Data-Stream-Bulk-Array-pm-2252-block.html#15">line 15 of Data/Stream/Bulk/Array.pm</a>
+#      once (13&micro;s+5.48ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#55">line 55 of KiokuDB/Entry.pm</a>
+#      once (13&micro;s+5.48ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#79">line 79 of KiokuDB.pm</a>
+#      once (14&micro;s+5.47ms) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#41">line 41 of Parse/Method/Signatures.pm</a>
+#      once (16&micro;s+5.46ms) by KiokuDB::GC::Naive::BEGIN@7 at <a href="KiokuDB-GC-Naive-Sweep-pm-1400-block.html#25">line 25 of KiokuDB/GC/Naive/Sweep.pm</a>
+#      once (10&micro;s+5.46ms) by MooseX::Role::Parameterized::BEGIN@7 at <a href="MooseX-Parameterizable-pm-830-block.html#34">line 34 of MooseX/Role/Parameterized/Meta/Role/Parameterizable.pm</a>
+#      once (12&micro;s+5.45ms) by KiokuDB::Collapser::BEGIN@15 at <a href="KiokuDB-Entry-Skip-pm-1589-block.html#20">line 20 of KiokuDB/Entry/Skip.pm</a>
+#      once (13&micro;s+5.41ms) by Text::Tradition::BEGIN@6 at <a href="lib-Text-Tradition-Collation-pm-686-block.html#90">line 90 of lib/Text/Tradition/Collation.pm</a>
+#      once (15&micro;s+5.35ms) by KiokuDB::BEGIN@11 at <a href="KiokuDB-Collapser-pm-1524-block.html#30">line 30 of KiokuDB/Collapser.pm</a>
+#      once (11&micro;s+5.35ms) by KiokuDB::Collapser::BEGIN@18 at <a href="KiokuDB-Error-UnknownObjects-pm-1626-block.html#10">line 10 of KiokuDB/Error/UnknownObjects.pm</a>
+#      once (11&micro;s+5.34ms) by Module::Runtime::require_module at <a href="Parse-Method-Signatures-Sig-pm-1184-block.html#27">line 27 of Parse/Method/Signatures/Sig.pm</a>
+#      once (11&micro;s+5.32ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#71">line 71 of KiokuDB/Entry.pm</a>
+#      once (13&micro;s+5.30ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#25">line 25 of Catalyst/Request.pm</a>
+#      once (10&micro;s+5.24ms) by MooseX::Meta::TypeConstraint::Structured::BEGIN@6 at <a href="Devel-PartialDump-pm-1206-block.html#59">line 59 of Devel/PartialDump.pm</a>
+#      once (11&micro;s+5.19ms) by MooseX::Role::Parameterized::BEGIN@7 at <a href="MooseX-Parameterizable-pm-830-block.html#22">line 22 of MooseX/Role/Parameterized/Meta/Role/Parameterizable.pm</a>
+#      once (9&micro;s+5.18ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#177">line 177 of KiokuDB/Backend/DBI.pm</a>
+#      once (10&micro;s+5.02ms) by KiokuDB::BEGIN@11 at <a href="KiokuDB-Collapser-pm-1524-block.html#61">line 61 of KiokuDB/Collapser.pm</a>
+#      once (8&micro;s+5.01ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#296">line 296 of KiokuDB/Backend/DBI.pm</a>
+#      once (12&micro;s+4.98ms) by Module::Runtime::require_module at <a href="Parse-Method-Signatures-Param-pm-1199-block.html#17">line 17 of Parse/Method/Signatures/Param.pm</a>
+#      once (9&micro;s+4.94ms) by Module::Runtime::require_module at <a href="KiokuX-Model-pm-1511-block.html#48">line 48 of KiokuX/Model.pm</a>
+#      once (16&micro;s+4.91ms) by Text::Tradition::Collation::BEGIN@10 at <a href="lib-Text-Tradition-Collation-RelationshipStore-pm-811-block.html#64">line 64 of lib/Text/Tradition/Collation/RelationshipStore.pm</a>
+#      once (11&micro;s+4.87ms) by Module::Runtime::require_module at <a href="Parse-Method-Signatures-TypeConstraint-pm-1283-block.html#20">line 20 of Parse/Method/Signatures/TypeConstraint.pm</a>
+#      once (8&micro;s+4.83ms) by Text::Tradition::BEGIN@8 at <a href="lib-Text-Tradition-Witness-pm-1180-block.html#295">line 295 of lib/Text/Tradition/Witness.pm</a>
+#      once (15&micro;s+4.82ms) by Catalyst::BEGIN@16 at <a href="Catalyst-Controller-pm-576-block.html#16">line 16 of Catalyst/Controller.pm</a>
+#      once (12&micro;s+4.81ms) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#47">line 47 of Parse/Method/Signatures.pm</a>
+#      once (9&micro;s+4.79ms) by KiokuDB::Collapser::BEGIN@15 at <a href="KiokuDB-Entry-Skip-pm-1589-block.html#14">line 14 of KiokuDB/Entry/Skip.pm</a>
+#      once (11&micro;s+4.77ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#83">line 83 of KiokuDB/Entry.pm</a>
+#      once (9&micro;s+4.73ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#156">line 156 of KiokuDB.pm</a>
+#      once (9&micro;s+4.70ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#279">line 279 of KiokuDB/Backend/DBI.pm</a>
+#      once (12&micro;s+4.67ms) by KiokuDB::BEGIN@15 at <a href="KiokuDB-TypeMap-Shadow-pm-1723-block.html#10">line 10 of KiokuDB/TypeMap/Shadow.pm</a>
+#      once (9&micro;s+4.66ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#268">line 268 of KiokuDB/Backend/DBI.pm</a>
+#      once (21&micro;s+4.64ms) by Module::Runtime::require_module at <a href="Parse-Method-Signatures-Param-pm-1199-block.html#11">line 11 of Parse/Method/Signatures/Param.pm</a>
+#      once (13&micro;s+4.63ms) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#29">line 29 of Parse/Method/Signatures.pm</a>
+#      once (12&micro;s+4.63ms) by KiokuDB::BEGIN@11 at <a href="KiokuDB-Collapser-pm-1524-block.html#44">line 44 of KiokuDB/Collapser.pm</a>
+#      once (13&micro;s+4.60ms) by Text::Tradition::BEGIN@8 at <a href="lib-Text-Tradition-Witness-pm-1180-block.html#253">line 253 of lib/Text/Tradition/Witness.pm</a>
+#      once (9&micro;s+4.55ms) by KiokuDB::BEGIN@11 at <a href="KiokuDB-Collapser-pm-1524-block.html#57">line 57 of KiokuDB/Collapser.pm</a>
+#      once (16&micro;s+4.50ms) by Module::Runtime::require_module at <a href="Catalyst-Component-pm-579-block.html#75">line 75 of Catalyst/Component.pm</a>
+#      once (11&micro;s+4.48ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#36">line 36 of KiokuDB/Entry.pm</a>
+#      once (16&micro;s+4.44ms) by Text::Tradition::BEGIN@6 at <a href="lib-Text-Tradition-Collation-pm-686-block.html#21">line 21 of lib/Text/Tradition/Collation.pm</a>
+#      once (11&micro;s+4.42ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#77">line 77 of KiokuDB/Entry.pm</a>
+#      once (10&micro;s+4.36ms) by Catalyst::BEGIN@32 at <a href="Catalyst-EngineLoader-pm-643-block.html#15">line 15 of Catalyst/EngineLoader.pm</a>
+#      once (15&micro;s+4.35ms) by Text::Tradition::BEGIN@6 at <a href="lib-Text-Tradition-Collation-pm-686-block.html#118">line 118 of lib/Text/Tradition/Collation.pm</a>
+#      once (15&micro;s+4.34ms) by Text::Tradition::BEGIN@8 at <a href="lib-Text-Tradition-Witness-pm-1180-block.html#218">line 218 of lib/Text/Tradition/Witness.pm</a>
+#      once (9&micro;s+4.34ms) by Text::Tradition::BEGIN@8 at <a href="lib-Text-Tradition-Witness-pm-1180-block.html#281">line 281 of lib/Text/Tradition/Witness.pm</a>
+#      once (14&micro;s+4.30ms) by Text::Tradition::BEGIN@6 at <a href="lib-Text-Tradition-Collation-pm-686-block.html#60">line 60 of lib/Text/Tradition/Collation.pm</a>
+#      once (11&micro;s+4.29ms) by Module::Runtime::require_module at <a href="Parse-Method-Signatures-Sig-pm-1184-block.html#10">line 10 of Parse/Method/Signatures/Sig.pm</a>
+#      once (10&micro;s+4.27ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#76">line 76 of KiokuDB/Backend/DBI.pm</a>
+#      once (10&micro;s+4.27ms) by KiokuDB::Backend::Serialize::JSPON::BEGIN@7 at <a href="KiokuDB-Backend-Serialize-JSPON-Collapser-pm-2360-block.html#14">line 14 of KiokuDB/Backend/Serialize/JSPON/Collapser.pm</a>
+#      once (14&micro;s+4.21ms) by MooseX::Types::Structured::BEGIN@15 at <a href="MooseX-Types-Structured-OverflowHandler-pm-1235-block.html#9">line 9 of MooseX/Types/Structured/OverflowHandler.pm</a>
+#      once (10&micro;s+4.15ms) by main::BEGIN@10 at <a href="lib-Text-Tradition-pm-673-block.html#38">line 38 of lib/Text/Tradition.pm</a>
+#      once (15&micro;s+4.15ms) by KiokuDB::Collapser::BEGIN@17 at <a href="KiokuDB-Collapser-Buffer-pm-1606-block.html#9">line 9 of KiokuDB/Collapser/Buffer.pm</a>
+#      once (8&micro;s+4.14ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#309">line 309 of KiokuDB/Backend/DBI.pm</a>
+#      once (10&micro;s+4.13ms) by Module::Runtime::require_module at <a href="KiokuDB-TypeMap-Entry-Callback-pm-2528-block.html#14">line 14 of KiokuDB/TypeMap/Entry/Callback.pm</a>
+#      once (11&micro;s+4.13ms) by Catalyst::BEGIN@14 at <a href="Catalyst-Response-pm-553-block.html#43">line 43 of Catalyst/Response.pm</a>
+#      once (9&micro;s+4.13ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#174">line 174 of KiokuDB.pm</a>
+#      once (8&micro;s+4.13ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#151">line 151 of KiokuDB/Backend/DBI.pm</a>
+#      once (8&micro;s+4.12ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#250">line 250 of KiokuDB/Backend/DBI.pm</a>
+#      once (16&micro;s+4.08ms) by KiokuDB::BEGIN@16 at <a href="KiokuDB-TypeMap-Resolver-pm-1730-block.html#22">line 22 of KiokuDB/TypeMap/Resolver.pm</a>
+#      once (11&micro;s+4.09ms) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#53">line 53 of Parse/Method/Signatures.pm</a>
+#      once (10&micro;s+4.07ms) by KiokuDB::Backend::Serialize::JSPON::BEGIN@6 at <a href="KiokuDB-Backend-Serialize-JSPON-Expander-pm-2336-block.html#22">line 22 of KiokuDB/Backend/Serialize/JSPON/Expander.pm</a>
+#      once (8&micro;s+4.04ms) by Module::Runtime::require_module at <a href="KiokuDB-TypeMap-Entry-Callback-pm-2528-block.html#20">line 20 of KiokuDB/TypeMap/Entry/Callback.pm</a>
+#      once (10&micro;s+4.04ms) by KiokuDB::BEGIN@12 at <a href="KiokuDB-Linker-pm-1662-block.html#22">line 22 of KiokuDB/Linker.pm</a>
+#      once (12&micro;s+4.01ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#42">line 42 of KiokuDB/Entry.pm</a>
+#      once (12&micro;s+3.99ms) by Catalyst::BEGIN@16 at <a href="Catalyst-Controller-pm-576-block.html#24">line 24 of Catalyst/Controller.pm</a>
+#      once (15&micro;s+3.98ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#139">line 139 of Catalyst/Request.pm</a>
+#      once (14&micro;s+3.95ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#288">line 288 of Catalyst/Request.pm</a>
+#      once (15&micro;s+3.94ms) by KiokuDB::BEGIN@17 at <a href="KiokuDB-Stream-Objects-pm-1765-block.html#14">line 14 of KiokuDB/Stream/Objects.pm</a>
+#      once (15&micro;s+3.93ms) by Text::Tradition::BEGIN@6 at <a href="lib-Text-Tradition-Collation-pm-686-block.html#78">line 78 of lib/Text/Tradition/Collation.pm</a>
+#      once (14&micro;s+3.92ms) by Text::Tradition::BEGIN@6 at <a href="lib-Text-Tradition-Collation-pm-686-block.html#66">line 66 of lib/Text/Tradition/Collation.pm</a>
+#      once (15&micro;s+3.92ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#62">line 62 of Catalyst/Request.pm</a>
+#      once (13&micro;s+3.92ms) by Text::Tradition::BEGIN@8 at <a href="lib-Text-Tradition-Witness-pm-1180-block.html#225">line 225 of lib/Text/Tradition/Witness.pm</a>
+#      once (14&micro;s+3.88ms) by KiokuDB::TypeMap::Resolver::BEGIN@9 at <a href="KiokuDB-TypeMap-Entry-MOP-pm-1731-block.html#46">line 46 of KiokuDB/TypeMap/Entry/MOP.pm</a>
+#      once (14&micro;s+3.87ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#69">line 69 of KiokuDB.pm</a>
+#      once (13&micro;s+3.87ms) by Text::Tradition::BEGIN@7 at <a href="lib-Text-Tradition-Stemma-pm-1135-block.html#105">line 105 of lib/Text/Tradition/Stemma.pm</a>
+#      once (12&micro;s+3.87ms) by KiokuDB::TypeMap::Entry::MOP::BEGIN@9 at <a href="KiokuDB-Thunk-pm-1734-block.html#19">line 19 of KiokuDB/Thunk.pm</a>
+#      once (8&micro;s+3.86ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#230">line 230 of KiokuDB/Backend/DBI.pm</a>
+#      once (7&micro;s+3.82ms) by KiokuDB::TypeMap::Entry::Set::BEGIN@9 at <a href="KiokuDB-Set-Deferred-pm-2579-block.html#25">line 25 of KiokuDB/Set/Deferred.pm</a>
+#      once (12&micro;s+3.81ms) by Module::Runtime::require_module at <a href="Data-Stream-Bulk-Cat-pm-1780-block.html#15">line 15 of Data/Stream/Bulk/Cat.pm</a>
+#      once (8&micro;s+3.81ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#117">line 117 of KiokuDB/Backend/DBI.pm</a>
+#      once (18&micro;s+3.78ms) by KiokuDB::TypeMap::BEGIN@10 at <a href="KiokuDB-TypeMap-Entry-Alias-pm-1445-block.html#8">line 8 of KiokuDB/TypeMap/Entry/Alias.pm</a>
+#      once (15&micro;s+3.77ms) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#850">line 850 of Parse/Method/Signatures.pm</a>
+#      once (11&micro;s+3.76ms) by Module::Runtime::require_module at <a href="Parse-Method-Signatures-TypeConstraint-pm-1283-block.html#37">line 37 of Parse/Method/Signatures/TypeConstraint.pm</a>
+#      once (15&micro;s+3.73ms) by Text::Tradition::BEGIN@6 at <a href="lib-Text-Tradition-Collation-pm-686-block.html#84">line 84 of lib/Text/Tradition/Collation.pm</a>
+#      once (8&micro;s+3.74ms) by Text::Tradition::Collation::BEGIN@9 at <a href="lib-Text-Tradition-Collation-Reading-pm-747-block.html#125">line 125 of lib/Text/Tradition/Collation/Reading.pm</a>
+#      once (11&micro;s+3.72ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#17">line 17 of Catalyst/Request.pm</a>
+#      once (13&micro;s+3.72ms) by Catalyst::BEGIN@16 at <a href="Catalyst-Controller-pm-576-block.html#40">line 40 of Catalyst/Controller.pm</a>
+#      once (14&micro;s+3.71ms) by Text::Tradition::Collation::BEGIN@10 at <a href="lib-Text-Tradition-Collation-RelationshipStore-pm-811-block.html#100">line 100 of lib/Text/Tradition/Collation/RelationshipStore.pm</a>
+#      once (10&micro;s+3.71ms) by Catalyst::BEGIN@32 at <a href="Catalyst-EngineLoader-pm-643-block.html#27">line 27 of Catalyst/EngineLoader.pm</a>
+#      once (11&micro;s+3.70ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#128">line 128 of Catalyst/Request.pm</a>
+#      once (16&micro;s+3.67ms) by Catalyst::BEGIN@13 at <a href="Catalyst-Request-Upload-pm-537-block.html#35">line 35 of Catalyst/Request/Upload.pm</a>
+#      once (15&micro;s+3.65ms) by KiokuDB::GC::Naive::BEGIN@7 at <a href="KiokuDB-GC-Naive-Sweep-pm-1400-block.html#20">line 20 of KiokuDB/GC/Naive/Sweep.pm</a>
+#      once (17&micro;s+3.64ms) by KiokuDB::BEGIN@16 at <a href="KiokuDB-TypeMap-Resolver-pm-1730-block.html#13">line 13 of KiokuDB/TypeMap/Resolver.pm</a>
+#      once (15&micro;s+3.63ms) by KiokuDB::TypeMap::Resolver::BEGIN@9 at <a href="KiokuDB-TypeMap-Entry-MOP-pm-1731-block.html#28">line 28 of KiokuDB/TypeMap/Entry/MOP.pm</a>
+#      once (15&micro;s+3.61ms) by KiokuDB::BEGIN@16 at <a href="KiokuDB-TypeMap-Resolver-pm-1730-block.html#28">line 28 of KiokuDB/TypeMap/Resolver.pm</a>
+#      once (11&micro;s+3.60ms) by Text::Tradition::Collation::BEGIN@9 at <a href="lib-Text-Tradition-Collation-Reading-pm-747-block.html#354">line 354 of lib/Text/Tradition/Collation/Reading.pm</a>
+#      once (17&micro;s+3.59ms) by Text::Tradition::Collation::BEGIN@9 at <a href="lib-Text-Tradition-Collation-Reading-pm-747-block.html#342">line 342 of lib/Text/Tradition/Collation/Reading.pm</a>
+#      once (17&micro;s+3.59ms) by KiokuDB::TypeMap::Entry::MOP::BEGIN@9 at <a href="KiokuDB-Thunk-pm-1734-block.html#8">line 8 of KiokuDB/Thunk.pm</a>
+#      once (12&micro;s+3.59ms) by KiokuDB::Collapser::BEGIN@15 at <a href="KiokuDB-Entry-Skip-pm-1589-block.html#8">line 8 of KiokuDB/Entry/Skip.pm</a>
+#      once (12&micro;s+3.58ms) by Text::Tradition::BEGIN@8 at <a href="lib-Text-Tradition-Witness-pm-1180-block.html#259">line 259 of lib/Text/Tradition/Witness.pm</a>
+#      once (14&micro;s+3.58ms) by MooseX::Meta::TypeConstraint::Structured::BEGIN@6 at <a href="Devel-PartialDump-pm-1206-block.html#80">line 80 of Devel/PartialDump.pm</a>
+#      once (14&micro;s+3.58ms) by KiokuDB::TypeMap::Entry::Std::BEGIN@6 at <a href="KiokuDB-TypeMap-Entry-Compiled-pm-1479-block.html#20">line 20 of KiokuDB/TypeMap/Entry/Compiled.pm</a>
+#      once (16&micro;s+3.55ms) by Text::Tradition::BEGIN@7 at <a href="lib-Text-Tradition-Stemma-pm-1135-block.html#98">line 98 of lib/Text/Tradition/Stemma.pm</a>
+#      once (14&micro;s+3.52ms) by KiokuDB::BEGIN@13 at <a href="KiokuDB-LiveObjects-pm-1680-block.html#22">line 22 of KiokuDB/LiveObjects.pm</a>
+#      once (10&micro;s+3.52ms) by Catalyst::BEGIN@11 at <a href="Catalyst-Log-pm-469-block.html#13">line 13 of Catalyst/Log.pm</a>
+#      once (9&micro;s+3.52ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#178">line 178 of Catalyst/Request.pm</a>
+#      once (11&micro;s+3.51ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#266">line 266 of Catalyst/Request.pm</a>
+#      once (13&micro;s+3.48ms) by Module::Runtime::require_module at <a href="Parse-Method-Signatures-TypeConstraint-pm-1283-block.html#11">line 11 of Parse/Method/Signatures/TypeConstraint.pm</a>
+#      once (15&micro;s+3.45ms) by KiokuDB::BEGIN@13 at <a href="KiokuDB-LiveObjects-pm-1680-block.html#57">line 57 of KiokuDB/LiveObjects.pm</a>
+#      once (12&micro;s+3.45ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#141">line 141 of Catalyst/Request.pm</a>
+#      once (11&micro;s+3.45ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#45">line 45 of Catalyst/Request.pm</a>
+#      once (13&micro;s+3.45ms) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#1987">line 1987 of Catalyst.pm</a>
+#      once (11&micro;s+3.45ms) by KiokuDB::GC::Naive::BEGIN@6 at <a href="KiokuDB-GC-Naive-Mark-pm-1363-block.html#25">line 25 of KiokuDB/GC/Naive/Mark.pm</a>
+#      once (11&micro;s+3.44ms) by KiokuDB::BEGIN@13 at <a href="KiokuDB-LiveObjects-pm-1680-block.html#27">line 27 of KiokuDB/LiveObjects.pm</a>
+#      once (14&micro;s+3.42ms) by KiokuDB::TypeMap::Entry::Std::BEGIN@6 at <a href="KiokuDB-TypeMap-Entry-Compiled-pm-1479-block.html#14">line 14 of KiokuDB/TypeMap/Entry/Compiled.pm</a>
+#      once (13&micro;s+3.42ms) by Text::Tradition::Collation::BEGIN@9 at <a href="lib-Text-Tradition-Collation-Reading-pm-747-block.html#162">line 162 of lib/Text/Tradition/Collation/Reading.pm</a>
+#      once (17&micro;s+3.41ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#64">line 64 of KiokuDB.pm</a>
+#      once (12&micro;s+3.40ms) by MooseX::Role::Parameterized::BEGIN@7 at <a href="MooseX-Parameterizable-pm-830-block.html#16">line 16 of MooseX/Role/Parameterized/Meta/Role/Parameterizable.pm</a>
+#      once (11&micro;s+3.39ms) by Text::Tradition::Collation::BEGIN@9 at <a href="lib-Text-Tradition-Collation-Reading-pm-747-block.html#82">line 82 of lib/Text/Tradition/Collation/Reading.pm</a>
+#      once (11&micro;s+3.35ms) by Catalyst::Utils::ensure_class_loaded at <a href="lib-stemmaweb-Model-Directory-pm-2052-block.html#9">line 9 of lib/stemmaweb/Model/Directory.pm</a>
+#      once (9&micro;s+3.35ms) by Text::Tradition::Collation::RelationshipStore::BEGIN@6 at <a href="lib-Text-Tradition-Collation-Relationship-pm-888-block.html#107">line 107 of lib/Text/Tradition/Collation/Relationship.pm</a>
+#      once (13&micro;s+3.34ms) by MooseX::Types::Structured::BEGIN@13 at <a href="MooseX-Meta-TypeConstraint-Structured-pm-1203-block.html#13">line 13 of MooseX/Meta/TypeConstraint/Structured.pm</a>
+#      once (14&micro;s+3.34ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#210">line 210 of KiokuDB.pm</a>
+#      once (15&micro;s+3.33ms) by KiokuDB::Collapser::BEGIN@16 at <a href="KiokuDB-Reference-pm-1599-block.html#10">line 10 of KiokuDB/Reference.pm</a>
+#      once (11&micro;s+3.32ms) by KiokuDB::BEGIN@17 at <a href="KiokuDB-Stream-Objects-pm-1765-block.html#45">line 45 of KiokuDB/Stream/Objects.pm</a>
+#      once (15&micro;s+3.30ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#40">line 40 of Catalyst/Request.pm</a>
+#      once (14&micro;s+3.29ms) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#65">line 65 of Catalyst.pm</a>
+#      once (17&micro;s+3.26ms) by KiokuDB::BEGIN@11 at <a href="KiokuDB-Collapser-pm-1524-block.html#38">line 38 of KiokuDB/Collapser.pm</a>
+#      once (10&micro;s+3.26ms) by KiokuDB::LiveObjects::BEGIN@13 at <a href="KiokuDB-LiveObjects-Scope-pm-1683-block.html#25">line 25 of KiokuDB/LiveObjects/Scope.pm</a>
+#      once (15&micro;s+3.25ms) by Catalyst::BEGIN@13 at <a href="Catalyst-Request-Upload-pm-537-block.html#13">line 13 of Catalyst/Request/Upload.pm</a>
+#      once (12&micro;s+3.25ms) by KiokuDB::Collapser::BEGIN@16 at <a href="KiokuDB-Reference-pm-1599-block.html#16">line 16 of KiokuDB/Reference.pm</a>
+#      once (11&micro;s+3.25ms) by Module::Runtime::require_module at <a href="Data-Stream-Bulk-Chunked-pm-1787-block.html#21">line 21 of Data/Stream/Bulk/Chunked.pm</a>
+#      once (16&micro;s+3.23ms) by KiokuDB::BEGIN@17 at <a href="KiokuDB-Stream-Objects-pm-1765-block.html#8">line 8 of KiokuDB/Stream/Objects.pm</a>
+#      once (11&micro;s+3.23ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#61">line 61 of Catalyst/Request.pm</a>
+#      once (8&micro;s+3.23ms) by Module::Runtime::require_module at <a href="KiokuX-Model-pm-1511-block.html#24">line 24 of KiokuX/Model.pm</a>
+#      once (15&micro;s+3.22ms) by Text::Tradition::Directory::BEGIN@8 at <a href="KiokuDB-GC-Naive-pm-1360-block.html#13">line 13 of KiokuDB/GC/Naive.pm</a>
+#      once (13&micro;s+3.22ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#64">line 64 of Catalyst/Request.pm</a>
+#      once (16&micro;s+3.21ms) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#846">line 846 of Parse/Method/Signatures.pm</a>
+#      once (8&micro;s+3.22ms) by Text::Tradition::BEGIN@8 at <a href="lib-Text-Tradition-Witness-pm-1180-block.html#265">line 265 of lib/Text/Tradition/Witness.pm</a>
+#      once (8&micro;s+3.21ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#95">line 95 of KiokuDB/Backend/DBI.pm</a>
+#      once (17&micro;s+3.20ms) by Catalyst::BEGIN@13 at <a href="Catalyst-Request-Upload-pm-537-block.html#12">line 12 of Catalyst/Request/Upload.pm</a>
+#      once (14&micro;s+3.19ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#217">line 217 of KiokuDB.pm</a>
+#      once (13&micro;s+3.18ms) by KiokuDB::Collapser::BEGIN@17 at <a href="KiokuDB-Collapser-Buffer-pm-1606-block.html#107">line 107 of KiokuDB/Collapser/Buffer.pm</a>
+#      once (11&micro;s+3.18ms) by MooseX::Meta::TypeConstraint::Structured::BEGIN@6 at <a href="Devel-PartialDump-pm-1206-block.html#92">line 92 of Devel/PartialDump.pm</a>
+#      once (13&micro;s+3.17ms) by KiokuDB::Collapser::BEGIN@17 at <a href="KiokuDB-Collapser-Buffer-pm-1606-block.html#101">line 101 of KiokuDB/Collapser/Buffer.pm</a>
+#      once (9&micro;s+3.15ms) by MooseX::Types::Structured::BEGIN@13 at <a href="MooseX-Meta-TypeConstraint-Structured-pm-1203-block.html#20">line 20 of MooseX/Meta/TypeConstraint/Structured.pm</a>
+#      once (8&micro;s+3.14ms) by Text::Tradition::Collation::BEGIN@9 at <a href="lib-Text-Tradition-Collation-Reading-pm-747-block.html#134">line 134 of lib/Text/Tradition/Collation/Reading.pm</a>
+#      once (28&micro;s+3.12ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#60">line 60 of Catalyst/Request.pm</a>
+#      once (13&micro;s+3.13ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#88">line 88 of Catalyst/Request.pm</a>
+#      once (13&micro;s+3.13ms) by KiokuDB::TypeMap::Entry::MOP::BEGIN@9 at <a href="KiokuDB-Thunk-pm-1734-block.html#14">line 14 of KiokuDB/Thunk.pm</a>
+#      once (9&micro;s+3.12ms) by Module::Runtime::require_module at <a href="Data-Stream-Bulk-Filter-pm-1803-block.html#21">line 21 of Data/Stream/Bulk/Filter.pm</a>
+#      once (14&micro;s+3.11ms) by Text::Tradition::Collation::BEGIN@9 at <a href="lib-Text-Tradition-Collation-Reading-pm-747-block.html#348">line 348 of lib/Text/Tradition/Collation/Reading.pm</a>
+#      once (10&micro;s+3.10ms) by Catalyst::BEGIN@14 at <a href="Catalyst-Response-pm-553-block.html#37">line 37 of Catalyst/Response.pm</a>
+#      once (7&micro;s+3.10ms) by Catalyst::Plugin::ConfigLoader::BEGIN@8 at <a href="Data-Visitor-Callback-pm-1863-block.html#37">line 37 of Data/Visitor/Callback.pm</a>
+#      once (11&micro;s+3.08ms) by Catalyst::BEGIN@16 at <a href="Catalyst-Controller-pm-576-block.html#32">line 32 of Catalyst/Controller.pm</a>
+#      once (15&micro;s+3.07ms) by Catalyst::BEGIN@11 at <a href="Catalyst-Log-pm-469-block.html#15">line 15 of Catalyst/Log.pm</a>
+#      once (14&micro;s+3.07ms) by Catalyst::BEGIN@14 at <a href="Catalyst-Response-pm-553-block.html#31">line 31 of Catalyst/Response.pm</a>
+#      once (8&micro;s+3.08ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#192">line 192 of KiokuDB/Backend/DBI.pm</a>
+#      once (10&micro;s+3.07ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#44">line 44 of Catalyst/Request.pm</a>
+#      once (13&micro;s+3.07ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#58">line 58 of Catalyst/Request.pm</a>
+#      once (23&micro;s+3.05ms) by Catalyst::BEGIN@14 at <a href="Catalyst-Response-pm-553-block.html#35">line 35 of Catalyst/Response.pm</a>
+#      once (9&micro;s+3.04ms) by main::BEGIN@10 at <a href="lib-Text-Tradition-pm-673-block.html#13">line 13 of lib/Text/Tradition.pm</a>
+#      once (12&micro;s+3.04ms) by Text::Tradition::BEGIN@6 at <a href="lib-Text-Tradition-Collation-pm-686-block.html#72">line 72 of lib/Text/Tradition/Collation.pm</a>
+#      once (12&micro;s+3.04ms) by Catalyst::BEGIN@14 at <a href="Catalyst-Response-pm-553-block.html#36">line 36 of Catalyst/Response.pm</a>
+#      once (10&micro;s+3.04ms) by KiokuDB::Backend::DBI::BEGIN@21 at <a href="Data-Stream-Bulk-DBI-pm-2152-block.html#15">line 15 of Data/Stream/Bulk/DBI.pm</a>
+#      once (11&micro;s+3.04ms) by Text::Tradition::BEGIN@8 at <a href="lib-Text-Tradition-Witness-pm-1180-block.html#240">line 240 of lib/Text/Tradition/Witness.pm</a>
+#      once (10&micro;s+3.02ms) by Text::Tradition::Collation::BEGIN@9 at <a href="lib-Text-Tradition-Collation-Reading-pm-747-block.html#69">line 69 of lib/Text/Tradition/Collation/Reading.pm</a>
+#      once (8&micro;s+3.00ms) by Text::Tradition::BEGIN@8 at <a href="lib-Text-Tradition-Witness-pm-1180-block.html#303">line 303 of lib/Text/Tradition/Witness.pm</a>
+#      once (9&micro;s+2.99ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#22">line 22 of Catalyst/Request.pm</a>
+#      once (11&micro;s+2.99ms) by MooseX::Meta::TypeConstraint::Structured::BEGIN@6 at <a href="Devel-PartialDump-pm-1206-block.html#98">line 98 of Devel/PartialDump.pm</a>
+#      once (14&micro;s+2.96ms) by KiokuDB::BEGIN@13 at <a href="KiokuDB-LiveObjects-pm-1680-block.html#167">line 167 of KiokuDB/LiveObjects.pm</a>
+#      once (9&micro;s+2.96ms) by Module::Runtime::require_module at <a href="Catalyst-Engine-pm-1927-block.html#24">line 24 of Catalyst/Engine.pm</a>
+#      once (16&micro;s+2.95ms) by Catalyst::BEGIN@14 at <a href="Catalyst-Response-pm-553-block.html#32">line 32 of Catalyst/Response.pm</a>
+#      once (15&micro;s+2.95ms) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#46">line 46 of Catalyst.pm</a>
+#      once (14&micro;s+2.94ms) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#47">line 47 of Catalyst.pm</a>
+#      once (9&micro;s+2.94ms) by Text::Tradition::Collation::RelationshipStore::BEGIN@6 at <a href="lib-Text-Tradition-Collation-Relationship-pm-888-block.html#95">line 95 of lib/Text/Tradition/Collation/Relationship.pm</a>
+#      once (8&micro;s+2.92ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#292">line 292 of KiokuDB/Backend/DBI.pm</a>
+#      once (14&micro;s+2.87ms) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#57">line 57 of Catalyst.pm</a>
+#      once (10&micro;s+2.86ms) by Module::Runtime::require_module at <a href="Catalyst-DispatchType-Regex-pm-2487-block.html#15">line 15 of Catalyst/DispatchType/Regex.pm</a>
+#      once (8&micro;s+2.85ms) by KiokuDB::TypeMap::Entry::Set::BEGIN@9 at <a href="KiokuDB-Set-Deferred-pm-2579-block.html#18">line 18 of KiokuDB/Set/Deferred.pm</a>
+#      once (8&micro;s+2.83ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#100">line 100 of KiokuDB/Backend/DBI.pm</a>
+#      once (10&micro;s+2.82ms) by Module::Runtime::require_module at <a href="Catalyst-Model-KiokuDB-pm-2055-block.html#79">line 79 of Catalyst/Model/KiokuDB.pm</a>
+#      once (12&micro;s+2.80ms) by Text::Tradition::BEGIN@8 at <a href="lib-Text-Tradition-Witness-pm-1180-block.html#203">line 203 of lib/Text/Tradition/Witness.pm</a>
+#      once (14&micro;s+2.79ms) by MooseX::Role::Parameterized::BEGIN@7 at <a href="MooseX-Parameterizable-pm-830-block.html#10">line 10 of MooseX/Role/Parameterized/Meta/Role/Parameterizable.pm</a>
+#      once (12&micro;s+2.78ms) by Catalyst::BEGIN@11 at <a href="Catalyst-Log-pm-469-block.html#14">line 14 of Catalyst/Log.pm</a>
+#      once (10&micro;s+2.74ms) by Module::Runtime::require_module at <a href="Catalyst-Model-KiokuDB-pm-2055-block.html#41">line 41 of Catalyst/Model/KiokuDB.pm</a>
+#      once (9&micro;s+2.73ms) by MooseX::Meta::TypeConstraint::Structured::BEGIN@6 at <a href="Devel-PartialDump-pm-1206-block.html#67">line 67 of Devel/PartialDump.pm</a>
+#      once (10&micro;s+2.73ms) by Text::Tradition::BEGIN@8 at <a href="lib-Text-Tradition-Witness-pm-1180-block.html#230">line 230 of lib/Text/Tradition/Witness.pm</a>
+#      once (14&micro;s+2.71ms) by KiokuDB::Collapser::BEGIN@17 at <a href="KiokuDB-Collapser-Buffer-pm-1606-block.html#93">line 93 of KiokuDB/Collapser/Buffer.pm</a>
+#      once (8&micro;s+2.71ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#111">line 111 of KiokuDB/Backend/DBI.pm</a>
+#      once (12&micro;s+2.65ms) by Catalyst::BEGIN@13 at <a href="Catalyst-Request-Upload-pm-537-block.html#14">line 14 of Catalyst/Request/Upload.pm</a>
+#      once (12&micro;s+2.63ms) by Catalyst::BEGIN@13 at <a href="Catalyst-Request-Upload-pm-537-block.html#15">line 15 of Catalyst/Request/Upload.pm</a>
+#      once (7&micro;s+2.64ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#185">line 185 of KiokuDB/Backend/DBI.pm</a>
+#      once (9&micro;s+2.62ms) by KiokuDB::Collapser::BEGIN@20 at <a href="Data-Visitor-pm-1636-block.html#33">line 33 of Data/Visitor.pm</a>
+#      once (14&micro;s+2.61ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#224">line 224 of KiokuDB/Backend/DBI.pm</a>
+#      once (7&micro;s+2.58ms) by KiokuDB::TypeMap::Entry::Set::BEGIN@9 at <a href="KiokuDB-Set-Deferred-pm-2579-block.html#37">line 37 of KiokuDB/Set/Deferred.pm</a>
+#      once (15&micro;s+2.57ms) by Module::Runtime::require_module at <a href="KiokuX-Model-pm-1511-block.html#19">line 19 of KiokuX/Model.pm</a>
+#      once (7&micro;s+2.57ms) by Module::Runtime::require_module at <a href="KiokuX-Model-pm-1511-block.html#30">line 30 of KiokuX/Model.pm</a>
+#      once (14&micro;s+2.57ms) by Text::Tradition::BEGIN@8 at <a href="lib-Text-Tradition-Witness-pm-1180-block.html#247">line 247 of lib/Text/Tradition/Witness.pm</a>
+#      once (16&micro;s+2.56ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#57">line 57 of Catalyst/Request.pm</a>
+#      once (11&micro;s+2.54ms) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#43">line 43 of Catalyst.pm</a>
+#      once (9&micro;s+2.50ms) by KiokuDB::BEGIN@12 at <a href="KiokuDB-Linker-pm-1662-block.html#35">line 35 of KiokuDB/Linker.pm</a>
+#      once (9&micro;s+2.48ms) by Module::Runtime::require_module at <a href="Catalyst-DispatchType-Chained-pm-2498-block.html#17">line 17 of Catalyst/DispatchType/Chained.pm</a>
+#      once (9&micro;s+2.48ms) by Module::Runtime::require_module at <a href="Catalyst-DispatchType-Path-pm-2481-block.html#15">line 15 of Catalyst/DispatchType/Path.pm</a>
+#      once (14&micro;s+2.46ms) by Module::Runtime::require_module at <a href="Data-Stream-Bulk-Chunked-pm-1787-block.html#15">line 15 of Data/Stream/Bulk/Chunked.pm</a>
+#      once (8&micro;s+2.47ms) by Catalyst::Plugin::ConfigLoader::BEGIN@8 at <a href="Data-Visitor-Callback-pm-1863-block.html#29">line 29 of Data/Visitor/Callback.pm</a>
+#      once (9&micro;s+2.46ms) by Module::Runtime::require_module at <a href="Catalyst-Model-KiokuDB-pm-2055-block.html#67">line 67 of Catalyst/Model/KiokuDB.pm</a>
+#      once (10&micro;s+2.46ms) by main::BEGIN@11 at <a href="lib-Text-Tradition-Directory-pm-1356-block.html#169">line 169 of lib/Text/Tradition/Directory.pm</a>
+#      once (12&micro;s+2.44ms) by KiokuDB::Collapser::BEGIN@20 at <a href="Data-Visitor-pm-1636-block.html#27">line 27 of Data/Visitor.pm</a>
+#      once (10&micro;s+2.44ms) by Text::Tradition::Collation::BEGIN@9 at <a href="lib-Text-Tradition-Collation-Reading-pm-747-block.html#156">line 156 of lib/Text/Tradition/Collation/Reading.pm</a>
+#      once (11&micro;s+2.43ms) by Catalyst::BEGIN@32 at <a href="Catalyst-EngineLoader-pm-643-block.html#9">line 9 of Catalyst/EngineLoader.pm</a>
+#      once (15&micro;s+2.43ms) by KiokuDB::Collapser::BEGIN@17 at <a href="KiokuDB-Collapser-Buffer-pm-1606-block.html#76">line 76 of KiokuDB/Collapser/Buffer.pm</a>
+#      once (10&micro;s+2.43ms) by MooseX::Meta::TypeConstraint::Structured::BEGIN@6 at <a href="Devel-PartialDump-pm-1206-block.html#86">line 86 of Devel/PartialDump.pm</a>
+#      once (9&micro;s+2.43ms) by Text::Tradition::BEGIN@8 at <a href="lib-Text-Tradition-Witness-pm-1180-block.html#235">line 235 of lib/Text/Tradition/Witness.pm</a>
+#      once (11&micro;s+2.42ms) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#45">line 45 of Catalyst.pm</a>
+#      once (9&micro;s+2.41ms) by KiokuDB::BEGIN@11 at <a href="KiokuDB-Collapser-pm-1524-block.html#51">line 51 of KiokuDB/Collapser.pm</a>
+#      once (8&micro;s+2.41ms) by KiokuDB::BEGIN@12 at <a href="KiokuDB-Linker-pm-1662-block.html#52">line 52 of KiokuDB/Linker.pm</a>
+#      once (11&micro;s+2.40ms) by MooseX::Meta::TypeConstraint::Structured::BEGIN@6 at <a href="Devel-PartialDump-pm-1206-block.html#74">line 74 of Devel/PartialDump.pm</a>
+#      once (12&micro;s+2.40ms) by Catalyst::Dispatcher::BEGIN@9 at <a href="Catalyst-Action-pm-1880-block.html#28">line 28 of Catalyst/Action.pm</a>
+#      once (9&micro;s+2.40ms) by KiokuDB::LiveObjects::BEGIN@13 at <a href="KiokuDB-LiveObjects-Scope-pm-1683-block.html#20">line 20 of KiokuDB/LiveObjects/Scope.pm</a>
+#      once (14&micro;s+2.38ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#56">line 56 of Catalyst/Request.pm</a>
+#      once (13&micro;s+2.35ms) by KiokuDB::BEGIN@13 at <a href="KiokuDB-LiveObjects-pm-1680-block.html#38">line 38 of KiokuDB/LiveObjects.pm</a>
+#      once (11&micro;s+2.35ms) by KiokuDB::LiveObjects::BEGIN@14 at <a href="KiokuDB-LiveObjects-TXNScope-pm-1695-block.html#14">line 14 of KiokuDB/LiveObjects/TXNScope.pm</a>
+#      once (10&micro;s+2.30ms) by Text::Tradition::Collation::RelationshipStore::BEGIN@6 at <a href="lib-Text-Tradition-Collation-Relationship-pm-888-block.html#77">line 77 of lib/Text/Tradition/Collation/Relationship.pm</a>
+#      once (17&micro;s+2.29ms) by KiokuDB::BEGIN@11 at <a href="KiokuDB-Collapser-pm-1524-block.html#32">line 32 of KiokuDB/Collapser.pm</a>
+#      once (11&micro;s+2.29ms) by KiokuDB::Backend::DBI::BEGIN@28 at <a href="KiokuDB-TypeMap-Entry-DBIC-Row-pm-2211-block.html#21">line 21 of KiokuDB/TypeMap/Entry/DBIC/Row.pm</a>
+#      once (11&micro;s+2.29ms) by Module::Runtime::require_module at <a href="Catalyst-Model-KiokuDB-pm-2055-block.html#47">line 47 of Catalyst/Model/KiokuDB.pm</a>
+#      once (7&micro;s+2.27ms) by Catalyst::Dispatcher::BEGIN@9 at <a href="Catalyst-Action-pm-1880-block.html#39">line 39 of Catalyst/Action.pm</a>
+#      once (12&micro;s+2.27ms) by KiokuDB::Collapser::BEGIN@17 at <a href="KiokuDB-Collapser-Buffer-pm-1606-block.html#19">line 19 of KiokuDB/Collapser/Buffer.pm</a>
+#      once (10&micro;s+2.27ms) by Module::Runtime::require_module at <a href="Catalyst-Model-KiokuDB-pm-2055-block.html#29">line 29 of Catalyst/Model/KiokuDB.pm</a>
+#      once (10&micro;s+2.27ms) by Module::Runtime::require_module at <a href="Catalyst-Model-KiokuDB-pm-2055-block.html#77">line 77 of Catalyst/Model/KiokuDB.pm</a>
+#      once (8&micro;s+2.27ms) by Module::Runtime::require_module at <a href="Catalyst-DispatchType-Chained-pm-2498-block.html#24">line 24 of Catalyst/DispatchType/Chained.pm</a>
+#      once (15&micro;s+2.25ms) by Catalyst::BEGIN@13 at <a href="Catalyst-Request-Upload-pm-537-block.html#16">line 16 of Catalyst/Request/Upload.pm</a>
+#      once (8&micro;s+2.25ms) by main::BEGIN@10 at <a href="lib-Text-Tradition-pm-673-block.html#32">line 32 of lib/Text/Tradition.pm</a>
+#      once (10&micro;s+2.24ms) by Module::Runtime::require_module at <a href="Data-Stream-Bulk-Filter-pm-1803-block.html#15">line 15 of Data/Stream/Bulk/Filter.pm</a>
+#      once (18&micro;s+2.23ms) by KiokuDB::Linker::BEGIN@18 at <a href="KiokuDB-Error-MissingObjects-pm-1665-block.html#10">line 10 of KiokuDB/Error/MissingObjects.pm</a>
+#      once (12&micro;s+2.22ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#43">line 43 of Catalyst/Request.pm</a>
+#      once (9&micro;s+2.21ms) by KiokuDB::Collapser::BEGIN@17 at <a href="KiokuDB-Collapser-Buffer-pm-1606-block.html#38">line 38 of KiokuDB/Collapser/Buffer.pm</a>
+#      once (9&micro;s+2.20ms) by KiokuDB::LiveObjects::BEGIN@14 at <a href="KiokuDB-LiveObjects-TXNScope-pm-1695-block.html#16">line 16 of KiokuDB/LiveObjects/TXNScope.pm</a>
+#      once (8&micro;s+2.18ms) by KiokuDB::BEGIN@12 at <a href="KiokuDB-Linker-pm-1662-block.html#42">line 42 of KiokuDB/Linker.pm</a>
+#      once (10&micro;s+2.18ms) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#44">line 44 of Catalyst.pm</a>
+#      once (8&micro;s+2.18ms) by Catalyst::Dispatcher::BEGIN@12 at <a href="Catalyst-DispatchType-Index-pm-1909-block.html#32">line 32 of Catalyst/DispatchType/Index.pm</a>
+#      once (9&micro;s+2.17ms) by MooseX::Types::Structured::BEGIN@13 at <a href="MooseX-Meta-TypeConstraint-Structured-pm-1203-block.html#26">line 26 of MooseX/Meta/TypeConstraint/Structured.pm</a>
+#      once (8&micro;s+2.17ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#90">line 90 of KiokuDB/Backend/DBI.pm</a>
+#      once (12&micro;s+2.16ms) by Module::Runtime::require_module at <a href="Parse-Method-Signatures-Param-pm-1199-block.html#52">line 52 of Parse/Method/Signatures/Param.pm</a>
+#      once (10&micro;s+2.16ms) by KiokuDB::Collapser::BEGIN@17 at <a href="KiokuDB-Collapser-Buffer-pm-1606-block.html#44">line 44 of KiokuDB/Collapser/Buffer.pm</a>
+#      once (10&micro;s+2.15ms) by Text::Tradition::Collation::RelationshipStore::BEGIN@6 at <a href="lib-Text-Tradition-Collation-Relationship-pm-888-block.html#101">line 101 of lib/Text/Tradition/Collation/Relationship.pm</a>
+#      once (9&micro;s+2.14ms) by KiokuDB::BEGIN@17 at <a href="KiokuDB-Stream-Objects-pm-1765-block.html#51">line 51 of KiokuDB/Stream/Objects.pm</a>
+#      once (10&micro;s+2.13ms) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#67">line 67 of Catalyst.pm</a>
+#      once (10&micro;s+2.11ms) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#48">line 48 of Catalyst.pm</a>
+#      once (11&micro;s+2.11ms) by Catalyst::Dispatcher::BEGIN@9 at <a href="Catalyst-Action-pm-1880-block.html#27">line 27 of Catalyst/Action.pm</a>
+#      once (9&micro;s+2.10ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#59">line 59 of Catalyst/Request.pm</a>
+#      once (8&micro;s+2.10ms) by Module::Runtime::require_module at <a href="Catalyst-DispatchType-Chained-pm-2498-block.html#31">line 31 of Catalyst/DispatchType/Chained.pm</a>
+#      once (7&micro;s+2.10ms) by Text::Tradition::Collation::BEGIN@9 at <a href="lib-Text-Tradition-Collation-Reading-pm-747-block.html#119">line 119 of lib/Text/Tradition/Collation/Reading.pm</a>
+#      once (9&micro;s+2.09ms) by KiokuDB::BEGIN@12 at <a href="KiokuDB-Linker-pm-1662-block.html#29">line 29 of KiokuDB/Linker.pm</a>
+#      once (9&micro;s+2.06ms) by Text::Tradition::Collation::RelationshipStore::BEGIN@6 at <a href="lib-Text-Tradition-Collation-Relationship-pm-888-block.html#89">line 89 of lib/Text/Tradition/Collation/Relationship.pm</a>
+#      once (9&micro;s+2.03ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#105">line 105 of KiokuDB/Backend/DBI.pm</a>
+#      once (8&micro;s+2.01ms) by Catalyst::Dispatcher::BEGIN@10 at <a href="Catalyst-ActionContainer-pm-1892-block.html#21">line 21 of Catalyst/ActionContainer.pm</a>
+#      once (10&micro;s+1.99ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#19">line 19 of Catalyst/Request.pm</a>
+#      once (9&micro;s+1.99ms) by Text::Tradition::Collation::RelationshipStore::BEGIN@6 at <a href="lib-Text-Tradition-Collation-Relationship-pm-888-block.html#83">line 83 of lib/Text/Tradition/Collation/Relationship.pm</a>
+#      once (9&micro;s+1.99ms) by KiokuDB::GC::Naive::BEGIN@6 at <a href="KiokuDB-GC-Naive-Mark-pm-1363-block.html#27">line 27 of KiokuDB/GC/Naive/Mark.pm</a>
+#      once (7&micro;s+1.98ms) by Catalyst::Plugin::ConfigLoader::BEGIN@8 at <a href="Data-Visitor-Callback-pm-1863-block.html#35">line 35 of Data/Visitor/Callback.pm</a>
+#      once (9&micro;s+1.98ms) by Catalyst::Utils::ensure_class_loaded at <a href="Catalyst-Stats-pm-1947-block.html#12">line 12 of Catalyst/Stats.pm</a>
+#      once (7&micro;s+1.98ms) by Catalyst::Utils::ensure_class_loaded at <a href="Catalyst-Stats-pm-1947-block.html#17">line 17 of Catalyst/Stats.pm</a>
+#      once (7&micro;s+1.96ms) by KiokuDB::Backend::DBI::BEGIN@21 at <a href="Data-Stream-Bulk-DBI-pm-2152-block.html#27">line 27 of Data/Stream/Bulk/DBI.pm</a>
+#      once (9&micro;s+1.95ms) by KiokuDB::BEGIN@12 at <a href="KiokuDB-Linker-pm-1662-block.html#58">line 58 of KiokuDB/Linker.pm</a>
+#      once (7&micro;s+1.94ms) by Text::Tradition::BEGIN@8 at <a href="lib-Text-Tradition-Witness-pm-1180-block.html#309">line 309 of lib/Text/Tradition/Witness.pm</a>
+#      once (9&micro;s+1.94ms) by Text::Tradition::Collation::RelationshipStore::BEGIN@6 at <a href="lib-Text-Tradition-Collation-Relationship-pm-888-block.html#113">line 113 of lib/Text/Tradition/Collation/Relationship.pm</a>
+#      once (10&micro;s+1.91ms) by Catalyst::Dispatcher::BEGIN@9 at <a href="Catalyst-Action-pm-1880-block.html#29">line 29 of Catalyst/Action.pm</a>
+#      once (8&micro;s+1.90ms) by Module::Runtime::require_module at <a href="KiokuDB-TypeMap-Entry-Passthrough-pm-2609-block.html#16">line 16 of KiokuDB/TypeMap/Entry/Passthrough.pm</a>
+#      once (8&micro;s+1.88ms) by Text::Tradition::Collation::RelationshipStore::BEGIN@6 at <a href="lib-Text-Tradition-Collation-Relationship-pm-888-block.html#118">line 118 of lib/Text/Tradition/Collation/Relationship.pm</a>
+#      once (8&micro;s+1.88ms) by Module::Runtime::require_module at <a href="Catalyst-Model-KiokuDB-pm-2055-block.html#35">line 35 of Catalyst/Model/KiokuDB.pm</a>
+#      once (10&micro;s+1.87ms) by Module::Runtime::require_module at <a href="Catalyst-Dispatcher-pm-1877-block.html#33">line 33 of Catalyst/Dispatcher.pm</a>
+#      once (8&micro;s+1.87ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#144">line 144 of KiokuDB.pm</a>
+#      once (7&micro;s+1.87ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#84">line 84 of KiokuDB/Backend/DBI.pm</a>
+#      once (9&micro;s+1.84ms) by Module::Runtime::require_module at <a href="KiokuDB-Backend-DBI-pm-2149-block.html#82">line 82 of KiokuDB/Backend/DBI.pm</a>
+#      once (10&micro;s+1.84ms) by Module::Runtime::require_module at <a href="KiokuDB-TypeMap-Entry-Set-pm-2565-block.html#19">line 19 of KiokuDB/TypeMap/Entry/Set.pm</a>
+#      once (9&micro;s+1.82ms) by Module::Runtime::require_module at <a href="Catalyst-Dispatcher-pm-1877-block.html#36">line 36 of Catalyst/Dispatcher.pm</a>
+#      once (8&micro;s+1.82ms) by KiokuDB::LiveObjects::BEGIN@14 at <a href="KiokuDB-LiveObjects-TXNScope-pm-1695-block.html#22">line 22 of KiokuDB/LiveObjects/TXNScope.pm</a>
+#      once (8&micro;s+1.80ms) by Text::Tradition::Collation::BEGIN@9 at <a href="lib-Text-Tradition-Collation-Reading-pm-747-block.html#89">line 89 of lib/Text/Tradition/Collation/Reading.pm</a>
+#      once (8&micro;s+1.75ms) by Text::Tradition::Collation::BEGIN@9 at <a href="lib-Text-Tradition-Collation-Reading-pm-747-block.html#113">line 113 of lib/Text/Tradition/Collation/Reading.pm</a>
+#      once (9&micro;s+1.74ms) by Module::Runtime::require_module at <a href="Catalyst-Dispatcher-pm-1877-block.html#31">line 31 of Catalyst/Dispatcher.pm</a>
+#      once (7&micro;s+1.74ms) by Catalyst::DispatchType::Chained::BEGIN@7 at <a href="Catalyst-ActionChain-pm-2501-block.html#6">line 6 of Catalyst/ActionChain.pm</a>
+#      once (8&micro;s+1.73ms) by Text::Tradition::Collation::BEGIN@9 at <a href="lib-Text-Tradition-Collation-Reading-pm-747-block.html#107">line 107 of lib/Text/Tradition/Collation/Reading.pm</a>
+#      once (8&micro;s+1.72ms) by Text::Tradition::BEGIN@8 at <a href="lib-Text-Tradition-Witness-pm-1180-block.html#273">line 273 of lib/Text/Tradition/Witness.pm</a>
+#      once (9&micro;s+1.72ms) by Text::Tradition::Collation::BEGIN@9 at <a href="lib-Text-Tradition-Collation-Reading-pm-747-block.html#76">line 76 of lib/Text/Tradition/Collation/Reading.pm</a>
+#      once (7&micro;s+1.71ms) by Catalyst::Dispatcher::BEGIN@9 at <a href="Catalyst-Action-pm-1880-block.html#31">line 31 of Catalyst/Action.pm</a>
+#      once (8&micro;s+1.70ms) by Module::Runtime::require_module at <a href="Catalyst-Dispatcher-pm-1877-block.html#32">line 32 of Catalyst/Dispatcher.pm</a>
+#      once (9&micro;s+1.70ms) by KiokuDB::TypeMap::Entry::Set::BEGIN@8 at <a href="KiokuDB-Set-Stored-pm-2568-block.html#10">line 10 of KiokuDB/Set/Stored.pm</a>
+#      once (6&micro;s+1.68ms) by Module::Runtime::require_module at <a href="Catalyst-Dispatcher-pm-1877-block.html#35">line 35 of Catalyst/Dispatcher.pm</a>
+#      once (7&micro;s+1.66ms) by Text::Tradition::Collation::BEGIN@9 at <a href="lib-Text-Tradition-Collation-Reading-pm-747-block.html#95">line 95 of lib/Text/Tradition/Collation/Reading.pm</a>
+#      once (7&micro;s+1.66ms) by Catalyst::Dispatcher::BEGIN@10 at <a href="Catalyst-ActionContainer-pm-1892-block.html#22">line 22 of Catalyst/ActionContainer.pm</a>
+#      once (7&micro;s+1.63ms) by Catalyst::Dispatcher::BEGIN@9 at <a href="Catalyst-Action-pm-1880-block.html#32">line 32 of Catalyst/Action.pm</a>
+#      once (7&micro;s+1.59ms) by Text::Tradition::Collation::BEGIN@9 at <a href="lib-Text-Tradition-Collation-Reading-pm-747-block.html#101">line 101 of lib/Text/Tradition/Collation/Reading.pm</a>
+#      once (6&micro;s+1.58ms) by Catalyst::Utils::ensure_class_loaded at <a href="Catalyst-Stats-pm-1947-block.html#24">line 24 of Catalyst/Stats.pm</a>
+#      once (8&micro;s+1.54ms) by Module::Runtime::require_module at <a href="Catalyst-Dispatcher-pm-1877-block.html#34">line 34 of Catalyst/Dispatcher.pm</a>
+#      once (7&micro;s+1.51ms) by KiokuDB::Backend::DBI::BEGIN@21 at <a href="Data-Stream-Bulk-DBI-pm-2152-block.html#23">line 23 of Data/Stream/Bulk/DBI.pm</a>
+#      once (7&micro;s+1.45ms) by Catalyst::Dispatcher::BEGIN@9 at <a href="Catalyst-Action-pm-1880-block.html#30">line 30 of Catalyst/Action.pm</a></div></div>sub has {</td></tr>
+<tr><td class="h"><a name="71"></a>71</td><td class="c0">2262</td><td class="c0"><span title="Avg 4&micro;s">8.87ms</span></td><td></td><td></td><td class="s">    my $meta = shift;</td></tr>
+<tr><td class="h"><a name="72"></a>72</td><td></td><td></td><td></td><td></td><td class="s">    my $name = shift;</td></tr>
+<tr><td class="h"><a name="73"></a>73</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="74"></a>74</td><td></td><td></td><td></td><td></td><td class="s">    Moose-&gt;throw_error('Usage: has \'name\' =&gt; ( key =&gt; value, ... )')</td></tr>
+<tr><td class="h"><a name="75"></a>75</td><td></td><td></td><td></td><td></td><td class="s">        if @_ % 2 == 1;</td></tr>
+<tr><td class="h"><a name="76"></a>76</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="77"></a>77</td><td></td><td></td><td class="c0">377</td><td class="c3">4.44ms</td><td class="s">    my %options = ( definition_context =&gt; Moose::Util::_caller_info(), @_ );<div class="calls"><div class="calls_out">    # spent  4.44ms making 377 calls to <a href="Moose-Util-pm-158-block.html#284">Moose::Util::_caller_info</a>, avg 12&micro;s/call</div></div></td></tr>
+<tr><td class="h"><a name="78"></a>78</td><td></td><td></td><td></td><td></td><td class="s">    my $attrs = ( ref($name) eq 'ARRAY' ) ? $name : [ ($name) ];</td></tr>
+<tr><td class="h"><a name="79"></a>79</td><td></td><td></td><td class="c0">390</td><td class="c0">2.15s</td><td class="s">    $meta-&gt;add_attribute( $_, %options ) for @$attrs;<div class="calls"><div class="calls_out">    # spent  2.15s making 390 calls to <a href="Moose-Meta-Class-pm-136-block.html#564">Moose::Meta::Class::add_attribute</a>, avg 5.51ms/call</div></div></td></tr>
+<tr><td class="h"><a name="80"></a>80</td><td></td><td></td><td></td><td></td><td class="s">}</td></tr>
+<tr><td class="h"><a name="81"></a>81</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="82"></a>82</td><td></td><td></td><td></td><td></td><td class="s"><div class="calls"><div class="calls_in"># spent 2.36ms (28&micro;s+2.33) within Moose::before which was called 4 times, avg 589&micro;s/call:
+# 2 times (10&micro;s+1.15ms) by Moose::before at <a href="Moose-Exporter-pm-82-block.html#382">line 382 of Moose/Exporter.pm</a>, avg 580&micro;s/call
+#    once (8&micro;s+847&micro;s) by main::BEGIN@11 at <a href="lib-Text-Tradition-Directory-pm-1356-block.html#214">line 214 of lib/Text/Tradition/Directory.pm</a>
+#    once (11&micro;s+330&micro;s) by KiokuDB::BEGIN@17 at <a href="KiokuDB-Stream-Objects-pm-1765-block.html#82">line 82 of KiokuDB/Stream/Objects.pm</a></div></div>sub before {</td></tr>
+<tr><td class="h"><a name="83"></a>83</td><td class="c3">2</td><td class="c3"><span title="Avg 5&micro;s">9&micro;s</span></td><td class="c3">2</td><td class="c3">1.15ms</td><td class="s">    Moose::Util::add_method_modifier(shift, 'before', \@_);<div class="calls"><div class="calls_out">    # spent  1.15ms making 2 calls to <a href="Moose-Util-pm-158-block.html#237">Moose::Util::add_method_modifier</a>, avg 575&micro;s/call</div></div></td></tr>
+<tr><td class="h"><a name="84"></a>84</td><td></td><td></td><td></td><td></td><td class="s">}</td></tr>
+<tr><td class="h"><a name="85"></a>85</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="86"></a>86</td><td></td><td></td><td></td><td></td><td class="s">sub after {</td></tr>
+<tr><td class="h"><a name="87"></a>87</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Util::add_method_modifier(shift, 'after', \@_);</td></tr>
+<tr><td class="h"><a name="88"></a>88</td><td></td><td></td><td></td><td></td><td class="s">}</td></tr>
+<tr><td class="h"><a name="89"></a>89</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="90"></a>90</td><td></td><td></td><td></td><td></td><td class="s"><div class="calls"><div class="calls_in"># spent 26.4ms (433&micro;s+26.0) within Moose::around which was called 54 times, avg 489&micro;s/call:
+# 27 times (142&micro;s+12.7ms) by Moose::around at <a href="Moose-Exporter-pm-82-block.html#382">line 382 of Moose/Exporter.pm</a>, avg 477&micro;s/call
+#     once (15&micro;s+1.91ms) by Catalyst::BEGIN@16 at <a href="Catalyst-Controller-pm-576-block.html#181">line 181 of Catalyst/Controller.pm</a>
+#     once (14&micro;s+1.38ms) by Catalyst::BEGIN@16 at <a href="Catalyst-Controller-pm-576-block.html#195">line 195 of Catalyst/Controller.pm</a>
+#     once (9&micro;s+769&micro;s) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#945">line 945 of Catalyst.pm</a>
+#     once (15&micro;s+691&micro;s) by MooseX::Types::Structured::BEGIN@14 at <a href="MooseX-Meta-TypeConstraint-Structured-Optional-pm-1229-block.html#18">line 18 of MooseX/Meta/TypeConstraint/Structured/Optional.pm</a>
+#     once (12&micro;s+667&micro;s) by Text::Tradition::BEGIN@6 at <a href="lib-Text-Tradition-Collation-pm-686-block.html#519">line 519 of lib/Text/Tradition/Collation.pm</a>
+#     once (15&micro;s+565&micro;s) by Text::Tradition::Collation::BEGIN@9 at <a href="lib-Text-Tradition-Collation-Reading-pm-747-block.html#377">line 377 of lib/Text/Tradition/Collation/Reading.pm</a>
+#     once (15&micro;s+536&micro;s) by Text::Tradition::Collation::BEGIN@9 at <a href="lib-Text-Tradition-Collation-Reading-pm-747-block.html#195">line 195 of lib/Text/Tradition/Collation/Reading.pm</a>
+#     once (15&micro;s+506&micro;s) by Module::Runtime::require_module at <a href="Catalyst-Component-pm-579-block.html#85">line 85 of Catalyst/Component.pm</a>
+#     once (17&micro;s+494&micro;s) by Catalyst::BEGIN@11 at <a href="Catalyst-Log-pm-469-block.html#55">line 55 of Catalyst/Log.pm</a>
+#     once (8&micro;s+502&micro;s) by main::BEGIN@11 at <a href="lib-Text-Tradition-Directory-pm-1356-block.html#195">line 195 of lib/Text/Tradition/Directory.pm</a>
+#     once (10&micro;s+458&micro;s) by Catalyst::BEGIN@32 at <a href="Catalyst-EngineLoader-pm-643-block.html#120">line 120 of Catalyst/EngineLoader.pm</a>
+#     once (9&micro;s+444&micro;s) by MooseX::Types::Structured::BEGIN@13 at <a href="MooseX-Meta-TypeConstraint-Structured-pm-1203-block.html#131">line 131 of MooseX/Meta/TypeConstraint/Structured.pm</a>
+#     once (15&micro;s+407&micro;s) by Text::Tradition::BEGIN@6 at <a href="lib-Text-Tradition-Collation-pm-686-block.html#319">line 319 of lib/Text/Tradition/Collation.pm</a>
+#     once (10&micro;s+407&micro;s) by MooseX::Types::Structured::BEGIN@13 at <a href="MooseX-Meta-TypeConstraint-Structured-pm-1203-block.html#122">line 122 of MooseX/Meta/TypeConstraint/Structured.pm</a>
+#     once (11&micro;s+355&micro;s) by Text::Tradition::Collation::BEGIN@10 at <a href="lib-Text-Tradition-Collation-RelationshipStore-pm-811-block.html#130">line 130 of lib/Text/Tradition/Collation/RelationshipStore.pm</a>
+#     once (11&micro;s+344&micro;s) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#473">line 473 of Catalyst.pm</a>
+#     once (6&micro;s+323&micro;s) by MooseX::Types::Structured::BEGIN@13 at <a href="MooseX-Meta-TypeConstraint-Structured-pm-1203-block.html#262">line 262 of MooseX/Meta/TypeConstraint/Structured.pm</a>
+#     once (10&micro;s+305&micro;s) by Module::Runtime::require_module at <a href="Parse-Method-Signatures-Sig-pm-1184-block.html#74">line 74 of Parse/Method/Signatures/Sig.pm</a>
+#     once (9&micro;s+305&micro;s) by Text::Tradition::Collation::BEGIN@10 at <a href="lib-Text-Tradition-Collation-RelationshipStore-pm-811-block.html#138">line 138 of lib/Text/Tradition/Collation/RelationshipStore.pm</a>
+#     once (11&micro;s+265&micro;s) by main::BEGIN@10 at <a href="lib-Text-Tradition-pm-673-block.html#69">line 69 of lib/Text/Tradition.pm</a>
+#     once (9&micro;s+258&micro;s) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#256">line 256 of Catalyst/Request.pm</a>
+#     once (8&micro;s+256&micro;s) by Catalyst::Dispatcher::BEGIN@10 at <a href="Catalyst-ActionContainer-pm-1892-block.html#28">line 28 of Catalyst/ActionContainer.pm</a>
+#     once (7&micro;s+235&micro;s) by main::BEGIN@10 at <a href="lib-Text-Tradition-pm-673-block.html#88">line 88 of lib/Text/Tradition.pm</a>
+#     once (9&micro;s+227&micro;s) by Module::Runtime::require_module at <a href="Catalyst-Engine-pm-1927-block.html#34">line 34 of Catalyst/Engine.pm</a>
+#     once (8&micro;s+226&micro;s) by Text::Tradition::BEGIN@8 at <a href="lib-Text-Tradition-Witness-pm-1180-block.html#321">line 321 of lib/Text/Tradition/Witness.pm</a>
+#     once (6&micro;s+203&micro;s) by main::BEGIN@10 at <a href="lib-Text-Tradition-pm-673-block.html#81">line 81 of lib/Text/Tradition.pm</a>
+#     once (6&micro;s+191&micro;s) by Module::Runtime::require_module at <a href="Parse-Method-Signatures-Sig-pm-1184-block.html#83">line 83 of Parse/Method/Signatures/Sig.pm</a></div></div>sub around {</td></tr>
+<tr><td class="h"><a name="91"></a>91</td><td class="c0">27</td><td class="c3"><span title="Avg 6&micro;s">152&micro;s</span></td><td class="c0">27</td><td class="c0">12.7ms</td><td class="s">    Moose::Util::add_method_modifier(shift, 'around', \@_);<div class="calls"><div class="calls_out">    # spent  12.7ms making 27 calls to <a href="Moose-Util-pm-158-block.html#237">Moose::Util::add_method_modifier</a>, avg 472&micro;s/call</div></div></td></tr>
+<tr><td class="h"><a name="92"></a>92</td><td></td><td></td><td></td><td></td><td class="s">}</td></tr>
+<tr><td class="h"><a name="93"></a>93</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="94"></a>94</td><td class="c3">1</td><td class="c3"><span title="Avg 300ns">300ns</span></td><td></td><td></td><td class="s">our $SUPER_PACKAGE;</td></tr>
+<tr><td class="h"><a name="95"></a>95</td><td class="c3">1</td><td class="c3"><span title="Avg 200ns">200ns</span></td><td></td><td></td><td class="s">our $SUPER_BODY;</td></tr>
+<tr><td class="h"><a name="96"></a>96</td><td class="c3">1</td><td class="c3"><span title="Avg 700ns">700ns</span></td><td></td><td></td><td class="s">our @SUPER_ARGS;</td></tr>
+<tr><td class="h"><a name="97"></a>97</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="98"></a>98</td><td></td><td></td><td></td><td></td><td class="s"><div class="calls"><div class="calls_in"># spent 102&micro;s (56+46) within Moose::super which was called 8 times, avg 13&micro;s/call:
+# 8 times (56&micro;s+46&micro;s) by Parse::Method::Signatures::__ANON__[/Users/edenc/perl5/lib/perl5/Parse/Method/Signatures.pm:122] at <a href="Parse-Method-Signatures-pm-911-block.html#121">line 121 of Parse/Method/Signatures.pm</a>, avg 13&micro;s/call</div></div>sub super {</td></tr>
+<tr><td class="h"><a name="99"></a>99</td><td></td><td></td><td></td><td></td><td class="s">    # This check avoids a recursion loop - see</td></tr>
+<tr><td class="h"><a name="100"></a>100</td><td></td><td></td><td></td><td></td><td class="s">    # t/bugs/super_recursion.t</td></tr>
+<tr><td class="h"><a name="101"></a>101</td><td class="c0">24</td><td class="c3"><span title="Avg 2&micro;s">44&micro;s</span></td><td></td><td></td><td class="s">    return if defined $SUPER_PACKAGE &amp;&amp; $SUPER_PACKAGE ne caller();</td></tr>
+<tr><td class="h"><a name="102"></a>102</td><td></td><td></td><td class="c0">8</td><td class="c3">46&micro;s</td><td class="s">    return unless $SUPER_BODY; $SUPER_BODY-&gt;(@SUPER_ARGS);<div class="calls"><div class="calls_out">    # spent    46&micro;s making 8 calls to <a href="Moose-Object-pm-266-block.html#31">Moose::Object::BUILDARGS</a>, avg 6&micro;s/call</div></div></td></tr>
+<tr><td class="h"><a name="103"></a>103</td><td></td><td></td><td></td><td></td><td class="s">}</td></tr>
+<tr><td class="h"><a name="104"></a>104</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="105"></a>105</td><td></td><td></td><td></td><td></td><td class="s"><div class="calls"><div class="calls_in"># spent 4.61ms (90&micro;s+4.52) within Moose::override which was called 10 times, avg 461&micro;s/call:
+# 5 times (36&micro;s+2.21ms) by Moose::override at <a href="Moose-Exporter-pm-82-block.html#382">line 382 of Moose/Exporter.pm</a>, avg 449&micro;s/call
+#    once (13&micro;s+761&micro;s) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#865">line 865 of Parse/Method/Signatures.pm</a>
+#    once (11&micro;s+475&micro;s) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#892">line 892 of Parse/Method/Signatures.pm</a>
+#    once (10&micro;s+368&micro;s) by MooseX::Types::Structured::BEGIN@13 at <a href="MooseX-Meta-TypeConstraint-Structured-pm-1203-block.html#73">line 73 of MooseX/Meta/TypeConstraint/Structured.pm</a>
+#    once (11&micro;s+357&micro;s) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#122">line 122 of Parse/Method/Signatures.pm</a>
+#    once (9&micro;s+351&micro;s) by Module::Runtime::require_module at <a href="Parse-Method-Signatures-Sig-pm-1184-block.html#54">line 54 of Parse/Method/Signatures/Sig.pm</a></div></div>sub override {</td></tr>
+<tr><td class="h"><a name="106"></a>106</td><td class="c0">15</td><td class="c3"><span title="Avg 2&micro;s">31&micro;s</span></td><td></td><td></td><td class="s">    my $meta = shift;</td></tr>
+<tr><td class="h"><a name="107"></a>107</td><td></td><td></td><td></td><td></td><td class="s">    my ( $name, $method ) = @_;</td></tr>
+<tr><td class="h"><a name="108"></a>108</td><td></td><td></td><td class="c0">5</td><td class="c3">2.21ms</td><td class="s">    $meta-&gt;add_override_method_modifier( $name =&gt; $method );<div class="calls"><div class="calls_out">    # spent  2.21ms making 5 calls to <a href="Moose-Meta-Class-pm-136-block.html#579">Moose::Meta::Class::add_override_method_modifier</a>, avg 441&micro;s/call</div></div></td></tr>
+<tr><td class="h"><a name="109"></a>109</td><td></td><td></td><td></td><td></td><td class="s">}</td></tr>
+<tr><td class="h"><a name="110"></a>110</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="111"></a>111</td><td></td><td></td><td></td><td></td><td class="s">sub inner {</td></tr>
+<tr><td class="h"><a name="112"></a>112</td><td></td><td></td><td></td><td></td><td class="s">    my $pkg = caller();</td></tr>
+<tr><td class="h"><a name="113"></a>113</td><td></td><td></td><td></td><td></td><td class="s">    our ( %INNER_BODY, %INNER_ARGS );</td></tr>
+<tr><td class="h"><a name="114"></a>114</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="115"></a>115</td><td></td><td></td><td></td><td></td><td class="s">    if ( my $body = $INNER_BODY{$pkg} ) {</td></tr>
+<tr><td class="h"><a name="116"></a>116</td><td></td><td></td><td></td><td></td><td class="s">        my @args = @{ $INNER_ARGS{$pkg} };</td></tr>
+<tr><td class="h"><a name="117"></a>117</td><td></td><td></td><td></td><td></td><td class="s">        local $INNER_ARGS{$pkg};</td></tr>
+<tr><td class="h"><a name="118"></a>118</td><td></td><td></td><td></td><td></td><td class="s">        local $INNER_BODY{$pkg};</td></tr>
+<tr><td class="h"><a name="119"></a>119</td><td></td><td></td><td></td><td></td><td class="s">        return $body-&gt;(@args);</td></tr>
+<tr><td class="h"><a name="120"></a>120</td><td></td><td></td><td></td><td></td><td class="s">    } else {</td></tr>
+<tr><td class="h"><a name="121"></a>121</td><td></td><td></td><td></td><td></td><td class="s">        return;</td></tr>
+<tr><td class="h"><a name="122"></a>122</td><td></td><td></td><td></td><td></td><td class="s">    }</td></tr>
+<tr><td class="h"><a name="123"></a>123</td><td></td><td></td><td></td><td></td><td class="s">}</td></tr>
+<tr><td class="h"><a name="124"></a>124</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="125"></a>125</td><td></td><td></td><td></td><td></td><td class="s">sub augment {</td></tr>
+<tr><td class="h"><a name="126"></a>126</td><td></td><td></td><td></td><td></td><td class="s">    my $meta = shift;</td></tr>
+<tr><td class="h"><a name="127"></a>127</td><td></td><td></td><td></td><td></td><td class="s">    my ( $name, $method ) = @_;</td></tr>
+<tr><td class="h"><a name="128"></a>128</td><td></td><td></td><td></td><td></td><td class="s">    $meta-&gt;add_augment_method_modifier( $name =&gt; $method );</td></tr>
+<tr><td class="h"><a name="129"></a>129</td><td></td><td></td><td></td><td></td><td class="s">}</td></tr>
+<tr><td class="h"><a name="130"></a>130</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="131"></a>131</td><td class="c3">1</td><td class="c3"><span title="Avg 15&micro;s">15&micro;s</span></td><td class="c3">1</td><td class="c3">973&micro;s</td><td class="s">Moose::Exporter-&gt;setup_import_methods(<div class="calls"><div class="calls_out"># spent   973&micro;s making 1 call to <a href="Moose-Exporter-pm-82-block.html#22">Moose::Exporter::setup_import_methods</a></div></div></td></tr>
+<tr><td class="h"><a name="132"></a>132</td><td></td><td></td><td></td><td></td><td class="s">    with_meta =&gt; [</td></tr>
+<tr><td class="h"><a name="133"></a>133</td><td></td><td></td><td></td><td></td><td class="s">        qw( extends with has before after around override augment )</td></tr>
+<tr><td class="h"><a name="134"></a>134</td><td></td><td></td><td></td><td></td><td class="s">    ],</td></tr>
+<tr><td class="h"><a name="135"></a>135</td><td></td><td></td><td></td><td></td><td class="s">    as_is =&gt; [</td></tr>
+<tr><td class="h"><a name="136"></a>136</td><td></td><td></td><td></td><td></td><td class="s">        qw( super inner ),</td></tr>
+<tr><td class="h"><a name="137"></a>137</td><td></td><td></td><td></td><td></td><td class="s">        \&amp;Carp::confess,</td></tr>
+<tr><td class="h"><a name="138"></a>138</td><td></td><td></td><td></td><td></td><td class="s">        \&amp;Scalar::Util::blessed,</td></tr>
+<tr><td class="h"><a name="139"></a>139</td><td></td><td></td><td></td><td></td><td class="s">    ],</td></tr>
+<tr><td class="h"><a name="140"></a>140</td><td></td><td></td><td></td><td></td><td class="s">);</td></tr>
+<tr><td class="h"><a name="141"></a>141</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="142"></a>142</td><td></td><td></td><td></td><td></td><td class="s"><div class="calls"><div class="calls_in"># spent 449ms (7.77+442) within Moose::init_meta which was called 123 times, avg 3.65ms/call:
+# 123 times (7.77ms+442ms) by Moose::Exporter::__ANON__[/Users/edenc/perl5/lib/perl5/darwin-multi-2level/Moose/Exporter.pm:492] at <a href="Moose-Exporter-pm-82-block.html#447">line 447 of Moose/Exporter.pm</a>, avg 3.65ms/call</div></div>sub init_meta {</td></tr>
+<tr><td class="h"><a name="143"></a>143</td><td class="c0">1722</td><td class="c0"><span title="Avg 3&micro;s">5.57ms</span></td><td></td><td></td><td class="s">    shift;</td></tr>
+<tr><td class="h"><a name="144"></a>144</td><td></td><td></td><td></td><td></td><td class="s">    my %args = @_;</td></tr>
+<tr><td class="h"><a name="145"></a>145</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="146"></a>146</td><td></td><td></td><td></td><td></td><td class="s">    my $class = $args{for_class}</td></tr>
+<tr><td class="h"><a name="147"></a>147</td><td></td><td></td><td></td><td></td><td class="s">        or Moose-&gt;throw_error(&quot;Cannot call init_meta without specifying a for_class&quot;);</td></tr>
+<tr><td class="h"><a name="148"></a>148</td><td></td><td></td><td></td><td></td><td class="s">    my $base_class = $args{base_class} || 'Moose::Object';</td></tr>
+<tr><td class="h"><a name="149"></a>149</td><td></td><td></td><td></td><td></td><td class="s">    my $metaclass  = $args{metaclass}  || 'Moose::Meta::Class';</td></tr>
+<tr><td class="h"><a name="150"></a>150</td><td></td><td></td><td></td><td></td><td class="s">    my $meta_name  = exists $args{meta_name} ? $args{meta_name} : 'meta';</td></tr>
+<tr><td class="h"><a name="151"></a>151</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="152"></a>152</td><td></td><td></td><td class="c0">123</td><td class="c3">484&micro;s</td><td class="s">    Moose-&gt;throw_error(&quot;The Metaclass $metaclass must be loaded. (Perhaps you forgot to 'use $metaclass'?)&quot;)<div class="calls"><div class="calls_out">    # spent   484&micro;s making 123 calls to <a href="Class-Load-XS-pm-78-block.html#Class__Load__XS__is_class_loaded">Class::Load::XS::is_class_loaded</a>, avg 4&micro;s/call</div></div></td></tr>
+<tr><td class="h"><a name="153"></a>153</td><td></td><td></td><td></td><td></td><td class="s">        unless is_class_loaded($metaclass);</td></tr>
+<tr><td class="h"><a name="154"></a>154</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="155"></a>155</td><td></td><td></td><td class="c0">123</td><td class="c3">249&micro;s</td><td class="s">    Moose-&gt;throw_error(&quot;The Metaclass $metaclass must be a subclass of Moose::Meta::Class.&quot;)<div class="calls"><div class="calls_out">    # spent   249&micro;s making 123 calls to <a href="UNIVERSAL-pm-738-block.html#UNIVERSAL__isa">UNIVERSAL::isa</a>, avg 2&micro;s/call</div></div></td></tr>
+<tr><td class="h"><a name="156"></a>156</td><td></td><td></td><td></td><td></td><td class="s">        unless $metaclass-&gt;isa('Moose::Meta::Class');</td></tr>
+<tr><td class="h"><a name="157"></a>157</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="158"></a>158</td><td></td><td></td><td></td><td></td><td class="s">    # make a subtype for each Moose class</td></tr>
+<tr><td class="h"><a name="159"></a>159</td><td class="c3">1</td><td class="c3"><span title="Avg 4&micro;s">4&micro;s</span></td><td class="c0">246</td><td class="c0">108ms</td><td class="s">    class_type($class)<div class="calls"><div class="calls_out">    # spent   104ms making 117 calls to <a href="Moose-Util-TypeConstraints-pm-172-block.html#367">Moose::Util::TypeConstraints::class_type</a>, avg 893&micro;s/call
+    # spent  3.25ms making 123 calls to <a href="Moose-Util-TypeConstraints-pm-172-block.html#309">Moose::Util::TypeConstraints::find_type_constraint</a>, avg 26&micro;s/call
+    # spent    19&micro;s making   6 calls to <a href="Moose-Meta-TypeConstraint-pm-160-block.html#16">Moose::Meta::TypeConstraint::__ANON__[Moose/Meta/TypeConstraint.pm:16]</a>, avg 3&micro;s/call</div></div></td></tr>
+<tr><td class="h"><a name="160"></a>160</td><td></td><td></td><td></td><td></td><td class="s">        unless find_type_constraint($class);</td></tr>
+<tr><td class="h"><a name="161"></a>161</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="162"></a>162</td><td></td><td></td><td></td><td></td><td class="s">    my $meta;</td></tr>
+<tr><td class="h"><a name="163"></a>163</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="164"></a>164</td><td class="c0">365</td><td class="c0"><span title="Avg 5&micro;s">1.99ms</span></td><td class="c0">123</td><td class="c3">406&micro;s</td><td class="s">    if ( $meta = Class::MOP::get_metaclass_by_name($class) ) {<div class="calls"><div class="calls_out">    # spent   406&micro;s making 123 calls to <a href="Class-MOP-pm-83-block.html#55">Class::MOP::get_metaclass_by_name</a>, avg 3&micro;s/call</div></div></td></tr>
+<tr><td class="h"><a name="165"></a>165</td><td></td><td></td><td class="c3">2</td><td class="c3">2&micro;s</td><td class="s">        unless ( $meta-&gt;isa(&quot;Moose::Meta::Class&quot;) ) {<div class="calls"><div class="calls_out">        # spent     2&micro;s making 2 calls to <a href="UNIVERSAL-pm-738-block.html#UNIVERSAL__isa">UNIVERSAL::isa</a>, avg 1&micro;s/call</div></div></td></tr>
+<tr><td class="h"><a name="166"></a>166</td><td></td><td></td><td></td><td></td><td class="s">            my $error_message = &quot;$class already has a metaclass, but it does not inherit $metaclass ($meta).&quot;;</td></tr>
+<tr><td class="h"><a name="167"></a>167</td><td></td><td></td><td></td><td></td><td class="s">            if ( $meta-&gt;isa('Moose::Meta::Role') ) {</td></tr>
+<tr><td class="h"><a name="168"></a>168</td><td></td><td></td><td></td><td></td><td class="s">                Moose-&gt;throw_error($error_message . ' You cannot make the same thing a role and a class. Remove either Moose or Moose::Role.');</td></tr>
+<tr><td class="h"><a name="169"></a>169</td><td></td><td></td><td></td><td></td><td class="s">            } else {</td></tr>
+<tr><td class="h"><a name="170"></a>170</td><td></td><td></td><td></td><td></td><td class="s">                Moose-&gt;throw_error($error_message);</td></tr>
+<tr><td class="h"><a name="171"></a>171</td><td></td><td></td><td></td><td></td><td class="s">            }</td></tr>
+<tr><td class="h"><a name="172"></a>172</td><td></td><td></td><td></td><td></td><td class="s">        }</td></tr>
+<tr><td class="h"><a name="173"></a>173</td><td></td><td></td><td></td><td></td><td class="s">    } else {</td></tr>
+<tr><td class="h"><a name="174"></a>174</td><td></td><td></td><td></td><td></td><td class="s">        # no metaclass</td></tr>
+<tr><td class="h"><a name="175"></a>175</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="176"></a>176</td><td></td><td></td><td></td><td></td><td class="s">        # now we check whether our ancestors have metaclass, and if so borrow that</td></tr>
+<tr><td class="h"><a name="177"></a>177</td><td></td><td></td><td class="c0">121</td><td class="c3">792&micro;s</td><td class="s">        my ( undef, @isa ) = @{ mro::get_linear_isa($class) };<div class="calls"><div class="calls_out">        # spent   792&micro;s making 121 calls to <a href="mro-pm-85-block.html#mro__get_linear_isa">mro::get_linear_isa</a>, avg 7&micro;s/call</div></div></td></tr>
+<tr><td class="h"><a name="178"></a>178</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="179"></a>179</td><td></td><td></td><td></td><td></td><td class="s">        foreach my $ancestor ( @isa ) {</td></tr>
+<tr><td class="h"><a name="180"></a>180</td><td class="c0">9</td><td class="c3"><span title="Avg 4&micro;s">33&micro;s</span></td><td class="c0">7</td><td class="c3">14&micro;s</td><td class="s">            my $ancestor_meta = Class::MOP::get_metaclass_by_name($ancestor) || next;<div class="calls"><div class="calls_out">            # spent    14&micro;s making 7 calls to <a href="Class-MOP-pm-83-block.html#55">Class::MOP::get_metaclass_by_name</a>, avg 2&micro;s/call</div></div></td></tr>
+<tr><td class="h"><a name="181"></a>181</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="182"></a>182</td><td></td><td></td><td class="c3">1</td><td class="c3">14&micro;s</td><td class="s">            my $ancestor_meta_class = $ancestor_meta-&gt;_real_ref_name;<div class="calls"><div class="calls_out">            # spent    14&micro;s making 1 call to <a href="Class-MOP-Class-pm-103-block.html#123">Class::MOP::Class::_real_ref_name</a></div></div></td></tr>
+<tr><td class="h"><a name="183"></a>183</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="184"></a>184</td><td></td><td></td><td></td><td></td><td class="s">            # if we have an ancestor metaclass that inherits $metaclass, we use</td></tr>
+<tr><td class="h"><a name="185"></a>185</td><td></td><td></td><td></td><td></td><td class="s">            # that. This is like _fix_metaclass_incompatibility, but we can do it now.</td></tr>
+<tr><td class="h"><a name="186"></a>186</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="187"></a>187</td><td></td><td></td><td></td><td></td><td class="s">            # the case of having an ancestry is not very common, but arises in</td></tr>
+<tr><td class="h"><a name="188"></a>188</td><td></td><td></td><td></td><td></td><td class="s">            # e.g. Reaction</td></tr>
+<tr><td class="h"><a name="189"></a>189</td><td></td><td></td><td class="c3">1</td><td class="c3">3&micro;s</td><td class="s">            unless ( $metaclass-&gt;isa( $ancestor_meta_class ) ) {<div class="calls"><div class="calls_out">            # spent     3&micro;s making 1 call to <a href="UNIVERSAL-pm-738-block.html#UNIVERSAL__isa">UNIVERSAL::isa</a></div></div></td></tr>
+<tr><td class="h"><a name="190"></a>190</td><td></td><td></td><td></td><td></td><td class="s">                if ( $ancestor_meta_class-&gt;isa($metaclass) ) {</td></tr>
+<tr><td class="h"><a name="191"></a>191</td><td></td><td></td><td></td><td></td><td class="s">                    $metaclass = $ancestor_meta_class;</td></tr>
+<tr><td class="h"><a name="192"></a>192</td><td></td><td></td><td></td><td></td><td class="s">                }</td></tr>
+<tr><td class="h"><a name="193"></a>193</td><td></td><td></td><td></td><td></td><td class="s">            }</td></tr>
+<tr><td class="h"><a name="194"></a>194</td><td></td><td></td><td></td><td></td><td class="s">        }</td></tr>
+<tr><td class="h"><a name="195"></a>195</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="196"></a>196</td><td></td><td></td><td class="c0">121</td><td class="c0">111ms</td><td class="s">        $meta = $metaclass-&gt;initialize($class);<div class="calls"><div class="calls_out">        # spent   111ms making 121 calls to <a href="Moose-Meta-Class-pm-136-block.html#73">Moose::Meta::Class::initialize</a>, avg 914&micro;s/call</div></div></td></tr>
+<tr><td class="h"><a name="197"></a>197</td><td></td><td></td><td></td><td></td><td class="s">    }</td></tr>
+<tr><td class="h"><a name="198"></a>198</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="199"></a>199</td><td class="c0">369</td><td class="c0"><span title="Avg 2&micro;s">807&micro;s</span></td><td></td><td></td><td class="s">    if (defined $meta_name) {</td></tr>
+<tr><td class="h"><a name="200"></a>200</td><td></td><td></td><td></td><td></td><td class="s">        # also check for inherited non moose 'meta' method?</td></tr>
+<tr><td class="h"><a name="201"></a>201</td><td></td><td></td><td class="c0">123</td><td class="c2">5.22ms</td><td class="s">        my $existing = $meta-&gt;get_method($meta_name);<div class="calls"><div class="calls_out">        # spent  5.22ms making 123 calls to <a href="Class-MOP-Mixin-HasMethods-pm-91-block.html#113">Class::MOP::Mixin::HasMethods::get_method</a>, avg 42&micro;s/call</div></div></td></tr>
+<tr><td class="h"><a name="202"></a>202</td><td></td><td></td><td class="c3">2</td><td class="c3">2&micro;s</td><td class="s">        if ($existing &amp;&amp; !$existing-&gt;isa('Class::MOP::Method::Meta')) {<div class="calls"><div class="calls_out">        # spent     2&micro;s making 2 calls to <a href="UNIVERSAL-pm-738-block.html#UNIVERSAL__isa">UNIVERSAL::isa</a>, avg 1&micro;s/call</div></div></td></tr>
+<tr><td class="h"><a name="203"></a>203</td><td></td><td></td><td></td><td></td><td class="s">            Carp::cluck &quot;Moose is overwriting an existing method named &quot;</td></tr>
+<tr><td class="h"><a name="204"></a>204</td><td></td><td></td><td></td><td></td><td class="s">                      . &quot;$meta_name in class $class with a method &quot;</td></tr>
+<tr><td class="h"><a name="205"></a>205</td><td></td><td></td><td></td><td></td><td class="s">                      . &quot;which returns the class's metaclass. If this is &quot;</td></tr>
+<tr><td class="h"><a name="206"></a>206</td><td></td><td></td><td></td><td></td><td class="s">                      . &quot;actually what you want, you should remove the &quot;</td></tr>
+<tr><td class="h"><a name="207"></a>207</td><td></td><td></td><td></td><td></td><td class="s">                      . &quot;existing method, otherwise, you should rename or &quot;</td></tr>
+<tr><td class="h"><a name="208"></a>208</td><td></td><td></td><td></td><td></td><td class="s">                      . &quot;disable this generated method using the &quot;</td></tr>
+<tr><td class="h"><a name="209"></a>209</td><td></td><td></td><td></td><td></td><td class="s">                      . &quot;'-meta_name' option to 'use Moose'.&quot;;</td></tr>
+<tr><td class="h"><a name="210"></a>210</td><td></td><td></td><td></td><td></td><td class="s">        }</td></tr>
+<tr><td class="h"><a name="211"></a>211</td><td></td><td></td><td class="c0">123</td><td class="c0">77.1ms</td><td class="s">        $meta-&gt;_add_meta_method($meta_name);<div class="calls"><div class="calls_out">        # spent  77.1ms making 123 calls to <a href="Class-MOP-Mixin-HasMethods-pm-91-block.html#25">Class::MOP::Mixin::HasMethods::_add_meta_method</a>, avg 627&micro;s/call</div></div></td></tr>
+<tr><td class="h"><a name="212"></a>212</td><td></td><td></td><td></td><td></td><td class="s">    }</td></tr>
+<tr><td class="h"><a name="213"></a>213</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="214"></a>214</td><td></td><td></td><td></td><td></td><td class="s">    # make sure they inherit from Moose::Object</td></tr>
+<tr><td class="h"><a name="215"></a>215</td><td></td><td></td><td class="c0">242</td><td class="c0">99.5ms</td><td class="s">    $meta-&gt;superclasses($base_class)<div class="calls"><div class="calls_out">    # spent   139ms making 242 calls to <a href="Moose-Meta-Class-pm-136-block.html#549">Moose::Meta::Class::superclasses</a>, avg 575&micro;s/call, recursion: max depth 2, sum of overlapping time 39.5ms</div></div></td></tr>
+<tr><td class="h"><a name="216"></a>216</td><td></td><td></td><td></td><td></td><td class="s">      unless $meta-&gt;superclasses();</td></tr>
+<tr><td class="h"><a name="217"></a>217</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="218"></a>218</td><td></td><td></td><td></td><td></td><td class="s">    return $meta;</td></tr>
+<tr><td class="h"><a name="219"></a>219</td><td></td><td></td><td></td><td></td><td class="s">}</td></tr>
+<tr><td class="h"><a name="220"></a>220</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="221"></a>221</td><td></td><td></td><td></td><td></td><td class="s"># This may be used in some older MooseX extensions.</td></tr>
+<tr><td class="h"><a name="222"></a>222</td><td></td><td></td><td></td><td></td><td class="s">sub _get_caller {</td></tr>
+<tr><td class="h"><a name="223"></a>223</td><td></td><td></td><td></td><td></td><td class="s">    goto &amp;Moose::Exporter::_get_caller;</td></tr>
+<tr><td class="h"><a name="224"></a>224</td><td></td><td></td><td></td><td></td><td class="s">}</td></tr>
+<tr><td class="h"><a name="225"></a>225</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="226"></a>226</td><td></td><td></td><td></td><td></td><td class="s">## make 'em all immutable</td></tr>
+<tr><td class="h"><a name="227"></a>227</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="228"></a>228</td><td></td><td></td><td class="c0">21</td><td class="c3">27&micro;s</td><td class="s">$_-&gt;make_immutable(<div class="calls"><div class="calls_out"># spent    27&micro;s making 21 calls to <a href="Class-MOP-Class-pm-103-block.html#1259">Class::MOP::Class::is_mutable</a>, avg 1&micro;s/call</div></div></td></tr>
+<tr><td class="h"><a name="229"></a>229</td><td></td><td></td><td></td><td></td><td class="s">    inline_constructor =&gt; 1,</td></tr>
+<tr><td class="h"><a name="230"></a>230</td><td></td><td></td><td></td><td></td><td class="s">    constructor_name   =&gt; &quot;_new&quot;,</td></tr>
+<tr><td class="h"><a name="231"></a>231</td><td></td><td></td><td></td><td></td><td class="s">    # these are Class::MOP accessors, so they need inlining</td></tr>
+<tr><td class="h"><a name="232"></a>232</td><td></td><td></td><td></td><td></td><td class="s">    inline_accessors =&gt; 1</td></tr>
+<tr><td class="h"><a name="233"></a>233</td><td class="c0">43</td><td class="c2"><span title="Avg 6&micro;s">247&micro;s</span></td><td class="c0">42</td><td class="c0">114ms</td><td class="s">    ) for grep { $_-&gt;is_mutable }<div class="calls"><div class="calls_out">    # spent   110ms making 21 calls to <a href="Class-MOP-Class-pm-103-block.html#1280">Class::MOP::Class::make_immutable</a>, avg 5.26ms/call
+    # spent  2.98ms making  9 calls to <a href="Class-MOP-Package-pm-122-block.html#221">Class::MOP::Object::meta</a>, avg 331&micro;s/call
+    # spent    38&micro;s making  2 calls to <a href="Class-MOP-Package-pm-122-block.html#221">Moose::Meta::Role::Method::Required::meta</a>, avg 19&micro;s/call
+    # spent    26&micro;s making  1 call to <a href="Class-MOP-Package-pm-122-block.html#221">Moose::Meta::Role::meta</a>
+    # spent    23&micro;s making  1 call to <a href="Class-MOP-Package-pm-122-block.html#221">Moose::Meta::Role::Application::ToRole::meta</a>
+    # spent    21&micro;s making  1 call to <a href="Class-MOP-Package-pm-122-block.html#221">Moose::Meta::Role::Application::ToClass::meta</a>
+    # spent    21&micro;s making  1 call to <a href="Class-MOP-Package-pm-122-block.html#221">Class::MOP::Mixin::meta</a>
+    # spent    20&micro;s making  1 call to <a href="Class-MOP-Package-pm-122-block.html#221">Moose::Meta::Role::Application::RoleSummation::meta</a>
+    # spent    19&micro;s making  1 call to <a href="Class-MOP-Package-pm-122-block.html#221">Moose::Meta::Role::Application::ToInstance::meta</a>
+    # spent    19&micro;s making  1 call to <a href="Class-MOP-Package-pm-122-block.html#221">Moose::Meta::Role::Composite::meta</a>
+    # spent    19&micro;s making  1 call to <a href="Class-MOP-Package-pm-122-block.html#221">Moose::Meta::Role::Application::meta</a>
+    # spent    13&micro;s making  1 call to <a href="Class-MOP-Package-pm-122-block.html#221">Moose::Meta::TypeCoercion::Union::meta</a>
+    # spent    12&micro;s making  1 call to <a href="Class-MOP-Package-pm-122-block.html#221">Moose::Meta::TypeCoercion::meta</a></div></div></td></tr>
+<tr><td class="h"><a name="234"></a>234</td><td></td><td></td><td></td><td></td><td class="s">    map { $_-&gt;meta }</td></tr>
+<tr><td class="h"><a name="235"></a>235</td><td></td><td></td><td></td><td></td><td class="s">    qw(</td></tr>
+<tr><td class="h"><a name="236"></a>236</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::Attribute</td></tr>
+<tr><td class="h"><a name="237"></a>237</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::Class</td></tr>
+<tr><td class="h"><a name="238"></a>238</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::Instance</td></tr>
+<tr><td class="h"><a name="239"></a>239</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="240"></a>240</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::TypeCoercion</td></tr>
+<tr><td class="h"><a name="241"></a>241</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::TypeCoercion::Union</td></tr>
+<tr><td class="h"><a name="242"></a>242</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="243"></a>243</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::Method</td></tr>
+<tr><td class="h"><a name="244"></a>244</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::Method::Constructor</td></tr>
+<tr><td class="h"><a name="245"></a>245</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::Method::Destructor</td></tr>
+<tr><td class="h"><a name="246"></a>246</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::Method::Overridden</td></tr>
+<tr><td class="h"><a name="247"></a>247</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::Method::Augmented</td></tr>
+<tr><td class="h"><a name="248"></a>248</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="249"></a>249</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::Role</td></tr>
+<tr><td class="h"><a name="250"></a>250</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::Role::Attribute</td></tr>
+<tr><td class="h"><a name="251"></a>251</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::Role::Method</td></tr>
+<tr><td class="h"><a name="252"></a>252</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::Role::Method::Required</td></tr>
+<tr><td class="h"><a name="253"></a>253</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::Role::Method::Conflicting</td></tr>
+<tr><td class="h"><a name="254"></a>254</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="255"></a>255</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::Role::Composite</td></tr>
+<tr><td class="h"><a name="256"></a>256</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="257"></a>257</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::Role::Application</td></tr>
+<tr><td class="h"><a name="258"></a>258</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::Role::Application::RoleSummation</td></tr>
+<tr><td class="h"><a name="259"></a>259</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::Role::Application::ToClass</td></tr>
+<tr><td class="h"><a name="260"></a>260</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::Role::Application::ToRole</td></tr>
+<tr><td class="h"><a name="261"></a>261</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::Role::Application::ToInstance</td></tr>
+<tr><td class="h"><a name="262"></a>262</td><td></td><td></td><td></td><td></td><td class="s">);</td></tr>
+<tr><td class="h"><a name="263"></a>263</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="264"></a>264</td><td></td><td></td><td class="c1">3</td><td class="c3">3&micro;s</td><td class="s">$_-&gt;make_immutable(<div class="calls"><div class="calls_out"># spent     3&micro;s making 3 calls to <a href="Class-MOP-Class-pm-103-block.html#1259">Class::MOP::Class::is_mutable</a>, avg 1&micro;s/call</div></div></td></tr>
+<tr><td class="h"><a name="265"></a>265</td><td></td><td></td><td></td><td></td><td class="s">    inline_constructor =&gt; 0,</td></tr>
+<tr><td class="h"><a name="266"></a>266</td><td></td><td></td><td></td><td></td><td class="s">    constructor_name   =&gt; undef,</td></tr>
+<tr><td class="h"><a name="267"></a>267</td><td></td><td></td><td></td><td></td><td class="s">    # these are Class::MOP accessors, so they need inlining</td></tr>
+<tr><td class="h"><a name="268"></a>268</td><td></td><td></td><td></td><td></td><td class="s">    inline_accessors =&gt; 1</td></tr>
+<tr><td class="h"><a name="269"></a>269</td><td class="c0">7</td><td class="c3"><span title="Avg 5&micro;s">34&micro;s</span></td><td class="c0">6</td><td class="c0">11.6ms</td><td class="s">    ) for grep { $_-&gt;is_mutable }<div class="calls"><div class="calls_out">    # spent  11.0ms making 3 calls to <a href="Class-MOP-Class-pm-103-block.html#1280">Class::MOP::Class::make_immutable</a>, avg 3.66ms/call
+    # spent   589&micro;s making 2 calls to <a href="Class-MOP-Package-pm-122-block.html#221">Class::MOP::Object::meta</a>, avg 294&micro;s/call
+    # spent    16&micro;s making 1 call to <a href="Class-MOP-Package-pm-122-block.html#221">Class::MOP::Mixin::meta</a></div></div></td></tr>
+<tr><td class="h"><a name="270"></a>270</td><td></td><td></td><td></td><td></td><td class="s">    map { $_-&gt;meta }</td></tr>
+<tr><td class="h"><a name="271"></a>271</td><td></td><td></td><td></td><td></td><td class="s">    qw(</td></tr>
+<tr><td class="h"><a name="272"></a>272</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::Method::Accessor</td></tr>
+<tr><td class="h"><a name="273"></a>273</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::Method::Delegation</td></tr>
+<tr><td class="h"><a name="274"></a>274</td><td></td><td></td><td></td><td></td><td class="s">    Moose::Meta::Mixin::AttributeCore</td></tr>
+<tr><td class="h"><a name="275"></a>275</td><td></td><td></td><td></td><td></td><td class="s">);</td></tr>
+<tr><td class="h"><a name="276"></a>276</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="277"></a>277</td><td class="c3">1</td><td class="c3"><span title="Avg 42&micro;s">42&micro;s</span></td><td></td><td></td><td class="s">1;</td></tr>
+<tr><td class="h"><a name="278"></a>278</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="279"></a>279</td><td></td><td></td><td></td><td></td><td class="s"># ABSTRACT: A postmodern object system for Perl 5</td></tr>
+<tr><td class="h"><a name="280"></a>280</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="- -"></a>- -</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="283"></a>283</td><td></td><td></td><td></td><td></td><td class="s">=pod</td></tr>
+<tr><td class="h"><a name="284"></a>284</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="285"></a>285</td><td></td><td></td><td></td><td></td><td class="s">=head1 NAME</td></tr>
+<tr><td class="h"><a name="286"></a>286</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="287"></a>287</td><td></td><td></td><td></td><td></td><td class="s">Moose - A postmodern object system for Perl 5</td></tr>
+<tr><td class="h"><a name="288"></a>288</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="289"></a>289</td><td></td><td></td><td></td><td></td><td class="s">=head1 VERSION</td></tr>
+<tr><td class="h"><a name="290"></a>290</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="291"></a>291</td><td></td><td></td><td></td><td></td><td class="s">version 2.0602</td></tr>
+<tr><td class="h"><a name="292"></a>292</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="293"></a>293</td><td></td><td></td><td></td><td></td><td class="s">=head1 SYNOPSIS</td></tr>
+<tr><td class="h"><a name="294"></a>294</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="295"></a>295</td><td></td><td></td><td></td><td></td><td class="s">  package Point;</td></tr>
+<tr><td class="h"><a name="296"></a>296</td><td></td><td></td><td></td><td></td><td class="s">  use Moose; # automatically turns on strict and warnings</td></tr>
+<tr><td class="h"><a name="297"></a>297</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="298"></a>298</td><td></td><td></td><td></td><td></td><td class="s">  has 'x' =&gt; (is =&gt; 'rw', isa =&gt; 'Int');</td></tr>
+<tr><td class="h"><a name="299"></a>299</td><td></td><td></td><td></td><td></td><td class="s">  has 'y' =&gt; (is =&gt; 'rw', isa =&gt; 'Int');</td></tr>
+<tr><td class="h"><a name="300"></a>300</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="301"></a>301</td><td></td><td></td><td></td><td></td><td class="s">  sub clear {</td></tr>
+<tr><td class="h"><a name="302"></a>302</td><td></td><td></td><td></td><td></td><td class="s">      my $self = shift;</td></tr>
+<tr><td class="h"><a name="303"></a>303</td><td></td><td></td><td></td><td></td><td class="s">      $self-&gt;x(0);</td></tr>
+<tr><td class="h"><a name="304"></a>304</td><td></td><td></td><td></td><td></td><td class="s">      $self-&gt;y(0);</td></tr>
+<tr><td class="h"><a name="305"></a>305</td><td></td><td></td><td></td><td></td><td class="s">  }</td></tr>
+<tr><td class="h"><a name="306"></a>306</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="307"></a>307</td><td></td><td></td><td></td><td></td><td class="s">  package Point3D;</td></tr>
+<tr><td class="h"><a name="308"></a>308</td><td></td><td></td><td></td><td></td><td class="s">  use Moose;</td></tr>
+<tr><td class="h"><a name="309"></a>309</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="310"></a>310</td><td></td><td></td><td></td><td></td><td class="s">  extends 'Point';</td></tr>
+<tr><td class="h"><a name="311"></a>311</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="312"></a>312</td><td></td><td></td><td></td><td></td><td class="s">  has 'z' =&gt; (is =&gt; 'rw', isa =&gt; 'Int');</td></tr>
+<tr><td class="h"><a name="313"></a>313</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="314"></a>314</td><td></td><td></td><td></td><td></td><td class="s">  after 'clear' =&gt; sub {</td></tr>
+<tr><td class="h"><a name="315"></a>315</td><td></td><td></td><td></td><td></td><td class="s">      my $self = shift;</td></tr>
+<tr><td class="h"><a name="316"></a>316</td><td></td><td></td><td></td><td></td><td class="s">      $self-&gt;z(0);</td></tr>
+<tr><td class="h"><a name="317"></a>317</td><td></td><td></td><td></td><td></td><td class="s">  };</td></tr>
+<tr><td class="h"><a name="318"></a>318</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="319"></a>319</td><td></td><td></td><td></td><td></td><td class="s">=head1 DESCRIPTION</td></tr>
+<tr><td class="h"><a name="320"></a>320</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="321"></a>321</td><td></td><td></td><td></td><td></td><td class="s">Moose is an extension of the Perl 5 object system.</td></tr>
+<tr><td class="h"><a name="322"></a>322</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="323"></a>323</td><td></td><td></td><td></td><td></td><td class="s">The main goal of Moose is to make Perl 5 Object Oriented programming</td></tr>
+<tr><td class="h"><a name="324"></a>324</td><td></td><td></td><td></td><td></td><td class="s">easier, more consistent, and less tedious. With Moose you can think</td></tr>
+<tr><td class="h"><a name="325"></a>325</td><td></td><td></td><td></td><td></td><td class="s">more about what you want to do and less about the mechanics of OOP.</td></tr>
+<tr><td class="h"><a name="326"></a>326</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="327"></a>327</td><td></td><td></td><td></td><td></td><td class="s">Additionally, Moose is built on top of L&lt;Class::MOP&gt;, which is a</td></tr>
+<tr><td class="h"><a name="328"></a>328</td><td></td><td></td><td></td><td></td><td class="s">metaclass system for Perl 5. This means that Moose not only makes</td></tr>
+<tr><td class="h"><a name="329"></a>329</td><td></td><td></td><td></td><td></td><td class="s">building normal Perl 5 objects better, but it provides the power of</td></tr>
+<tr><td class="h"><a name="330"></a>330</td><td></td><td></td><td></td><td></td><td class="s">metaclass programming as well.</td></tr>
+<tr><td class="h"><a name="331"></a>331</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="332"></a>332</td><td></td><td></td><td></td><td></td><td class="s">=head2 New to Moose?</td></tr>
+<tr><td class="h"><a name="333"></a>333</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="334"></a>334</td><td></td><td></td><td></td><td></td><td class="s">If you're new to Moose, the best place to start is the</td></tr>
+<tr><td class="h"><a name="335"></a>335</td><td></td><td></td><td></td><td></td><td class="s">L&lt;Moose::Manual&gt; docs, followed by the L&lt;Moose::Cookbook&gt;. The intro</td></tr>
+<tr><td class="h"><a name="336"></a>336</td><td></td><td></td><td></td><td></td><td class="s">will show you what Moose is, and how it makes Perl 5 OO better.</td></tr>
+<tr><td class="h"><a name="337"></a>337</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="338"></a>338</td><td></td><td></td><td></td><td></td><td class="s">The cookbook recipes on Moose basics will get you up to speed with</td></tr>
+<tr><td class="h"><a name="339"></a>339</td><td></td><td></td><td></td><td></td><td class="s">many of Moose's features quickly. Once you have an idea of what Moose</td></tr>
+<tr><td class="h"><a name="340"></a>340</td><td></td><td></td><td></td><td></td><td class="s">can do, you can use the API documentation to get more detail on</td></tr>
+<tr><td class="h"><a name="341"></a>341</td><td></td><td></td><td></td><td></td><td class="s">features which interest you.</td></tr>
+<tr><td class="h"><a name="342"></a>342</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="343"></a>343</td><td></td><td></td><td></td><td></td><td class="s">=head2 Moose Extensions</td></tr>
+<tr><td class="h"><a name="344"></a>344</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="345"></a>345</td><td></td><td></td><td></td><td></td><td class="s">The C&lt;MooseX::&gt; namespace is the official place to find Moose extensions.</td></tr>
+<tr><td class="h"><a name="346"></a>346</td><td></td><td></td><td></td><td></td><td class="s">These extensions can be found on the CPAN.  The easiest way to find them</td></tr>
+<tr><td class="h"><a name="347"></a>347</td><td></td><td></td><td></td><td></td><td class="s">is to search for them (L&lt;http://search.cpan.org/search?query=MooseX::&gt;),</td></tr>
+<tr><td class="h"><a name="348"></a>348</td><td></td><td></td><td></td><td></td><td class="s">or to examine L&lt;Task::Moose&gt; which aims to keep an up-to-date, easily</td></tr>
+<tr><td class="h"><a name="349"></a>349</td><td></td><td></td><td></td><td></td><td class="s">installable list of Moose extensions.</td></tr>
+<tr><td class="h"><a name="350"></a>350</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="351"></a>351</td><td></td><td></td><td></td><td></td><td class="s">=head1 TRANSLATIONS</td></tr>
+<tr><td class="h"><a name="352"></a>352</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="353"></a>353</td><td></td><td></td><td></td><td></td><td class="s">Much of the Moose documentation has been translated into other languages.</td></tr>
+<tr><td class="h"><a name="354"></a>354</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="355"></a>355</td><td></td><td></td><td></td><td></td><td class="s">=over 4</td></tr>
+<tr><td class="h"><a name="356"></a>356</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="357"></a>357</td><td></td><td></td><td></td><td></td><td class="s">=item Japanese</td></tr>
+<tr><td class="h"><a name="358"></a>358</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="359"></a>359</td><td></td><td></td><td></td><td></td><td class="s">Japanese docs can be found at</td></tr>
+<tr><td class="h"><a name="360"></a>360</td><td></td><td></td><td></td><td></td><td class="s">L&lt;http://perldoc.perlassociation.org/pod/Moose-Doc-JA/index.html&gt;. The</td></tr>
+<tr><td class="h"><a name="361"></a>361</td><td></td><td></td><td></td><td></td><td class="s">source POD files can be found in GitHub:</td></tr>
+<tr><td class="h"><a name="362"></a>362</td><td></td><td></td><td></td><td></td><td class="s">L&lt;http://github.com/jpa/Moose-Doc-JA&gt;</td></tr>
+<tr><td class="h"><a name="363"></a>363</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="364"></a>364</td><td></td><td></td><td></td><td></td><td class="s">=back</td></tr>
+<tr><td class="h"><a name="365"></a>365</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="366"></a>366</td><td></td><td></td><td></td><td></td><td class="s">=head1 BUILDING CLASSES WITH MOOSE</td></tr>
+<tr><td class="h"><a name="367"></a>367</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="368"></a>368</td><td></td><td></td><td></td><td></td><td class="s">Moose makes every attempt to provide as much convenience as possible during</td></tr>
+<tr><td class="h"><a name="369"></a>369</td><td></td><td></td><td></td><td></td><td class="s">class construction/definition, but still stay out of your way if you want it</td></tr>
+<tr><td class="h"><a name="370"></a>370</td><td></td><td></td><td></td><td></td><td class="s">to. Here are a few items to note when building classes with Moose.</td></tr>
+<tr><td class="h"><a name="371"></a>371</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="372"></a>372</td><td></td><td></td><td></td><td></td><td class="s">When you C&lt;use Moose&gt;, Moose will set the class's parent class to</td></tr>
+<tr><td class="h"><a name="373"></a>373</td><td></td><td></td><td></td><td></td><td class="s">L&lt;Moose::Object&gt;, I&lt;unless&gt; the class using Moose already has a parent</td></tr>
+<tr><td class="h"><a name="374"></a>374</td><td></td><td></td><td></td><td></td><td class="s">class. In addition, specifying a parent with C&lt;extends&gt; will change the parent</td></tr>
+<tr><td class="h"><a name="375"></a>375</td><td></td><td></td><td></td><td></td><td class="s">class.</td></tr>
+<tr><td class="h"><a name="376"></a>376</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="377"></a>377</td><td></td><td></td><td></td><td></td><td class="s">Moose will also manage all attributes (including inherited ones) that are</td></tr>
+<tr><td class="h"><a name="378"></a>378</td><td></td><td></td><td></td><td></td><td class="s">defined with C&lt;has&gt;. And (assuming you call C&lt;new&gt;, which is inherited from</td></tr>
+<tr><td class="h"><a name="379"></a>379</td><td></td><td></td><td></td><td></td><td class="s">L&lt;Moose::Object&gt;) this includes properly initializing all instance slots,</td></tr>
+<tr><td class="h"><a name="380"></a>380</td><td></td><td></td><td></td><td></td><td class="s">setting defaults where appropriate, and performing any type constraint checking</td></tr>
+<tr><td class="h"><a name="381"></a>381</td><td></td><td></td><td></td><td></td><td class="s">or coercion.</td></tr>
+<tr><td class="h"><a name="382"></a>382</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="383"></a>383</td><td></td><td></td><td></td><td></td><td class="s">=head1 PROVIDED METHODS</td></tr>
+<tr><td class="h"><a name="384"></a>384</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="385"></a>385</td><td></td><td></td><td></td><td></td><td class="s">Moose provides a number of methods to all your classes, mostly through the</td></tr>
+<tr><td class="h"><a name="386"></a>386</td><td></td><td></td><td></td><td></td><td class="s">inheritance of L&lt;Moose::Object&gt;. There is however, one exception.</td></tr>
+<tr><td class="h"><a name="387"></a>387</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="388"></a>388</td><td></td><td></td><td></td><td></td><td class="s">=over 4</td></tr>
+<tr><td class="h"><a name="389"></a>389</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="390"></a>390</td><td></td><td></td><td></td><td></td><td class="s">=item B&lt;meta&gt;</td></tr>
+<tr><td class="h"><a name="391"></a>391</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="392"></a>392</td><td></td><td></td><td></td><td></td><td class="s">This is a method which provides access to the current class's metaclass.</td></tr>
+<tr><td class="h"><a name="393"></a>393</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="394"></a>394</td><td></td><td></td><td></td><td></td><td class="s">=back</td></tr>
+<tr><td class="h"><a name="395"></a>395</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="396"></a>396</td><td></td><td></td><td></td><td></td><td class="s">=head1 EXPORTED FUNCTIONS</td></tr>
+<tr><td class="h"><a name="397"></a>397</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="398"></a>398</td><td></td><td></td><td></td><td></td><td class="s">Moose will export a number of functions into the class's namespace which</td></tr>
+<tr><td class="h"><a name="399"></a>399</td><td></td><td></td><td></td><td></td><td class="s">may then be used to set up the class. These functions all work directly</td></tr>
+<tr><td class="h"><a name="400"></a>400</td><td></td><td></td><td></td><td></td><td class="s">on the current class.</td></tr>
+<tr><td class="h"><a name="401"></a>401</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="402"></a>402</td><td></td><td></td><td></td><td></td><td class="s">=over 4</td></tr>
+<tr><td class="h"><a name="403"></a>403</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="404"></a>404</td><td></td><td></td><td></td><td></td><td class="s">=item B&lt;extends (@superclasses)&gt;</td></tr>
+<tr><td class="h"><a name="405"></a>405</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="406"></a>406</td><td></td><td></td><td></td><td></td><td class="s">This function will set the superclass(es) for the current class.</td></tr>
+<tr><td class="h"><a name="407"></a>407</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="408"></a>408</td><td></td><td></td><td></td><td></td><td class="s">This approach is recommended instead of C&lt;use base&gt;, because C&lt;use base&gt;</td></tr>
+<tr><td class="h"><a name="409"></a>409</td><td></td><td></td><td></td><td></td><td class="s">actually C&lt;push&gt;es onto the class's C&lt;@ISA&gt;, whereas C&lt;extends&gt; will</td></tr>
+<tr><td class="h"><a name="410"></a>410</td><td></td><td></td><td></td><td></td><td class="s">replace it. This is important to ensure that classes which do not have</td></tr>
+<tr><td class="h"><a name="411"></a>411</td><td></td><td></td><td></td><td></td><td class="s">superclasses still properly inherit from L&lt;Moose::Object&gt;.</td></tr>
+<tr><td class="h"><a name="412"></a>412</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="413"></a>413</td><td></td><td></td><td></td><td></td><td class="s">Each superclass can be followed by a hash reference with options. Currently,</td></tr>
+<tr><td class="h"><a name="414"></a>414</td><td></td><td></td><td></td><td></td><td class="s">only L&lt;-version|Class::MOP/Class Loading Options&gt; is recognized:</td></tr>
+<tr><td class="h"><a name="415"></a>415</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="416"></a>416</td><td></td><td></td><td></td><td></td><td class="s">    extends 'My::Parent'      =&gt; { -version =&gt; 0.01 },</td></tr>
+<tr><td class="h"><a name="417"></a>417</td><td></td><td></td><td></td><td></td><td class="s">            'My::OtherParent' =&gt; { -version =&gt; 0.03 };</td></tr>
+<tr><td class="h"><a name="418"></a>418</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="419"></a>419</td><td></td><td></td><td></td><td></td><td class="s">An exception will be thrown if the version requirements are not</td></tr>
+<tr><td class="h"><a name="420"></a>420</td><td></td><td></td><td></td><td></td><td class="s">satisfied.</td></tr>
+<tr><td class="h"><a name="421"></a>421</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="422"></a>422</td><td></td><td></td><td></td><td></td><td class="s">=item B&lt;with (@roles)&gt;</td></tr>
+<tr><td class="h"><a name="423"></a>423</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="424"></a>424</td><td></td><td></td><td></td><td></td><td class="s">This will apply a given set of C&lt;@roles&gt; to the local class.</td></tr>
+<tr><td class="h"><a name="425"></a>425</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="426"></a>426</td><td></td><td></td><td></td><td></td><td class="s">Like with C&lt;extends&gt;, each specified role can be followed by a hash</td></tr>
+<tr><td class="h"><a name="427"></a>427</td><td></td><td></td><td></td><td></td><td class="s">reference with a L&lt;-version|Class::MOP/Class Loading Options&gt; option:</td></tr>
+<tr><td class="h"><a name="428"></a>428</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="429"></a>429</td><td></td><td></td><td></td><td></td><td class="s">    with 'My::Role'      =&gt; { -version =&gt; 0.32 },</td></tr>
+<tr><td class="h"><a name="430"></a>430</td><td></td><td></td><td></td><td></td><td class="s">         'My::Otherrole' =&gt; { -version =&gt; 0.23 };</td></tr>
+<tr><td class="h"><a name="431"></a>431</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="432"></a>432</td><td></td><td></td><td></td><td></td><td class="s">The specified version requirements must be satisfied, otherwise an</td></tr>
+<tr><td class="h"><a name="433"></a>433</td><td></td><td></td><td></td><td></td><td class="s">exception will be thrown.</td></tr>
+<tr><td class="h"><a name="434"></a>434</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="435"></a>435</td><td></td><td></td><td></td><td></td><td class="s">If your role takes options or arguments, they can be passed along in the</td></tr>
+<tr><td class="h"><a name="436"></a>436</td><td></td><td></td><td></td><td></td><td class="s">hash reference as well.</td></tr>
+<tr><td class="h"><a name="437"></a>437</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="438"></a>438</td><td></td><td></td><td></td><td></td><td class="s">=item B&lt;has $name|@$names =E&lt;gt&gt; %options&gt;</td></tr>
+<tr><td class="h"><a name="439"></a>439</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="440"></a>440</td><td></td><td></td><td></td><td></td><td class="s">This will install an attribute of a given C&lt;$name&gt; into the current class. If</td></tr>
+<tr><td class="h"><a name="441"></a>441</td><td></td><td></td><td></td><td></td><td class="s">the first parameter is an array reference, it will create an attribute for</td></tr>
+<tr><td class="h"><a name="442"></a>442</td><td></td><td></td><td></td><td></td><td class="s">every C&lt;$name&gt; in the list. The C&lt;%options&gt; will be passed to the constructor</td></tr>
+<tr><td class="h"><a name="443"></a>443</td><td></td><td></td><td></td><td></td><td class="s">for L&lt;Moose::Meta::Attribute&gt; (which inherits from L&lt;Class::MOP::Attribute&gt;),</td></tr>
+<tr><td class="h"><a name="444"></a>444</td><td></td><td></td><td></td><td></td><td class="s">so the full documentation for the valid options can be found there. These are</td></tr>
+<tr><td class="h"><a name="445"></a>445</td><td></td><td></td><td></td><td></td><td class="s">the most commonly used options:</td></tr>
+<tr><td class="h"><a name="446"></a>446</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="447"></a>447</td><td></td><td></td><td></td><td></td><td class="s">=over 4</td></tr>
+<tr><td class="h"><a name="448"></a>448</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="449"></a>449</td><td></td><td></td><td></td><td></td><td class="s">=item I&lt;is =E&lt;gt&gt; 'rw'|'ro'&gt;</td></tr>
+<tr><td class="h"><a name="450"></a>450</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="451"></a>451</td><td></td><td></td><td></td><td></td><td class="s">The I&lt;is&gt; option accepts either I&lt;rw&gt; (for read/write) or I&lt;ro&gt; (for read</td></tr>
+<tr><td class="h"><a name="452"></a>452</td><td></td><td></td><td></td><td></td><td class="s">only). These will create either a read/write accessor or a read-only</td></tr>
+<tr><td class="h"><a name="453"></a>453</td><td></td><td></td><td></td><td></td><td class="s">accessor respectively, using the same name as the C&lt;$name&gt; of the attribute.</td></tr>
+<tr><td class="h"><a name="454"></a>454</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="455"></a>455</td><td></td><td></td><td></td><td></td><td class="s">If you need more control over how your accessors are named, you can</td></tr>
+<tr><td class="h"><a name="456"></a>456</td><td></td><td></td><td></td><td></td><td class="s">use the L&lt;reader|Class::MOP::Attribute/reader&gt;,</td></tr>
+<tr><td class="h"><a name="457"></a>457</td><td></td><td></td><td></td><td></td><td class="s">L&lt;writer|Class::MOP::Attribute/writer&gt; and</td></tr>
+<tr><td class="h"><a name="458"></a>458</td><td></td><td></td><td></td><td></td><td class="s">L&lt;accessor|Class::MOP::Attribute/accessor&gt; options inherited from</td></tr>
+<tr><td class="h"><a name="459"></a>459</td><td></td><td></td><td></td><td></td><td class="s">L&lt;Class::MOP::Attribute&gt;, however if you use those, you won't need the</td></tr>
+<tr><td class="h"><a name="460"></a>460</td><td></td><td></td><td></td><td></td><td class="s">I&lt;is&gt; option.</td></tr>
+<tr><td class="h"><a name="461"></a>461</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="462"></a>462</td><td></td><td></td><td></td><td></td><td class="s">=item I&lt;isa =E&lt;gt&gt; $type_name&gt;</td></tr>
+<tr><td class="h"><a name="463"></a>463</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="464"></a>464</td><td></td><td></td><td></td><td></td><td class="s">The I&lt;isa&gt; option uses Moose's type constraint facilities to set up runtime</td></tr>
+<tr><td class="h"><a name="465"></a>465</td><td></td><td></td><td></td><td></td><td class="s">type checking for this attribute. Moose will perform the checks during class</td></tr>
+<tr><td class="h"><a name="466"></a>466</td><td></td><td></td><td></td><td></td><td class="s">construction, and within any accessors. The C&lt;$type_name&gt; argument must be a</td></tr>
+<tr><td class="h"><a name="467"></a>467</td><td></td><td></td><td></td><td></td><td class="s">string. The string may be either a class name or a type defined using</td></tr>
+<tr><td class="h"><a name="468"></a>468</td><td></td><td></td><td></td><td></td><td class="s">Moose's type definition features. (Refer to L&lt;Moose::Util::TypeConstraints&gt;</td></tr>
+<tr><td class="h"><a name="469"></a>469</td><td></td><td></td><td></td><td></td><td class="s">for information on how to define a new type, and how to retrieve type meta-data).</td></tr>
+<tr><td class="h"><a name="470"></a>470</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="471"></a>471</td><td></td><td></td><td></td><td></td><td class="s">=item I&lt;coerce =E&lt;gt&gt; (1|0)&gt;</td></tr>
+<tr><td class="h"><a name="472"></a>472</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="473"></a>473</td><td></td><td></td><td></td><td></td><td class="s">This will attempt to use coercion with the supplied type constraint to change</td></tr>
+<tr><td class="h"><a name="474"></a>474</td><td></td><td></td><td></td><td></td><td class="s">the value passed into any accessors or constructors. You B&lt;must&gt; supply a type</td></tr>
+<tr><td class="h"><a name="475"></a>475</td><td></td><td></td><td></td><td></td><td class="s">constraint, and that type constraint B&lt;must&gt; define a coercion. See</td></tr>
+<tr><td class="h"><a name="476"></a>476</td><td></td><td></td><td></td><td></td><td class="s">L&lt;Moose::Cookbook::Basics::HTTP_SubtypesAndCoercion&gt; for an example.</td></tr>
+<tr><td class="h"><a name="477"></a>477</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="478"></a>478</td><td></td><td></td><td></td><td></td><td class="s">=item I&lt;does =E&lt;gt&gt; $role_name&gt;</td></tr>
+<tr><td class="h"><a name="479"></a>479</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="480"></a>480</td><td></td><td></td><td></td><td></td><td class="s">This will accept the name of a role which the value stored in this attribute</td></tr>
+<tr><td class="h"><a name="481"></a>481</td><td></td><td></td><td></td><td></td><td class="s">is expected to have consumed.</td></tr>
+<tr><td class="h"><a name="482"></a>482</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="483"></a>483</td><td></td><td></td><td></td><td></td><td class="s">=item I&lt;required =E&lt;gt&gt; (1|0)&gt;</td></tr>
+<tr><td class="h"><a name="484"></a>484</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="485"></a>485</td><td></td><td></td><td></td><td></td><td class="s">This marks the attribute as being required. This means a value must be</td></tr>
+<tr><td class="h"><a name="486"></a>486</td><td></td><td></td><td></td><td></td><td class="s">supplied during class construction, I&lt;or&gt; the attribute must be lazy</td></tr>
+<tr><td class="h"><a name="487"></a>487</td><td></td><td></td><td></td><td></td><td class="s">and have either a default or a builder. Note that c&lt;required&gt; does not</td></tr>
+<tr><td class="h"><a name="488"></a>488</td><td></td><td></td><td></td><td></td><td class="s">say anything about the attribute's value, which can be C&lt;undef&gt;.</td></tr>
+<tr><td class="h"><a name="489"></a>489</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="490"></a>490</td><td></td><td></td><td></td><td></td><td class="s">=item I&lt;weak_ref =E&lt;gt&gt; (1|0)&gt;</td></tr>
+<tr><td class="h"><a name="491"></a>491</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="492"></a>492</td><td></td><td></td><td></td><td></td><td class="s">This will tell the class to store the value of this attribute as a weakened</td></tr>
+<tr><td class="h"><a name="493"></a>493</td><td></td><td></td><td></td><td></td><td class="s">reference. If an attribute is a weakened reference, it B&lt;cannot&gt; also be</td></tr>
+<tr><td class="h"><a name="494"></a>494</td><td></td><td></td><td></td><td></td><td class="s">coerced. Note that when a weak ref expires, the attribute's value becomes</td></tr>
+<tr><td class="h"><a name="495"></a>495</td><td></td><td></td><td></td><td></td><td class="s">undefined, and is still considered to be set for purposes of predicate,</td></tr>
+<tr><td class="h"><a name="496"></a>496</td><td></td><td></td><td></td><td></td><td class="s">default, etc.</td></tr>
+<tr><td class="h"><a name="497"></a>497</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="498"></a>498</td><td></td><td></td><td></td><td></td><td class="s">=item I&lt;lazy =E&lt;gt&gt; (1|0)&gt;</td></tr>
+<tr><td class="h"><a name="499"></a>499</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="500"></a>500</td><td></td><td></td><td></td><td></td><td class="s">This will tell the class to not create this slot until absolutely necessary.</td></tr>
+<tr><td class="h"><a name="501"></a>501</td><td></td><td></td><td></td><td></td><td class="s">If an attribute is marked as lazy it B&lt;must&gt; have a default or builder</td></tr>
+<tr><td class="h"><a name="502"></a>502</td><td></td><td></td><td></td><td></td><td class="s">supplied.</td></tr>
+<tr><td class="h"><a name="503"></a>503</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="504"></a>504</td><td></td><td></td><td></td><td></td><td class="s">=item I&lt;trigger =E&lt;gt&gt; $code&gt;</td></tr>
+<tr><td class="h"><a name="505"></a>505</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="506"></a>506</td><td></td><td></td><td></td><td></td><td class="s">The I&lt;trigger&gt; option is a CODE reference which will be called after</td></tr>
+<tr><td class="h"><a name="507"></a>507</td><td></td><td></td><td></td><td></td><td class="s">the value of the attribute is set. The CODE ref is passed the</td></tr>
+<tr><td class="h"><a name="508"></a>508</td><td></td><td></td><td></td><td></td><td class="s">instance itself, the updated value, and the original value if the</td></tr>
+<tr><td class="h"><a name="509"></a>509</td><td></td><td></td><td></td><td></td><td class="s">attribute was already set.</td></tr>
+<tr><td class="h"><a name="510"></a>510</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="511"></a>511</td><td></td><td></td><td></td><td></td><td class="s">You B&lt;can&gt; have a trigger on a read-only attribute.</td></tr>
+<tr><td class="h"><a name="512"></a>512</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="513"></a>513</td><td></td><td></td><td></td><td></td><td class="s">B&lt;NOTE:&gt; Triggers will only fire when you B&lt;assign&gt; to the attribute,</td></tr>
+<tr><td class="h"><a name="514"></a>514</td><td></td><td></td><td></td><td></td><td class="s">either in the constructor, or using the writer. Default and built values will</td></tr>
+<tr><td class="h"><a name="515"></a>515</td><td></td><td></td><td></td><td></td><td class="s">B&lt;not&gt; cause the trigger to be fired.</td></tr>
+<tr><td class="h"><a name="516"></a>516</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="517"></a>517</td><td></td><td></td><td></td><td></td><td class="s">=item I&lt;handles =E&lt;gt&gt; ARRAY | HASH | REGEXP | ROLE | ROLETYPE | DUCKTYPE | CODE&gt;</td></tr>
+<tr><td class="h"><a name="518"></a>518</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="519"></a>519</td><td></td><td></td><td></td><td></td><td class="s">The I&lt;handles&gt; option provides Moose classes with automated delegation features.</td></tr>
+<tr><td class="h"><a name="520"></a>520</td><td></td><td></td><td></td><td></td><td class="s">This is a pretty complex and powerful option. It accepts many different option</td></tr>
+<tr><td class="h"><a name="521"></a>521</td><td></td><td></td><td></td><td></td><td class="s">formats, each with its own benefits and drawbacks.</td></tr>
+<tr><td class="h"><a name="522"></a>522</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="523"></a>523</td><td></td><td></td><td></td><td></td><td class="s">B&lt;NOTE:&gt; The class being delegated to does not need to be a Moose based class,</td></tr>
+<tr><td class="h"><a name="524"></a>524</td><td></td><td></td><td></td><td></td><td class="s">which is why this feature is especially useful when wrapping non-Moose classes.</td></tr>
+<tr><td class="h"><a name="525"></a>525</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="526"></a>526</td><td></td><td></td><td></td><td></td><td class="s">All I&lt;handles&gt; option formats share the following traits:</td></tr>
+<tr><td class="h"><a name="527"></a>527</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="528"></a>528</td><td></td><td></td><td></td><td></td><td class="s">You cannot override a locally defined method with a delegated method; an</td></tr>
+<tr><td class="h"><a name="529"></a>529</td><td></td><td></td><td></td><td></td><td class="s">exception will be thrown if you try. That is to say, if you define C&lt;foo&gt; in</td></tr>
+<tr><td class="h"><a name="530"></a>530</td><td></td><td></td><td></td><td></td><td class="s">your class, you cannot override it with a delegated C&lt;foo&gt;. This is almost never</td></tr>
+<tr><td class="h"><a name="531"></a>531</td><td></td><td></td><td></td><td></td><td class="s">something you would want to do, and if it is, you should do it by hand and not</td></tr>
+<tr><td class="h"><a name="532"></a>532</td><td></td><td></td><td></td><td></td><td class="s">use Moose.</td></tr>
+<tr><td class="h"><a name="533"></a>533</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="534"></a>534</td><td></td><td></td><td></td><td></td><td class="s">You cannot override any of the methods found in Moose::Object, or the C&lt;BUILD&gt;</td></tr>
+<tr><td class="h"><a name="535"></a>535</td><td></td><td></td><td></td><td></td><td class="s">and C&lt;DEMOLISH&gt; methods. These will not throw an exception, but will silently</td></tr>
+<tr><td class="h"><a name="536"></a>536</td><td></td><td></td><td></td><td></td><td class="s">move on to the next method in the list. My reasoning for this is that you would</td></tr>
+<tr><td class="h"><a name="537"></a>537</td><td></td><td></td><td></td><td></td><td class="s">almost never want to do this, since it usually breaks your class. As with</td></tr>
+<tr><td class="h"><a name="538"></a>538</td><td></td><td></td><td></td><td></td><td class="s">overriding locally defined methods, if you do want to do this, you should do it</td></tr>
+<tr><td class="h"><a name="539"></a>539</td><td></td><td></td><td></td><td></td><td class="s">manually, not with Moose.</td></tr>
+<tr><td class="h"><a name="540"></a>540</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="541"></a>541</td><td></td><td></td><td></td><td></td><td class="s">You do not I&lt;need&gt; to have a reader (or accessor) for the attribute in order</td></tr>
+<tr><td class="h"><a name="542"></a>542</td><td></td><td></td><td></td><td></td><td class="s">to delegate to it. Moose will create a means of accessing the value for you,</td></tr>
+<tr><td class="h"><a name="543"></a>543</td><td></td><td></td><td></td><td></td><td class="s">however this will be several times B&lt;less&gt; efficient then if you had given</td></tr>
+<tr><td class="h"><a name="544"></a>544</td><td></td><td></td><td></td><td></td><td class="s">the attribute a reader (or accessor) to use.</td></tr>
+<tr><td class="h"><a name="545"></a>545</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="546"></a>546</td><td></td><td></td><td></td><td></td><td class="s">Below is the documentation for each option format:</td></tr>
+<tr><td class="h"><a name="547"></a>547</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="548"></a>548</td><td></td><td></td><td></td><td></td><td class="s">=over 4</td></tr>
+<tr><td class="h"><a name="549"></a>549</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="550"></a>550</td><td></td><td></td><td></td><td></td><td class="s">=item C&lt;ARRAY&gt;</td></tr>
+<tr><td class="h"><a name="551"></a>551</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="552"></a>552</td><td></td><td></td><td></td><td></td><td class="s">This is the most common usage for I&lt;handles&gt;. You basically pass a list of</td></tr>
+<tr><td class="h"><a name="553"></a>553</td><td></td><td></td><td></td><td></td><td class="s">method names to be delegated, and Moose will install a delegation method</td></tr>
+<tr><td class="h"><a name="554"></a>554</td><td></td><td></td><td></td><td></td><td class="s">for each one.</td></tr>
+<tr><td class="h"><a name="555"></a>555</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="556"></a>556</td><td></td><td></td><td></td><td></td><td class="s">=item C&lt;HASH&gt;</td></tr>
+<tr><td class="h"><a name="557"></a>557</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="558"></a>558</td><td></td><td></td><td></td><td></td><td class="s">This is the second most common usage for I&lt;handles&gt;. Instead of a list of</td></tr>
+<tr><td class="h"><a name="559"></a>559</td><td></td><td></td><td></td><td></td><td class="s">method names, you pass a HASH ref where each key is the method name you</td></tr>
+<tr><td class="h"><a name="560"></a>560</td><td></td><td></td><td></td><td></td><td class="s">want installed locally, and its value is the name of the original method</td></tr>
+<tr><td class="h"><a name="561"></a>561</td><td></td><td></td><td></td><td></td><td class="s">in the class being delegated to.</td></tr>
+<tr><td class="h"><a name="562"></a>562</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="563"></a>563</td><td></td><td></td><td></td><td></td><td class="s">This can be very useful for recursive classes like trees. Here is a</td></tr>
+<tr><td class="h"><a name="564"></a>564</td><td></td><td></td><td></td><td></td><td class="s">quick example (soon to be expanded into a Moose::Cookbook recipe):</td></tr>
+<tr><td class="h"><a name="565"></a>565</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="566"></a>566</td><td></td><td></td><td></td><td></td><td class="s">  package Tree;</td></tr>
+<tr><td class="h"><a name="567"></a>567</td><td></td><td></td><td></td><td></td><td class="s">  use Moose;</td></tr>
+<tr><td class="h"><a name="568"></a>568</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="569"></a>569</td><td></td><td></td><td></td><td></td><td class="s">  has 'node' =&gt; (is =&gt; 'rw', isa =&gt; 'Any');</td></tr>
+<tr><td class="h"><a name="570"></a>570</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="571"></a>571</td><td></td><td></td><td></td><td></td><td class="s">  has 'children' =&gt; (</td></tr>
+<tr><td class="h"><a name="572"></a>572</td><td></td><td></td><td></td><td></td><td class="s">      is      =&gt; 'ro',</td></tr>
+<tr><td class="h"><a name="573"></a>573</td><td></td><td></td><td></td><td></td><td class="s">      isa     =&gt; 'ArrayRef',</td></tr>
+<tr><td class="h"><a name="574"></a>574</td><td></td><td></td><td></td><td></td><td class="s">      default =&gt; sub { [] }</td></tr>
+<tr><td class="h"><a name="575"></a>575</td><td></td><td></td><td></td><td></td><td class="s">  );</td></tr>
+<tr><td class="h"><a name="576"></a>576</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="577"></a>577</td><td></td><td></td><td></td><td></td><td class="s">  has 'parent' =&gt; (</td></tr>
+<tr><td class="h"><a name="578"></a>578</td><td></td><td></td><td></td><td></td><td class="s">      is          =&gt; 'rw',</td></tr>
+<tr><td class="h"><a name="579"></a>579</td><td></td><td></td><td></td><td></td><td class="s">      isa         =&gt; 'Tree',</td></tr>
+<tr><td class="h"><a name="580"></a>580</td><td></td><td></td><td></td><td></td><td class="s">      weak_ref    =&gt; 1,</td></tr>
+<tr><td class="h"><a name="581"></a>581</td><td></td><td></td><td></td><td></td><td class="s">      handles     =&gt; {</td></tr>
+<tr><td class="h"><a name="582"></a>582</td><td></td><td></td><td></td><td></td><td class="s">          parent_node =&gt; 'node',</td></tr>
+<tr><td class="h"><a name="583"></a>583</td><td></td><td></td><td></td><td></td><td class="s">          siblings    =&gt; 'children',</td></tr>
+<tr><td class="h"><a name="584"></a>584</td><td></td><td></td><td></td><td></td><td class="s">      }</td></tr>
+<tr><td class="h"><a name="585"></a>585</td><td></td><td></td><td></td><td></td><td class="s">  );</td></tr>
+<tr><td class="h"><a name="586"></a>586</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="587"></a>587</td><td></td><td></td><td></td><td></td><td class="s">In this example, the Tree package gets C&lt;parent_node&gt; and C&lt;siblings&gt; methods,</td></tr>
+<tr><td class="h"><a name="588"></a>588</td><td></td><td></td><td></td><td></td><td class="s">which delegate to the C&lt;node&gt; and C&lt;children&gt; methods (respectively) of the Tree</td></tr>
+<tr><td class="h"><a name="589"></a>589</td><td></td><td></td><td></td><td></td><td class="s">instance stored in the C&lt;parent&gt; slot.</td></tr>
+<tr><td class="h"><a name="590"></a>590</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="591"></a>591</td><td></td><td></td><td></td><td></td><td class="s">You may also use an array reference to curry arguments to the original method.</td></tr>
+<tr><td class="h"><a name="592"></a>592</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="593"></a>593</td><td></td><td></td><td></td><td></td><td class="s">  has 'thing' =&gt; (</td></tr>
+<tr><td class="h"><a name="594"></a>594</td><td></td><td></td><td></td><td></td><td class="s">      ...</td></tr>
+<tr><td class="h"><a name="595"></a>595</td><td></td><td></td><td></td><td></td><td class="s">      handles =&gt; { set_foo =&gt; [ set =&gt; 'foo' ] },</td></tr>
+<tr><td class="h"><a name="596"></a>596</td><td></td><td></td><td></td><td></td><td class="s">  );</td></tr>
+<tr><td class="h"><a name="597"></a>597</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="598"></a>598</td><td></td><td></td><td></td><td></td><td class="s">  # $self-&gt;set_foo(...) calls $self-&gt;thing-&gt;set('foo', ...)</td></tr>
+<tr><td class="h"><a name="599"></a>599</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="600"></a>600</td><td></td><td></td><td></td><td></td><td class="s">The first element of the array reference is the original method name, and the</td></tr>
+<tr><td class="h"><a name="601"></a>601</td><td></td><td></td><td></td><td></td><td class="s">rest is a list of curried arguments.</td></tr>
+<tr><td class="h"><a name="602"></a>602</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="603"></a>603</td><td></td><td></td><td></td><td></td><td class="s">=item C&lt;REGEXP&gt;</td></tr>
+<tr><td class="h"><a name="604"></a>604</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="605"></a>605</td><td></td><td></td><td></td><td></td><td class="s">The regexp option works very similar to the ARRAY option, except that it builds</td></tr>
+<tr><td class="h"><a name="606"></a>606</td><td></td><td></td><td></td><td></td><td class="s">the list of methods for you. It starts by collecting all possible methods of the</td></tr>
+<tr><td class="h"><a name="607"></a>607</td><td></td><td></td><td></td><td></td><td class="s">class being delegated to, then filters that list using the regexp supplied here.</td></tr>
+<tr><td class="h"><a name="608"></a>608</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="609"></a>609</td><td></td><td></td><td></td><td></td><td class="s">B&lt;NOTE:&gt; An I&lt;isa&gt; option is required when using the regexp option format. This</td></tr>
+<tr><td class="h"><a name="610"></a>610</td><td></td><td></td><td></td><td></td><td class="s">is so that we can determine (at compile time) the method list from the class.</td></tr>
+<tr><td class="h"><a name="611"></a>611</td><td></td><td></td><td></td><td></td><td class="s">Without an I&lt;isa&gt; this is just not possible.</td></tr>
+<tr><td class="h"><a name="612"></a>612</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="613"></a>613</td><td></td><td></td><td></td><td></td><td class="s">=item C&lt;ROLE&gt; or C&lt;ROLETYPE&gt;</td></tr>
+<tr><td class="h"><a name="614"></a>614</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="615"></a>615</td><td></td><td></td><td></td><td></td><td class="s">With the role option, you specify the name of a role or a</td></tr>
+<tr><td class="h"><a name="616"></a>616</td><td></td><td></td><td></td><td></td><td class="s">L&lt;role type|Moose::Meta::TypeConstraint::Role&gt; whose &quot;interface&quot; then becomes</td></tr>
+<tr><td class="h"><a name="617"></a>617</td><td></td><td></td><td></td><td></td><td class="s">the list of methods to handle. The &quot;interface&quot; can be defined as; the methods</td></tr>
+<tr><td class="h"><a name="618"></a>618</td><td></td><td></td><td></td><td></td><td class="s">of the role and any required methods of the role. It should be noted that this</td></tr>
+<tr><td class="h"><a name="619"></a>619</td><td></td><td></td><td></td><td></td><td class="s">does B&lt;not&gt; include any method modifiers or generated attribute methods (which</td></tr>
+<tr><td class="h"><a name="620"></a>620</td><td></td><td></td><td></td><td></td><td class="s">is consistent with role composition).</td></tr>
+<tr><td class="h"><a name="621"></a>621</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="622"></a>622</td><td></td><td></td><td></td><td></td><td class="s">=item C&lt;DUCKTYPE&gt;</td></tr>
+<tr><td class="h"><a name="623"></a>623</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="624"></a>624</td><td></td><td></td><td></td><td></td><td class="s">With the duck type option, you pass a duck type object whose &quot;interface&quot; then</td></tr>
+<tr><td class="h"><a name="625"></a>625</td><td></td><td></td><td></td><td></td><td class="s">becomes the list of methods to handle. The &quot;interface&quot; can be defined as the</td></tr>
+<tr><td class="h"><a name="626"></a>626</td><td></td><td></td><td></td><td></td><td class="s">list of methods passed to C&lt;duck_type&gt; to create a duck type object. For more</td></tr>
+<tr><td class="h"><a name="627"></a>627</td><td></td><td></td><td></td><td></td><td class="s">information on C&lt;duck_type&gt; please check</td></tr>
+<tr><td class="h"><a name="628"></a>628</td><td></td><td></td><td></td><td></td><td class="s">L&lt;Moose::Util::TypeConstraints&gt;.</td></tr>
+<tr><td class="h"><a name="629"></a>629</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="630"></a>630</td><td></td><td></td><td></td><td></td><td class="s">=item C&lt;CODE&gt;</td></tr>
+<tr><td class="h"><a name="631"></a>631</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="632"></a>632</td><td></td><td></td><td></td><td></td><td class="s">This is the option to use when you really want to do something funky. You should</td></tr>
+<tr><td class="h"><a name="633"></a>633</td><td></td><td></td><td></td><td></td><td class="s">only use it if you really know what you are doing, as it involves manual</td></tr>
+<tr><td class="h"><a name="634"></a>634</td><td></td><td></td><td></td><td></td><td class="s">metaclass twiddling.</td></tr>
+<tr><td class="h"><a name="635"></a>635</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="636"></a>636</td><td></td><td></td><td></td><td></td><td class="s">This takes a code reference, which should expect two arguments. The first is the</td></tr>
+<tr><td class="h"><a name="637"></a>637</td><td></td><td></td><td></td><td></td><td class="s">attribute meta-object this I&lt;handles&gt; is attached to. The second is the</td></tr>
+<tr><td class="h"><a name="638"></a>638</td><td></td><td></td><td></td><td></td><td class="s">metaclass of the class being delegated to. It expects you to return a hash (not</td></tr>
+<tr><td class="h"><a name="639"></a>639</td><td></td><td></td><td></td><td></td><td class="s">a HASH ref) of the methods you want mapped.</td></tr>
+<tr><td class="h"><a name="640"></a>640</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="641"></a>641</td><td></td><td></td><td></td><td></td><td class="s">=back</td></tr>
+<tr><td class="h"><a name="642"></a>642</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="643"></a>643</td><td></td><td></td><td></td><td></td><td class="s">=item I&lt;traits =E&lt;gt&gt; [ @role_names ]&gt;</td></tr>
+<tr><td class="h"><a name="644"></a>644</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="645"></a>645</td><td></td><td></td><td></td><td></td><td class="s">This tells Moose to take the list of C&lt;@role_names&gt; and apply them to the</td></tr>
+<tr><td class="h"><a name="646"></a>646</td><td></td><td></td><td></td><td></td><td class="s">attribute meta-object. Custom attribute metaclass traits are useful for</td></tr>
+<tr><td class="h"><a name="647"></a>647</td><td></td><td></td><td></td><td></td><td class="s">extending the capabilities of the I&lt;has&gt; keyword: they are the simplest way to</td></tr>
+<tr><td class="h"><a name="648"></a>648</td><td></td><td></td><td></td><td></td><td class="s">extend the MOP, but they are still a fairly advanced topic and too much to</td></tr>
+<tr><td class="h"><a name="649"></a>649</td><td></td><td></td><td></td><td></td><td class="s">cover here.</td></tr>
+<tr><td class="h"><a name="650"></a>650</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="651"></a>651</td><td></td><td></td><td></td><td></td><td class="s">See L&lt;Metaclass and Trait Name Resolution&gt; for details on how a trait name is</td></tr>
+<tr><td class="h"><a name="652"></a>652</td><td></td><td></td><td></td><td></td><td class="s">resolved to a role name.</td></tr>
+<tr><td class="h"><a name="653"></a>653</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="654"></a>654</td><td></td><td></td><td></td><td></td><td class="s">Also see L&lt;Moose::Cookbook::Meta::Labeled_AttributeTrait&gt; for a metaclass</td></tr>
+<tr><td class="h"><a name="655"></a>655</td><td></td><td></td><td></td><td></td><td class="s">trait example.</td></tr>
+<tr><td class="h"><a name="656"></a>656</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="657"></a>657</td><td></td><td></td><td></td><td></td><td class="s">=item I&lt;builder&gt; =&gt; Str</td></tr>
+<tr><td class="h"><a name="658"></a>658</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="659"></a>659</td><td></td><td></td><td></td><td></td><td class="s">The value of this key is the name of the method that will be called to obtain</td></tr>
+<tr><td class="h"><a name="660"></a>660</td><td></td><td></td><td></td><td></td><td class="s">the value used to initialize the attribute. See the L&lt;builder option docs in</td></tr>
+<tr><td class="h"><a name="661"></a>661</td><td></td><td></td><td></td><td></td><td class="s">Class::MOP::Attribute|Class::MOP::Attribute/builder&gt; and/or</td></tr>
+<tr><td class="h"><a name="662"></a>662</td><td></td><td></td><td></td><td></td><td class="s">L&lt;Moose::Cookbook::Basics::BinaryTree_BuilderAndLazyBuild&gt; for more</td></tr>
+<tr><td class="h"><a name="663"></a>663</td><td></td><td></td><td></td><td></td><td class="s">information.</td></tr>
+<tr><td class="h"><a name="664"></a>664</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="665"></a>665</td><td></td><td></td><td></td><td></td><td class="s">=item I&lt;default&gt; =&gt; SCALAR | CODE</td></tr>
+<tr><td class="h"><a name="666"></a>666</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="667"></a>667</td><td></td><td></td><td></td><td></td><td class="s">The value of this key is the default value which will initialize the attribute.</td></tr>
+<tr><td class="h"><a name="668"></a>668</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="669"></a>669</td><td></td><td></td><td></td><td></td><td class="s">NOTE: If the value is a simple scalar (string or number), then it can</td></tr>
+<tr><td class="h"><a name="670"></a>670</td><td></td><td></td><td></td><td></td><td class="s">be just passed as is.  However, if you wish to initialize it with a</td></tr>
+<tr><td class="h"><a name="671"></a>671</td><td></td><td></td><td></td><td></td><td class="s">HASH or ARRAY ref, then you need to wrap that inside a CODE reference.</td></tr>
+<tr><td class="h"><a name="672"></a>672</td><td></td><td></td><td></td><td></td><td class="s">See the L&lt;default option docs in</td></tr>
+<tr><td class="h"><a name="673"></a>673</td><td></td><td></td><td></td><td></td><td class="s">Class::MOP::Attribute|Class::MOP::Attribute/default&gt; for more</td></tr>
+<tr><td class="h"><a name="674"></a>674</td><td></td><td></td><td></td><td></td><td class="s">information.</td></tr>
+<tr><td class="h"><a name="675"></a>675</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="676"></a>676</td><td></td><td></td><td></td><td></td><td class="s">=item I&lt;clearer&gt; =&gt; Str</td></tr>
+<tr><td class="h"><a name="677"></a>677</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="678"></a>678</td><td></td><td></td><td></td><td></td><td class="s">Creates a method allowing you to clear the value. See the L&lt;clearer option</td></tr>
+<tr><td class="h"><a name="679"></a>679</td><td></td><td></td><td></td><td></td><td class="s">docs in Class::MOP::Attribute|Class::MOP::Attribute/clearer&gt; for more</td></tr>
+<tr><td class="h"><a name="680"></a>680</td><td></td><td></td><td></td><td></td><td class="s">information.</td></tr>
+<tr><td class="h"><a name="681"></a>681</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="682"></a>682</td><td></td><td></td><td></td><td></td><td class="s">=item I&lt;predicate&gt; =&gt; Str</td></tr>
+<tr><td class="h"><a name="683"></a>683</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="684"></a>684</td><td></td><td></td><td></td><td></td><td class="s">Creates a method to perform a basic test to see if a value has been set in the</td></tr>
+<tr><td class="h"><a name="685"></a>685</td><td></td><td></td><td></td><td></td><td class="s">attribute. See the L&lt;predicate option docs in</td></tr>
+<tr><td class="h"><a name="686"></a>686</td><td></td><td></td><td></td><td></td><td class="s">Class::MOP::Attribute|Class::MOP::Attribute/predicate&gt; for more information.</td></tr>
+<tr><td class="h"><a name="687"></a>687</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="688"></a>688</td><td></td><td></td><td></td><td></td><td class="s">Note that the predicate will return true even for a C&lt;weak_ref&gt; attribute</td></tr>
+<tr><td class="h"><a name="689"></a>689</td><td></td><td></td><td></td><td></td><td class="s">whose value has expired.</td></tr>
+<tr><td class="h"><a name="690"></a>690</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="691"></a>691</td><td></td><td></td><td></td><td></td><td class="s">=item I&lt;documentation&gt; =&gt; $string</td></tr>
+<tr><td class="h"><a name="692"></a>692</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="693"></a>693</td><td></td><td></td><td></td><td></td><td class="s">An arbitrary string that can be retrieved later by calling C&lt;&lt;</td></tr>
+<tr><td class="h"><a name="694"></a>694</td><td></td><td></td><td></td><td></td><td class="s">$attr-&gt;documentation &gt;&gt;.</td></tr>
+<tr><td class="h"><a name="695"></a>695</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="696"></a>696</td><td></td><td></td><td></td><td></td><td class="s">=back</td></tr>
+<tr><td class="h"><a name="697"></a>697</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="698"></a>698</td><td></td><td></td><td></td><td></td><td class="s">=item B&lt;has +$name =E&lt;gt&gt; %options&gt;</td></tr>
+<tr><td class="h"><a name="699"></a>699</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="700"></a>700</td><td></td><td></td><td></td><td></td><td class="s">This is variation on the normal attribute creator C&lt;has&gt; which allows you to</td></tr>
+<tr><td class="h"><a name="701"></a>701</td><td></td><td></td><td></td><td></td><td class="s">clone and extend an attribute from a superclass or from a role. Here is an</td></tr>
+<tr><td class="h"><a name="702"></a>702</td><td></td><td></td><td></td><td></td><td class="s">example of the superclass usage:</td></tr>
+<tr><td class="h"><a name="703"></a>703</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="704"></a>704</td><td></td><td></td><td></td><td></td><td class="s">  package Foo;</td></tr>
+<tr><td class="h"><a name="705"></a>705</td><td></td><td></td><td></td><td></td><td class="s">  use Moose;</td></tr>
+<tr><td class="h"><a name="706"></a>706</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="707"></a>707</td><td></td><td></td><td></td><td></td><td class="s">  has 'message' =&gt; (</td></tr>
+<tr><td class="h"><a name="708"></a>708</td><td></td><td></td><td></td><td></td><td class="s">      is      =&gt; 'rw',</td></tr>
+<tr><td class="h"><a name="709"></a>709</td><td></td><td></td><td></td><td></td><td class="s">      isa     =&gt; 'Str',</td></tr>
+<tr><td class="h"><a name="710"></a>710</td><td></td><td></td><td></td><td></td><td class="s">      default =&gt; 'Hello, I am a Foo'</td></tr>
+<tr><td class="h"><a name="711"></a>711</td><td></td><td></td><td></td><td></td><td class="s">  );</td></tr>
+<tr><td class="h"><a name="712"></a>712</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="713"></a>713</td><td></td><td></td><td></td><td></td><td class="s">  package My::Foo;</td></tr>
+<tr><td class="h"><a name="714"></a>714</td><td></td><td></td><td></td><td></td><td class="s">  use Moose;</td></tr>
+<tr><td class="h"><a name="715"></a>715</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="716"></a>716</td><td></td><td></td><td></td><td></td><td class="s">  extends 'Foo';</td></tr>
+<tr><td class="h"><a name="717"></a>717</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="718"></a>718</td><td></td><td></td><td></td><td></td><td class="s">  has '+message' =&gt; (default =&gt; 'Hello I am My::Foo');</td></tr>
+<tr><td class="h"><a name="719"></a>719</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="720"></a>720</td><td></td><td></td><td></td><td></td><td class="s">What is happening here is that B&lt;My::Foo&gt; is cloning the C&lt;message&gt; attribute</td></tr>
+<tr><td class="h"><a name="721"></a>721</td><td></td><td></td><td></td><td></td><td class="s">from its parent class B&lt;Foo&gt;, retaining the C&lt;is =E&lt;gt&gt; 'rw'&gt; and C&lt;isa =E&lt;gt&gt;</td></tr>
+<tr><td class="h"><a name="722"></a>722</td><td></td><td></td><td></td><td></td><td class="s">'Str'&gt; characteristics, but changing the value in C&lt;default&gt;.</td></tr>
+<tr><td class="h"><a name="723"></a>723</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="724"></a>724</td><td></td><td></td><td></td><td></td><td class="s">Here is another example, but within the context of a role:</td></tr>
+<tr><td class="h"><a name="725"></a>725</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="726"></a>726</td><td></td><td></td><td></td><td></td><td class="s">  package Foo::Role;</td></tr>
+<tr><td class="h"><a name="727"></a>727</td><td></td><td></td><td></td><td></td><td class="s">  use Moose::Role;</td></tr>
+<tr><td class="h"><a name="728"></a>728</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="729"></a>729</td><td></td><td></td><td></td><td></td><td class="s">  has 'message' =&gt; (</td></tr>
+<tr><td class="h"><a name="730"></a>730</td><td></td><td></td><td></td><td></td><td class="s">      is      =&gt; 'rw',</td></tr>
+<tr><td class="h"><a name="731"></a>731</td><td></td><td></td><td></td><td></td><td class="s">      isa     =&gt; 'Str',</td></tr>
+<tr><td class="h"><a name="732"></a>732</td><td></td><td></td><td></td><td></td><td class="s">      default =&gt; 'Hello, I am a Foo'</td></tr>
+<tr><td class="h"><a name="733"></a>733</td><td></td><td></td><td></td><td></td><td class="s">  );</td></tr>
+<tr><td class="h"><a name="734"></a>734</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="735"></a>735</td><td></td><td></td><td></td><td></td><td class="s">  package My::Foo;</td></tr>
+<tr><td class="h"><a name="736"></a>736</td><td></td><td></td><td></td><td></td><td class="s">  use Moose;</td></tr>
+<tr><td class="h"><a name="737"></a>737</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="738"></a>738</td><td></td><td></td><td></td><td></td><td class="s">  with 'Foo::Role';</td></tr>
+<tr><td class="h"><a name="739"></a>739</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="740"></a>740</td><td></td><td></td><td></td><td></td><td class="s">  has '+message' =&gt; (default =&gt; 'Hello I am My::Foo');</td></tr>
+<tr><td class="h"><a name="741"></a>741</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="742"></a>742</td><td></td><td></td><td></td><td></td><td class="s">In this case, we are basically taking the attribute which the role supplied</td></tr>
+<tr><td class="h"><a name="743"></a>743</td><td></td><td></td><td></td><td></td><td class="s">and altering it within the bounds of this feature.</td></tr>
+<tr><td class="h"><a name="744"></a>744</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="745"></a>745</td><td></td><td></td><td></td><td></td><td class="s">Note that you can only extend an attribute from either a superclass or a role,</td></tr>
+<tr><td class="h"><a name="746"></a>746</td><td></td><td></td><td></td><td></td><td class="s">you cannot extend an attribute in a role that composes over an attribute from</td></tr>
+<tr><td class="h"><a name="747"></a>747</td><td></td><td></td><td></td><td></td><td class="s">another role.</td></tr>
+<tr><td class="h"><a name="748"></a>748</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="749"></a>749</td><td></td><td></td><td></td><td></td><td class="s">Aside from where the attributes come from (one from superclass, the other</td></tr>
+<tr><td class="h"><a name="750"></a>750</td><td></td><td></td><td></td><td></td><td class="s">from a role), this feature works exactly the same. This feature is restricted</td></tr>
+<tr><td class="h"><a name="751"></a>751</td><td></td><td></td><td></td><td></td><td class="s">somewhat, so as to try and force at least I&lt;some&gt; sanity into it. Most options work the same, but there are some exceptions:</td></tr>
+<tr><td class="h"><a name="752"></a>752</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="753"></a>753</td><td></td><td></td><td></td><td></td><td class="s">=over 4</td></tr>
+<tr><td class="h"><a name="754"></a>754</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="755"></a>755</td><td></td><td></td><td></td><td></td><td class="s">=item I&lt;reader&gt;</td></tr>
+<tr><td class="h"><a name="756"></a>756</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="757"></a>757</td><td></td><td></td><td></td><td></td><td class="s">=item I&lt;writer&gt;</td></tr>
+<tr><td class="h"><a name="758"></a>758</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="759"></a>759</td><td></td><td></td><td></td><td></td><td class="s">=item I&lt;accessor&gt;</td></tr>
+<tr><td class="h"><a name="760"></a>760</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="761"></a>761</td><td></td><td></td><td></td><td></td><td class="s">=item I&lt;clearer&gt;</td></tr>
+<tr><td class="h"><a name="762"></a>762</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="763"></a>763</td><td></td><td></td><td></td><td></td><td class="s">=item I&lt;predicate&gt;</td></tr>
+<tr><td class="h"><a name="764"></a>764</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="765"></a>765</td><td></td><td></td><td></td><td></td><td class="s">These options can be added, but cannot override a superclass definition.</td></tr>
+<tr><td class="h"><a name="766"></a>766</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="767"></a>767</td><td></td><td></td><td></td><td></td><td class="s">=item I&lt;traits&gt;</td></tr>
+<tr><td class="h"><a name="768"></a>768</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="769"></a>769</td><td></td><td></td><td></td><td></td><td class="s">You are allowed to B&lt;add&gt; additional traits to the C&lt;traits&gt; definition.</td></tr>
+<tr><td class="h"><a name="770"></a>770</td><td></td><td></td><td></td><td></td><td class="s">These traits will be composed into the attribute, but preexisting traits</td></tr>
+<tr><td class="h"><a name="771"></a>771</td><td></td><td></td><td></td><td></td><td class="s">B&lt;are not&gt; overridden, or removed.</td></tr>
+<tr><td class="h"><a name="772"></a>772</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="773"></a>773</td><td></td><td></td><td></td><td></td><td class="s">=back</td></tr>
+<tr><td class="h"><a name="774"></a>774</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="775"></a>775</td><td></td><td></td><td></td><td></td><td class="s">=item B&lt;before $name|@names|\@names|qr/.../ =E&lt;gt&gt; sub { ... }&gt;</td></tr>
+<tr><td class="h"><a name="776"></a>776</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="777"></a>777</td><td></td><td></td><td></td><td></td><td class="s">=item B&lt;after $name|@names|\@names|qr/.../ =E&lt;gt&gt; sub { ... }&gt;</td></tr>
+<tr><td class="h"><a name="778"></a>778</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="779"></a>779</td><td></td><td></td><td></td><td></td><td class="s">=item B&lt;around $name|@names|\@names|qr/.../ =E&lt;gt&gt; sub { ... }&gt;</td></tr>
+<tr><td class="h"><a name="780"></a>780</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="781"></a>781</td><td></td><td></td><td></td><td></td><td class="s">These three items are syntactic sugar for the before, after, and around method</td></tr>
+<tr><td class="h"><a name="782"></a>782</td><td></td><td></td><td></td><td></td><td class="s">modifier features that L&lt;Class::MOP&gt; provides. More information on these may be</td></tr>
+<tr><td class="h"><a name="783"></a>783</td><td></td><td></td><td></td><td></td><td class="s">found in L&lt;Moose::Manual::MethodModifiers&gt; and the</td></tr>
+<tr><td class="h"><a name="784"></a>784</td><td></td><td></td><td></td><td></td><td class="s">L&lt;Class::MOP::Class documentation|Class::MOP::Class/&quot;Method Modifiers&quot;&gt;.</td></tr>
+<tr><td class="h"><a name="785"></a>785</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="786"></a>786</td><td></td><td></td><td></td><td></td><td class="s">=item B&lt;override ($name, &amp;sub)&gt;</td></tr>
+<tr><td class="h"><a name="787"></a>787</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="788"></a>788</td><td></td><td></td><td></td><td></td><td class="s">An C&lt;override&gt; method is a way of explicitly saying &quot;I am overriding this</td></tr>
+<tr><td class="h"><a name="789"></a>789</td><td></td><td></td><td></td><td></td><td class="s">method from my superclass&quot;. You can call C&lt;super&gt; within this method, and</td></tr>
+<tr><td class="h"><a name="790"></a>790</td><td></td><td></td><td></td><td></td><td class="s">it will work as expected. The same thing I&lt;can&gt; be accomplished with a normal</td></tr>
+<tr><td class="h"><a name="791"></a>791</td><td></td><td></td><td></td><td></td><td class="s">method call and the C&lt;SUPER::&gt; pseudo-package; it is really your choice.</td></tr>
+<tr><td class="h"><a name="792"></a>792</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="793"></a>793</td><td></td><td></td><td></td><td></td><td class="s">=item B&lt;super&gt;</td></tr>
+<tr><td class="h"><a name="794"></a>794</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="795"></a>795</td><td></td><td></td><td></td><td></td><td class="s">The keyword C&lt;super&gt; is a no-op when called outside of an C&lt;override&gt; method. In</td></tr>
+<tr><td class="h"><a name="796"></a>796</td><td></td><td></td><td></td><td></td><td class="s">the context of an C&lt;override&gt; method, it will call the next most appropriate</td></tr>
+<tr><td class="h"><a name="797"></a>797</td><td></td><td></td><td></td><td></td><td class="s">superclass method with the same arguments as the original method.</td></tr>
+<tr><td class="h"><a name="798"></a>798</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="799"></a>799</td><td></td><td></td><td></td><td></td><td class="s">=item B&lt;augment ($name, &amp;sub)&gt;</td></tr>
+<tr><td class="h"><a name="800"></a>800</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="801"></a>801</td><td></td><td></td><td></td><td></td><td class="s">An C&lt;augment&gt; method, is a way of explicitly saying &quot;I am augmenting this</td></tr>
+<tr><td class="h"><a name="802"></a>802</td><td></td><td></td><td></td><td></td><td class="s">method from my superclass&quot;. Once again, the details of how C&lt;inner&gt; and</td></tr>
+<tr><td class="h"><a name="803"></a>803</td><td></td><td></td><td></td><td></td><td class="s">C&lt;augment&gt; work is best described in the</td></tr>
+<tr><td class="h"><a name="804"></a>804</td><td></td><td></td><td></td><td></td><td class="s">L&lt;Moose::Cookbook::Basics::Document_AugmentAndInner&gt;.</td></tr>
+<tr><td class="h"><a name="805"></a>805</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="806"></a>806</td><td></td><td></td><td></td><td></td><td class="s">=item B&lt;inner&gt;</td></tr>
+<tr><td class="h"><a name="807"></a>807</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="808"></a>808</td><td></td><td></td><td></td><td></td><td class="s">The keyword C&lt;inner&gt;, much like C&lt;super&gt;, is a no-op outside of the context of</td></tr>
+<tr><td class="h"><a name="809"></a>809</td><td></td><td></td><td></td><td></td><td class="s">an C&lt;augment&gt; method. You can think of C&lt;inner&gt; as being the inverse of</td></tr>
+<tr><td class="h"><a name="810"></a>810</td><td></td><td></td><td></td><td></td><td class="s">C&lt;super&gt;; the details of how C&lt;inner&gt; and C&lt;augment&gt; work is best described in</td></tr>
+<tr><td class="h"><a name="811"></a>811</td><td></td><td></td><td></td><td></td><td class="s">the L&lt;Moose::Cookbook::Basics::Document_AugmentAndInner&gt;.</td></tr>
+<tr><td class="h"><a name="812"></a>812</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="813"></a>813</td><td></td><td></td><td></td><td></td><td class="s">=item B&lt;blessed&gt;</td></tr>
+<tr><td class="h"><a name="814"></a>814</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="815"></a>815</td><td></td><td></td><td></td><td></td><td class="s">This is the C&lt;Scalar::Util::blessed&gt; function. It is highly recommended that</td></tr>
+<tr><td class="h"><a name="816"></a>816</td><td></td><td></td><td></td><td></td><td class="s">this is used instead of C&lt;ref&gt; anywhere you need to test for an object's class</td></tr>
+<tr><td class="h"><a name="817"></a>817</td><td></td><td></td><td></td><td></td><td class="s">name.</td></tr>
+<tr><td class="h"><a name="818"></a>818</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="819"></a>819</td><td></td><td></td><td></td><td></td><td class="s">=item B&lt;confess&gt;</td></tr>
+<tr><td class="h"><a name="820"></a>820</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="821"></a>821</td><td></td><td></td><td></td><td></td><td class="s">This is the C&lt;Carp::confess&gt; function, and exported here for historical</td></tr>
+<tr><td class="h"><a name="822"></a>822</td><td></td><td></td><td></td><td></td><td class="s">reasons.</td></tr>
+<tr><td class="h"><a name="823"></a>823</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="824"></a>824</td><td></td><td></td><td></td><td></td><td class="s">=back</td></tr>
+<tr><td class="h"><a name="825"></a>825</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="826"></a>826</td><td></td><td></td><td></td><td></td><td class="s">=head1 METACLASS</td></tr>
+<tr><td class="h"><a name="827"></a>827</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="828"></a>828</td><td></td><td></td><td></td><td></td><td class="s">When you use Moose, you can specify traits which will be applied to your</td></tr>
+<tr><td class="h"><a name="829"></a>829</td><td></td><td></td><td></td><td></td><td class="s">metaclass:</td></tr>
+<tr><td class="h"><a name="830"></a>830</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="831"></a>831</td><td></td><td></td><td></td><td></td><td class="s">    use Moose -traits =&gt; 'My::Trait';</td></tr>
+<tr><td class="h"><a name="832"></a>832</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="833"></a>833</td><td></td><td></td><td></td><td></td><td class="s">This is very similar to the attribute traits feature. When you do</td></tr>
+<tr><td class="h"><a name="834"></a>834</td><td></td><td></td><td></td><td></td><td class="s">this, your class's C&lt;meta&gt; object will have the specified traits</td></tr>
+<tr><td class="h"><a name="835"></a>835</td><td></td><td></td><td></td><td></td><td class="s">applied to it. See L&lt;Metaclass and Trait Name Resolution&gt; for more</td></tr>
+<tr><td class="h"><a name="836"></a>836</td><td></td><td></td><td></td><td></td><td class="s">details.</td></tr>
+<tr><td class="h"><a name="837"></a>837</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="838"></a>838</td><td></td><td></td><td></td><td></td><td class="s">=head2 Metaclass and Trait Name Resolution</td></tr>
+<tr><td class="h"><a name="839"></a>839</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="840"></a>840</td><td></td><td></td><td></td><td></td><td class="s">By default, when given a trait name, Moose simply tries to load a</td></tr>
+<tr><td class="h"><a name="841"></a>841</td><td></td><td></td><td></td><td></td><td class="s">class of the same name. If such a class does not exist, it then looks</td></tr>
+<tr><td class="h"><a name="842"></a>842</td><td></td><td></td><td></td><td></td><td class="s">for for a class matching</td></tr>
+<tr><td class="h"><a name="843"></a>843</td><td></td><td></td><td></td><td></td><td class="s">B&lt;Moose::Meta::$type::Custom::Trait::$trait_name&gt;. The C&lt;$type&gt;</td></tr>
+<tr><td class="h"><a name="844"></a>844</td><td></td><td></td><td></td><td></td><td class="s">variable here will be one of B&lt;Attribute&gt; or B&lt;Class&gt;, depending on</td></tr>
+<tr><td class="h"><a name="845"></a>845</td><td></td><td></td><td></td><td></td><td class="s">what the trait is being applied to.</td></tr>
+<tr><td class="h"><a name="846"></a>846</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="847"></a>847</td><td></td><td></td><td></td><td></td><td class="s">If a class with this long name exists, Moose checks to see if it has</td></tr>
+<tr><td class="h"><a name="848"></a>848</td><td></td><td></td><td></td><td></td><td class="s">the method C&lt;register_implementation&gt;. This method is expected to</td></tr>
+<tr><td class="h"><a name="849"></a>849</td><td></td><td></td><td></td><td></td><td class="s">return the I&lt;real&gt; class name of the trait. If there is no</td></tr>
+<tr><td class="h"><a name="850"></a>850</td><td></td><td></td><td></td><td></td><td class="s">C&lt;register_implementation&gt; method, it will fall back to using</td></tr>
+<tr><td class="h"><a name="851"></a>851</td><td></td><td></td><td></td><td></td><td class="s">B&lt;Moose::Meta::$type::Custom::Trait::$trait&gt; as the trait name.</td></tr>
+<tr><td class="h"><a name="852"></a>852</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="853"></a>853</td><td></td><td></td><td></td><td></td><td class="s">The lookup method for metaclasses is the same, except that it looks</td></tr>
+<tr><td class="h"><a name="854"></a>854</td><td></td><td></td><td></td><td></td><td class="s">for a class matching B&lt;Moose::Meta::$type::Custom::$metaclass_name&gt;.</td></tr>
+<tr><td class="h"><a name="855"></a>855</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="856"></a>856</td><td></td><td></td><td></td><td></td><td class="s">If all this is confusing, take a look at</td></tr>
+<tr><td class="h"><a name="857"></a>857</td><td></td><td></td><td></td><td></td><td class="s">L&lt;Moose::Cookbook::Meta::Labeled_AttributeTrait&gt;, which demonstrates how to</td></tr>
+<tr><td class="h"><a name="858"></a>858</td><td></td><td></td><td></td><td></td><td class="s">create an attribute trait.</td></tr>
+<tr><td class="h"><a name="859"></a>859</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="860"></a>860</td><td></td><td></td><td></td><td></td><td class="s">=head1 UNIMPORTING FUNCTIONS</td></tr>
+<tr><td class="h"><a name="861"></a>861</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="862"></a>862</td><td></td><td></td><td></td><td></td><td class="s">=head2 B&lt;unimport&gt;</td></tr>
+<tr><td class="h"><a name="863"></a>863</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="864"></a>864</td><td></td><td></td><td></td><td></td><td class="s">Moose offers a way to remove the keywords it exports, through the C&lt;unimport&gt;</td></tr>
+<tr><td class="h"><a name="865"></a>865</td><td></td><td></td><td></td><td></td><td class="s">method. You simply have to say C&lt;no Moose&gt; at the bottom of your code for this</td></tr>
+<tr><td class="h"><a name="866"></a>866</td><td></td><td></td><td></td><td></td><td class="s">to work. Here is an example:</td></tr>
+<tr><td class="h"><a name="867"></a>867</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="868"></a>868</td><td></td><td></td><td></td><td></td><td class="s">    package Person;</td></tr>
+<tr><td class="h"><a name="869"></a>869</td><td></td><td></td><td></td><td></td><td class="s">    use Moose;</td></tr>
+<tr><td class="h"><a name="870"></a>870</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="871"></a>871</td><td></td><td></td><td></td><td></td><td class="s">    has 'first_name' =&gt; (is =&gt; 'rw', isa =&gt; 'Str');</td></tr>
+<tr><td class="h"><a name="872"></a>872</td><td></td><td></td><td></td><td></td><td class="s">    has 'last_name'  =&gt; (is =&gt; 'rw', isa =&gt; 'Str');</td></tr>
+<tr><td class="h"><a name="873"></a>873</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="874"></a>874</td><td></td><td></td><td></td><td></td><td class="s">    sub full_name {</td></tr>
+<tr><td class="h"><a name="875"></a>875</td><td></td><td></td><td></td><td></td><td class="s">        my $self = shift;</td></tr>
+<tr><td class="h"><a name="876"></a>876</td><td></td><td></td><td></td><td></td><td class="s">        $self-&gt;first_name . ' ' . $self-&gt;last_name</td></tr>
+<tr><td class="h"><a name="877"></a>877</td><td></td><td></td><td></td><td></td><td class="s">    }</td></tr>
+<tr><td class="h"><a name="878"></a>878</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="879"></a>879</td><td></td><td></td><td></td><td></td><td class="s">    no Moose; # keywords are removed from the Person package</td></tr>
+<tr><td class="h"><a name="880"></a>880</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="881"></a>881</td><td></td><td></td><td></td><td></td><td class="s">=head1 EXTENDING AND EMBEDDING MOOSE</td></tr>
+<tr><td class="h"><a name="882"></a>882</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="883"></a>883</td><td></td><td></td><td></td><td></td><td class="s">To learn more about extending Moose, we recommend checking out the</td></tr>
+<tr><td class="h"><a name="884"></a>884</td><td></td><td></td><td></td><td></td><td class="s">&quot;Extending&quot; recipes in the L&lt;Moose::Cookbook&gt;, starting with</td></tr>
+<tr><td class="h"><a name="885"></a>885</td><td></td><td></td><td></td><td></td><td class="s">L&lt;Moose::Cookbook::Extending::ExtensionOverview&gt;, which provides an overview of</td></tr>
+<tr><td class="h"><a name="886"></a>886</td><td></td><td></td><td></td><td></td><td class="s">all the different ways you might extend Moose. L&lt;Moose::Exporter&gt; and</td></tr>
+<tr><td class="h"><a name="887"></a>887</td><td></td><td></td><td></td><td></td><td class="s">L&lt;Moose::Util::MetaRole&gt; are the modules which provide the majority of the</td></tr>
+<tr><td class="h"><a name="888"></a>888</td><td></td><td></td><td></td><td></td><td class="s">extension functionality, so reading their documentation should also be helpful.</td></tr>
+<tr><td class="h"><a name="889"></a>889</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="890"></a>890</td><td></td><td></td><td></td><td></td><td class="s">=head2 The MooseX:: namespace</td></tr>
+<tr><td class="h"><a name="891"></a>891</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="892"></a>892</td><td></td><td></td><td></td><td></td><td class="s">Generally if you're writing an extension I&lt;for&gt; Moose itself you'll want</td></tr>
+<tr><td class="h"><a name="893"></a>893</td><td></td><td></td><td></td><td></td><td class="s">to put your extension in the C&lt;MooseX::&gt; namespace. This namespace is</td></tr>
+<tr><td class="h"><a name="894"></a>894</td><td></td><td></td><td></td><td></td><td class="s">specifically for extensions that make Moose better or different in some</td></tr>
+<tr><td class="h"><a name="895"></a>895</td><td></td><td></td><td></td><td></td><td class="s">fundamental way. It is traditionally B&lt;not&gt; for a package that just happens</td></tr>
+<tr><td class="h"><a name="896"></a>896</td><td></td><td></td><td></td><td></td><td class="s">to use Moose. This namespace follows from the examples of the C&lt;LWPx::&gt;</td></tr>
+<tr><td class="h"><a name="897"></a>897</td><td></td><td></td><td></td><td></td><td class="s">and C&lt;DBIx::&gt; namespaces that perform the same function for C&lt;LWP&gt; and C&lt;DBI&gt;</td></tr>
+<tr><td class="h"><a name="898"></a>898</td><td></td><td></td><td></td><td></td><td class="s">respectively.</td></tr>
+<tr><td class="h"><a name="899"></a>899</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="900"></a>900</td><td></td><td></td><td></td><td></td><td class="s">=head1 METACLASS COMPATIBILITY AND MOOSE</td></tr>
+<tr><td class="h"><a name="901"></a>901</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="902"></a>902</td><td></td><td></td><td></td><td></td><td class="s">Metaclass compatibility is a thorny subject. You should start by</td></tr>
+<tr><td class="h"><a name="903"></a>903</td><td></td><td></td><td></td><td></td><td class="s">reading the &quot;About Metaclass compatibility&quot; section in the</td></tr>
+<tr><td class="h"><a name="904"></a>904</td><td></td><td></td><td></td><td></td><td class="s">C&lt;Class::MOP&gt; docs.</td></tr>
+<tr><td class="h"><a name="905"></a>905</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="906"></a>906</td><td></td><td></td><td></td><td></td><td class="s">Moose will attempt to resolve a few cases of metaclass incompatibility</td></tr>
+<tr><td class="h"><a name="907"></a>907</td><td></td><td></td><td></td><td></td><td class="s">when you set the superclasses for a class, in addition to the cases that</td></tr>
+<tr><td class="h"><a name="908"></a>908</td><td></td><td></td><td></td><td></td><td class="s">C&lt;Class::MOP&gt; handles.</td></tr>
+<tr><td class="h"><a name="909"></a>909</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="910"></a>910</td><td></td><td></td><td></td><td></td><td class="s">Moose tries to determine if the metaclasses only &quot;differ by roles&quot;. This</td></tr>
+<tr><td class="h"><a name="911"></a>911</td><td></td><td></td><td></td><td></td><td class="s">means that the parent and child's metaclass share a common ancestor in</td></tr>
+<tr><td class="h"><a name="912"></a>912</td><td></td><td></td><td></td><td></td><td class="s">their respective hierarchies, and that the subclasses under the common</td></tr>
+<tr><td class="h"><a name="913"></a>913</td><td></td><td></td><td></td><td></td><td class="s">ancestor are only different because of role applications. This case is</td></tr>
+<tr><td class="h"><a name="914"></a>914</td><td></td><td></td><td></td><td></td><td class="s">actually fairly common when you mix and match various C&lt;MooseX::*&gt;</td></tr>
+<tr><td class="h"><a name="915"></a>915</td><td></td><td></td><td></td><td></td><td class="s">modules, many of which apply roles to the metaclass.</td></tr>
+<tr><td class="h"><a name="916"></a>916</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="917"></a>917</td><td></td><td></td><td></td><td></td><td class="s">If the parent and child do differ by roles, Moose replaces the</td></tr>
+<tr><td class="h"><a name="918"></a>918</td><td></td><td></td><td></td><td></td><td class="s">metaclass in the child with a newly created metaclass. This metaclass</td></tr>
+<tr><td class="h"><a name="919"></a>919</td><td></td><td></td><td></td><td></td><td class="s">is a subclass of the parent's metaclass which does all of the roles that</td></tr>
+<tr><td class="h"><a name="920"></a>920</td><td></td><td></td><td></td><td></td><td class="s">the child's metaclass did before being replaced. Effectively, this</td></tr>
+<tr><td class="h"><a name="921"></a>921</td><td></td><td></td><td></td><td></td><td class="s">means the new metaclass does all of the roles done by both the</td></tr>
+<tr><td class="h"><a name="922"></a>922</td><td></td><td></td><td></td><td></td><td class="s">parent's and child's original metaclasses.</td></tr>
+<tr><td class="h"><a name="923"></a>923</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="924"></a>924</td><td></td><td></td><td></td><td></td><td class="s">Ultimately, this is all transparent to you except in the case of an</td></tr>
+<tr><td class="h"><a name="925"></a>925</td><td></td><td></td><td></td><td></td><td class="s">unresolvable conflict.</td></tr>
+<tr><td class="h"><a name="926"></a>926</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="927"></a>927</td><td></td><td></td><td></td><td></td><td class="s">=head1 CAVEATS</td></tr>
+<tr><td class="h"><a name="928"></a>928</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="929"></a>929</td><td></td><td></td><td></td><td></td><td class="s">=over 4</td></tr>
+<tr><td class="h"><a name="930"></a>930</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="931"></a>931</td><td></td><td></td><td></td><td></td><td class="s">=item *</td></tr>
+<tr><td class="h"><a name="932"></a>932</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="933"></a>933</td><td></td><td></td><td></td><td></td><td class="s">It should be noted that C&lt;super&gt; and C&lt;inner&gt; B&lt;cannot&gt; be used in the same</td></tr>
+<tr><td class="h"><a name="934"></a>934</td><td></td><td></td><td></td><td></td><td class="s">method. However, they may be combined within the same class hierarchy; see</td></tr>
+<tr><td class="h"><a name="935"></a>935</td><td></td><td></td><td></td><td></td><td class="s">F&lt;t/basics/override_augment_inner_super.t&gt; for an example.</td></tr>
+<tr><td class="h"><a name="936"></a>936</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="937"></a>937</td><td></td><td></td><td></td><td></td><td class="s">The reason for this is that C&lt;super&gt; is only valid within a method</td></tr>
+<tr><td class="h"><a name="938"></a>938</td><td></td><td></td><td></td><td></td><td class="s">with the C&lt;override&gt; modifier, and C&lt;inner&gt; will never be valid within an</td></tr>
+<tr><td class="h"><a name="939"></a>939</td><td></td><td></td><td></td><td></td><td class="s">C&lt;override&gt; method. In fact, C&lt;augment&gt; will skip over any C&lt;override&gt; methods</td></tr>
+<tr><td class="h"><a name="940"></a>940</td><td></td><td></td><td></td><td></td><td class="s">when searching for its appropriate C&lt;inner&gt;.</td></tr>
+<tr><td class="h"><a name="941"></a>941</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="942"></a>942</td><td></td><td></td><td></td><td></td><td class="s">This might seem like a restriction, but I am of the opinion that keeping these</td></tr>
+<tr><td class="h"><a name="943"></a>943</td><td></td><td></td><td></td><td></td><td class="s">two features separate (yet interoperable) actually makes them easy to use, since</td></tr>
+<tr><td class="h"><a name="944"></a>944</td><td></td><td></td><td></td><td></td><td class="s">their behavior is then easier to predict. Time will tell whether I am right or</td></tr>
+<tr><td class="h"><a name="945"></a>945</td><td></td><td></td><td></td><td></td><td class="s">not (UPDATE: so far so good).</td></tr>
+<tr><td class="h"><a name="946"></a>946</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="947"></a>947</td><td></td><td></td><td></td><td></td><td class="s">=back</td></tr>
+<tr><td class="h"><a name="948"></a>948</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="949"></a>949</td><td></td><td></td><td></td><td></td><td class="s">=head1 GETTING HELP</td></tr>
+<tr><td class="h"><a name="950"></a>950</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="951"></a>951</td><td></td><td></td><td></td><td></td><td class="s">We offer both a mailing list and a very active IRC channel.</td></tr>
+<tr><td class="h"><a name="952"></a>952</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="953"></a>953</td><td></td><td></td><td></td><td></td><td class="s">The mailing list is L&lt;mailto:moose@perl.org&gt;. You must be subscribed to send</td></tr>
+<tr><td class="h"><a name="954"></a>954</td><td></td><td></td><td></td><td></td><td class="s">a message. To subscribe, send an empty message to</td></tr>
+<tr><td class="h"><a name="955"></a>955</td><td></td><td></td><td></td><td></td><td class="s">L&lt;mailto:moose-subscribe@perl.org&gt;</td></tr>
+<tr><td class="h"><a name="956"></a>956</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="957"></a>957</td><td></td><td></td><td></td><td></td><td class="s">You can also visit us at C&lt;#moose&gt; on L&lt;irc://irc.perl.org/#moose&gt;</td></tr>
+<tr><td class="h"><a name="958"></a>958</td><td></td><td></td><td></td><td></td><td class="s">This channel is quite active, and questions at all levels (on Moose-related</td></tr>
+<tr><td class="h"><a name="959"></a>959</td><td></td><td></td><td></td><td></td><td class="s">topics ;) are welcome.</td></tr>
+<tr><td class="h"><a name="960"></a>960</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="961"></a>961</td><td></td><td></td><td></td><td></td><td class="s">=head1 ACKNOWLEDGEMENTS</td></tr>
+<tr><td class="h"><a name="962"></a>962</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="963"></a>963</td><td></td><td></td><td></td><td></td><td class="s">=over 4</td></tr>
+<tr><td class="h"><a name="964"></a>964</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="965"></a>965</td><td></td><td></td><td></td><td></td><td class="s">=item I blame Sam Vilain for introducing me to the insanity that is meta-models.</td></tr>
+<tr><td class="h"><a name="966"></a>966</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="967"></a>967</td><td></td><td></td><td></td><td></td><td class="s">=item I blame Audrey Tang for then encouraging my meta-model habit in #perl6.</td></tr>
+<tr><td class="h"><a name="968"></a>968</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="969"></a>969</td><td></td><td></td><td></td><td></td><td class="s">=item Without Yuval &quot;nothingmuch&quot; Kogman this module would not be possible,</td></tr>
+<tr><td class="h"><a name="970"></a>970</td><td></td><td></td><td></td><td></td><td class="s">and it certainly wouldn't have this name ;P</td></tr>
+<tr><td class="h"><a name="971"></a>971</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="972"></a>972</td><td></td><td></td><td></td><td></td><td class="s">=item The basis of the TypeContraints module was Rob Kinyon's idea</td></tr>
+<tr><td class="h"><a name="973"></a>973</td><td></td><td></td><td></td><td></td><td class="s">originally, I just ran with it.</td></tr>
+<tr><td class="h"><a name="974"></a>974</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="975"></a>975</td><td></td><td></td><td></td><td></td><td class="s">=item Thanks to mst &amp; chansen and the whole #moose posse for all the</td></tr>
+<tr><td class="h"><a name="976"></a>976</td><td></td><td></td><td></td><td></td><td class="s">early ideas/feature-requests/encouragement/bug-finding.</td></tr>
+<tr><td class="h"><a name="977"></a>977</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="978"></a>978</td><td></td><td></td><td></td><td></td><td class="s">=item Thanks to David &quot;Theory&quot; Wheeler for meta-discussions and spelling fixes.</td></tr>
+<tr><td class="h"><a name="979"></a>979</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="980"></a>980</td><td></td><td></td><td></td><td></td><td class="s">=back</td></tr>
+<tr><td class="h"><a name="981"></a>981</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="982"></a>982</td><td></td><td></td><td></td><td></td><td class="s">=head1 SEE ALSO</td></tr>
+<tr><td class="h"><a name="983"></a>983</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="984"></a>984</td><td></td><td></td><td></td><td></td><td class="s">=over 4</td></tr>
+<tr><td class="h"><a name="985"></a>985</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="986"></a>986</td><td></td><td></td><td></td><td></td><td class="s">=item L&lt;http://www.iinteractive.com/moose&gt;</td></tr>
+<tr><td class="h"><a name="987"></a>987</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="988"></a>988</td><td></td><td></td><td></td><td></td><td class="s">This is the official web home of Moose. It contains links to our public git</td></tr>
+<tr><td class="h"><a name="989"></a>989</td><td></td><td></td><td></td><td></td><td class="s">repository, as well as links to a number of talks and articles on Moose and</td></tr>
+<tr><td class="h"><a name="990"></a>990</td><td></td><td></td><td></td><td></td><td class="s">Moose related technologies.</td></tr>
+<tr><td class="h"><a name="991"></a>991</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="992"></a>992</td><td></td><td></td><td></td><td></td><td class="s">=item the L&lt;Moose manual|Moose::Manual&gt;</td></tr>
+<tr><td class="h"><a name="993"></a>993</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="994"></a>994</td><td></td><td></td><td></td><td></td><td class="s">This is an introduction to Moose which covers most of the basics.</td></tr>
+<tr><td class="h"><a name="995"></a>995</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="996"></a>996</td><td></td><td></td><td></td><td></td><td class="s">=item Modern Perl, by chromatic</td></tr>
+<tr><td class="h"><a name="997"></a>997</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="998"></a>998</td><td></td><td></td><td></td><td></td><td class="s">This is an introduction to modern Perl programming, which includes a section on</td></tr>
+<tr><td class="h"><a name="999"></a>999</td><td></td><td></td><td></td><td></td><td class="s">Moose. It is available in print and as a free download from</td></tr>
+<tr><td class="h"><a name="1000"></a>1000</td><td></td><td></td><td></td><td></td><td class="s">L&lt;http://onyxneon.com/books/modern_perl/&gt;.</td></tr>
+<tr><td class="h"><a name="1001"></a>1001</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1002"></a>1002</td><td></td><td></td><td></td><td></td><td class="s">=item The Moose is flying, a tutorial by Randal Schwartz</td></tr>
+<tr><td class="h"><a name="1003"></a>1003</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1004"></a>1004</td><td></td><td></td><td></td><td></td><td class="s">Part 1 - L&lt;http://www.stonehenge.com/merlyn/LinuxMag/col94.html&gt;</td></tr>
+<tr><td class="h"><a name="1005"></a>1005</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1006"></a>1006</td><td></td><td></td><td></td><td></td><td class="s">Part 2 - L&lt;http://www.stonehenge.com/merlyn/LinuxMag/col95.html&gt;</td></tr>
+<tr><td class="h"><a name="1007"></a>1007</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1008"></a>1008</td><td></td><td></td><td></td><td></td><td class="s">=item Several Moose extension modules in the C&lt;MooseX::&gt; namespace.</td></tr>
+<tr><td class="h"><a name="1009"></a>1009</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1010"></a>1010</td><td></td><td></td><td></td><td></td><td class="s">See L&lt;http://search.cpan.org/search?query=MooseX::&gt; for extensions.</td></tr>
+<tr><td class="h"><a name="1011"></a>1011</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1012"></a>1012</td><td></td><td></td><td></td><td></td><td class="s">=back</td></tr>
+<tr><td class="h"><a name="1013"></a>1013</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1014"></a>1014</td><td></td><td></td><td></td><td></td><td class="s">=head2 Books</td></tr>
+<tr><td class="h"><a name="1015"></a>1015</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1016"></a>1016</td><td></td><td></td><td></td><td></td><td class="s">=over 4</td></tr>
+<tr><td class="h"><a name="1017"></a>1017</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1018"></a>1018</td><td></td><td></td><td></td><td></td><td class="s">=item The Art of the MetaObject Protocol</td></tr>
+<tr><td class="h"><a name="1019"></a>1019</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1020"></a>1020</td><td></td><td></td><td></td><td></td><td class="s">I mention this in the L&lt;Class::MOP&gt; docs too, as this book was critical in</td></tr>
+<tr><td class="h"><a name="1021"></a>1021</td><td></td><td></td><td></td><td></td><td class="s">the development of both modules and is highly recommended.</td></tr>
+<tr><td class="h"><a name="1022"></a>1022</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1023"></a>1023</td><td></td><td></td><td></td><td></td><td class="s">=back</td></tr>
+<tr><td class="h"><a name="1024"></a>1024</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1025"></a>1025</td><td></td><td></td><td></td><td></td><td class="s">=head2 Papers</td></tr>
+<tr><td class="h"><a name="1026"></a>1026</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1027"></a>1027</td><td></td><td></td><td></td><td></td><td class="s">=over 4</td></tr>
+<tr><td class="h"><a name="1028"></a>1028</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1029"></a>1029</td><td></td><td></td><td></td><td></td><td class="s">=item L&lt;http://www.cs.utah.edu/plt/publications/oopsla04-gff.pdf&gt;</td></tr>
+<tr><td class="h"><a name="1030"></a>1030</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1031"></a>1031</td><td></td><td></td><td></td><td></td><td class="s">This paper (suggested by lbr on #moose) was what lead to the implementation</td></tr>
+<tr><td class="h"><a name="1032"></a>1032</td><td></td><td></td><td></td><td></td><td class="s">of the C&lt;super&gt;/C&lt;override&gt; and C&lt;inner&gt;/C&lt;augment&gt; features. If you really</td></tr>
+<tr><td class="h"><a name="1033"></a>1033</td><td></td><td></td><td></td><td></td><td class="s">want to understand them, I suggest you read this.</td></tr>
+<tr><td class="h"><a name="1034"></a>1034</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1035"></a>1035</td><td></td><td></td><td></td><td></td><td class="s">=back</td></tr>
+<tr><td class="h"><a name="1036"></a>1036</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1037"></a>1037</td><td></td><td></td><td></td><td></td><td class="s">=head1 BUGS</td></tr>
+<tr><td class="h"><a name="1038"></a>1038</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1039"></a>1039</td><td></td><td></td><td></td><td></td><td class="s">All complex software has bugs lurking in it, and this module is no</td></tr>
+<tr><td class="h"><a name="1040"></a>1040</td><td></td><td></td><td></td><td></td><td class="s">exception.</td></tr>
+<tr><td class="h"><a name="1041"></a>1041</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1042"></a>1042</td><td></td><td></td><td></td><td></td><td class="s">Please report any bugs to C&lt;bug-moose@rt.cpan.org&gt;, or through the web</td></tr>
+<tr><td class="h"><a name="1043"></a>1043</td><td></td><td></td><td></td><td></td><td class="s">interface at L&lt;http://rt.cpan.org&gt;.</td></tr>
+<tr><td class="h"><a name="1044"></a>1044</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1045"></a>1045</td><td></td><td></td><td></td><td></td><td class="s">You can also discuss feature requests or possible bugs on the Moose mailing</td></tr>
+<tr><td class="h"><a name="1046"></a>1046</td><td></td><td></td><td></td><td></td><td class="s">list (moose@perl.org) or on IRC at L&lt;irc://irc.perl.org/#moose&gt;.</td></tr>
+<tr><td class="h"><a name="1047"></a>1047</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1048"></a>1048</td><td></td><td></td><td></td><td></td><td class="s">=head1 FEATURE REQUESTS</td></tr>
+<tr><td class="h"><a name="1049"></a>1049</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1050"></a>1050</td><td></td><td></td><td></td><td></td><td class="s">We are very strict about what features we add to the Moose core, especially</td></tr>
+<tr><td class="h"><a name="1051"></a>1051</td><td></td><td></td><td></td><td></td><td class="s">the user-visible features. Instead we have made sure that the underlying</td></tr>
+<tr><td class="h"><a name="1052"></a>1052</td><td></td><td></td><td></td><td></td><td class="s">meta-system of Moose is as extensible as possible so that you can add your</td></tr>
+<tr><td class="h"><a name="1053"></a>1053</td><td></td><td></td><td></td><td></td><td class="s">own features easily.</td></tr>
+<tr><td class="h"><a name="1054"></a>1054</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1055"></a>1055</td><td></td><td></td><td></td><td></td><td class="s">That said, occasionally there is a feature needed in the meta-system</td></tr>
+<tr><td class="h"><a name="1056"></a>1056</td><td></td><td></td><td></td><td></td><td class="s">to support your planned extension, in which case you should either</td></tr>
+<tr><td class="h"><a name="1057"></a>1057</td><td></td><td></td><td></td><td></td><td class="s">email the mailing list (moose@perl.org) or join us on IRC at</td></tr>
+<tr><td class="h"><a name="1058"></a>1058</td><td></td><td></td><td></td><td></td><td class="s">L&lt;irc://irc.perl.org/#moose&gt; to discuss. The</td></tr>
+<tr><td class="h"><a name="1059"></a>1059</td><td></td><td></td><td></td><td></td><td class="s">L&lt;Moose::Manual::Contributing&gt; has more detail about how and when you</td></tr>
+<tr><td class="h"><a name="1060"></a>1060</td><td></td><td></td><td></td><td></td><td class="s">can contribute.</td></tr>
+<tr><td class="h"><a name="1061"></a>1061</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1062"></a>1062</td><td></td><td></td><td></td><td></td><td class="s">=head1 CABAL</td></tr>
+<tr><td class="h"><a name="1063"></a>1063</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1064"></a>1064</td><td></td><td></td><td></td><td></td><td class="s">There are only a few people with the rights to release a new version</td></tr>
+<tr><td class="h"><a name="1065"></a>1065</td><td></td><td></td><td></td><td></td><td class="s">of Moose. The Moose Cabal are the people to go to with questions regarding</td></tr>
+<tr><td class="h"><a name="1066"></a>1066</td><td></td><td></td><td></td><td></td><td class="s">the wider purview of Moose. They help maintain not just the code</td></tr>
+<tr><td class="h"><a name="1067"></a>1067</td><td></td><td></td><td></td><td></td><td class="s">but the community as well.</td></tr>
+<tr><td class="h"><a name="1068"></a>1068</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1069"></a>1069</td><td></td><td></td><td></td><td></td><td class="s">Stevan (stevan) Little E&lt;lt&gt;stevan@iinteractive.comE&lt;gt&gt;</td></tr>
+<tr><td class="h"><a name="1070"></a>1070</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1071"></a>1071</td><td></td><td></td><td></td><td></td><td class="s">Jesse (doy) Luehrs E&lt;lt&gt;doy at tozt dot netE&lt;gt&gt;</td></tr>
+<tr><td class="h"><a name="1072"></a>1072</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1073"></a>1073</td><td></td><td></td><td></td><td></td><td class="s">Yuval (nothingmuch) Kogman</td></tr>
+<tr><td class="h"><a name="1074"></a>1074</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1075"></a>1075</td><td></td><td></td><td></td><td></td><td class="s">Shawn (sartak) Moore E&lt;lt&gt;sartak@bestpractical.comE&lt;gt&gt;</td></tr>
+<tr><td class="h"><a name="1076"></a>1076</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1077"></a>1077</td><td></td><td></td><td></td><td></td><td class="s">Hans Dieter (confound) Pearcey E&lt;lt&gt;hdp@pobox.comE&lt;gt&gt;</td></tr>
+<tr><td class="h"><a name="1078"></a>1078</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1079"></a>1079</td><td></td><td></td><td></td><td></td><td class="s">Chris (perigrin) Prather</td></tr>
+<tr><td class="h"><a name="1080"></a>1080</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1081"></a>1081</td><td></td><td></td><td></td><td></td><td class="s">Florian Ragwitz E&lt;lt&gt;rafl@debian.orgE&lt;gt&gt;</td></tr>
+<tr><td class="h"><a name="1082"></a>1082</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1083"></a>1083</td><td></td><td></td><td></td><td></td><td class="s">Dave (autarch) Rolsky E&lt;lt&gt;autarch@urth.orgE&lt;gt&gt;</td></tr>
+<tr><td class="h"><a name="1084"></a>1084</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1085"></a>1085</td><td></td><td></td><td></td><td></td><td class="s">=head1 CONTRIBUTORS</td></tr>
+<tr><td class="h"><a name="1086"></a>1086</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1087"></a>1087</td><td></td><td></td><td></td><td></td><td class="s">Moose is a community project, and as such, involves the work of many, many</td></tr>
+<tr><td class="h"><a name="1088"></a>1088</td><td></td><td></td><td></td><td></td><td class="s">members of the community beyond just the members in the cabal. In particular:</td></tr>
+<tr><td class="h"><a name="1089"></a>1089</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1090"></a>1090</td><td></td><td></td><td></td><td></td><td class="s">Dave (autarch) Rolsky wrote most of the documentation in L&lt;Moose::Manual&gt;.</td></tr>
+<tr><td class="h"><a name="1091"></a>1091</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1092"></a>1092</td><td></td><td></td><td></td><td></td><td class="s">John (jgoulah) Goulah wrote L&lt;Moose::Cookbook::Snack::Keywords&gt;.</td></tr>
+<tr><td class="h"><a name="1093"></a>1093</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1094"></a>1094</td><td></td><td></td><td></td><td></td><td class="s">Jess (castaway) Robinson wrote L&lt;Moose::Cookbook::Snack::Types&gt;.</td></tr>
+<tr><td class="h"><a name="1095"></a>1095</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1096"></a>1096</td><td></td><td></td><td></td><td></td><td class="s">Aran (bluefeet) Clary Deltac wrote</td></tr>
+<tr><td class="h"><a name="1097"></a>1097</td><td></td><td></td><td></td><td></td><td class="s">L&lt;Moose::Cookbook::Basics::Genome_OverloadingSubtypesAndCoercion&gt;.</td></tr>
+<tr><td class="h"><a name="1098"></a>1098</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1099"></a>1099</td><td></td><td></td><td></td><td></td><td class="s">Anders (Debolaz) Nor Berle contributed L&lt;Test::Moose&gt; and L&lt;Moose::Util&gt;.</td></tr>
+<tr><td class="h"><a name="1100"></a>1100</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1101"></a>1101</td><td></td><td></td><td></td><td></td><td class="s">Also, the code in L&lt;Moose::Meta::Attribute::Native&gt; is based on code from the</td></tr>
+<tr><td class="h"><a name="1102"></a>1102</td><td></td><td></td><td></td><td></td><td class="s">L&lt;MooseX::AttributeHelpers&gt; distribution, which had contributions from:</td></tr>
+<tr><td class="h"><a name="1103"></a>1103</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1104"></a>1104</td><td></td><td></td><td></td><td></td><td class="s">Chris (perigrin) Prather</td></tr>
+<tr><td class="h"><a name="1105"></a>1105</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1106"></a>1106</td><td></td><td></td><td></td><td></td><td class="s">Cory (gphat) Watson</td></tr>
+<tr><td class="h"><a name="1107"></a>1107</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1108"></a>1108</td><td></td><td></td><td></td><td></td><td class="s">Evan Carroll</td></tr>
+<tr><td class="h"><a name="1109"></a>1109</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1110"></a>1110</td><td></td><td></td><td></td><td></td><td class="s">Florian (rafl) Ragwitz</td></tr>
+<tr><td class="h"><a name="1111"></a>1111</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1112"></a>1112</td><td></td><td></td><td></td><td></td><td class="s">Jason May</td></tr>
+<tr><td class="h"><a name="1113"></a>1113</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1114"></a>1114</td><td></td><td></td><td></td><td></td><td class="s">Jay Hannah</td></tr>
+<tr><td class="h"><a name="1115"></a>1115</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1116"></a>1116</td><td></td><td></td><td></td><td></td><td class="s">Jesse (doy) Luehrs</td></tr>
+<tr><td class="h"><a name="1117"></a>1117</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1118"></a>1118</td><td></td><td></td><td></td><td></td><td class="s">Paul (frodwith) Driver</td></tr>
+<tr><td class="h"><a name="1119"></a>1119</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1120"></a>1120</td><td></td><td></td><td></td><td></td><td class="s">Robert (rlb3) Boone</td></tr>
+<tr><td class="h"><a name="1121"></a>1121</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1122"></a>1122</td><td></td><td></td><td></td><td></td><td class="s">Robert Buels</td></tr>
+<tr><td class="h"><a name="1123"></a>1123</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1124"></a>1124</td><td></td><td></td><td></td><td></td><td class="s">Robert (phaylon) Sedlacek</td></tr>
+<tr><td class="h"><a name="1125"></a>1125</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1126"></a>1126</td><td></td><td></td><td></td><td></td><td class="s">Shawn (Sartak) Moore</td></tr>
+<tr><td class="h"><a name="1127"></a>1127</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1128"></a>1128</td><td></td><td></td><td></td><td></td><td class="s">Stevan Little</td></tr>
+<tr><td class="h"><a name="1129"></a>1129</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1130"></a>1130</td><td></td><td></td><td></td><td></td><td class="s">Tom (dec) Lanyon</td></tr>
+<tr><td class="h"><a name="1131"></a>1131</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1132"></a>1132</td><td></td><td></td><td></td><td></td><td class="s">Yuval Kogman</td></tr>
+<tr><td class="h"><a name="1133"></a>1133</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1134"></a>1134</td><td></td><td></td><td></td><td></td><td class="s">Finally, these people also contributed various tests, bug fixes,</td></tr>
+<tr><td class="h"><a name="1135"></a>1135</td><td></td><td></td><td></td><td></td><td class="s">documentation, and features to the Moose codebase:</td></tr>
+<tr><td class="h"><a name="1136"></a>1136</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1137"></a>1137</td><td></td><td></td><td></td><td></td><td class="s">Aankhen</td></tr>
+<tr><td class="h"><a name="1138"></a>1138</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1139"></a>1139</td><td></td><td></td><td></td><td></td><td class="s">Adam (Alias) Kennedy</td></tr>
+<tr><td class="h"><a name="1140"></a>1140</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1141"></a>1141</td><td></td><td></td><td></td><td></td><td class="s">Christian (chansen) Hansen</td></tr>
+<tr><td class="h"><a name="1142"></a>1142</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1143"></a>1143</td><td></td><td></td><td></td><td></td><td class="s">Cory (gphat) Watson</td></tr>
+<tr><td class="h"><a name="1144"></a>1144</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1145"></a>1145</td><td></td><td></td><td></td><td></td><td class="s">Dylan Hardison (doc fixes)</td></tr>
+<tr><td class="h"><a name="1146"></a>1146</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1147"></a>1147</td><td></td><td></td><td></td><td></td><td class="s">Eric (ewilhelm) Wilhelm</td></tr>
+<tr><td class="h"><a name="1148"></a>1148</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1149"></a>1149</td><td></td><td></td><td></td><td></td><td class="s">Evan Carroll</td></tr>
+<tr><td class="h"><a name="1150"></a>1150</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1151"></a>1151</td><td></td><td></td><td></td><td></td><td class="s">Guillermo (groditi) Roditi</td></tr>
+<tr><td class="h"><a name="1152"></a>1152</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1153"></a>1153</td><td></td><td></td><td></td><td></td><td class="s">Jason May</td></tr>
+<tr><td class="h"><a name="1154"></a>1154</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1155"></a>1155</td><td></td><td></td><td></td><td></td><td class="s">Jay Hannah</td></tr>
+<tr><td class="h"><a name="1156"></a>1156</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1157"></a>1157</td><td></td><td></td><td></td><td></td><td class="s">Jonathan (jrockway) Rockway</td></tr>
+<tr><td class="h"><a name="1158"></a>1158</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1159"></a>1159</td><td></td><td></td><td></td><td></td><td class="s">Matt (mst) Trout</td></tr>
+<tr><td class="h"><a name="1160"></a>1160</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1161"></a>1161</td><td></td><td></td><td></td><td></td><td class="s">Nathan (kolibrie) Gray</td></tr>
+<tr><td class="h"><a name="1162"></a>1162</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1163"></a>1163</td><td></td><td></td><td></td><td></td><td class="s">Paul (frodwith) Driver</td></tr>
+<tr><td class="h"><a name="1164"></a>1164</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1165"></a>1165</td><td></td><td></td><td></td><td></td><td class="s">Piotr (dexter) Roszatycki</td></tr>
+<tr><td class="h"><a name="1166"></a>1166</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1167"></a>1167</td><td></td><td></td><td></td><td></td><td class="s">Robert Buels</td></tr>
+<tr><td class="h"><a name="1168"></a>1168</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1169"></a>1169</td><td></td><td></td><td></td><td></td><td class="s">Robert (phaylon) Sedlacek</td></tr>
+<tr><td class="h"><a name="1170"></a>1170</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1171"></a>1171</td><td></td><td></td><td></td><td></td><td class="s">Robert (rlb3) Boone</td></tr>
+<tr><td class="h"><a name="1172"></a>1172</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1173"></a>1173</td><td></td><td></td><td></td><td></td><td class="s">Sam (mugwump) Vilain</td></tr>
+<tr><td class="h"><a name="1174"></a>1174</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1175"></a>1175</td><td></td><td></td><td></td><td></td><td class="s">Scott (konobi) McWhirter</td></tr>
+<tr><td class="h"><a name="1176"></a>1176</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1177"></a>1177</td><td></td><td></td><td></td><td></td><td class="s">Shlomi (rindolf) Fish</td></tr>
+<tr><td class="h"><a name="1178"></a>1178</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1179"></a>1179</td><td></td><td></td><td></td><td></td><td class="s">Tom (dec) Lanyon</td></tr>
+<tr><td class="h"><a name="1180"></a>1180</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1181"></a>1181</td><td></td><td></td><td></td><td></td><td class="s">Wallace (wreis) Reis</td></tr>
+<tr><td class="h"><a name="1182"></a>1182</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1183"></a>1183</td><td></td><td></td><td></td><td></td><td class="s">... and many other #moose folks</td></tr>
+<tr><td class="h"><a name="1184"></a>1184</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1185"></a>1185</td><td></td><td></td><td></td><td></td><td class="s">=head1 AUTHOR</td></tr>
+<tr><td class="h"><a name="1186"></a>1186</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1187"></a>1187</td><td></td><td></td><td></td><td></td><td class="s">Moose is maintained by the Moose Cabal, along with the help of many contributors. See L&lt;Moose/CABAL&gt; and L&lt;Moose/CONTRIBUTORS&gt; for details.</td></tr>
+<tr><td class="h"><a name="1188"></a>1188</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1189"></a>1189</td><td></td><td></td><td></td><td></td><td class="s">=head1 COPYRIGHT AND LICENSE</td></tr>
+<tr><td class="h"><a name="1190"></a>1190</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1191"></a>1191</td><td></td><td></td><td></td><td></td><td class="s">This software is copyright (c) 2012 by Infinity Interactive, Inc..</td></tr>
+<tr><td class="h"><a name="1192"></a>1192</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1193"></a>1193</td><td></td><td></td><td></td><td></td><td class="s">This is free software; you can redistribute it and/or modify it under</td></tr>
+<tr><td class="h"><a name="1194"></a>1194</td><td></td><td></td><td></td><td></td><td class="s">the same terms as the Perl 5 programming language system itself.</td></tr>
+<tr><td class="h"><a name="1195"></a>1195</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1196"></a>1196</td><td></td><td></td><td></td><td></td><td class="s">=cut</td></tr>
+<tr><td class="h"><a name="1197"></a>1197</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1198"></a>1198</td><td></td><td></td><td></td><td></td><td class="s"></td></tr>
+<tr><td class="h"><a name="1199"></a>1199</td><td></td><td></td><td></td><td></td><td class="s">__END__</td></tr>
+</tbody></table></div>
+        
+            <script type="text/javascript"> $(document).ready(function() { 
+
+        $("#subs_table").tablesorter({
+            sortList: [[3,1]],
+            headers: {
+                3: { sorter: 'fmt_time' },
+                4: { sorter: 'fmt_time' }
+            }
+        });
+    
+ } ); </script>
+        
+        <div class="footer">Report produced by the
+        <a href="http://search.cpan.org/dist/Devel-NYTProf/">NYTProf 4.06</a>
+        Perl profiler, developed by
+        <a href="http://www.linkedin.com/in/timbunce">Tim Bunce</a> and
+        <a href="http://code.nytimes.com">Adam Kaplan</a>.
+        </div>
+        <br /><br /><br /><br /><br /><br /><br /><br /><br /><br />
+    </body></html>
\ No newline at end of file