@bbn/bbn 1.0.138 → 1.0.140

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -15,5 +15,6 @@ declare const analyzeFunction: (fn: any) => {
15
15
  name: string;
16
16
  isAsync: boolean;
17
17
  hash: string;
18
+ returnType: string;
18
19
  };
19
20
  export { analyzeFunction };
@@ -31,13 +31,14 @@ var analyzeFunction = function (fn) {
31
31
  var isComment = false;
32
32
  var isCommentLine = false;
33
33
  var isDestructuring = false;
34
+ var returnType = "";
34
35
  for (var i = 0; i < all.length; i++) {
35
36
  // Handle string literals
36
37
  if (!isComment && all[i] === "/" && all[i + 1] === "*") {
37
38
  isComment = true;
38
39
  exp = "";
39
40
  }
40
- else if (all[i] === "*" && all[i + 1] === "/") {
41
+ else if (all[i] === "/" && all[i - 1] === "*") {
41
42
  isComment = false;
42
43
  }
43
44
  else if (!isCommentLine && all[i] === "/" && all[i + 1] === "/") {
@@ -70,6 +71,10 @@ var analyzeFunction = function (fn) {
70
71
  }
71
72
  else if (exp.trim() !== "async") {
72
73
  name = exp.trim();
74
+ var tmp = name.match(/^([a-zA-Z0-9_]+)<[a-zA-Z0-9_]+>$/);
75
+ if (tmp) {
76
+ name = tmp[1];
77
+ }
73
78
  }
74
79
  exp = "";
75
80
  }
@@ -94,6 +99,15 @@ var analyzeFunction = function (fn) {
94
99
  else if (isDestructuring && all[i] !== "}") {
95
100
  exp += all[i];
96
101
  }
102
+ else if (parOpened && parOpened === parClosed && all[i] === ":") {
103
+ var matches = all.substring(i + 1).trim().match(/^\s*([a-zA-Z0-9_]+)\s*\{/);
104
+ if (!matches) {
105
+ throw Error("Unexpected ':' while parsing function");
106
+ }
107
+ returnType = matches[1];
108
+ body = all.substring(i + matches[0].length).trim();
109
+ break;
110
+ }
97
111
  else if (all[i] === "=" && all[i + 1] === ">") {
98
112
  if (exp.trim() !== "" && parOpened === parClosed) {
99
113
  currentArg["name"] = exp.trim();
@@ -162,7 +176,12 @@ var analyzeFunction = function (fn) {
162
176
  if (exp.trim() === "async") {
163
177
  isAsync = true;
164
178
  }
165
- exp = "";
179
+ if (parOpened > parClosed) {
180
+ exp += all[i];
181
+ }
182
+ else {
183
+ exp = "";
184
+ }
166
185
  }
167
186
  }
168
187
  else {
@@ -190,6 +209,7 @@ var analyzeFunction = function (fn) {
190
209
  name: name,
191
210
  isAsync: isAsync,
192
211
  hash: hash,
212
+ returnType: returnType
193
213
  };
194
214
  };
195
215
  export { analyzeFunction };
package/dist/fn.d.ts CHANGED
@@ -20,6 +20,7 @@ declare const fn: {
20
20
  name: string;
21
21
  isAsync: boolean;
22
22
  hash: string;
23
+ returnType: string;
23
24
  };
24
25
  animateCss: (ele: any, animationName: any, callback: any) => void;
25
26
  arrayBuffer2String: (buf: any) => any;