@tricoteuses/assemblee 1.0.0-next.2 → 1.0.2

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.
Files changed (135) hide show
  1. package/README.md +2 -0
  2. package/lib/api.js +23 -7
  3. package/lib/api.mjs +41 -0
  4. package/lib/bugs/acteur-00010/plugin.test.js +139 -33
  5. package/lib/bugs/acteur-00010/plugin.test.mjs +33 -0
  6. package/lib/bugs/acteur-00010.js +166 -24
  7. package/lib/bugs/acteur-00010.mjs +31 -0
  8. package/lib/bugs/agenda-00002/plugin.test.js +178 -52
  9. package/lib/bugs/agenda-00002/plugin.test.mjs +52 -0
  10. package/lib/bugs/agenda-00002.js +507 -143
  11. package/lib/bugs/agenda-00002.mjs +197 -0
  12. package/lib/bugs/agenda-00008/plugin.test.js +143 -31
  13. package/lib/bugs/agenda-00008/plugin.test.mjs +31 -0
  14. package/lib/bugs/agenda-00008.js +180 -25
  15. package/lib/bugs/agenda-00008.mjs +30 -0
  16. package/lib/bugs/agenda-00011/plugin.test.js +371 -156
  17. package/lib/bugs/agenda-00011/plugin.test.mjs +156 -0
  18. package/lib/bugs/agenda-00011.js +416 -117
  19. package/lib/bugs/agenda-00011.mjs +150 -0
  20. package/lib/bugs.js +591 -54
  21. package/lib/bugs.mjs +93 -0
  22. package/lib/cleaners/actes_legislatifs.js +149 -61
  23. package/lib/cleaners/actes_legislatifs.mjs +311 -0
  24. package/lib/cleaners/acteurs.js +255 -123
  25. package/lib/cleaners/acteurs.mjs +211 -0
  26. package/lib/cleaners/amendements.js +242 -117
  27. package/lib/cleaners/amendements.mjs +292 -0
  28. package/lib/cleaners/documents.js +147 -62
  29. package/lib/cleaners/documents.mjs +162 -0
  30. package/lib/cleaners/dossiers_legislatifs.js +132 -45
  31. package/lib/cleaners/dossiers_legislatifs.mjs +123 -0
  32. package/lib/cleaners/index.js +64 -8
  33. package/lib/cleaners/index.mjs +8 -0
  34. package/lib/cleaners/organes.js +54 -21
  35. package/lib/cleaners/organes.mjs +64 -0
  36. package/lib/cleaners/reunions.js +237 -127
  37. package/lib/cleaners/reunions.mjs +318 -0
  38. package/lib/cleaners/scrutins.js +261 -99
  39. package/lib/cleaners/scrutins.mjs +254 -0
  40. package/lib/cleaners/xml.js +81 -16
  41. package/lib/cleaners/xml.mjs +42 -0
  42. package/lib/datasets.js +284 -153
  43. package/lib/datasets.mjs +596 -0
  44. package/lib/dates.js +93 -34
  45. package/lib/dates.mjs +98 -0
  46. package/lib/dossiers_legislatifs.js +107 -33
  47. package/lib/dossiers_legislatifs.mjs +215 -0
  48. package/lib/file_systems.js +203 -35
  49. package/lib/file_systems.mjs +64 -0
  50. package/lib/git.js +139 -41
  51. package/lib/git.mjs +114 -0
  52. package/lib/index.js +310 -16
  53. package/lib/index.mjs +16 -0
  54. package/lib/inserters.js +355 -131
  55. package/lib/inserters.mjs +413 -0
  56. package/lib/loaders.js +900 -440
  57. package/lib/loaders.mjs +678 -0
  58. package/lib/organes.js +15 -5
  59. package/lib/organes.mjs +18 -0
  60. package/lib/parsers/documents.js +241 -89
  61. package/lib/parsers/documents.mjs +433 -0
  62. package/lib/parsers/index.js +36 -3
  63. package/lib/parsers/index.mjs +3 -0
  64. package/lib/parsers/recherche_amendements.js +616 -173
  65. package/lib/parsers/recherche_amendements.mjs +189 -0
  66. package/lib/raw_types/acteurs_et_organes.d.ts +36 -148
  67. package/lib/raw_types/acteurs_et_organes.js +228 -506
  68. package/lib/raw_types/acteurs_et_organes.mjs +1240 -0
  69. package/lib/raw_types/agendas.js +165 -75
  70. package/lib/raw_types/agendas.mjs +944 -0
  71. package/lib/raw_types/amendements.js +165 -77
  72. package/lib/raw_types/amendements.mjs +1040 -0
  73. package/lib/raw_types/dossiers_legislatifs.d.ts +1 -43
  74. package/lib/raw_types/dossiers_legislatifs.js +181 -143
  75. package/lib/raw_types/dossiers_legislatifs.mjs +1792 -0
  76. package/lib/raw_types/scrutins.js +144 -61
  77. package/lib/raw_types/scrutins.mjs +645 -0
  78. package/lib/scripts/bugs_helper.js +657 -155
  79. package/lib/scripts/bugs_helper.mjs +286 -0
  80. package/lib/scripts/clean_data.js +380 -145
  81. package/lib/scripts/clean_data.mjs +190 -0
  82. package/lib/scripts/clean_reorganized_data.js +627 -331
  83. package/lib/scripts/clean_reorganized_data.mjs +520 -0
  84. package/lib/scripts/diff_amendements.js +159 -73
  85. package/lib/scripts/diff_amendements.mjs +234 -0
  86. package/lib/scripts/document_dossiers_legislatifs.js +570 -288
  87. package/lib/scripts/document_dossiers_legislatifs.mjs +494 -0
  88. package/lib/scripts/get_today_reunions.js +37 -20
  89. package/lib/scripts/get_today_reunions.mjs +41 -0
  90. package/lib/scripts/merge_scrutins.js +121 -39
  91. package/lib/scripts/merge_scrutins.mjs +69 -0
  92. package/lib/scripts/parse_textes_lois.js +179 -125
  93. package/lib/scripts/parse_textes_lois.mjs +215 -0
  94. package/lib/scripts/raw_types_from_amendements.js +276 -77
  95. package/lib/scripts/raw_types_from_amendements.mjs +118 -0
  96. package/lib/scripts/reorganize_data.js +867 -446
  97. package/lib/scripts/reorganize_data.mjs +712 -0
  98. package/lib/scripts/retrieve_deputes_photos.js +378 -157
  99. package/lib/scripts/retrieve_deputes_photos.mjs +230 -0
  100. package/lib/scripts/retrieve_documents.js +648 -172
  101. package/lib/scripts/retrieve_documents.mjs +292 -0
  102. package/lib/scripts/retrieve_open_data.js +286 -85
  103. package/lib/scripts/retrieve_open_data.mjs +125 -0
  104. package/lib/scripts/retrieve_pending_amendments.js +302 -69
  105. package/lib/scripts/retrieve_pending_amendments.mjs +130 -0
  106. package/lib/scripts/retrieve_senateurs_photos.js +374 -198
  107. package/lib/scripts/retrieve_senateurs_photos.mjs +277 -0
  108. package/lib/scripts/retrieve_textes_lois.js +343 -89
  109. package/lib/scripts/retrieve_textes_lois.mjs +168 -0
  110. package/lib/scripts/test_load.js +30 -11
  111. package/lib/scripts/test_load.mjs +26 -0
  112. package/lib/scripts/test_load_big_files.js +30 -11
  113. package/lib/scripts/test_load_big_files.mjs +26 -0
  114. package/lib/scripts/validate_json.js +370 -120
  115. package/lib/scripts/validate_json.mjs +216 -0
  116. package/lib/shared_types/codes_actes.js +50 -15
  117. package/lib/shared_types/codes_actes.mjs +228 -0
  118. package/lib/strings.js +16 -3
  119. package/lib/strings.mjs +7 -0
  120. package/lib/types/acteurs_et_organes.js +156 -71
  121. package/lib/types/acteurs_et_organes.mjs +918 -0
  122. package/lib/types/agendas.js +154 -67
  123. package/lib/types/agendas.mjs +623 -0
  124. package/lib/types/amendements.js +166 -77
  125. package/lib/types/amendements.mjs +885 -0
  126. package/lib/types/dossiers_legislatifs.d.ts +1 -42
  127. package/lib/types/dossiers_legislatifs.js +182 -143
  128. package/lib/types/dossiers_legislatifs.mjs +1120 -0
  129. package/lib/types/legislatures.js +12 -3
  130. package/lib/types/legislatures.mjs +9 -0
  131. package/lib/types/scrutins.js +144 -61
  132. package/lib/types/scrutins.mjs +528 -0
  133. package/lib/urls.js +44 -25
  134. package/lib/urls.mjs +201 -0
  135. package/package.json +33 -12
package/lib/git.js CHANGED
@@ -1,27 +1,88 @@
1
- import path from "path";
2
- import fs from "fs-extra";
3
- import { getFiles } from "./file_systems.js";
4
- import { execSync } from "child_process";
5
- const MAXBUFFER = 50 * 1024 * 1024;
6
- export function run(repositoryDir, args, verbose) {
1
+ "use strict";
2
+
3
+ require("core-js/modules/es.array.slice.js");
4
+
5
+ require("core-js/modules/es.function.name.js");
6
+
7
+ require("core-js/modules/es.array.from.js");
8
+
9
+ require("core-js/modules/es.string.iterator.js");
10
+
11
+ require("core-js/modules/es.symbol.js");
12
+
13
+ require("core-js/modules/es.symbol.description.js");
14
+
15
+ require("core-js/modules/es.symbol.iterator.js");
16
+
17
+ require("core-js/modules/es.array.iterator.js");
18
+
19
+ require("core-js/modules/web.dom-collections.iterator.js");
20
+
21
+ require("core-js/modules/es.array.is-array.js");
22
+
23
+ require("core-js/modules/es.object.define-property.js");
24
+
25
+ Object.defineProperty(exports, "__esModule", {
26
+ value: true
27
+ });
28
+ exports.commit = commit;
29
+ exports.run = run;
30
+ exports.test = test;
31
+ exports.uidBranchUpdate = uidBranchUpdate;
32
+
33
+ require("core-js/modules/es.array.concat.js");
34
+
35
+ require("core-js/modules/es.string.trim.js");
36
+
37
+ require("core-js/modules/es.date.to-string.js");
38
+
39
+ require("core-js/modules/es.object.to-string.js");
40
+
41
+ require("core-js/modules/es.regexp.to-string.js");
42
+
43
+ require("core-js/modules/es.regexp.exec.js");
44
+
45
+ var _path = _interopRequireDefault(require("path"));
46
+
47
+ var _fsExtra = _interopRequireDefault(require("fs-extra"));
48
+
49
+ var _file_systems = require("./file_systems");
50
+
51
+ var _child_process = require("child_process");
52
+
53
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
54
+
55
+ function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
56
+
57
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
58
+
59
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
60
+
61
+ var MAXBUFFER = 50 * 1024 * 1024;
62
+
63
+ function run(repositoryDir, args, verbose) {
7
64
  try {
8
- if (verbose) console.log(`git -C ${repositoryDir} ${args}`);
9
- const output = execSync(`git ${args}`, {
65
+ if (verbose) console.log("git -C ".concat(repositoryDir, " ").concat(args));
66
+ var output = (0, _child_process.execSync)("git ".concat(args), {
10
67
  cwd: repositoryDir,
11
68
  maxBuffer: MAXBUFFER
12
69
  }).toString().trim();
13
70
  if (verbose) console.log(output);
14
71
  return output;
15
72
  } catch (childProcess) {
16
- for (const output of ["stdout", "stderr"]) console.error(`${output}: ${childProcess[output]}`);
73
+ for (var _i = 0, _arr = ["stdout", "stderr"]; _i < _arr.length; _i++) {
74
+ var _output = _arr[_i];
75
+ console.error("".concat(_output, ": ").concat(childProcess[_output]));
76
+ }
17
77
 
18
78
  throw childProcess;
19
79
  }
20
80
  }
21
- export function test(repositoryDir, args, verbose) {
81
+
82
+ function test(repositoryDir, args, verbose) {
22
83
  try {
23
- if (verbose) console.log(`git -C ${repositoryDir} ${args}`);
24
- const output = execSync(`git ${args}`, {
84
+ if (verbose) console.log("git -C ".concat(repositoryDir, " ").concat(args));
85
+ var output = (0, _child_process.execSync)("git ".concat(args), {
25
86
  cwd: repositoryDir,
26
87
  stdio: ["ignore", "pipe", "pipe"],
27
88
  maxBuffer: MAXBUFFER
@@ -33,8 +94,9 @@ export function test(repositoryDir, args, verbose) {
33
94
  throw childProcess;
34
95
  }
35
96
  }
36
- export function commit(repositoryDir, message) {
37
- execSync("git add .", {
97
+
98
+ function commit(repositoryDir, message) {
99
+ (0, _child_process.execSync)("git add .", {
38
100
  cwd: repositoryDir,
39
101
  env: process.env,
40
102
  encoding: "utf-8",
@@ -43,7 +105,7 @@ export function commit(repositoryDir, message) {
43
105
  });
44
106
 
45
107
  try {
46
- execSync(`git commit -m "${message}"`, {
108
+ (0, _child_process.execSync)("git commit -m \"".concat(message, "\""), {
47
109
  cwd: repositoryDir,
48
110
  env: process.env,
49
111
  encoding: "utf-8",
@@ -59,56 +121,92 @@ export function commit(repositoryDir, message) {
59
121
  return false;
60
122
  }
61
123
  }
62
- export function uidBranchUpdate(repositoryDir, subdirectories, notHard) {
63
- const previousBranch = run(repositoryDir, "rev-parse --abbrev-ref HEAD");
64
- const branch = "uid";
65
- const cwd = process.cwd();
124
+
125
+ function uidBranchUpdate(repositoryDir, subdirectories, notHard) {
126
+ var previousBranch = run(repositoryDir, "rev-parse --abbrev-ref HEAD");
127
+ var branch = "uid";
128
+ var cwd = process.cwd();
66
129
  process.chdir(repositoryDir);
67
130
 
68
- for (const subdirectory of subdirectories) {
69
- const uidDirectory = `${subdirectory}/uid`;
70
- fs.ensureDirSync(uidDirectory);
131
+ var _iterator = _createForOfIteratorHelper(subdirectories),
132
+ _step;
71
133
 
72
- for (const pathname of getFiles([`${subdirectory}/**/*.json`])) {
73
- const filename = path.basename(pathname);
74
- fs.renameSync(pathname, `${uidDirectory}/${filename}`);
134
+ try {
135
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
136
+ var subdirectory = _step.value;
137
+ var uidDirectory = "".concat(subdirectory, "/uid");
138
+
139
+ _fsExtra["default"].ensureDirSync(uidDirectory);
140
+
141
+ var _iterator3 = _createForOfIteratorHelper((0, _file_systems.getFiles)(["".concat(subdirectory, "/**/*.json")])),
142
+ _step3;
143
+
144
+ try {
145
+ for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
146
+ var pathname = _step3.value;
147
+
148
+ var filename = _path["default"].basename(pathname);
149
+
150
+ _fsExtra["default"].renameSync(pathname, "".concat(uidDirectory, "/").concat(filename));
151
+ }
152
+ } catch (err) {
153
+ _iterator3.e(err);
154
+ } finally {
155
+ _iterator3.f();
156
+ }
75
157
  }
158
+ } catch (err) {
159
+ _iterator.e(err);
160
+ } finally {
161
+ _iterator.f();
76
162
  }
77
163
 
78
164
  process.chdir(cwd);
79
165
 
80
- if (test(repositoryDir, `rev-parse remotes/origin/${branch}`)) {
166
+ if (test(repositoryDir, "rev-parse remotes/origin/".concat(branch))) {
81
167
  // if a remote branch exists, it must be used even if a local branch exists
82
- run(repositoryDir, `branch --force ${branch} origin/${branch}`);
83
- run(repositoryDir, `symbolic-ref HEAD refs/heads/${branch}`);
168
+ run(repositoryDir, "branch --force ".concat(branch, " origin/").concat(branch));
169
+ run(repositoryDir, "symbolic-ref HEAD refs/heads/".concat(branch));
84
170
  run(repositoryDir, "reset");
85
- } else if (test(repositoryDir, `rev-parse refs/heads/${branch}`)) {
171
+ } else if (test(repositoryDir, "rev-parse refs/heads/".concat(branch))) {
86
172
  // if no remote branch exists but a local one exists, use it
87
- run(repositoryDir, `symbolic-ref HEAD refs/heads/${branch}`);
173
+ run(repositoryDir, "symbolic-ref HEAD refs/heads/".concat(branch));
88
174
  run(repositoryDir, "reset");
89
175
  } else {
90
176
  // if there are no remote or local branches, create a new one
91
- run(repositoryDir, `branch --force ${branch} master`);
92
- run(repositoryDir, `symbolic-ref HEAD refs/heads/${branch}`);
177
+ run(repositoryDir, "branch --force ".concat(branch, " master"));
178
+ run(repositoryDir, "symbolic-ref HEAD refs/heads/".concat(branch));
93
179
  run(repositoryDir, "reset");
94
180
  run(repositoryDir, "rm -r .");
95
181
  }
96
182
 
97
- for (const subdirectory of subdirectories) {
98
- const uidDirectory = `${subdirectory}/uid`;
99
- run(repositoryDir, `add ${uidDirectory}`);
183
+ var _iterator2 = _createForOfIteratorHelper(subdirectories),
184
+ _step2;
185
+
186
+ try {
187
+ for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
188
+ var _subdirectory = _step2.value;
189
+
190
+ var _uidDirectory = "".concat(_subdirectory, "/uid");
191
+
192
+ run(repositoryDir, "add ".concat(_uidDirectory));
193
+ }
194
+ } catch (err) {
195
+ _iterator2.e(err);
196
+ } finally {
197
+ _iterator2.f();
100
198
  }
101
199
 
102
- let status = false;
200
+ var status = false;
103
201
 
104
202
  if (!test(repositoryDir, "diff --quiet --cached")) {
105
- run(repositoryDir, `commit -m 'Update'`);
203
+ run(repositoryDir, "commit -m 'Update'");
106
204
  status = true;
107
205
  }
108
206
 
109
- run(repositoryDir, `symbolic-ref HEAD refs/heads/${previousBranch}`);
110
- const resetOption = notHard ? "" : "--hard";
111
- run(repositoryDir, `reset ${resetOption}`);
207
+ run(repositoryDir, "symbolic-ref HEAD refs/heads/".concat(previousBranch));
208
+ var resetOption = notHard ? "" : "--hard";
209
+ run(repositoryDir, "reset ".concat(resetOption));
112
210
  return status;
113
211
  }
114
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["path","fs","getFiles","execSync","MAXBUFFER","run","repositoryDir","args","verbose","console","log","output","cwd","maxBuffer","toString","trim","childProcess","error","test","stdio","status","commit","message","env","process","encoding","stdout","uidBranchUpdate","subdirectories","notHard","previousBranch","branch","chdir","subdirectory","uidDirectory","ensureDirSync","pathname","filename","basename","renameSync","resetOption"],"sources":["../src/git.ts"],"sourcesContent":["import path from \"path\"\nimport fs from \"fs-extra\"\nimport { getFiles } from \"./file_systems\"\nimport { ChildProcess, execSync } from \"child_process\"\n\nconst MAXBUFFER = 50 * 1024 * 1024\n\nexport function run(\n  repositoryDir: string,\n  args: string,\n  verbose?: boolean,\n): string {\n  try {\n    if (verbose) console.log(`git -C ${repositoryDir} ${args}`)\n    const output = execSync(`git ${args}`, {\n      cwd: repositoryDir,\n      maxBuffer: MAXBUFFER,\n    })\n      .toString()\n      .trim()\n    if (verbose) console.log(output)\n    return output\n  } catch (childProcess) {\n    for (const output of [\"stdout\", \"stderr\"])\n      console.error(`${output}: ${(childProcess as any)[output]}`)\n    throw childProcess\n  }\n}\n\nexport function test(\n  repositoryDir: string,\n  args: string,\n  verbose?: boolean,\n): boolean {\n  try {\n    if (verbose) console.log(`git -C ${repositoryDir} ${args}`)\n    const output = execSync(`git ${args}`, {\n      cwd: repositoryDir,\n      stdio: [\"ignore\", \"pipe\", \"pipe\"],\n      maxBuffer: MAXBUFFER,\n    })\n      .toString()\n      .trim()\n    if (verbose) console.log(output)\n    return true\n  } catch (childProcess) {\n    if ((childProcess as any).status != 0) return false\n    throw childProcess\n  }\n}\n\nexport function commit(repositoryDir: string, message: string): boolean {\n  execSync(\"git add .\", {\n    cwd: repositoryDir,\n    env: process.env,\n    encoding: \"utf-8\",\n    stdio: [\"ignore\", \"ignore\", \"pipe\"],\n    maxBuffer: MAXBUFFER,\n  })\n  try {\n    execSync(`git commit -m \"${message}\"`, {\n      cwd: repositoryDir,\n      env: process.env,\n      encoding: \"utf-8\",\n      stdio: [\"ignore\", \"pipe\", \"pipe\"],\n    })\n    return true\n  } catch (childProcess) {\n    if (\n      (childProcess as ChildProcess).stdout === null ||\n      !/nothing to commit/.test((childProcess as any).stdout)\n    ) {\n      console.error((childProcess as any).output)\n      throw childProcess\n    }\n    return false\n  }\n}\n\nexport function uidBranchUpdate(\n  repositoryDir: string,\n  subdirectories: any,\n  notHard: boolean,\n): boolean {\n  const previousBranch = run(repositoryDir, \"rev-parse --abbrev-ref HEAD\")\n  const branch = \"uid\"\n  const cwd = process.cwd()\n  process.chdir(repositoryDir)\n  for (const subdirectory of subdirectories) {\n    const uidDirectory = `${subdirectory}/uid`\n    fs.ensureDirSync(uidDirectory)\n    for (const pathname of getFiles([`${subdirectory}/**/*.json`])) {\n      const filename = path.basename(pathname)\n      fs.renameSync(pathname, `${uidDirectory}/${filename}`)\n    }\n  }\n  process.chdir(cwd)\n  if (test(repositoryDir, `rev-parse remotes/origin/${branch}`)) {\n    // if a remote branch exists, it must be used even if a local branch exists\n    run(repositoryDir, `branch --force ${branch} origin/${branch}`)\n    run(repositoryDir, `symbolic-ref HEAD refs/heads/${branch}`)\n    run(repositoryDir, \"reset\")\n  } else if (test(repositoryDir, `rev-parse refs/heads/${branch}`)) {\n    // if no remote branch exists but a local one exists, use it\n    run(repositoryDir, `symbolic-ref HEAD refs/heads/${branch}`)\n    run(repositoryDir, \"reset\")\n  } else {\n    // if there are no remote or local branches, create a new one\n    run(repositoryDir, `branch --force ${branch} master`)\n    run(repositoryDir, `symbolic-ref HEAD refs/heads/${branch}`)\n    run(repositoryDir, \"reset\")\n    run(repositoryDir, \"rm -r .\")\n  }\n  for (const subdirectory of subdirectories) {\n    const uidDirectory = `${subdirectory}/uid`\n    run(repositoryDir, `add ${uidDirectory}`)\n  }\n  let status = false\n  if (!test(repositoryDir, \"diff --quiet --cached\")) {\n    run(repositoryDir, `commit -m 'Update'`)\n    status = true\n  }\n  run(repositoryDir, `symbolic-ref HEAD refs/heads/${previousBranch}`)\n  const resetOption = notHard ? \"\" : \"--hard\"\n  run(repositoryDir, `reset ${resetOption}`)\n  return status\n}\n"],"mappings":"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"}
212
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["MAXBUFFER","run","repositoryDir","args","verbose","console","log","output","execSync","cwd","maxBuffer","toString","trim","childProcess","error","test","stdio","status","commit","message","env","process","encoding","stdout","uidBranchUpdate","subdirectories","notHard","previousBranch","branch","chdir","subdirectory","uidDirectory","fs","ensureDirSync","getFiles","pathname","filename","path","basename","renameSync","resetOption"],"sources":["../src/git.ts"],"sourcesContent":["import path from \"path\"\nimport fs from \"fs-extra\"\nimport { getFiles } from \"./file_systems\"\nimport { ChildProcess, execSync } from \"child_process\"\n\nconst MAXBUFFER = 50 * 1024 * 1024\n\nexport function run(\n  repositoryDir: string,\n  args: string,\n  verbose?: boolean,\n): string {\n  try {\n    if (verbose) console.log(`git -C ${repositoryDir} ${args}`)\n    const output = execSync(`git ${args}`, {\n      cwd: repositoryDir,\n      maxBuffer: MAXBUFFER,\n    })\n      .toString()\n      .trim()\n    if (verbose) console.log(output)\n    return output\n  } catch (childProcess) {\n    for (const output of [\"stdout\", \"stderr\"])\n      console.error(`${output}: ${(childProcess as any)[output]}`)\n    throw childProcess\n  }\n}\n\nexport function test(\n  repositoryDir: string,\n  args: string,\n  verbose?: boolean,\n): boolean {\n  try {\n    if (verbose) console.log(`git -C ${repositoryDir} ${args}`)\n    const output = execSync(`git ${args}`, {\n      cwd: repositoryDir,\n      stdio: [\"ignore\", \"pipe\", \"pipe\"],\n      maxBuffer: MAXBUFFER,\n    })\n      .toString()\n      .trim()\n    if (verbose) console.log(output)\n    return true\n  } catch (childProcess) {\n    if ((childProcess as any).status != 0) return false\n    throw childProcess\n  }\n}\n\nexport function commit(repositoryDir: string, message: string): boolean {\n  execSync(\"git add .\", {\n    cwd: repositoryDir,\n    env: process.env,\n    encoding: \"utf-8\",\n    stdio: [\"ignore\", \"ignore\", \"pipe\"],\n    maxBuffer: MAXBUFFER,\n  })\n  try {\n    execSync(`git commit -m \"${message}\"`, {\n      cwd: repositoryDir,\n      env: process.env,\n      encoding: \"utf-8\",\n      stdio: [\"ignore\", \"pipe\", \"pipe\"],\n    })\n    return true\n  } catch (childProcess) {\n    if (\n      (childProcess as ChildProcess).stdout === null ||\n      !/nothing to commit/.test((childProcess as any).stdout)\n    ) {\n      console.error((childProcess as any).output)\n      throw childProcess\n    }\n    return false\n  }\n}\n\nexport function uidBranchUpdate(\n  repositoryDir: string,\n  subdirectories: any,\n  notHard: boolean,\n): boolean {\n  const previousBranch = run(repositoryDir, \"rev-parse --abbrev-ref HEAD\")\n  const branch = \"uid\"\n  const cwd = process.cwd()\n  process.chdir(repositoryDir)\n  for (const subdirectory of subdirectories) {\n    const uidDirectory = `${subdirectory}/uid`\n    fs.ensureDirSync(uidDirectory)\n    for (const pathname of getFiles([`${subdirectory}/**/*.json`])) {\n      const filename = path.basename(pathname)\n      fs.renameSync(pathname, `${uidDirectory}/${filename}`)\n    }\n  }\n  process.chdir(cwd)\n  if (test(repositoryDir, `rev-parse remotes/origin/${branch}`)) {\n    // if a remote branch exists, it must be used even if a local branch exists\n    run(repositoryDir, `branch --force ${branch} origin/${branch}`)\n    run(repositoryDir, `symbolic-ref HEAD refs/heads/${branch}`)\n    run(repositoryDir, \"reset\")\n  } else if (test(repositoryDir, `rev-parse refs/heads/${branch}`)) {\n    // if no remote branch exists but a local one exists, use it\n    run(repositoryDir, `symbolic-ref HEAD refs/heads/${branch}`)\n    run(repositoryDir, \"reset\")\n  } else {\n    // if there are no remote or local branches, create a new one\n    run(repositoryDir, `branch --force ${branch} master`)\n    run(repositoryDir, `symbolic-ref HEAD refs/heads/${branch}`)\n    run(repositoryDir, \"reset\")\n    run(repositoryDir, \"rm -r .\")\n  }\n  for (const subdirectory of subdirectories) {\n    const uidDirectory = `${subdirectory}/uid`\n    run(repositoryDir, `add ${uidDirectory}`)\n  }\n  let status = false\n  if (!test(repositoryDir, \"diff --quiet --cached\")) {\n    run(repositoryDir, `commit -m 'Update'`)\n    status = true\n  }\n  run(repositoryDir, `symbolic-ref HEAD refs/heads/${previousBranch}`)\n  const resetOption = notHard ? \"\" : \"--hard\"\n  run(repositoryDir, `reset ${resetOption}`)\n  return status\n}\n"],"mappings":"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"}
package/lib/git.mjs ADDED
@@ -0,0 +1,114 @@
1
+ import path from "path";
2
+ import fs from "fs-extra";
3
+ import { getFiles } from "./file_systems.mjs";
4
+ import { execSync } from "child_process";
5
+ const MAXBUFFER = 50 * 1024 * 1024;
6
+ export function run(repositoryDir, args, verbose) {
7
+ try {
8
+ if (verbose) console.log(`git -C ${repositoryDir} ${args}`);
9
+ const output = execSync(`git ${args}`, {
10
+ cwd: repositoryDir,
11
+ maxBuffer: MAXBUFFER
12
+ }).toString().trim();
13
+ if (verbose) console.log(output);
14
+ return output;
15
+ } catch (childProcess) {
16
+ for (const output of ["stdout", "stderr"]) console.error(`${output}: ${childProcess[output]}`);
17
+
18
+ throw childProcess;
19
+ }
20
+ }
21
+ export function test(repositoryDir, args, verbose) {
22
+ try {
23
+ if (verbose) console.log(`git -C ${repositoryDir} ${args}`);
24
+ const output = execSync(`git ${args}`, {
25
+ cwd: repositoryDir,
26
+ stdio: ["ignore", "pipe", "pipe"],
27
+ maxBuffer: MAXBUFFER
28
+ }).toString().trim();
29
+ if (verbose) console.log(output);
30
+ return true;
31
+ } catch (childProcess) {
32
+ if (childProcess.status != 0) return false;
33
+ throw childProcess;
34
+ }
35
+ }
36
+ export function commit(repositoryDir, message) {
37
+ execSync("git add .", {
38
+ cwd: repositoryDir,
39
+ env: process.env,
40
+ encoding: "utf-8",
41
+ stdio: ["ignore", "ignore", "pipe"],
42
+ maxBuffer: MAXBUFFER
43
+ });
44
+
45
+ try {
46
+ execSync(`git commit -m "${message}"`, {
47
+ cwd: repositoryDir,
48
+ env: process.env,
49
+ encoding: "utf-8",
50
+ stdio: ["ignore", "pipe", "pipe"]
51
+ });
52
+ return true;
53
+ } catch (childProcess) {
54
+ if (childProcess.stdout === null || !/nothing to commit/.test(childProcess.stdout)) {
55
+ console.error(childProcess.output);
56
+ throw childProcess;
57
+ }
58
+
59
+ return false;
60
+ }
61
+ }
62
+ export function uidBranchUpdate(repositoryDir, subdirectories, notHard) {
63
+ const previousBranch = run(repositoryDir, "rev-parse --abbrev-ref HEAD");
64
+ const branch = "uid";
65
+ const cwd = process.cwd();
66
+ process.chdir(repositoryDir);
67
+
68
+ for (const subdirectory of subdirectories) {
69
+ const uidDirectory = `${subdirectory}/uid`;
70
+ fs.ensureDirSync(uidDirectory);
71
+
72
+ for (const pathname of getFiles([`${subdirectory}/**/*.json`])) {
73
+ const filename = path.basename(pathname);
74
+ fs.renameSync(pathname, `${uidDirectory}/${filename}`);
75
+ }
76
+ }
77
+
78
+ process.chdir(cwd);
79
+
80
+ if (test(repositoryDir, `rev-parse remotes/origin/${branch}`)) {
81
+ // if a remote branch exists, it must be used even if a local branch exists
82
+ run(repositoryDir, `branch --force ${branch} origin/${branch}`);
83
+ run(repositoryDir, `symbolic-ref HEAD refs/heads/${branch}`);
84
+ run(repositoryDir, "reset");
85
+ } else if (test(repositoryDir, `rev-parse refs/heads/${branch}`)) {
86
+ // if no remote branch exists but a local one exists, use it
87
+ run(repositoryDir, `symbolic-ref HEAD refs/heads/${branch}`);
88
+ run(repositoryDir, "reset");
89
+ } else {
90
+ // if there are no remote or local branches, create a new one
91
+ run(repositoryDir, `branch --force ${branch} master`);
92
+ run(repositoryDir, `symbolic-ref HEAD refs/heads/${branch}`);
93
+ run(repositoryDir, "reset");
94
+ run(repositoryDir, "rm -r .");
95
+ }
96
+
97
+ for (const subdirectory of subdirectories) {
98
+ const uidDirectory = `${subdirectory}/uid`;
99
+ run(repositoryDir, `add ${uidDirectory}`);
100
+ }
101
+
102
+ let status = false;
103
+
104
+ if (!test(repositoryDir, "diff --quiet --cached")) {
105
+ run(repositoryDir, `commit -m 'Update'`);
106
+ status = true;
107
+ }
108
+
109
+ run(repositoryDir, `symbolic-ref HEAD refs/heads/${previousBranch}`);
110
+ const resetOption = notHard ? "" : "--hard";
111
+ run(repositoryDir, `reset ${resetOption}`);
112
+ return status;
113
+ }
114
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["path","fs","getFiles","execSync","MAXBUFFER","run","repositoryDir","args","verbose","console","log","output","cwd","maxBuffer","toString","trim","childProcess","error","test","stdio","status","commit","message","env","process","encoding","stdout","uidBranchUpdate","subdirectories","notHard","previousBranch","branch","chdir","subdirectory","uidDirectory","ensureDirSync","pathname","filename","basename","renameSync","resetOption"],"sources":["../src/git.ts"],"sourcesContent":["import path from \"path\"\nimport fs from \"fs-extra\"\nimport { getFiles } from \"./file_systems\"\nimport { ChildProcess, execSync } from \"child_process\"\n\nconst MAXBUFFER = 50 * 1024 * 1024\n\nexport function run(\n  repositoryDir: string,\n  args: string,\n  verbose?: boolean,\n): string {\n  try {\n    if (verbose) console.log(`git -C ${repositoryDir} ${args}`)\n    const output = execSync(`git ${args}`, {\n      cwd: repositoryDir,\n      maxBuffer: MAXBUFFER,\n    })\n      .toString()\n      .trim()\n    if (verbose) console.log(output)\n    return output\n  } catch (childProcess) {\n    for (const output of [\"stdout\", \"stderr\"])\n      console.error(`${output}: ${(childProcess as any)[output]}`)\n    throw childProcess\n  }\n}\n\nexport function test(\n  repositoryDir: string,\n  args: string,\n  verbose?: boolean,\n): boolean {\n  try {\n    if (verbose) console.log(`git -C ${repositoryDir} ${args}`)\n    const output = execSync(`git ${args}`, {\n      cwd: repositoryDir,\n      stdio: [\"ignore\", \"pipe\", \"pipe\"],\n      maxBuffer: MAXBUFFER,\n    })\n      .toString()\n      .trim()\n    if (verbose) console.log(output)\n    return true\n  } catch (childProcess) {\n    if ((childProcess as any).status != 0) return false\n    throw childProcess\n  }\n}\n\nexport function commit(repositoryDir: string, message: string): boolean {\n  execSync(\"git add .\", {\n    cwd: repositoryDir,\n    env: process.env,\n    encoding: \"utf-8\",\n    stdio: [\"ignore\", \"ignore\", \"pipe\"],\n    maxBuffer: MAXBUFFER,\n  })\n  try {\n    execSync(`git commit -m \"${message}\"`, {\n      cwd: repositoryDir,\n      env: process.env,\n      encoding: \"utf-8\",\n      stdio: [\"ignore\", \"pipe\", \"pipe\"],\n    })\n    return true\n  } catch (childProcess) {\n    if (\n      (childProcess as ChildProcess).stdout === null ||\n      !/nothing to commit/.test((childProcess as any).stdout)\n    ) {\n      console.error((childProcess as any).output)\n      throw childProcess\n    }\n    return false\n  }\n}\n\nexport function uidBranchUpdate(\n  repositoryDir: string,\n  subdirectories: any,\n  notHard: boolean,\n): boolean {\n  const previousBranch = run(repositoryDir, \"rev-parse --abbrev-ref HEAD\")\n  const branch = \"uid\"\n  const cwd = process.cwd()\n  process.chdir(repositoryDir)\n  for (const subdirectory of subdirectories) {\n    const uidDirectory = `${subdirectory}/uid`\n    fs.ensureDirSync(uidDirectory)\n    for (const pathname of getFiles([`${subdirectory}/**/*.json`])) {\n      const filename = path.basename(pathname)\n      fs.renameSync(pathname, `${uidDirectory}/${filename}`)\n    }\n  }\n  process.chdir(cwd)\n  if (test(repositoryDir, `rev-parse remotes/origin/${branch}`)) {\n    // if a remote branch exists, it must be used even if a local branch exists\n    run(repositoryDir, `branch --force ${branch} origin/${branch}`)\n    run(repositoryDir, `symbolic-ref HEAD refs/heads/${branch}`)\n    run(repositoryDir, \"reset\")\n  } else if (test(repositoryDir, `rev-parse refs/heads/${branch}`)) {\n    // if no remote branch exists but a local one exists, use it\n    run(repositoryDir, `symbolic-ref HEAD refs/heads/${branch}`)\n    run(repositoryDir, \"reset\")\n  } else {\n    // if there are no remote or local branches, create a new one\n    run(repositoryDir, `branch --force ${branch} master`)\n    run(repositoryDir, `symbolic-ref HEAD refs/heads/${branch}`)\n    run(repositoryDir, \"reset\")\n    run(repositoryDir, \"rm -r .\")\n  }\n  for (const subdirectory of subdirectories) {\n    const uidDirectory = `${subdirectory}/uid`\n    run(repositoryDir, `add ${uidDirectory}`)\n  }\n  let status = false\n  if (!test(repositoryDir, \"diff --quiet --cached\")) {\n    run(repositoryDir, `commit -m 'Update'`)\n    status = true\n  }\n  run(repositoryDir, `symbolic-ref HEAD refs/heads/${previousBranch}`)\n  const resetOption = notHard ? \"\" : \"--hard\"\n  run(repositoryDir, `reset ${resetOption}`)\n  return status\n}\n"],"mappings":"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"}