@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.
- package/README.md +2 -0
- package/lib/api.js +23 -7
- package/lib/api.mjs +41 -0
- package/lib/bugs/acteur-00010/plugin.test.js +139 -33
- package/lib/bugs/acteur-00010/plugin.test.mjs +33 -0
- package/lib/bugs/acteur-00010.js +166 -24
- package/lib/bugs/acteur-00010.mjs +31 -0
- package/lib/bugs/agenda-00002/plugin.test.js +178 -52
- package/lib/bugs/agenda-00002/plugin.test.mjs +52 -0
- package/lib/bugs/agenda-00002.js +507 -143
- package/lib/bugs/agenda-00002.mjs +197 -0
- package/lib/bugs/agenda-00008/plugin.test.js +143 -31
- package/lib/bugs/agenda-00008/plugin.test.mjs +31 -0
- package/lib/bugs/agenda-00008.js +180 -25
- package/lib/bugs/agenda-00008.mjs +30 -0
- package/lib/bugs/agenda-00011/plugin.test.js +371 -156
- package/lib/bugs/agenda-00011/plugin.test.mjs +156 -0
- package/lib/bugs/agenda-00011.js +416 -117
- package/lib/bugs/agenda-00011.mjs +150 -0
- package/lib/bugs.js +591 -54
- package/lib/bugs.mjs +93 -0
- package/lib/cleaners/actes_legislatifs.js +149 -61
- package/lib/cleaners/actes_legislatifs.mjs +311 -0
- package/lib/cleaners/acteurs.js +255 -123
- package/lib/cleaners/acteurs.mjs +211 -0
- package/lib/cleaners/amendements.js +242 -117
- package/lib/cleaners/amendements.mjs +292 -0
- package/lib/cleaners/documents.js +147 -62
- package/lib/cleaners/documents.mjs +162 -0
- package/lib/cleaners/dossiers_legislatifs.js +132 -45
- package/lib/cleaners/dossiers_legislatifs.mjs +123 -0
- package/lib/cleaners/index.js +64 -8
- package/lib/cleaners/index.mjs +8 -0
- package/lib/cleaners/organes.js +54 -21
- package/lib/cleaners/organes.mjs +64 -0
- package/lib/cleaners/reunions.js +237 -127
- package/lib/cleaners/reunions.mjs +318 -0
- package/lib/cleaners/scrutins.js +261 -99
- package/lib/cleaners/scrutins.mjs +254 -0
- package/lib/cleaners/xml.js +81 -16
- package/lib/cleaners/xml.mjs +42 -0
- package/lib/datasets.js +284 -153
- package/lib/datasets.mjs +596 -0
- package/lib/dates.js +93 -34
- package/lib/dates.mjs +98 -0
- package/lib/dossiers_legislatifs.js +107 -33
- package/lib/dossiers_legislatifs.mjs +215 -0
- package/lib/file_systems.js +203 -35
- package/lib/file_systems.mjs +64 -0
- package/lib/git.js +139 -41
- package/lib/git.mjs +114 -0
- package/lib/index.js +310 -16
- package/lib/index.mjs +16 -0
- package/lib/inserters.js +355 -131
- package/lib/inserters.mjs +413 -0
- package/lib/loaders.js +900 -440
- package/lib/loaders.mjs +678 -0
- package/lib/organes.js +15 -5
- package/lib/organes.mjs +18 -0
- package/lib/parsers/documents.js +241 -89
- package/lib/parsers/documents.mjs +433 -0
- package/lib/parsers/index.js +36 -3
- package/lib/parsers/index.mjs +3 -0
- package/lib/parsers/recherche_amendements.js +616 -173
- package/lib/parsers/recherche_amendements.mjs +189 -0
- package/lib/raw_types/acteurs_et_organes.d.ts +36 -148
- package/lib/raw_types/acteurs_et_organes.js +228 -506
- package/lib/raw_types/acteurs_et_organes.mjs +1240 -0
- package/lib/raw_types/agendas.js +165 -75
- package/lib/raw_types/agendas.mjs +944 -0
- package/lib/raw_types/amendements.js +165 -77
- package/lib/raw_types/amendements.mjs +1040 -0
- package/lib/raw_types/dossiers_legislatifs.d.ts +1 -43
- package/lib/raw_types/dossiers_legislatifs.js +181 -143
- package/lib/raw_types/dossiers_legislatifs.mjs +1792 -0
- package/lib/raw_types/scrutins.js +144 -61
- package/lib/raw_types/scrutins.mjs +645 -0
- package/lib/scripts/bugs_helper.js +657 -155
- package/lib/scripts/bugs_helper.mjs +286 -0
- package/lib/scripts/clean_data.js +380 -145
- package/lib/scripts/clean_data.mjs +190 -0
- package/lib/scripts/clean_reorganized_data.js +627 -331
- package/lib/scripts/clean_reorganized_data.mjs +520 -0
- package/lib/scripts/diff_amendements.js +159 -73
- package/lib/scripts/diff_amendements.mjs +234 -0
- package/lib/scripts/document_dossiers_legislatifs.js +570 -288
- package/lib/scripts/document_dossiers_legislatifs.mjs +494 -0
- package/lib/scripts/get_today_reunions.js +37 -20
- package/lib/scripts/get_today_reunions.mjs +41 -0
- package/lib/scripts/merge_scrutins.js +121 -39
- package/lib/scripts/merge_scrutins.mjs +69 -0
- package/lib/scripts/parse_textes_lois.js +179 -125
- package/lib/scripts/parse_textes_lois.mjs +215 -0
- package/lib/scripts/raw_types_from_amendements.js +276 -77
- package/lib/scripts/raw_types_from_amendements.mjs +118 -0
- package/lib/scripts/reorganize_data.js +867 -446
- package/lib/scripts/reorganize_data.mjs +712 -0
- package/lib/scripts/retrieve_deputes_photos.js +378 -157
- package/lib/scripts/retrieve_deputes_photos.mjs +230 -0
- package/lib/scripts/retrieve_documents.js +648 -172
- package/lib/scripts/retrieve_documents.mjs +292 -0
- package/lib/scripts/retrieve_open_data.js +286 -85
- package/lib/scripts/retrieve_open_data.mjs +125 -0
- package/lib/scripts/retrieve_pending_amendments.js +302 -69
- package/lib/scripts/retrieve_pending_amendments.mjs +130 -0
- package/lib/scripts/retrieve_senateurs_photos.js +374 -198
- package/lib/scripts/retrieve_senateurs_photos.mjs +277 -0
- package/lib/scripts/retrieve_textes_lois.js +343 -89
- package/lib/scripts/retrieve_textes_lois.mjs +168 -0
- package/lib/scripts/test_load.js +30 -11
- package/lib/scripts/test_load.mjs +26 -0
- package/lib/scripts/test_load_big_files.js +30 -11
- package/lib/scripts/test_load_big_files.mjs +26 -0
- package/lib/scripts/validate_json.js +370 -120
- package/lib/scripts/validate_json.mjs +216 -0
- package/lib/shared_types/codes_actes.js +50 -15
- package/lib/shared_types/codes_actes.mjs +228 -0
- package/lib/strings.js +16 -3
- package/lib/strings.mjs +7 -0
- package/lib/types/acteurs_et_organes.js +156 -71
- package/lib/types/acteurs_et_organes.mjs +918 -0
- package/lib/types/agendas.js +154 -67
- package/lib/types/agendas.mjs +623 -0
- package/lib/types/amendements.js +166 -77
- package/lib/types/amendements.mjs +885 -0
- package/lib/types/dossiers_legislatifs.d.ts +1 -42
- package/lib/types/dossiers_legislatifs.js +182 -143
- package/lib/types/dossiers_legislatifs.mjs +1120 -0
- package/lib/types/legislatures.js +12 -3
- package/lib/types/legislatures.mjs +9 -0
- package/lib/types/scrutins.js +144 -61
- package/lib/types/scrutins.mjs +528 -0
- package/lib/urls.js +44 -25
- package/lib/urls.mjs +201 -0
- package/package.json +33 -12
package/lib/git.js
CHANGED
|
@@ -1,27 +1,88 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
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(
|
|
9
|
-
|
|
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 (
|
|
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
|
-
|
|
81
|
+
|
|
82
|
+
function test(repositoryDir, args, verbose) {
|
|
22
83
|
try {
|
|
23
|
-
if (verbose) console.log(
|
|
24
|
-
|
|
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
|
-
|
|
37
|
-
|
|
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(
|
|
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
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
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
|
-
|
|
69
|
-
|
|
70
|
-
fs.ensureDirSync(uidDirectory);
|
|
131
|
+
var _iterator = _createForOfIteratorHelper(subdirectories),
|
|
132
|
+
_step;
|
|
71
133
|
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
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,
|
|
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,
|
|
83
|
-
run(repositoryDir,
|
|
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,
|
|
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,
|
|
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,
|
|
92
|
-
run(repositoryDir,
|
|
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
|
-
|
|
98
|
-
|
|
99
|
-
|
|
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
|
-
|
|
200
|
+
var status = false;
|
|
103
201
|
|
|
104
202
|
if (!test(repositoryDir, "diff --quiet --cached")) {
|
|
105
|
-
run(repositoryDir,
|
|
203
|
+
run(repositoryDir, "commit -m 'Update'");
|
|
106
204
|
status = true;
|
|
107
205
|
}
|
|
108
206
|
|
|
109
|
-
run(repositoryDir,
|
|
110
|
-
|
|
111
|
-
run(repositoryDir,
|
|
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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"}
|