scancscode 1.0.13 → 1.0.14

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.
@@ -10,7 +10,7 @@ class CSCodeScanner {
10
10
  // 正则表达式匹配 匹配每个字符串
11
11
  static stringPattern = /\$?"([^"]*)"/mg;
12
12
  // 正则表达式匹配 匹配获取成员值的表达式
13
- static getMemberValuePattern = /\s*(?:\+\s*)?([\w\.\u4e00-\u9fff\[\]]+)(\.TR\(\))?/mg;
13
+ static getMemberValuePattern = /^(\s*)([\w\.\u4e00-\u9fff\[\]]+)(\.TR\(\))?(\s*)$/m;
14
14
  static memberSplit = /^[\s\+;]/;
15
15
  // 正则表达式匹配插值表达式 {...}
16
16
  static interpolationPattern = /\{([^}]+?)(\:[a-zA-Z\d-\.\#(?:\\\\:)\u4e00-\u9fff]+)?\}/mg;
@@ -185,22 +185,16 @@ class CSCodeScanner {
185
185
  }
186
186
  }
187
187
  else {
188
- const memberMatchs = [...bodyLine.matchAll(CSCodeScanner.getMemberValuePattern)];
189
- if (memberMatchs.length == 1) {
190
- let match1 = memberMatchs[0];
191
- let c2 = bodyLine.substring(match1.index + match1[0].length);
192
- if (c2 != '' && c2.match(CSCodeScanner.memberSplit) == null) {
193
- memberMatchs.length = 0;
194
- }
195
- }
196
- if (memberMatchs.length > 0) {
197
- let memberLines = [];
198
- for (let i = 0; i < memberMatchs.length; i++) {
199
- let memberMatch = memberMatchs[i];
200
- let memberLine = memberMatch[1];
201
- memberLines.push(`${memberLine}.TR()`);
188
+ let memberLines = bodyLine.split("+");
189
+ if (memberLines.length > 0) {
190
+ for (let i = 0; i < memberLines.length; i++) {
191
+ let memberLine = memberLines[i];
192
+ let match = memberLine.match(this.getMemberValuePattern);
193
+ if (match != null) {
194
+ memberLines[i] = match[1] + match[2] + ".TR()" + match[4];
195
+ }
202
196
  }
203
- convertedAssignLine = assignHead + memberLines.join(" + ") + ";";
197
+ convertedAssignLine = assignHead + memberLines.join("+") + ";";
204
198
  }
205
199
  else {
206
200
  convertedAssignLine = assignLine;
@@ -46,8 +46,8 @@ class LiteralCollector {
46
46
  return;
47
47
  }
48
48
  let files = glob_1.glob.sync("**/*.cs", { cwd: folder });
49
- let testFullPath = "@";
50
- // let testFullPath = "E:/DATA/Projects/ZhiYou/ProjectFClient/GameClient/Assets/Bundles/FGUI/RefineUI_FurnaceUpgradeDialog/Comp/ItemFurnaceRateComp.cs";
49
+ // let testFullPath = "@";
50
+ let testFullPath = "E:/DATA/Projects/ZhiYou/ProjectFClient/GameClient/Assets/Bundles/FGUI/TopRank/Comp/SubTopRankSelfComp.cs";
51
51
  for (const filePath of files) {
52
52
  let fullPath = folder + filePath;
53
53
  if (testFullPath != "@") {
package/dist/index.js CHANGED
@@ -1,4 +1,4 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const CmdExecutor_1 = require("./CmdExecutor");
4
- CmdExecutor_1.CmdExecutor.runConvertWithCmdOptions();
4
+ CmdExecutor_1.CmdExecutor.testConvert();
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "scancscode",
3
- "version": "1.0.13",
3
+ "version": "1.0.14",
4
4
  "description": "",
5
5
  "main": "./dist/index.js",
6
6
  "bin": {
@@ -11,7 +11,7 @@ export class CSCodeScanner {
11
11
  // 正则表达式匹配 匹配每个字符串
12
12
  private static readonly stringPattern = /\$?"([^"]*)"/mg;
13
13
  // 正则表达式匹配 匹配获取成员值的表达式
14
- private static readonly getMemberValuePattern = /\s*(?:\+\s*)?([\w\.\u4e00-\u9fff\[\]]+)(\.TR\(\))?/mg;
14
+ private static readonly getMemberValuePattern = /^(\s*)([\w\.\u4e00-\u9fff\[\]]+)(\.TR\(\))?(\s*)$/m;
15
15
  private static readonly memberSplit = /^[\s\+;]/;
16
16
  // 正则表达式匹配插值表达式 {...}
17
17
  private static readonly interpolationPattern = /\{([^}]+?)(\:[a-zA-Z\d-\.\#(?:\\\\:)\u4e00-\u9fff]+)?\}/mg;
@@ -193,22 +193,16 @@ export class CSCodeScanner {
193
193
  convertedAssignLine = stringLines.join("");
194
194
  }
195
195
  } else {
196
- const memberMatchs = [...bodyLine.matchAll(CSCodeScanner.getMemberValuePattern)];
197
- if (memberMatchs.length == 1) {
198
- let match1 = memberMatchs[0]
199
- let c2 = bodyLine.substring(match1.index + match1[0].length)
200
- if (c2 != '' && c2.match(CSCodeScanner.memberSplit) == null) {
201
- memberMatchs.length = 0;
202
- }
203
- }
204
- if (memberMatchs.length > 0) {
205
- let memberLines: string[] = []
206
- for (let i = 0; i < memberMatchs.length; i++) {
207
- let memberMatch = memberMatchs[i];
208
- let memberLine = memberMatch[1];
209
- memberLines.push(`${memberLine}.TR()`);
196
+ let memberLines = bodyLine.split("+");
197
+ if (memberLines.length > 0) {
198
+ for (let i = 0; i < memberLines.length; i++) {
199
+ let memberLine = memberLines[i];
200
+ let match = memberLine.match(this.getMemberValuePattern);
201
+ if (match != null) {
202
+ memberLines[i] = match[1] + match[2] + ".TR()" + match[4];
203
+ }
210
204
  }
211
- convertedAssignLine = assignHead + memberLines.join(" + ") + ";";
205
+ convertedAssignLine = assignHead + memberLines.join("+") + ";";
212
206
  } else {
213
207
  convertedAssignLine = assignLine;
214
208
  }
@@ -14,8 +14,8 @@ export class LiteralCollector {
14
14
  }
15
15
 
16
16
  let files = glob.sync("**/*.cs", { cwd: folder });
17
- let testFullPath = "@";
18
- // let testFullPath = "E:/DATA/Projects/ZhiYou/ProjectFClient/GameClient/Assets/Bundles/FGUI/RefineUI_FurnaceUpgradeDialog/Comp/ItemFurnaceRateComp.cs";
17
+ // let testFullPath = "@";
18
+ let testFullPath = "E:/DATA/Projects/ZhiYou/ProjectFClient/GameClient/Assets/Bundles/FGUI/TopRank/Comp/SubTopRankSelfComp.cs";
19
19
  for (const filePath of files) {
20
20
  let fullPath = folder + filePath;
21
21
  if (testFullPath != "@") {
package/src/index.ts CHANGED
@@ -1,3 +1,3 @@
1
1
  import { CmdExecutor } from "./CmdExecutor";
2
2
 
3
- CmdExecutor.runConvertWithCmdOptions()
3
+ CmdExecutor.testConvert()