mirror of
https://github.com/Start9Labs/start-os.git
synced 2026-03-30 20:14:49 +00:00
139 lines
5.1 KiB
HTML
139 lines
5.1 KiB
HTML
<!doctype html>
|
|
<html lang="en">
|
|
<head>
|
|
<title>Code coverage report for util/deepMerge.ts</title>
|
|
<meta charset="utf-8" />
|
|
<link rel="stylesheet" href="../prettify.css" />
|
|
<link rel="stylesheet" href="../base.css" />
|
|
<link rel="shortcut icon" type="image/x-icon" href="../favicon.png" />
|
|
<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">util</a> deepMerge.ts
|
|
</h1>
|
|
<div class="clearfix">
|
|
<div class="fl pad1y space-right2">
|
|
<span class="strong">94.44% </span>
|
|
<span class="quiet">Statements</span>
|
|
<span class="fraction">17/18</span>
|
|
</div>
|
|
|
|
<div class="fl pad1y space-right2">
|
|
<span class="strong">80% </span>
|
|
<span class="quiet">Branches</span>
|
|
<span class="fraction">4/5</span>
|
|
</div>
|
|
|
|
<div class="fl pad1y space-right2">
|
|
<span class="strong">100% </span>
|
|
<span class="quiet">Functions</span>
|
|
<span class="fraction">4/4</span>
|
|
</div>
|
|
|
|
<div class="fl pad1y space-right2">
|
|
<span class="strong">100% </span>
|
|
<span class="quiet">Lines</span>
|
|
<span class="fraction">13/13</span>
|
|
</div>
|
|
</div>
|
|
<p class="quiet">
|
|
Press <em>n</em> or <em>j</em> to go to the next uncovered block,
|
|
<em>b</em>, <em>p</em> or <em>k</em> for the previous block.
|
|
</p>
|
|
<template id="filterTemplate">
|
|
<div class="quiet">
|
|
Filter:
|
|
<input oninput="onInput()" type="search" id="fileSearch" />
|
|
</div>
|
|
</template>
|
|
</div>
|
|
<div class="status-line high"></div>
|
|
<pre><table class="coverage">
|
|
<tr><td class="line-count quiet"><a name='L1'></a><a href='#L1'>1</a>
|
|
<a name='L2'></a><a href='#L2'>2</a>
|
|
<a name='L3'></a><a href='#L3'>3</a>
|
|
<a name='L4'></a><a href='#L4'>4</a>
|
|
<a name='L5'></a><a href='#L5'>5</a>
|
|
<a name='L6'></a><a href='#L6'>6</a>
|
|
<a name='L7'></a><a href='#L7'>7</a>
|
|
<a name='L8'></a><a href='#L8'>8</a>
|
|
<a name='L9'></a><a href='#L9'>9</a>
|
|
<a name='L10'></a><a href='#L10'>10</a>
|
|
<a name='L11'></a><a href='#L11'>11</a>
|
|
<a name='L12'></a><a href='#L12'>12</a>
|
|
<a name='L13'></a><a href='#L13'>13</a>
|
|
<a name='L14'></a><a href='#L14'>14</a>
|
|
<a name='L15'></a><a href='#L15'>15</a>
|
|
<a name='L16'></a><a href='#L16'>16</a>
|
|
<a name='L17'></a><a href='#L17'>17</a>
|
|
<a name='L18'></a><a href='#L18'>18</a></td><td class="line-coverage quiet"><span class="cline-any cline-yes">1x</span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">1x</span>
|
|
<span class="cline-any cline-yes">13x</span>
|
|
<span class="cline-any cline-yes">13x</span>
|
|
<span class="cline-any cline-yes">14x</span>
|
|
<span class="cline-any cline-yes">7x</span>
|
|
<span class="cline-any cline-yes">5x</span>
|
|
<span class="cline-any cline-yes">11x</span>
|
|
<span class="cline-any cline-yes">5x</span>
|
|
<span class="cline-any cline-yes">8x</span>
|
|
<span class="cline-any cline-yes">18x</span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">8x</span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">5x</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 { object } from "ts-matches"
|
|
|
|
export function deepMerge(...args: unknown[]): unknown {
|
|
const lastItem = (args as any)[args.length - 1]
|
|
if (!object.test(lastItem)) return lastItem
|
|
const objects = args.filter(object.test).filter((x) => !Array.isArray(x))
|
|
if (objects.length === 0) return lastItem as any
|
|
<span class="missing-if-branch" title="if path not taken" >I</span>if (objects.length === 1) <span class="cstat-no" title="statement not covered" >objects.unshift({})</span>
|
|
const allKeys = new Set(objects.flatMap((x) => Object.keys(x)))
|
|
for (const key of allKeys) {
|
|
const filteredValues = objects.flatMap((x) =>
|
|
key in x ? [(x as any)[key]] : [],
|
|
)
|
|
;(objects as any)[0][key] = deepMerge(...filteredValues)
|
|
}
|
|
return objects[0] as any
|
|
}
|
|
</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"
|
|
rel="noopener noreferrer"
|
|
>istanbul</a
|
|
>
|
|
at 2024-07-04T02:41:23.401Z
|
|
</div>
|
|
<script src="../prettify.js"></script>
|
|
<script>
|
|
window.onload = function () {
|
|
prettyPrint();
|
|
};
|
|
</script>
|
|
<script src="../sorter.js"></script>
|
|
<script src="../block-navigation.js"></script>
|
|
</body>
|
|
</html>
|