summaryrefslogtreecommitdiff
path: root/std/util/deep_assign.ts
diff options
context:
space:
mode:
authorRyan Dahl <ry@tinyclouds.org>2019-10-09 17:18:08 -0400
committerRyan Dahl <ry@tinyclouds.org>2019-10-09 17:18:08 -0400
commit28293acd9c12a94f5d769706291032e844c7b92b (patch)
tree1fec6a3cd8d7c9e8bc9b1486f5c8438eb906a595 /std/util/deep_assign.ts
parent5c6835efd82c298df99ce71c4a36ca23515333a3 (diff)
parent151ce0266eb4de2c8fc600c81c192a5f791b6169 (diff)
Merge branch 'std_modified' into merge_std3
Diffstat (limited to 'std/util/deep_assign.ts')
-rw-r--r--std/util/deep_assign.ts31
1 files changed, 31 insertions, 0 deletions
diff --git a/std/util/deep_assign.ts b/std/util/deep_assign.ts
new file mode 100644
index 000000000..b1c9f9ac9
--- /dev/null
+++ b/std/util/deep_assign.ts
@@ -0,0 +1,31 @@
+// Copyright 2018-2019 the Deno authors. All rights reserved. MIT license.
+export function deepAssign(
+ target: Record<string, unknown>,
+ ...sources: object[]
+): object | undefined {
+ for (let i = 0; i < sources.length; i++) {
+ const source = sources[i];
+ if (!source || typeof source !== `object`) {
+ return;
+ }
+ Object.entries(source).forEach(([key, value]: [string, unknown]): void => {
+ if (value instanceof Date) {
+ target[key] = new Date(value);
+ return;
+ }
+ if (!value || typeof value !== `object`) {
+ target[key] = value;
+ return;
+ }
+ if (Array.isArray(value)) {
+ target[key] = [];
+ }
+ // value is an Object
+ if (typeof target[key] !== `object` || !target[key]) {
+ target[key] = {};
+ }
+ deepAssign(target[key] as Record<string, unknown>, value!);
+ });
+ }
+ return target;
+}