--- /dev/null
+ <!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 µ ? */
+ 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">← Index</a>
+ </div>
+<div class="headerForeground" style="float: left">
+ <span class="siteTitle">NYTProf Performance Profile</span>
+ <span class="siteSubtitle">  <span>« <span class="mode_btn mode_btn_selected">block view</span> • <span class="mode_btn"><a href="Moose-pm-62-line.html">line view</a></span> • <span class="mode_btn"><a href="Moose-pm-62-sub.html">sub view</a></span> »</span><br />
+ For script/nytprof.pl
+ </span>
+</div>
+<div class="headerForeground" style="float: right; text-align: right">
+ <span class="siteTitle"> </span>
+ <span class="siteSubtitle">Run on Thu May 31 16:29:39 2012<br />Reported on Thu May 31 16:35:20 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 17.2ms</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%">10.3ms</span></td><td class="c0"><span title="6.0%">3.14s</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%">6.19ms</span></td><td class="c0"><span title="0.7%">364ms</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%">4.01ms</span></td><td class="c0"><span title="0.0%">20.7ms</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%">3.70ms</span></td><td class="c0"><span title="0.0%">17.7ms</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.21ms</span></td><td class="c0"><span title="0.2%">85.2ms</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.33ms</span></td><td class="c0"><span title="0.0%">9.20ms</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%">1.49ms</span></td><td class="c3"><span title="0.0%">2.58ms</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="c1"><span title="0.0%">1.25ms</span></td><td class="c3"><span title="0.0%">3.04ms</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.07ms</span></td><td class="c0"><span title="0.0%">11.2ms</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="c1"><span title="0.0%">986µs</span></td><td class="c3"><span title="0.0%">1.69ms</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%">946µs</span></td><td class="c2"><span title="0.0%">3.74ms</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%">936µs</span></td><td class="c3"><span title="0.0%">2.83ms</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%">870µs</span></td><td class="c0"><span title="4.5%">2.36s</span></td><td class="sub_name"><span style="display: none;">Moose::::with</span>Moose::<a href="Moose-pm-62-block.html#66">with</a> (recurses: max depth 1, inclusive time 149ms)</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%">810µs</span></td><td class="c0"><span title="0.2%">103ms</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%">700µs</span></td><td class="c3"><span title="0.0%">2.00ms</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="c0">70</td><td class="c0">36</td><td class="c0">36</td><td class="c3"><span title="0.0%">544µs</span></td><td class="c0"><span title="3.8%">2.00s</span></td><td class="sub_name"><span style="display: none;">Moose::::extends</span>Moose::<a href="Moose-pm-62-block.html#55">extends</a> (recurses: max depth 2, inclusive time 11.3ms)</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%">517µs</span></td><td class="c3"><span title="0.0%">829µs</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%">468µs</span></td><td class="c3"><span title="0.0%">2.08ms</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%">460µs</span></td><td class="c3"><span title="0.0%">1.52ms</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">54</td><td class="c0">28</td><td class="c0">18</td><td class="c3"><span title="0.0%">363µs</span></td><td class="c0"><span title="0.0%">20.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%">267µs</span></td><td class="c3"><span title="0.0%">1.58ms</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="c3">1</td><td class="c3">1</td><td class="c3">1</td><td class="c3"><span title="0.0%">234µs</span></td><td class="c3"><span title="0.0%">2.33ms</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%">76µs</span></td><td class="c3"><span title="0.0%">3.31ms</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µs</span></td><td class="c3"><span title="0.0%">110µ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%">38µs</span></td><td class="c3"><span title="0.0%">38µ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%">30µs</span></td><td class="c3"><span title="0.0%">2.81ms</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%">11µs</span></td><td class="c3"><span title="0.0%">14µ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%">10µs</span></td><td class="c3"><span title="0.0%">19µ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%">10µs</span></td><td class="c3"><span title="0.0%">1.66ms</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%">9µs</span></td><td class="c3"><span title="0.0%">9µ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µs</span></td><td class="c3"><span title="0.0%">46µ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%">6µs</span></td><td class="c3"><span title="0.0%">6µ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%">5µs</span></td><td class="c3"><span title="0.0%">5µ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%">5µs</span></td><td class="c3"><span title="0.0%">5µ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">1</td><td class="c3">1</td><td class="c3">1</td><td class="c3"><span title="0.0%">4µs</span></td><td class="c3"><span title="0.0%">4µ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">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 9µs within Moose::BEGIN@2 which was called:
+# once (9µ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µs">5µ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 26µs">26µs</span></td><td class="c3">1</td><td class="c3">9µs</td><td class="s">}<div class="calls"><div class="calls_out"># spent 9µ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 750ns">2µ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 12µs">24µs</span></td><td class="c3">2</td><td class="c3">17µs</td><td class="s"><div class="calls"><div class="calls_in"># spent 14µs (11+3) within Moose::BEGIN@8 which was called:
+# once (11µs+3µ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 14µs making 1 call to <a href="Moose-pm-62-block.html#8">Moose::BEGIN@8</a>
+# spent 3µ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 12µs">24µs</span></td><td class="c3">2</td><td class="c3">27µs</td><td class="s"><div class="calls"><div class="calls_in"># spent 19µs (10+8) within Moose::BEGIN@9 which was called:
+# once (10µs+8µ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 19µs making 1 call to <a href="Moose-pm-62-block.html#9">Moose::BEGIN@9</a>
+# spent 8µ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 33µs">67µs</span></td><td class="c3">1</td><td class="c3">38µs</td><td class="s"><div class="calls"><div class="calls_in"># spent 38µs within Moose::BEGIN@11 which was called:
+# once (38µ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 38µ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 52µs">103µs</span></td><td class="c3">2</td><td class="c3">884µs</td><td class="s"><div class="calls"><div class="calls_in"># spent 829µs (517+312) within Moose::BEGIN@13 which was called:
+# once (517µs+312µ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 829µs making 1 call to <a href="Moose-pm-62-block.html#13">Moose::BEGIN@13</a>
+# spent 55µ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 12µs">25µs</span></td><td class="c3">2</td><td class="c3">84µs</td><td class="s"><div class="calls"><div class="calls_in"># spent 46µs (8+38) within Moose::BEGIN@14 which was called:
+# once (8µs+38µ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 46µs making 1 call to <a href="Moose-pm-62-block.html#14">Moose::BEGIN@14</a>
+# spent 38µ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="c3"><span title="Avg 59µs">117µs</span></td><td class="c3">2</td><td class="c0">11.3ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 11.2ms (1.07+10.2) within Moose::BEGIN@15 which was called:
+# once (1.07ms+10.2ms) 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 11.2ms making 1 call to <a href="Moose-pm-62-block.html#15">Moose::BEGIN@15</a>
+# spent 40µ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 52µs">104µs</span></td><td class="c3">2</td><td class="c3">2.34ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 2.33ms (234µs+2.10) within Moose::BEGIN@18 which was called:
+# once (234µs+2.10ms) 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 2.33ms making 1 call to <a href="Moose-pm-62-block.html#18">Moose::BEGIN@18</a>
+# spent 7µ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 55µs">110µs</span></td><td class="c3">2</td><td class="c0">85.2ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 85.2ms (3.21+82.0) within Moose::BEGIN@19 which was called:
+# once (3.21ms+82.0ms) 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 85.2ms making 1 call to <a href="Moose-pm-62-block.html#19">Moose::BEGIN@19</a>
+# spent 19µ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 22µs">45µs</span></td><td class="c3">1</td><td class="c3">5µs</td><td class="s"><div class="calls"><div class="calls_in"># spent 5µs within Moose::BEGIN@21 which was called:
+# once (5µ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 5µ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 4µs within Moose::BEGIN@23 which was called:
+# once (4µ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 4µs">4µs</span></td><td></td><td></td><td class="s"> die "Class::MOP version $Moose::VERSION required--this is version $Class::MOP::VERSION"</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 && $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 19µs">19µs</span></td><td class="c3">1</td><td class="c3">4µs</td><td class="s">}<div class="calls"><div class="calls_out"># spent 4µ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="c3"><span title="Avg 70µs">141µs</span></td><td class="c3">1</td><td class="c0">20.7ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 20.7ms (4.01+16.7) within Moose::BEGIN@28 which was called:
+# once (4.01ms+16.7ms) 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 20.7ms 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="c1"><span title="Avg 92µs">184µs</span></td><td class="c3">1</td><td class="c0">9.20ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 9.20ms (2.33+6.87) within Moose::BEGIN@29 which was called:
+# once (2.33ms+6.87ms) 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 9.20ms 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="c2"><span title="Avg 80µs">160µs</span></td><td class="c3">1</td><td class="c0">103ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 103ms (810µs+102) within Moose::BEGIN@30 which was called:
+# once (810µs+102ms) 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 103ms 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 11µs">22µs</span></td><td class="c3">1</td><td class="c3">6µs</td><td class="s"><div class="calls"><div class="calls_in"># spent 6µs within Moose::BEGIN@31 which was called:
+# once (6µ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 6µ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="c2"><span title="Avg 72µs">144µs</span></td><td class="c3">1</td><td class="c3">1.58ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 1.58ms (267µs+1.31) within Moose::BEGIN@32 which was called:
+# once (267µs+1.31ms) 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 1.58ms 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="c3"><span title="Avg 56µs">111µs</span></td><td class="c3">1</td><td class="c1">3.74ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 3.74ms (946µs+2.79) within Moose::BEGIN@34 which was called:
+# once (946µs+2.79ms) 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 3.74ms 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="c3"><span title="Avg 65µs">130µs</span></td><td class="c3">1</td><td class="c0">17.7ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 17.7ms (3.70+14.0) within Moose::BEGIN@36 which was called:
+# once (3.70ms+14.0ms) 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 17.7ms 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 88µs">176µs</span></td><td class="c3">1</td><td class="c2">2.83ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 2.83ms (936µs+1.89) within Moose::BEGIN@37 which was called:
+# once (936µs+1.89ms) 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 2.83ms 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="c3"><span title="Avg 66µs">132µs</span></td><td class="c3">1</td><td class="c3">2.00ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 2.00ms (700µs+1.30) within Moose::BEGIN@38 which was called:
+# once (700µs+1.30ms) 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 2.00ms 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="c3"><span title="Avg 57µs">114µs</span></td><td class="c3">1</td><td class="c2">2.58ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 2.58ms (1.49+1.09) within Moose::BEGIN@39 which was called:
+# once (1.49ms+1.09ms) 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 2.58ms 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 63µs">125µs</span></td><td class="c3">1</td><td class="c2">3.04ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 3.04ms (1.25+1.78) within Moose::BEGIN@40 which was called:
+# once (1.25ms+1.78ms) 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 3.04ms 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 72µs">144µs</span></td><td class="c3">1</td><td class="c3">1.69ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 1.69ms (986µs+702µs) within Moose::BEGIN@41 which was called:
+# once (986µs+702µs) 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 1.69ms 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="c3"><span title="Avg 55µs">110µs</span></td><td class="c3">1</td><td class="c3">1.52ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 1.52ms (460µs+1.05) within Moose::BEGIN@42 which was called:
+# once (460µs+1.05ms) 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 1.52ms 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 16µs">33µs</span></td><td class="c3">2</td><td class="c2">3.31ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 1.66ms (10µs+1.65) within Moose::BEGIN@44 which was called:
+# once (10µs+1.65ms) 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 1.66ms making 1 call to <a href="Moose-pm-62-block.html#44">Moose::BEGIN@44</a>
+# spent 1.65ms 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 11µs">22µs</span></td><td class="c3">1</td><td class="c3">5µs</td><td class="s"><div class="calls"><div class="calls_in"># spent 5µs within Moose::BEGIN@45 which was called:
+# once (5µ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 5µ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 674µs">1.35ms</span></td><td class="c3">1</td><td class="c3">2.08ms</td><td class="s"><div class="calls"><div class="calls_in"># spent 2.08ms (468µs+1.62) within Moose::BEGIN@47 which was called:
+# once (468µs+1.62ms) 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 2.08ms 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 \&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.00s (544µs+2.00) within Moose::extends which was called 70 times, avg 28.6ms/call:
+# 35 times (217µs+996ms) by Moose::extends at <a href="Moose-Exporter-pm-82-block.html#382">line 382 of Moose/Exporter.pm</a>, avg 28.5ms/call
+# once (12µs+758ms) 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 (9µs+96.8ms) by Catalyst::Controller::BEGIN@8 at <a href="Catalyst-Controller-pm-576-block.html#8">line 8 of Catalyst/Controller.pm</a>
+# once (10µs+50.4ms) 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µs+22.0ms) 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µs+10.1ms) 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 (11µs+9.83ms) 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µs+9.56ms) 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 (13µs+7.02ms) by Catalyst::BEGIN@32 at <a href="Catalyst-EngineLoader-pm-643-block.html#7">line 7 of Catalyst/EngineLoader.pm</a>
+# once (8µs+6.90ms) 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µs+6.25ms) 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 (9µs+5.63ms) 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 (9µs+5.29ms) 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 (10µs+1.02ms) 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µs+1.00ms) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#5">line 5 of Catalyst.pm</a>
+# once (9µs+980µ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 (9µs+977µs) by main::BEGIN@9 at <a href="lib-stemmaweb-pm-61-block.html#25">line 25 of lib/stemmaweb.pm</a>
+# once (11µs+970µ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 (10µs+965µs) 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 (10µs+941µs) by KiokuDB::BEGIN@11 at <a href="KiokuDB-Collapser-pm-1524-block.html#26">line 26 of KiokuDB/Collapser.pm</a>
+# once (9µs+933µ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 (10µs+932µs) 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 (9µs+931µ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µs+905µ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>
+# once (9µs+898µ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 (8µs+883µ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 (9µs+849µs) 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 (9µs+849µs) by base::import at <a href="Catalyst-View-pm-2019-block.html#4">line 4 of Catalyst/View.pm</a>
+# once (8µs+833µs) by Module::Runtime::require_module at <a href="Catalyst-Model-pm-2058-block.html#4">line 4 of Catalyst/Model.pm</a>
+# once (8µs+822µs) 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µs+797µs) by Catalyst::Exception::BEGIN@63 at <a href="Catalyst-Exception-pm-384-block.html#64">line 64 of Catalyst/Exception.pm</a>
+# once (8µs+787µs) 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 (8µs+762µs) 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 (7µs+759µs) 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 (9µs+754µs) 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 (7µs+734µs) 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></div></div>sub extends {</td></tr>
+<tr><td class="h"><a name="56"></a>56</td><td class="c0">105</td><td class="c1"><span title="Avg 2µs">193µ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->throw_error("Must derive at least one class") 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">996ms</td><td class="s"> $meta->superclasses(@_);<div class="calls"><div class="calls_out"> # spent 1.01s making 35 calls to <a href="Moose-Meta-Class-pm-136-block.html#549">Moose::Meta::Class::superclasses</a>, avg 28.8ms/call, recursion: max depth 2, sum of overlapping time 11.3ms</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.36s (870µs+2.35) within Moose::with which was called 114 times, avg 20.7ms/call:
+# 57 times (290µs+1.10s) by Moose::with at <a href="Moose-Exporter-pm-82-block.html#382">line 382 of Moose/Exporter.pm</a>, avg 19.3ms/call
+# once (10µ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 (10µs+171ms) by Catalyst::BEGIN@8 at <a href="Catalyst-Exception-pm-384-block.html#50">line 50 of Catalyst/Exception.pm</a>
+# once (11µs+115ms) 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 (8µs+73.9ms) 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 (9µs+71.5ms) by KiokuDB::BEGIN@17 at <a href="KiokuDB-Stream-Objects-pm-1765-block.html#56">line 56 of KiokuDB/Stream/Objects.pm</a>
+# once (9µs+51.7ms) 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 (12µs+43.4ms) 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 (10µs+38.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µs+34.4ms) 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 (9µs+31.6ms) 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 (10µs+25.4ms) 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 (10µs+25.0ms) 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 (9µs+23.3ms) 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 (8µs+16.5ms) 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 (9µs+14.1ms) by Catalyst::BEGIN@11 at <a href="Catalyst-Log-pm-469-block.html#4">line 4 of Catalyst/Log.pm</a>
+# once (10µs+12.5ms) 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µs+12.4ms) 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 (9µs+12.2ms) by KiokuDB::BEGIN@11 at <a href="KiokuDB-Collapser-pm-1524-block.html#28">line 28 of KiokuDB/Collapser.pm</a>
+# once (10µs+12.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 (10µs+11.6ms) 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 (13µs+10.9ms) 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 (15µs+9.05ms) by Text::Tradition::Directory::BEGIN@9 at <a href="KiokuDB-TypeMap-pm-1440-block.html#14">line 14 of KiokuDB/TypeMap.pm</a>
+# once (18µs+8.91ms) by Catalyst::BEGIN@16 at <a href="Catalyst-Controller-pm-576-block.html#14">line 14 of Catalyst/Controller.pm</a>
+# once (10µs+8.43ms) 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 (10µs+8.19ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#248">line 248 of KiokuDB.pm</a>
+# once (15µs+7.99ms) 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 (11µs+7.98ms) 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 (12µs+7.95ms) by Module::Runtime::require_module at <a href="Catalyst-Component-pm-579-block.html#15">line 15 of Catalyst/Component.pm</a>
+# once (10µs+7.71ms) 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 (8µs+6.75ms) by Catalyst::BEGIN@9 at <a href="Catalyst-Exception-Detach-pm-455-block.html#6">line 6 of Catalyst/Exception/Detach.pm</a>
+# once (9µs+6.64ms) by Catalyst::BEGIN@10 at <a href="Catalyst-Exception-Go-pm-462-block.html#6">line 6 of Catalyst/Exception/Go.pm</a>
+# once (12µs+6.35ms) 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 (10µs+6.28ms) 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 (13µs+5.19ms) 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 (9µs+4.81ms) 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µs+4.55ms) 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 (13µs+4.49ms) by Catalyst::BEGIN@13 at <a href="Catalyst-Request-Upload-pm-537-block.html#4">line 4 of Catalyst/Request/Upload.pm</a>
+# once (9µs+2.99ms) 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 (10µs+2.98ms) 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 (12µs+2.68ms) by Module::Runtime::require_module at <a href="Catalyst-Component-pm-579-block.html#14">line 14 of Catalyst/Component.pm</a>
+# once (8µs+2.57ms) by Catalyst::Dispatcher::BEGIN@9 at <a href="Catalyst-Action-pm-1880-block.html#24">line 24 of Catalyst/Action.pm</a>
+# once (10µs+2.55ms) by Module::Runtime::require_module at <a href="Catalyst-Engine-pm-1927-block.html#4">line 4 of Catalyst/Engine.pm</a>
+# once (10µs+2.54ms) by Catalyst::BEGIN@14 at <a href="Catalyst-Response-pm-553-block.html#8">line 8 of Catalyst/Response.pm</a>
+# once (10µs+2.52ms) by Catalyst::Dispatcher::BEGIN@10 at <a href="Catalyst-ActionContainer-pm-1892-block.html#19">line 19 of Catalyst/ActionContainer.pm</a>
+# once (8µs+2.34ms) by Module::Runtime::require_module at <a href="Catalyst-Dispatcher-pm-1877-block.html#5">line 5 of Catalyst/Dispatcher.pm</a>
+# once (9µs+2.26ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#15">line 15 of Catalyst/Request.pm</a>
+# once (8µs+2.25ms) by Module::Runtime::require_module at <a href="Catalyst-DispatchType-pm-1902-block.html#4">line 4 of Catalyst/DispatchType.pm</a>
+# once (9µs+2.18ms) 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µs+1.59ms) 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 (8µs+1.50ms) 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 (14µs+1.35ms) 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 (10µs+1.22ms) 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 (9µs+861µs) by KiokuDB::Collapser::BEGIN@16 at <a href="KiokuDB-Reference-pm-1599-block.html#8">line 8 of KiokuDB/Reference.pm</a>
+# once (9µs+774µ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 (10µs+679µs) 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 (9µs+662µ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>
+# once (9µs+662µ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></div></div>sub with {</td></tr>
+<tr><td class="h"><a name="67"></a>67</td><td class="c0">57</td><td class="c0"><span title="Avg 5µs">298µs</span></td><td class="c0">57</td><td class="c0">1.09s</td><td class="s"> Moose::Util::apply_all_roles(shift, @_);<div class="calls"><div class="calls_out"> # spent 1.25s making 57 calls to <a href="Moose-Util-pm-158-block.html#97">Moose::Util::apply_all_roles</a>, avg 22.0ms/call, recursion: max depth 3, sum of overlapping time 166ms</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 3.14s (10.3ms+3.13) within Moose::has which was called 754 times, avg 4.17ms/call:
+# 377 times (7.12ms+1.56s) by Moose::has at <a href="Moose-Exporter-pm-82-block.html#382">line 382 of Moose/Exporter.pm</a>, avg 4.16ms/call
+# 2 times (16µ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.01ms/call
+# once (10µs+166ms) 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 (9µs+95.1ms) 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 (9µs+54.4ms) 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 (10µs+52.1ms) 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 (12µs+27.4ms) by main::BEGIN@10 at <a href="lib-Text-Tradition-pm-673-block.html#55">line 55 of lib/Text/Tradition.pm</a>
+# once (8µs+18.8ms) 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 (9µs+12.7ms) by main::BEGIN@10 at <a href="lib-Text-Tradition-pm-673-block.html#30">line 30 of lib/Text/Tradition.pm</a>
+# once (11µs+10.2ms) 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 (8µs+10.1ms) 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 (8µs+9.74ms) by Module::Runtime::require_module at <a href="KiokuX-Model-pm-1511-block.html#36">line 36 of KiokuX/Model.pm</a>
+# once (9µs+9.61ms) 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 (9µs+9.60ms) 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 (12µs+9.06ms) 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 (17µs+8.40ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#100">line 100 of KiokuDB/Entry.pm</a>
+# once (9µs+7.98ms) 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 (9µs+7.91ms) 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µs+7.80ms) 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 (10µs+7.78ms) by Text::Tradition::Directory::BEGIN@9 at <a href="KiokuDB-TypeMap-pm-1440-block.html#16">line 16 of KiokuDB/TypeMap.pm</a>
+# once (9µs+7.71ms) 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µs+7.44ms) 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 (24µs+7.15ms) by Catalyst::BEGIN@14 at <a href="Catalyst-Response-pm-553-block.html#43">line 43 of Catalyst/Response.pm</a>
+# once (8µs+7.14ms) by Text::Tradition::Directory::BEGIN@9 at <a href="KiokuDB-TypeMap-pm-1440-block.html#25">line 25 of KiokuDB/TypeMap.pm</a>
+# once (13µs+6.95ms) 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 (10µs+6.85ms) by Catalyst::BEGIN@14 at <a href="Catalyst-Response-pm-553-block.html#21">line 21 of Catalyst/Response.pm</a>
+# once (8µs+6.73ms) 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 (8µs+6.52ms) 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 (12µs+6.48ms) 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µs+6.35ms) by Catalyst::BEGIN@14 at <a href="Catalyst-Response-pm-553-block.html#10">line 10 of Catalyst/Response.pm</a>
+# once (20µs+6.06ms) 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 (8µs+5.93ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#154">line 154 of KiokuDB.pm</a>
+# once (8µs+5.93ms) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#65">line 65 of Parse/Method/Signatures.pm</a>
+# once (14µs+5.81ms) 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 (12µs+5.77ms) 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µs+5.63ms) 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 (9µs+5.59ms) 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 (9µs+5.59ms) 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 (10µs+5.50ms) 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µs+5.48ms) 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 (9µs+5.37ms) 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 (8µs+5.37ms) 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 (9µs+5.27ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#12">line 12 of KiokuDB/Entry.pm</a>
+# once (11µs+5.22ms) by Catalyst::BEGIN@13 at <a href="Catalyst-Request-Upload-pm-537-block.html#17">line 17 of Catalyst/Request/Upload.pm</a>
+# once (9µs+5.22ms) 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 (9µs+5.20ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#172">line 172 of KiokuDB/Entry.pm</a>
+# once (11µs+5.14ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#129">line 129 of KiokuDB/Entry.pm</a>
+# once (12µs+5.11ms) 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 (8µs+5.11ms) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#79">line 79 of Parse/Method/Signatures.pm</a>
+# once (8µs+5.08ms) 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 (8µs+4.99ms) by KiokuDB::BEGIN@13 at <a href="KiokuDB-LiveObjects-pm-1680-block.html#49">line 49 of KiokuDB/LiveObjects.pm</a>
+# once (8µs+4.94ms) 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 (9µs+4.92ms) 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 (8µs+4.89ms) 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 (8µs+4.89ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#65">line 65 of Catalyst/Request.pm</a>
+# once (13µs+4.81ms) 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 (9µs+4.71ms) by Module::Runtime::require_module at <a href="KiokuX-Model-pm-1511-block.html#48">line 48 of KiokuX/Model.pm</a>
+# once (10µs+4.67ms) 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 (10µs+4.66ms) by Catalyst::BEGIN@16 at <a href="Catalyst-Controller-pm-576-block.html#24">line 24 of Catalyst/Controller.pm</a>
+# once (11µs+4.64ms) 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 (10µs+4.63ms) 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µs+4.64ms) 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 (8µs+4.63ms) by KiokuDB::BEGIN@17 at <a href="KiokuDB-Stream-Objects-pm-1765-block.html#33">line 33 of KiokuDB/Stream/Objects.pm</a>
+# once (9µs+4.52ms) 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 (13µs+4.51ms) 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 (11µs+4.51ms) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#35">line 35 of Parse/Method/Signatures.pm</a>
+# once (9µs+4.51ms) 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µs+4.47ms) by Text::Tradition::Directory::BEGIN@9 at <a href="KiokuDB-TypeMap-pm-1440-block.html#31">line 31 of KiokuDB/TypeMap.pm</a>
+# once (9µs+4.44ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#156">line 156 of KiokuDB.pm</a>
+# once (6µs+4.36ms) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#59">line 59 of Parse/Method/Signatures.pm</a>
+# once (8µs+4.34ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#194">line 194 of KiokuDB.pm</a>
+# once (7µs+4.32ms) 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 (10µs+4.31ms) 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 (8µs+4.29ms) 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µs+4.25ms) 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 (9µs+4.25ms) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#71">line 71 of Parse/Method/Signatures.pm</a>
+# once (9µs+4.23ms) 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 (10µs+4.22ms) 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 (9µs+4.19ms) 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µs+4.18ms) 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 (8µs+4.17ms) 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 (10µs+4.15ms) 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 (7µs+4.15ms) 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 (7µs+4.13ms) 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 (8µs+4.12ms) 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µs+4.09ms) 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 (8µs+4.10ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#20">line 20 of KiokuDB/Entry.pm</a>
+# once (8µs+4.10ms) 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 (10µs+4.08ms) 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 (12µs+4.08ms) by Catalyst::BEGIN@32 at <a href="Catalyst-EngineLoader-pm-643-block.html#27">line 27 of Catalyst/EngineLoader.pm</a>
+# once (9µs+4.00ms) 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µs+3.99ms) 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 (8µs+3.98ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#174">line 174 of KiokuDB.pm</a>
+# once (8µs+3.97ms) 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 (8µs+3.97ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#79">line 79 of KiokuDB.pm</a>
+# once (10µs+3.96ms) 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 (9µs+3.94ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#55">line 55 of KiokuDB/Entry.pm</a>
+# once (10µs+3.94ms) 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 (6µs+3.93ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#223">line 223 of KiokuDB.pm</a>
+# once (11µs+3.92ms) by Catalyst::BEGIN@9 at <a href="Catalyst-Exception-Detach-pm-455-block.html#8">line 8 of Catalyst/Exception/Detach.pm</a>
+# once (8µs+3.89ms) 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 (7µs+3.86ms) by KiokuDB::BEGIN@13 at <a href="KiokuDB-LiveObjects-pm-1680-block.html#240">line 240 of KiokuDB/LiveObjects.pm</a>
+# once (11µs+3.86ms) by KiokuDB::BEGIN@13 at <a href="KiokuDB-LiveObjects-pm-1680-block.html#32">line 32 of KiokuDB/LiveObjects.pm</a>
+# once (8µs+3.82ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#48">line 48 of KiokuDB/Entry.pm</a>
+# once (7µs+3.82ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#62">line 62 of KiokuDB/Entry.pm</a>
+# once (10µs+3.82ms) 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µs+3.77ms) by KiokuDB::BEGIN@13 at <a href="KiokuDB-LiveObjects-pm-1680-block.html#155">line 155 of KiokuDB/LiveObjects.pm</a>
+# once (8µs+3.72ms) 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 (10µs+3.70ms) 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 (10µs+3.67ms) 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 (7µs+3.61ms) by KiokuDB::BEGIN@11 at <a href="KiokuDB-Collapser-pm-1524-block.html#61">line 61 of KiokuDB/Collapser.pm</a>
+# once (11µs+3.60ms) by Catalyst::BEGIN@16 at <a href="Catalyst-Controller-pm-576-block.html#16">line 16 of Catalyst/Controller.pm</a>
+# once (7µs+3.60ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#74">line 74 of KiokuDB.pm</a>
+# once (8µs+3.59ms) 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 (6µs+3.55ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#83">line 83 of KiokuDB/Entry.pm</a>
+# once (15µs+3.50ms) by Catalyst::BEGIN@13 at <a href="Catalyst-Request-Upload-pm-537-block.html#35">line 35 of Catalyst/Request/Upload.pm</a>
+# once (16µs+3.50ms) by Module::Runtime::require_module at <a href="Catalyst-Component-pm-579-block.html#75">line 75 of Catalyst/Component.pm</a>
+# once (7µs+3.51ms) 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 (11µs+3.49ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#25">line 25 of Catalyst/Request.pm</a>
+# once (9µs+3.45ms) 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 (8µs+3.44ms) 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 (8µs+3.43ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#71">line 71 of KiokuDB/Entry.pm</a>
+# once (11µs+3.39ms) by Module::Runtime::require_module at <a href="KiokuX-Model-pm-1511-block.html#24">line 24 of KiokuX/Model.pm</a>
+# once (10µs+3.39ms) by KiokuDB::BEGIN@11 at <a href="KiokuDB-Collapser-pm-1524-block.html#30">line 30 of KiokuDB/Collapser.pm</a>
+# once (9µs+3.38ms) 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 (7µs+3.38ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#290">line 290 of Catalyst/Request.pm</a>
+# once (9µs+3.36ms) by main::BEGIN@10 at <a href="lib-Text-Tradition-pm-673-block.html#13">line 13 of lib/Text/Tradition.pm</a>
+# once (7µs+3.30ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#268">line 268 of Catalyst/Request.pm</a>
+# once (10µs+3.28ms) 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 (11µs+3.27ms) by Module::Runtime::require_module at <a href="KiokuX-Model-pm-1511-block.html#30">line 30 of KiokuX/Model.pm</a>
+# once (9µs+3.27ms) by KiokuDB::BEGIN@12 at <a href="KiokuDB-Linker-pm-1662-block.html#22">line 22 of KiokuDB/Linker.pm</a>
+# once (11µs+3.26ms) 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 (8µs+3.25ms) 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 (9µs+3.24ms) 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µs+3.24ms) by Catalyst::BEGIN@10 at <a href="Catalyst-Exception-Go-pm-462-block.html#8">line 8 of Catalyst/Exception/Go.pm</a>
+# once (8µs+3.24ms) 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µs+3.20ms) by KiokuDB::BEGIN@15 at <a href="KiokuDB-TypeMap-Shadow-pm-1723-block.html#10">line 10 of KiokuDB/TypeMap/Shadow.pm</a>
+# once (12µs+3.19ms) 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 (7µs+3.19ms) 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 (10µs+3.17ms) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#29">line 29 of Parse/Method/Signatures.pm</a>
+# once (8µs+3.16ms) 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 (8µs+3.16ms) 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 (8µs+3.12ms) 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 (7µs+3.11ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#42">line 42 of KiokuDB/Entry.pm</a>
+# once (9µs+3.08ms) by KiokuDB::BEGIN@17 at <a href="KiokuDB-Stream-Objects-pm-1765-block.html#45">line 45 of KiokuDB/Stream/Objects.pm</a>
+# once (10µs+3.03ms) 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 (12µs+3.02ms) by Catalyst::BEGIN@13 at <a href="Catalyst-Request-Upload-pm-537-block.html#15">line 15 of Catalyst/Request/Upload.pm</a>
+# once (10µs+3.01ms) 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 (7µs+3.00ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#77">line 77 of KiokuDB/Entry.pm</a>
+# once (8µs+2.98ms) 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 (7µs+2.97ms) by KiokuDB::BEGIN@11 at <a href="KiokuDB-Collapser-pm-1524-block.html#57">line 57 of KiokuDB/Collapser.pm</a>
+# once (10µs+2.96ms) 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 (8µs+2.94ms) 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 (10µs+2.93ms) 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µs+2.93ms) by main::BEGIN@10 at <a href="lib-Text-Tradition-pm-673-block.html#38">line 38 of lib/Text/Tradition.pm</a>
+# once (7µs+2.93ms) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#47">line 47 of Parse/Method/Signatures.pm</a>
+# once (8µs+2.93ms) 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 (10µs+2.91ms) 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 (14µs+2.91ms) by Catalyst::BEGIN@14 at <a href="Catalyst-Response-pm-553-block.html#32">line 32 of Catalyst/Response.pm</a>
+# once (7µs+2.90ms) 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 (8µs+2.87ms) 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 (9µs+2.86ms) 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 (10µs+2.85ms) 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 (10µs+2.84ms) by Catalyst::BEGIN@32 at <a href="Catalyst-EngineLoader-pm-643-block.html#15">line 15 of Catalyst/EngineLoader.pm</a>
+# once (8µs+2.83ms) by Module::Runtime::require_module at <a href="Catalyst-Engine-pm-1927-block.html#24">line 24 of Catalyst/Engine.pm</a>
+# once (7µs+2.81ms) by KiokuDB::Collapser::BEGIN@14 at <a href="KiokuDB-Entry-pm-1529-block.html#36">line 36 of KiokuDB/Entry.pm</a>
+# once (15µs+2.79ms) by Catalyst::BEGIN@13 at <a href="Catalyst-Request-Upload-pm-537-block.html#12">line 12 of Catalyst/Request/Upload.pm</a>
+# once (7µs+2.80ms) by KiokuDB::BEGIN@11 at <a href="KiokuDB-Collapser-pm-1524-block.html#44">line 44 of KiokuDB/Collapser.pm</a>
+# once (7µs+2.73ms) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#53">line 53 of Parse/Method/Signatures.pm</a>
+# once (7µs+2.72ms) 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 (8µs+2.71ms) 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 (7µs+2.71ms) 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 (10µs+2.69ms) 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 (7µs+2.68ms) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#41">line 41 of Parse/Method/Signatures.pm</a>
+# once (10µs+2.68ms) 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 (6µs+2.64ms) 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 (8µs+2.63ms) 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 (7µs+2.63ms) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#1987">line 1987 of Catalyst.pm</a>
+# once (8µs+2.62ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#17">line 17 of Catalyst/Request.pm</a>
+# once (9µs+2.61ms) 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µs+2.60ms) 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 (10µs+2.54ms) by Catalyst::Dispatcher::BEGIN@10 at <a href="Catalyst-ActionContainer-pm-1892-block.html#21">line 21 of Catalyst/ActionContainer.pm</a>
+# once (9µs+2.52ms) 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 (10µs+2.50ms) by KiokuDB::BEGIN@17 at <a href="KiokuDB-Stream-Objects-pm-1765-block.html#8">line 8 of KiokuDB/Stream/Objects.pm</a>
+# once (7µs+2.49ms) 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µs+2.48ms) by Catalyst::BEGIN@13 at <a href="Catalyst-Request-Upload-pm-537-block.html#14">line 14 of Catalyst/Request/Upload.pm</a>
+# once (7µs+2.48ms) 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 (9µs+2.46ms) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#44">line 44 of Catalyst.pm</a>
+# once (6µs+2.47ms) 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 (7µs+2.46ms) 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 (9µs+2.46ms) 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µs+2.46ms) 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 (11µs+2.45ms) 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 (8µs+2.45ms) 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 (8µs+2.45ms) 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 (7µs+2.43ms) 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 (9µs+2.42ms) 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 (9µs+2.42ms) 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 (8µs+2.41ms) by KiokuDB::Collapser::BEGIN@16 at <a href="KiokuDB-Reference-pm-1599-block.html#10">line 10 of KiokuDB/Reference.pm</a>
+# once (6µs+2.42ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#63">line 63 of Catalyst/Request.pm</a>
+# once (9µs+2.40ms) 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µs+2.39ms) 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 (6µs+2.38ms) 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µs+2.37ms) 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 (8µs+2.36ms) by KiokuDB::BEGIN@13 at <a href="KiokuDB-LiveObjects-pm-1680-block.html#27">line 27 of KiokuDB/LiveObjects.pm</a>
+# once (7µs+2.37ms) 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 (8µs+2.36ms) 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 (8µs+2.36ms) by KiokuDB::Collapser::BEGIN@16 at <a href="KiokuDB-Reference-pm-1599-block.html#16">line 16 of KiokuDB/Reference.pm</a>
+# once (14µs+2.33ms) 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 (10µs+2.32ms) by KiokuDB::BEGIN@13 at <a href="KiokuDB-LiveObjects-pm-1680-block.html#22">line 22 of KiokuDB/LiveObjects.pm</a>
+# once (12µs+2.32ms) 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 (6µs+2.32ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#178">line 178 of Catalyst/Request.pm</a>
+# once (10µs+2.32ms) 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 (9µs+2.31ms) by main::BEGIN@10 at <a href="lib-Text-Tradition-pm-673-block.html#32">line 32 of lib/Text/Tradition.pm</a>
+# once (14µs+2.30ms) by Catalyst::Dispatcher::BEGIN@10 at <a href="Catalyst-ActionContainer-pm-1892-block.html#22">line 22 of Catalyst/ActionContainer.pm</a>
+# once (8µs+2.28ms) 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 (8µs+2.27ms) 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µs+2.27ms) by KiokuDB::Collapser::BEGIN@20 at <a href="Data-Visitor-pm-1636-block.html#27">line 27 of Data/Visitor.pm</a>
+# once (9µs+2.27ms) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#43">line 43 of Catalyst.pm</a>
+# once (8µs+2.26ms) by KiokuDB::BEGIN@17 at <a href="KiokuDB-Stream-Objects-pm-1765-block.html#14">line 14 of KiokuDB/Stream/Objects.pm</a>
+# once (9µs+2.26ms) 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 (9µs+2.24ms) by Catalyst::BEGIN@16 at <a href="Catalyst-Controller-pm-576-block.html#32">line 32 of Catalyst/Controller.pm</a>
+# once (8µs+2.24ms) 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 (10µs+2.23ms) 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 (8µs+2.23ms) 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 (8µs+2.23ms) by Catalyst::BEGIN@16 at <a href="Catalyst-Controller-pm-576-block.html#40">line 40 of Catalyst/Controller.pm</a>
+# once (7µs+2.23ms) by Catalyst::Dispatcher::BEGIN@9 at <a href="Catalyst-Action-pm-1880-block.html#39">line 39 of Catalyst/Action.pm</a>
+# once (10µs+2.22ms) 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 (10µs+2.20ms) by Module::Runtime::require_module at <a href="KiokuX-Model-pm-1511-block.html#19">line 19 of KiokuX/Model.pm</a>
+# once (9µs+2.14ms) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#65">line 65 of Catalyst.pm</a>
+# once (15µs+2.14ms) by Catalyst::BEGIN@14 at <a href="Catalyst-Response-pm-553-block.html#37">line 37 of Catalyst/Response.pm</a>
+# once (9µs+2.14ms) 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 (11µs+2.13ms) 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 (7µs+2.13ms) 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 (7µs+2.12ms) 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 (11µs+2.11ms) by Catalyst::BEGIN@32 at <a href="Catalyst-EngineLoader-pm-643-block.html#9">line 9 of Catalyst/EngineLoader.pm</a>
+# once (8µs+2.11ms) 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 (6µs+2.10ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#69">line 69 of KiokuDB.pm</a>
+# once (8µs+2.10ms) 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 (6µs+2.10ms) 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 (7µs+2.09ms) 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µs+2.08ms) by Catalyst::BEGIN@13 at <a href="Catalyst-Request-Upload-pm-537-block.html#13">line 13 of Catalyst/Request/Upload.pm</a>
+# once (7µs+2.08ms) 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 (7µs+2.08ms) 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µs+2.06ms) 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 (8µs+2.06ms) 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 (7µs+2.06ms) 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 (7µs+2.05ms) by Catalyst::Utils::ensure_class_loaded at <a href="Catalyst-Stats-pm-1947-block.html#17">line 17 of Catalyst/Stats.pm</a>
+# once (11µs+2.04ms) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#67">line 67 of Catalyst.pm</a>
+# once (10µs+2.04ms) by Catalyst::Utils::ensure_class_loaded at <a href="Catalyst-Stats-pm-1947-block.html#12">line 12 of Catalyst/Stats.pm</a>
+# once (9µs+2.03ms) 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 (7µs+2.04ms) 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 (6µs+2.03ms) by KiokuDB::BEGIN@12 at <a href="KiokuDB-Linker-pm-1662-block.html#35">line 35 of KiokuDB/Linker.pm</a>
+# once (8µs+2.03ms) by KiokuDB::BEGIN@11 at <a href="KiokuDB-Collapser-pm-1524-block.html#51">line 51 of KiokuDB/Collapser.pm</a>
+# once (9µs+2.03ms) 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 (8µs+2.02ms) 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 (10µs+2.01ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#64">line 64 of KiokuDB.pm</a>
+# once (7µs+2.01ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#45">line 45 of Catalyst/Request.pm</a>
+# once (7µs+2.00ms) 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 (9µs+2.00ms) by KiokuDB::BEGIN@16 at <a href="KiokuDB-TypeMap-Resolver-pm-1730-block.html#13">line 13 of KiokuDB/TypeMap/Resolver.pm</a>
+# once (8µs+2.00ms) by KiokuDB::BEGIN@13 at <a href="KiokuDB-LiveObjects-pm-1680-block.html#38">line 38 of KiokuDB/LiveObjects.pm</a>
+# once (8µs+1.99ms) 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 (6µs+1.99ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#128">line 128 of Catalyst/Request.pm</a>
+# once (10µs+1.99ms) by Module::Runtime::require_module at <a href="Catalyst-Dispatcher-pm-1877-block.html#33">line 33 of Catalyst/Dispatcher.pm</a>
+# once (7µs+1.99ms) 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 (7µs+1.98ms) 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 (9µs+1.97ms) by KiokuDB::BEGIN@12 at <a href="KiokuDB-Linker-pm-1662-block.html#52">line 52 of KiokuDB/Linker.pm</a>
+# once (8µs+1.97ms) by Module::Runtime::require_module at <a href="Catalyst-Dispatcher-pm-1877-block.html#32">line 32 of Catalyst/Dispatcher.pm</a>
+# once (8µs+1.97ms) 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 (8µs+1.97ms) 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 (8µs+1.96ms) by KiokuDB::BEGIN@12 at <a href="KiokuDB-Linker-pm-1662-block.html#42">line 42 of KiokuDB/Linker.pm</a>
+# once (17µs+1.95ms) by KiokuDB::BEGIN@17 at <a href="KiokuDB-Stream-Objects-pm-1765-block.html#51">line 51 of KiokuDB/Stream/Objects.pm</a>
+# once (7µs+1.96ms) 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 (8µs+1.95ms) 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 (7µs+1.95ms) by KiokuDB::Collapser::BEGIN@20 at <a href="Data-Visitor-pm-1636-block.html#33">line 33 of Data/Visitor.pm</a>
+# once (6µs+1.95ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#139">line 139 of Catalyst/Request.pm</a>
+# once (8µs+1.94ms) 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 (7µs+1.94ms) 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 (7µs+1.94ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#266">line 266 of Catalyst/Request.pm</a>
+# once (9µs+1.93ms) 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 (7µs+1.93ms) 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 (7µs+1.93ms) by KiokuDB::BEGIN@13 at <a href="KiokuDB-LiveObjects-pm-1680-block.html#167">line 167 of KiokuDB/LiveObjects.pm</a>
+# once (9µs+1.92ms) by Catalyst::BEGIN@14 at <a href="Catalyst-Response-pm-553-block.html#35">line 35 of Catalyst/Response.pm</a>
+# once (10µs+1.92ms) 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 (8µs+1.91ms) 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 (6µs+1.90ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#288">line 288 of Catalyst/Request.pm</a>
+# once (8µs+1.89ms) 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 (10µs+1.89ms) 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µs+1.88ms) 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 (8µs+1.88ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#210">line 210 of KiokuDB.pm</a>
+# once (8µs+1.88ms) by Catalyst::Dispatcher::BEGIN@9 at <a href="Catalyst-Action-pm-1880-block.html#27">line 27 of Catalyst/Action.pm</a>
+# once (6µs+1.87ms) 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 (6µs+1.87ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#141">line 141 of Catalyst/Request.pm</a>
+# once (10µs+1.86ms) by Catalyst::BEGIN@14 at <a href="Catalyst-Response-pm-553-block.html#36">line 36 of Catalyst/Response.pm</a>
+# once (6µs+1.86ms) 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 (7µs+1.86ms) 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µs+1.86ms) by Catalyst::BEGIN@11 at <a href="Catalyst-Log-pm-469-block.html#13">line 13 of Catalyst/Log.pm</a>
+# once (8µs+1.86ms) by KiokuDB::BEGIN@11 at <a href="KiokuDB-Collapser-pm-1524-block.html#32">line 32 of KiokuDB/Collapser.pm</a>
+# once (7µs+1.85ms) 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 (6µs+1.85ms) 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 (6µs+1.85ms) 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 (6µs+1.84ms) by Module::Runtime::require_module at <a href="Catalyst-Dispatcher-pm-1877-block.html#36">line 36 of Catalyst/Dispatcher.pm</a>
+# once (8µs+1.84ms) 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 (9µs+1.83ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#144">line 144 of KiokuDB.pm</a>
+# once (7µs+1.83ms) by KiokuDB::BEGIN@13 at <a href="KiokuDB-LiveObjects-pm-1680-block.html#57">line 57 of KiokuDB/LiveObjects.pm</a>
+# once (7µs+1.81ms) 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 (7µs+1.80ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#58">line 58 of Catalyst/Request.pm</a>
+# once (8µs+1.80ms) 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µs+1.80ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#88">line 88 of Catalyst/Request.pm</a>
+# once (9µs+1.79ms) 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 (10µs+1.79ms) by Catalyst::BEGIN@14 at <a href="Catalyst-Response-pm-553-block.html#31">line 31 of Catalyst/Response.pm</a>
+# once (7µs+1.79ms) 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µs+1.79ms) 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 (7µs+1.79ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#40">line 40 of Catalyst/Request.pm</a>
+# once (8µs+1.76ms) 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 (9µs+1.76ms) 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µs+1.75ms) 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 (8µs+1.75ms) by Module::Runtime::require_module at <a href="Catalyst-Dispatcher-pm-1877-block.html#31">line 31 of Catalyst/Dispatcher.pm</a>
+# once (6µs+1.75ms) by KiokuDB::BEGIN@12 at <a href="KiokuDB-Linker-pm-1662-block.html#29">line 29 of KiokuDB/Linker.pm</a>
+# once (9µs+1.74ms) 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 (7µs+1.74ms) 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 (7µs+1.73ms) 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 (6µs+1.73ms) by KiokuDB::BEGIN@16 at <a href="KiokuDB-TypeMap-Resolver-pm-1730-block.html#28">line 28 of KiokuDB/TypeMap/Resolver.pm</a>
+# once (7µs+1.73ms) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#57">line 57 of Catalyst.pm</a>
+# once (7µs+1.72ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#64">line 64 of Catalyst/Request.pm</a>
+# once (8µs+1.71ms) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#46">line 46 of Catalyst.pm</a>
+# once (7µs+1.71ms) 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 (7µs+1.71ms) 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 (7µs+1.71ms) by KiokuDB::BEGIN@16 at <a href="KiokuDB-TypeMap-Resolver-pm-1730-block.html#22">line 22 of KiokuDB/TypeMap/Resolver.pm</a>
+# once (6µs+1.71ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#57">line 57 of Catalyst/Request.pm</a>
+# once (7µs+1.70ms) 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 (6µs+1.70ms) by Module::Runtime::require_module at <a href="Catalyst-Dispatcher-pm-1877-block.html#35">line 35 of Catalyst/Dispatcher.pm</a>
+# once (6µs+1.70ms) by KiokuDB::BEGIN@11 at <a href="KiokuDB-Collapser-pm-1524-block.html#38">line 38 of KiokuDB/Collapser.pm</a>
+# once (8µs+1.70ms) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#45">line 45 of Catalyst.pm</a>
+# once (7µs+1.70ms) by Catalyst::Dispatcher::BEGIN@9 at <a href="Catalyst-Action-pm-1880-block.html#29">line 29 of Catalyst/Action.pm</a>
+# once (6µs+1.70ms) by KiokuX::Model::BEGIN@7 at <a href="KiokuDB-pm-1519-block.html#217">line 217 of KiokuDB.pm</a>
+# once (6µs+1.69ms) 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 (6µs+1.69ms) 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 (6µs+1.69ms) by Catalyst::Utils::ensure_class_loaded at <a href="Catalyst-Stats-pm-1947-block.html#24">line 24 of Catalyst/Stats.pm</a>
+# once (6µs+1.68ms) 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 (6µs+1.67ms) 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 (7µs+1.66ms) 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 (6µs+1.66ms) 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 (7µs+1.66ms) by KiokuDB::BEGIN@12 at <a href="KiokuDB-Linker-pm-1662-block.html#58">line 58 of KiokuDB/Linker.pm</a>
+# once (7µs+1.65ms) 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 (7µs+1.64ms) 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 (7µs+1.63ms) 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 (6µs+1.63ms) 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 (6µs+1.63ms) 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 (6µs+1.63ms) 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 (6µs+1.62ms) 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 (6µs+1.62ms) 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 (6µs+1.62ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#43">line 43 of Catalyst/Request.pm</a>
+# once (6µs+1.62ms) 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 (6µs+1.62ms) 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 (6µs+1.61ms) 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µs+1.60ms) 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 (7µs+1.59ms) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#47">line 47 of Catalyst.pm</a>
+# once (6µs+1.59ms) 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 (7µs+1.59ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#56">line 56 of Catalyst/Request.pm</a>
+# once (6µs+1.59ms) 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 (6µs+1.56ms) by Catalyst::Dispatcher::BEGIN@9 at <a href="Catalyst-Action-pm-1880-block.html#28">line 28 of Catalyst/Action.pm</a>
+# once (6µs+1.56ms) by Catalyst::Dispatcher::BEGIN@9 at <a href="Catalyst-Action-pm-1880-block.html#32">line 32 of Catalyst/Action.pm</a>
+# once (7µs+1.54ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#22">line 22 of Catalyst/Request.pm</a>
+# once (6µs+1.53ms) by Catalyst::Dispatcher::BEGIN@9 at <a href="Catalyst-Action-pm-1880-block.html#31">line 31 of Catalyst/Action.pm</a>
+# once (7µs+1.53ms) by Catalyst::BEGIN@11 at <a href="Catalyst-Log-pm-469-block.html#14">line 14 of Catalyst/Log.pm</a>
+# once (6µs+1.50ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#60">line 60 of Catalyst/Request.pm</a>
+# once (7µs+1.49ms) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#850">line 850 of Parse/Method/Signatures.pm</a>
+# once (6µs+1.48ms) by Module::Runtime::require_module at <a href="Catalyst-Dispatcher-pm-1877-block.html#34">line 34 of Catalyst/Dispatcher.pm</a>
+# once (7µs+1.48ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#59">line 59 of Catalyst/Request.pm</a>
+# once (7µs+1.45ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#44">line 44 of Catalyst/Request.pm</a>
+# once (7µs+1.44ms) by Catalyst::Dispatcher::BEGIN@9 at <a href="Catalyst-Action-pm-1880-block.html#30">line 30 of Catalyst/Action.pm</a>
+# once (5µs+1.44ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#62">line 62 of Catalyst/Request.pm</a>
+# once (5µs+1.43ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#61">line 61 of Catalyst/Request.pm</a>
+# once (6µs+1.42ms) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#48">line 48 of Catalyst.pm</a>
+# once (6µs+1.39ms) by Catalyst::BEGIN@11 at <a href="Catalyst-Log-pm-469-block.html#15">line 15 of Catalyst/Log.pm</a>
+# once (6µs+1.37ms) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#19">line 19 of Catalyst/Request.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 3µs">6.28ms</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->throw_error('Usage: has \'name\' => ( key => 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="c2">3.23ms</td><td class="s"> my %options = ( definition_context => Moose::Util::_caller_info(), @_ );<div class="calls"><div class="calls_out"> # spent 3.23ms making 377 calls to <a href="Moose-Util-pm-158-block.html#284">Moose::Util::_caller_info</a>, avg 9µ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">1.56s</td><td class="s"> $meta->add_attribute( $_, %options ) for @$attrs;<div class="calls"><div class="calls_out"> # spent 1.56s making 390 calls to <a href="Moose-Meta-Class-pm-136-block.html#564">Moose::Meta::Class::add_attribute</a>, avg 3.99ms/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.81ms (30µs+2.78) within Moose::before which was called 4 times, avg 702µs/call:
+# 2 times (10µs+1.38ms) by Moose::before at <a href="Moose-Exporter-pm-82-block.html#382">line 382 of Moose/Exporter.pm</a>, avg 692µs/call
+# once (9µs+876µ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 (12µs+527µ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µs">10µs</span></td><td class="c3">2</td><td class="c3">1.38ms</td><td class="s"> Moose::Util::add_method_modifier(shift, 'before', \@_);<div class="calls"><div class="calls_out"> # spent 1.38ms making 2 calls to <a href="Moose-Util-pm-158-block.html#237">Moose::Util::add_method_modifier</a>, avg 688µ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 20.4ms (363µs+20.0) within Moose::around which was called 54 times, avg 377µs/call:
+# 27 times (125µs+9.79ms) by Moose::around at <a href="Moose-Exporter-pm-82-block.html#382">line 382 of Moose/Exporter.pm</a>, avg 367µs/call
+# once (8µs+1.01ms) by Catalyst::BEGIN@16 at <a href="Catalyst-Controller-pm-576-block.html#181">line 181 of Catalyst/Controller.pm</a>
+# once (12µs+816µ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 (6µs+643µs) by Catalyst::BEGIN@16 at <a href="Catalyst-Controller-pm-576-block.html#195">line 195 of Catalyst/Controller.pm</a>
+# once (18µs+493µ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 (8µs+483µ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 (6µs+420µs) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#945">line 945 of Catalyst.pm</a>
+# once (13µs+408µ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 (11µs+390µ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 (9µs+379µs) by Catalyst::BEGIN@32 at <a href="Catalyst-EngineLoader-pm-643-block.html#120">line 120 of Catalyst/EngineLoader.pm</a>
+# once (6µs+378µ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 (7µs+373µ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 (9µs+351µ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 (8µs+344µ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 (5µs+339µ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 (13µs+318µ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 (11µs+302µ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 (9µs+303µs) by stemmaweb::BEGIN@19 at <a href="Catalyst-pm-381-block.html#473">line 473 of Catalyst.pm</a>
+# once (5µs+299µ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 (10µs+280µs) by Catalyst::BEGIN@11 at <a href="Catalyst-Log-pm-469-block.html#55">line 55 of Catalyst/Log.pm</a>
+# once (9µs+277µ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µs+272µs) by Module::Runtime::require_module at <a href="Catalyst-Component-pm-579-block.html#85">line 85 of Catalyst/Component.pm</a>
+# once (8µs+267µs) by Catalyst::Dispatcher::BEGIN@10 at <a href="Catalyst-ActionContainer-pm-1892-block.html#28">line 28 of Catalyst/ActionContainer.pm</a>
+# once (8µs+230µ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 (8µs+225µ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 (8µs+221µs) by Catalyst::BEGIN@12 at <a href="Catalyst-Request-pm-483-block.html#256">line 256 of Catalyst/Request.pm</a>
+# once (9µs+204µs) by Module::Runtime::require_module at <a href="Catalyst-Engine-pm-1927-block.html#34">line 34 of Catalyst/Engine.pm</a>
+# once (5µs+180µ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 5µs">126µs</span></td><td class="c0">27</td><td class="c0">9.79ms</td><td class="s"> Moose::Util::add_method_modifier(shift, 'around', \@_);<div class="calls"><div class="calls_out"> # spent 9.79ms making 27 calls to <a href="Moose-Util-pm-158-block.html#237">Moose::Util::add_method_modifier</a>, avg 363µ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 100ns">100ns</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 0s">0s</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 200ns">200ns</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 110µs (56+54) within Moose::super which was called 8 times, avg 14µs/call:
+# 8 times (56µs+54µ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 14µ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µs">46µs</span></td><td></td><td></td><td class="s"> return if defined $SUPER_PACKAGE && $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">54µs</td><td class="s"> return unless $SUPER_BODY; $SUPER_BODY->(@SUPER_ARGS);<div class="calls"><div class="calls_out"> # spent 54µs making 8 calls to <a href="Moose-Object-pm-266-block.html#31">Moose::Object::BUILDARGS</a>, avg 7µ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 3.31ms (76µs+3.23) within Moose::override which was called 10 times, avg 331µs/call:
+# 5 times (35µs+1.58ms) by Moose::override at <a href="Moose-Exporter-pm-82-block.html#382">line 382 of Moose/Exporter.pm</a>, avg 322µs/call
+# once (8µs+377µ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 (8µs+341µ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 (7µs+322µ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 (9µs+314µ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>
+# once (10µs+302µs) by TryCatch::BEGIN@11 at <a href="Parse-Method-Signatures-pm-911-block.html#122">line 122 of Parse/Method/Signatures.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µs">32µ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">1.58ms</td><td class="s"> $meta->add_override_method_modifier( $name => $method );<div class="calls"><div class="calls_out"> # spent 1.58ms making 5 calls to <a href="Moose-Meta-Class-pm-136-block.html#579">Moose::Meta::Class::add_override_method_modifier</a>, avg 315µ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->(@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->add_augment_method_modifier( $name => $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 8µs">8µs</span></td><td class="c3">1</td><td class="c3">897µs</td><td class="s">Moose::Exporter->setup_import_methods(<div class="calls"><div class="calls_out"># spent 897µ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 => [</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 => [</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"> \&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"> \&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 364ms (6.19+357) within Moose::init_meta which was called 123 times, avg 2.96ms/call:
+# 123 times (6.19ms+357ms) 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 2.96ms/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 2µs">4.03ms</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->throw_error("Cannot call init_meta without specifying a for_class");</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">357µs</td><td class="s"> Moose->throw_error("The Metaclass $metaclass must be loaded. (Perhaps you forgot to 'use $metaclass'?)")<div class="calls"><div class="calls_out"> # spent 357µ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 3µ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">198µs</td><td class="s"> Moose->throw_error("The Metaclass $metaclass must be a subclass of Moose::Meta::Class.")<div class="calls"><div class="calls_out"> # spent 198µs making 123 calls to <a href="UNIVERSAL-pm-738-block.html#UNIVERSAL__isa">UNIVERSAL::isa</a>, avg 2µ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->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 3µs">3µs</span></td><td class="c0">246</td><td class="c0">87.3ms</td><td class="s"> class_type($class)<div class="calls"><div class="calls_out"> # spent 84.5ms making 117 calls to <a href="Moose-Util-TypeConstraints-pm-172-block.html#367">Moose::Util::TypeConstraints::class_type</a>, avg 722µs/call
+ # spent 2.77ms making 123 calls to <a href="Moose-Util-TypeConstraints-pm-172-block.html#309">Moose::Util::TypeConstraints::find_type_constraint</a>, avg 23µs/call
+ # spent 13µ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 2µ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 4µs">1.51ms</span></td><td class="c0">123</td><td class="c3">317µs</td><td class="s"> if ( $meta = Class::MOP::get_metaclass_by_name($class) ) {<div class="calls"><div class="calls_out"> # spent 317µs making 123 calls to <a href="Class-MOP-pm-83-block.html#55">Class::MOP::get_metaclass_by_name</a>, avg 3µ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µs</td><td class="s"> unless ( $meta->isa("Moose::Meta::Class") ) {<div class="calls"><div class="calls_out"> # spent 2µs making 2 calls to <a href="UNIVERSAL-pm-738-block.html#UNIVERSAL__isa">UNIVERSAL::isa</a>, avg 1µ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 = "$class already has a metaclass, but it does not inherit $metaclass ($meta).";</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->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->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->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">554µs</td><td class="s"> my ( undef, @isa ) = @{ mro::get_linear_isa($class) };<div class="calls"><div class="calls_out"> # spent 554µs making 121 calls to <a href="mro-pm-85-block.html#mro__get_linear_isa">mro::get_linear_isa</a>, avg 5µ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 2µs">17µs</span></td><td class="c0">7</td><td class="c3">7µs</td><td class="s"> my $ancestor_meta = Class::MOP::get_metaclass_by_name($ancestor) || next;<div class="calls"><div class="calls_out"> # spent 7µs making 7 calls to <a href="Class-MOP-pm-83-block.html#55">Class::MOP::get_metaclass_by_name</a>, avg 1µ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">7µs</td><td class="s"> my $ancestor_meta_class = $ancestor_meta->_real_ref_name;<div class="calls"><div class="calls_out"> # spent 7µ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">2µs</td><td class="s"> unless ( $metaclass->isa( $ancestor_meta_class ) ) {<div class="calls"><div class="calls_out"> # spent 2µ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->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">90.8ms</td><td class="s"> $meta = $metaclass->initialize($class);<div class="calls"><div class="calls_out"> # spent 90.8ms making 121 calls to <a href="Moose-Meta-Class-pm-136-block.html#73">Moose::Meta::Class::initialize</a>, avg 750µ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µs">669µ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="c1">4.13ms</td><td class="s"> my $existing = $meta->get_method($meta_name);<div class="calls"><div class="calls_out"> # spent 4.13ms making 123 calls to <a href="Class-MOP-Mixin-HasMethods-pm-91-block.html#113">Class::MOP::Mixin::HasMethods::get_method</a>, avg 34µ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µs</td><td class="s"> if ($existing && !$existing->isa('Class::MOP::Method::Meta')) {<div class="calls"><div class="calls_out"> # spent 2µs making 2 calls to <a href="UNIVERSAL-pm-738-block.html#UNIVERSAL__isa">UNIVERSAL::isa</a>, avg 1µ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 "Moose is overwriting an existing method named "</td></tr>
+<tr><td class="h"><a name="204"></a>204</td><td></td><td></td><td></td><td></td><td class="s"> . "$meta_name in class $class with a method "</td></tr>
+<tr><td class="h"><a name="205"></a>205</td><td></td><td></td><td></td><td></td><td class="s"> . "which returns the class's metaclass. If this is "</td></tr>
+<tr><td class="h"><a name="206"></a>206</td><td></td><td></td><td></td><td></td><td class="s"> . "actually what you want, you should remove the "</td></tr>
+<tr><td class="h"><a name="207"></a>207</td><td></td><td></td><td></td><td></td><td class="s"> . "existing method, otherwise, you should rename or "</td></tr>
+<tr><td class="h"><a name="208"></a>208</td><td></td><td></td><td></td><td></td><td class="s"> . "disable this generated method using the "</td></tr>
+<tr><td class="h"><a name="209"></a>209</td><td></td><td></td><td></td><td></td><td class="s"> . "'-meta_name' option to 'use Moose'.";</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">63.1ms</td><td class="s"> $meta->_add_meta_method($meta_name);<div class="calls"><div class="calls_out"> # spent 63.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 513µ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">84.9ms</td><td class="s"> $meta->superclasses($base_class)<div class="calls"><div class="calls_out"> # spent 111ms making 242 calls to <a href="Moose-Meta-Class-pm-136-block.html#549">Moose::Meta::Class::superclasses</a>, avg 457µs/call, recursion: max depth 2, sum of overlapping time 25.8ms</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->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 &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">16µs</td><td class="s">$_->make_immutable(<div class="calls"><div class="calls_out"># spent 16µs making 21 calls to <a href="Class-MOP-Class-pm-103-block.html#1259">Class::MOP::Class::is_mutable</a>, avg 738ns/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 => 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 => "_new",</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 => 1</td></tr>
+<tr><td class="h"><a name="233"></a>233</td><td class="c0">43</td><td class="c2"><span title="Avg 3µs">150µs</span></td><td class="c0">42</td><td class="c0">75.4ms</td><td class="s"> ) for grep { $_->is_mutable }<div class="calls"><div class="calls_out"> # spent 73.3ms making 21 calls to <a href="Class-MOP-Class-pm-103-block.html#1280">Class::MOP::Class::make_immutable</a>, avg 3.49ms/call
+ # spent 1.91ms making 9 calls to <a href="Class-MOP-Package-pm-122-block.html#221">Class::MOP::Object::meta</a>, avg 212µs/call
+ # spent 21µs making 2 calls to <a href="Class-MOP-Package-pm-122-block.html#221">Moose::Meta::Role::Method::Required::meta</a>, avg 10µs/call
+ # spent 12µs making 1 call to <a href="Class-MOP-Package-pm-122-block.html#221">Moose::Meta::TypeCoercion::Union::meta</a>
+ # spent 12µs making 1 call to <a href="Class-MOP-Package-pm-122-block.html#221">Moose::Meta::Role::Application::ToRole::meta</a>
+ # spent 11µs making 1 call to <a href="Class-MOP-Package-pm-122-block.html#221">Moose::Meta::Role::meta</a>
+ # spent 11µs making 1 call to <a href="Class-MOP-Package-pm-122-block.html#221">Moose::Meta::TypeCoercion::meta</a>
+ # spent 11µs making 1 call to <a href="Class-MOP-Package-pm-122-block.html#221">Class::MOP::Mixin::meta</a>
+ # spent 11µs making 1 call to <a href="Class-MOP-Package-pm-122-block.html#221">Moose::Meta::Role::Application::ToInstance::meta</a>
+ # spent 11µs making 1 call to <a href="Class-MOP-Package-pm-122-block.html#221">Moose::Meta::Role::Application::meta</a>
+ # spent 11µs making 1 call to <a href="Class-MOP-Package-pm-122-block.html#221">Moose::Meta::Role::Application::RoleSummation::meta</a>
+ # spent 11µs making 1 call to <a href="Class-MOP-Package-pm-122-block.html#221">Moose::Meta::Role::Application::ToClass::meta</a>
+ # spent 10µs making 1 call to <a href="Class-MOP-Package-pm-122-block.html#221">Moose::Meta::Role::Composite::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 { $_->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µs</td><td class="s">$_->make_immutable(<div class="calls"><div class="calls_out"># spent 3µs making 3 calls to <a href="Class-MOP-Class-pm-103-block.html#1259">Class::MOP::Class::is_mutable</a>, avg 1µ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 => 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 => 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 => 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µs">33µs</span></td><td class="c0">6</td><td class="c0">10.0ms</td><td class="s"> ) for grep { $_->is_mutable }<div class="calls"><div class="calls_out"> # spent 9.38ms making 3 calls to <a href="Class-MOP-Class-pm-103-block.html#1280">Class::MOP::Class::make_immutable</a>, avg 3.13ms/call
+ # spent 610µs making 2 calls to <a href="Class-MOP-Package-pm-122-block.html#221">Class::MOP::Object::meta</a>, avg 305µs/call
+ # spent 15µ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 { $_->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 70µs">70µ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' => (is => 'rw', isa => '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' => (is => 'rw', isa => '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->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->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' => (is => 'rw', isa => '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' => 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->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<Class::MOP>, 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<Moose::Manual> docs, followed by the L<Moose::Cookbook>. 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<MooseX::> 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<http://search.cpan.org/search?query=MooseX::>),</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<Task::Moose> 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<http://perldoc.perlassociation.org/pod/Moose-Doc-JA/index.html>. 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<http://github.com/jpa/Moose-Doc-JA></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<use Moose>, 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<Moose::Object>, I<unless> 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<extends> 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<has>. And (assuming you call C<new>, 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<Moose::Object>) 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<Moose::Object>. 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<meta></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<extends (@superclasses)></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<use base>, because C<use base></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<push>es onto the class's C<@ISA>, whereas C<extends> 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<Moose::Object>.</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<-version|Class::MOP/Class Loading Options> 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' => { -version => 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' => { -version => 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<with (@roles)></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<@roles> 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<extends>, 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<-version|Class::MOP/Class Loading Options> 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' => { -version => 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' => { -version => 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<has $name|@$names =E<gt> %options></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<$name> 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<$name> in the list. The C<%options> 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<Moose::Meta::Attribute> (which inherits from L<Class::MOP::Attribute>),</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<is =E<gt> 'rw'|'ro'></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<is> option accepts either I<rw> (for read/write) or I<ro> (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<$name> 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<reader|Class::MOP::Attribute/reader>,</td></tr>
+<tr><td class="h"><a name="457"></a>457</td><td></td><td></td><td></td><td></td><td class="s">L<writer|Class::MOP::Attribute/writer> 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<accessor|Class::MOP::Attribute/accessor> 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<Class::MOP::Attribute>, 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<is> 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<isa =E<gt> $type_name></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<isa> 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<$type_name> 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<Moose::Util::TypeConstraints></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<coerce =E<gt> (1|0)></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<must> 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<must> 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<Moose::Cookbook::Basics::HTTP_SubtypesAndCoercion> 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<does =E<gt> $role_name></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<required =E<gt> (1|0)></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<or> 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<required> 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<undef>.</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<weak_ref =E<gt> (1|0)></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<cannot> 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<lazy =E<gt> (1|0)></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<must> 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<trigger =E<gt> $code></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<trigger> 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<can> 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<NOTE:> Triggers will only fire when you B<assign> 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<not> 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<handles =E<gt> ARRAY | HASH | REGEXP | ROLE | ROLETYPE | DUCKTYPE | CODE></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<handles> 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<NOTE:> 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<handles> 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<foo> 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<foo>. 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<BUILD></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<DEMOLISH> 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<need> 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<less> 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<ARRAY></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<handles>. 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<HASH></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<handles>. 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' => (is => 'rw', isa => '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' => (</td></tr>
+<tr><td class="h"><a name="572"></a>572</td><td></td><td></td><td></td><td></td><td class="s"> is => '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 => '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 => 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' => (</td></tr>
+<tr><td class="h"><a name="578"></a>578</td><td></td><td></td><td></td><td></td><td class="s"> is => '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 => '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 => 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 => {</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 => '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 => '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<parent_node> and C<siblings> 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<node> and C<children> 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<parent> 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' => (</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 => { set_foo => [ set => '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->set_foo(...) calls $self->thing->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<REGEXP></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<NOTE:> An I<isa> 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<isa> 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<ROLE> or C<ROLETYPE></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<role type|Moose::Meta::TypeConstraint::Role> whose "interface" 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 "interface" 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<not> 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<DUCKTYPE></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 "interface" 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 "interface" 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<duck_type> 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<duck_type> 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<Moose::Util::TypeConstraints>.</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<CODE></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<handles> 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<traits =E<gt> [ @role_names ]></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<@role_names> 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<has> 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<Metaclass and Trait Name Resolution> 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<Moose::Cookbook::Meta::Labeled_AttributeTrait> 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<builder> => 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<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> 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<Moose::Cookbook::Basics::BinaryTree_BuilderAndLazyBuild> 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<default> => 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<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> 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<clearer> => 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<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> 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<predicate> => 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<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> 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<weak_ref> 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<documentation> => $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<<</td></tr>
+<tr><td class="h"><a name="694"></a>694</td><td></td><td></td><td></td><td></td><td class="s">$attr->documentation >>.</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<has +$name =E<gt> %options></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<has> 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' => (</td></tr>
+<tr><td class="h"><a name="708"></a>708</td><td></td><td></td><td></td><td></td><td class="s"> is => '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 => '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 => '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' => (default => '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<My::Foo> is cloning the C<message> 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<Foo>, retaining the C<is =E<gt> 'rw'> and C<isa =E<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'> characteristics, but changing the value in C<default>.</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' => (</td></tr>
+<tr><td class="h"><a name="730"></a>730</td><td></td><td></td><td></td><td></td><td class="s"> is => '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 => '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 => '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' => (default => '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<some> 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<reader></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<writer></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<accessor></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<clearer></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<predicate></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<traits></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<add> additional traits to the C<traits> 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<are not> 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<before $name|@names|\@names|qr/.../ =E<gt> sub { ... }></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<after $name|@names|\@names|qr/.../ =E<gt> sub { ... }></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<around $name|@names|\@names|qr/.../ =E<gt> sub { ... }></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<Class::MOP> 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<Moose::Manual::MethodModifiers> 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<Class::MOP::Class documentation|Class::MOP::Class/"Method Modifiers">.</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<override ($name, &sub)></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<override> method is a way of explicitly saying "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". You can call C<super> 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<can> 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<SUPER::> 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<super></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<super> is a no-op when called outside of an C<override> 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<override> 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<augment ($name, &sub)></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<augment> method, is a way of explicitly saying "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". Once again, the details of how C<inner> 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<augment> 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<Moose::Cookbook::Basics::Document_AugmentAndInner>.</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<inner></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<inner>, much like C<super>, 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<augment> method. You can think of C<inner> 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<super>; the details of how C<inner> and C<augment> 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<Moose::Cookbook::Basics::Document_AugmentAndInner>.</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<blessed></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<Scalar::Util::blessed> 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<ref> 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<confess></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<Carp::confess> 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 => '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<meta> 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<Metaclass and Trait Name Resolution> 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<Moose::Meta::$type::Custom::Trait::$trait_name>. The C<$type></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<Attribute> or B<Class>, 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<register_implementation>. 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<real> 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<register_implementation> 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<Moose::Meta::$type::Custom::Trait::$trait> 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<Moose::Meta::$type::Custom::$metaclass_name>.</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<Moose::Cookbook::Meta::Labeled_AttributeTrait>, 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<unimport></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<unimport></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<no Moose> 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' => (is => 'rw', isa => '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' => (is => 'rw', isa => '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->first_name . ' ' . $self->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">"Extending" recipes in the L<Moose::Cookbook>, 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<Moose::Cookbook::Extending::ExtensionOverview>, 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<Moose::Exporter> 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<Moose::Util::MetaRole> 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<for> 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<MooseX::> 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<not> 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<LWPx::></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<DBIx::> namespaces that perform the same function for C<LWP> and C<DBI></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 "About Metaclass compatibility" 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<Class::MOP> 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<Class::MOP> 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 "differ by roles". 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<MooseX::*></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<super> and C<inner> B<cannot> 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<t/basics/override_augment_inner_super.t> 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<super> 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<override> modifier, and C<inner> 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<override> method. In fact, C<augment> will skip over any C<override> 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<inner>.</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<mailto:moose@perl.org>. 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<mailto:moose-subscribe@perl.org></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<#moose> on L<irc://irc.perl.org/#moose></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 "nothingmuch" 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 & 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 "Theory" 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<http://www.iinteractive.com/moose></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<Moose manual|Moose::Manual></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<http://onyxneon.com/books/modern_perl/>.</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<http://www.stonehenge.com/merlyn/LinuxMag/col94.html></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<http://www.stonehenge.com/merlyn/LinuxMag/col95.html></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<MooseX::> 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<http://search.cpan.org/search?query=MooseX::> 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<Class::MOP> 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<http://www.cs.utah.edu/plt/publications/oopsla04-gff.pdf></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<super>/C<override> and C<inner>/C<augment> 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<bug-moose@rt.cpan.org>, 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<http://rt.cpan.org>.</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<irc://irc.perl.org/#moose>.</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<irc://irc.perl.org/#moose> 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<Moose::Manual::Contributing> 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>stevan@iinteractive.comE<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>doy at tozt dot netE<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>sartak@bestpractical.comE<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>hdp@pobox.comE<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>rafl@debian.orgE<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>autarch@urth.orgE<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<Moose::Manual>.</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<Moose::Cookbook::Snack::Keywords>.</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<Moose::Cookbook::Snack::Types>.</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<Moose::Cookbook::Basics::Genome_OverloadingSubtypesAndCoercion>.</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<Test::Moose> and L<Moose::Util>.</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<Moose::Meta::Attribute::Native> 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<MooseX::AttributeHelpers> 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<Moose/CABAL> and L<Moose/CONTRIBUTORS> 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