<!doctype html> <html lang="en"> <head> <title>Code coverage report for scope/items/scopeAliasItem.js</title> <meta charset="utf-8" /> <link rel="stylesheet" href="../../prettify.css" /> <link rel="stylesheet" href="../../base.css" /> <meta name="viewport" content="width=device-width, initial-scale=1"> <style type='text/css'> .coverage-summary .sorter { background-image: url(../../sort-arrow-sprite.png); } </style> </head> <body> <div class='wrapper'> <div class='pad1'> <h1> <a href="../../index.html">All files</a> / <a href="index.html">scope/items</a> scopeAliasItem.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Statements</span> <span class='fraction'>0/6</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Branches</span> <span class='fraction'>0/4</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Functions</span> <span class='fraction'>0/3</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Lines</span> <span class='fraction'>0/6</span> </div> </div> </div> <div class='status-line low'></div> <pre><table class="coverage"> <tr><td class="line-count quiet">1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67</td><td class="line-coverage quiet"><span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import ScopeItem from '../scopeItem'; /** * References an alias or such to any value. This is used for example in thigns * like assignments. */ export default class ScopeAliasItem extends ScopeItem { /** * Creates an alias, an item representing a value. This will store a * ScopeItem for the instance which it represents. For example an object of * type `class A {}` would be `ScopeAliasItem(of: A.ref)` * * Additionally we'll keep track of variable candidates here. This will be * verified as the code is generated which will allow us to maintain * ambiguity for deffered resolution * * @param {string} rootId - The root primary identifier of this type. * @param {ScopeItem[]} candidates - The possible type of the item. * @param {Node} source - The source expression which the item was declared. */ <span class="fstat-no" title="function not covered" > co</span>nstructor(rootId: string, candidates: ScopeItem[], source: Node) { <span class="cstat-no" title="statement not covered" > super(rootId);</span> /** * All the possible types the alias can have. The generator will resolve * ambiguity between multiple but if they are 0 we can do nothing. * * Make sure to bind to the reference for type updating. * * @type {ScopeItem[]} */ <span class="cstat-no" title="statement not covered" > this.candidates = candidates;</span> /** * `true` if the type ever escapes the scope this means it is places * within a closure, or is ever returned. This is needed for memory * allocation as we don't want to RC every time. Instead we'll copy the * mem ref. to a object & unwrap if applicable. We can inline too but * avoiding branch analysis and domain masking is probably more complex * then initally is needed. * * @type {boolean} */ <span class="cstat-no" title="statement not covered" > this.escapesScope = false;</span> /** * The source node in which this item was declared. Do note that this * might now always be the same but you can assume it will have type * info e.g. `.typeCandidates`. * * @type {Node} */ <span class="cstat-no" title="statement not covered" > this.source = source;</span> } /** @override */ <span class="fstat-no" title="function not covered" > eq</span>ual(ref: ScopeItem): boolean { <span class="cstat-no" title="statement not covered" > return ref instanceof ScopeAliasItem && ref.rootId === this.rootId;</span> } /** @return {string} */ <span class="fstat-no" title="function not covered" > to</span>String() { <span class="cstat-no" title="statement not covered" > return `${this.rootId}: ${this.candidates ? this.candidates.join("\n") : "n/a"}`;</span> } } </pre></td></tr> </table></pre> <div class='push'></div><!-- for sticky footer --> </div><!-- /wrapper --> <div class='footer quiet pad2 space-top1 center small'> Code coverage generated by <a href="https://istanbul.js.org/" target="_blank">istanbul</a> at Thu Jun 08 2017 22:32:03 GMT-0700 (PDT) </div> </div> <script src="../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../sorter.js"></script> </body> </html>