UNPKG

@tricoteuses/assemblee

Version:

Retrieve, clean up & handle French Assemblée nationale's open data

655 lines (651 loc) 94.8 kB
"use strict"; function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } require("core-js/modules/es.symbol.js"); require("core-js/modules/es.symbol.description.js"); require("core-js/modules/es.symbol.iterator.js"); require("core-js/modules/es.symbol.to-primitive.js"); require("core-js/modules/es.array.is-array.js"); require("core-js/modules/es.array.slice.js"); require("core-js/modules/es.date.to-primitive.js"); require("core-js/modules/es.date.to-string.js"); require("core-js/modules/es.function.bind.js"); require("core-js/modules/es.number.constructor.js"); require("core-js/modules/es.object.create.js"); require("core-js/modules/es.object.define-property.js"); require("core-js/modules/es.object.get-prototype-of.js"); require("core-js/modules/es.object.set-prototype-of.js"); require("core-js/modules/es.reflect.construct.js"); require("core-js/modules/es.array.concat.js"); require("core-js/modules/es.array.from.js"); require("core-js/modules/es.array.iterator.js"); require("core-js/modules/es.array.join.js"); require("core-js/modules/es.array.map.js"); require("core-js/modules/es.function.name.js"); require("core-js/modules/es.map.js"); require("core-js/modules/es.object.assign.js"); require("core-js/modules/es.object.entries.js"); require("core-js/modules/es.object.keys.js"); require("core-js/modules/es.object.to-string.js"); require("core-js/modules/es.regexp.constructor.js"); require("core-js/modules/es.regexp.exec.js"); require("core-js/modules/es.regexp.to-string.js"); require("core-js/modules/es.set.js"); require("core-js/modules/es.string.ends-with.js"); require("core-js/modules/es.string.iterator.js"); require("core-js/modules/es.string.match.js"); require("core-js/modules/es.string.replace.js"); require("core-js/modules/es.string.starts-with.js"); require("core-js/modules/web.dom-collections.iterator.js"); var _commandLineArgs = _interopRequireDefault(require("command-line-args")); var _commandLineUsage = _interopRequireDefault(require("command-line-usage")); var _assert = _interopRequireDefault(require("assert")); var _file_systems = require("../file_systems"); var _LectureMapping; function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; } function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); } function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } function _arrayWithHoles(r) { if (Array.isArray(r)) return r; } function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); } function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); } function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); } function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, 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 o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; } function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } function parseArgs(argv) { var optionsDefinitions = [{ description: "pathname to a JSON file or a glob pattern to JSON files", defaultOption: true, multiple: true, name: "data", type: String }, { name: "no-sanity-checks", type: Boolean, description: "Do not perform sanity checks." }, { name: "verbose", type: Boolean, description: "increase verbosity" }, { name: "help", description: "Print this usage guide." }]; var sections = [{ header: "Aide à la documentation du dossier législatif", content: "Génère une hiérarchie des actes législatifs" }, { header: "Options", optionList: optionsDefinitions }]; var options = (0, _commandLineArgs["default"])(optionsDefinitions, { argv: argv }); if (!("help" in options) && !("data" in options)) { console.error("--data is mandatory"); options.help = true; } if ("help" in options) { var usage = (0, _commandLineUsage["default"])(sections); console.warn(usage); return null; } return options; } function eqSet(as, bs) { if (as.size !== bs.size) return false; var _iterator = _createForOfIteratorHelper(as), _step; try { for (_iterator.s(); !(_step = _iterator.n()).done;) { var a = _step.value; if (!bs.has(a)) return false; } } catch (err) { _iterator.e(err); } finally { _iterator.f(); } return true; } var Code2Pattern = /*#__PURE__*/_createClass(function Code2Pattern(pattern, children) { _classCallCheck(this, Code2Pattern); _defineProperty(this, "_pattern_", void 0); _defineProperty(this, "_match_count_", void 0); this._pattern_ = pattern; this._match_count_ = 0; Object.assign(this, children); }); var Code2PatternComFond = /*#__PURE__*/function (_Code2Pattern2) { function Code2PatternComFond() { _classCallCheck(this, Code2PatternComFond); return _callSuper(this, Code2PatternComFond, ["^/SAISIE/(/NOMIN/)*(/REUNION/)*(/RAPPORT/)*$", {}]); } _inherits(Code2PatternComFond, _Code2Pattern2); return _createClass(Code2PatternComFond); }(Code2Pattern); var LectureMapping = /*#__PURE__*/function () { function LectureMapping() { _classCallCheck(this, LectureMapping); _defineProperty(this, "libelle", {}); _defineProperty(this, "codes", new Set()); } return _createClass(LectureMapping, [{ key: "add", value: function add(acte) { this.codes.add(acte.codeActe); var type = LectureMapping.getType(acte); if (!(acte.libelleActe.nomCanonique in this.libelle)) this.libelle[acte.libelleActe.nomCanonique] = new Set(); this.libelle[acte.libelleActe.nomCanonique].add(type); } }, { key: "remap", value: function remap(acte, codeActe) { acte.codeActe = codeActe; var types = this.libelle[acte.libelleActe.nomCanonique]; if (!(types.has("SN") && types.has("AN"))) { if (types.has("SN")) acte.libelleActe.nomCanonique += " (Sénat)";else if (types.has("AN")) acte.libelleActe.nomCanonique += " (Assemblée Nationale)"; } } }, { key: "mergeCodes", value: function mergeCodes(codes) { for (var _i = 0, _Array$from = Array.from(this.codes); _i < _Array$from.length; _i++) { var c = _Array$from[_i]; codes.add(c); } } }, { key: "printAnchors", value: function printAnchors() { for (var _i2 = 0, _Array$from2 = Array.from(this.codes); _i2 < _Array$from2.length; _i2++) { var code = _Array$from2[_i2]; console.log(".. _".concat(code, ":")); } } }, { key: "getCodes", value: function getCodes() { return Array.from(this.codes).join(","); } }], [{ key: "isLecture", value: function isLecture(acte) { return acte.codeActe.match(LectureMapping.codes_lecture_regexp); } }, { key: "getType", value: function getType(acte) { if (acte.codeActe.match(/^AN/)) return "AN";else if (acte.codeActe.match(/^SN/)) return "SN";else throw Error("".concat(acte.codeActe, " does not start with AN or SN")); } }, { key: "map", value: function map(codeActe) { return codeActe.replace(LectureMapping.codes_lecture_regexp, "lecture$1"); } }, { key: "getCodeActe", value: function getCodeActe(acte) { if (!LectureMapping.isLecture(acte)) return; return LectureMapping.map(acte.codeActe); } }]); }(); _LectureMapping = LectureMapping; _defineProperty(LectureMapping, "codes_lecture", ["AN1", "SN1", "ANNLEC", "SNNLEC", "ANLDEF", "AN2", "SN2", "SN3"]); _defineProperty(LectureMapping, "codes_lecture_regexp", new RegExp("^(?:" + _LectureMapping.codes_lecture.join("|") + ")(-.*)?$")); var LectureMapper = /*#__PURE__*/function () { function LectureMapper() { _classCallCheck(this, LectureMapper); _defineProperty(this, "mapping", {}); } return _createClass(LectureMapper, [{ key: "has", value: function has(codeActe) { return codeActe in this.mapping; } }, { key: "collect", value: function collect(acte) { var codeActe = LectureMapping.getCodeActe(acte); if (codeActe != undefined) { var lectures = this.mapping; if (!(codeActe in lectures)) lectures[codeActe] = new LectureMapping(); lectures[codeActe].add(acte); } } }, { key: "remap", value: function remap(acte) { var codeActe = LectureMapping.getCodeActe(acte); if (codeActe != undefined) this.mapping[codeActe].remap(acte, codeActe); } }, { key: "mergeCodes", value: function mergeCodes(codes, codeActe) { this.mapping[codeActe].mergeCodes(codes); } }, { key: "printAnchors", value: function printAnchors(codeActe) { this.mapping[codeActe].printAnchors(); } }, { key: "getCodes", value: function getCodes(codeActe) { return this.mapping[codeActe].getCodes(); } }]); }(); var ActesDocumentation = /*#__PURE__*/function () { function ActesDocumentation(sanityChecks) { var verbose = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; _classCallCheck(this, ActesDocumentation); _defineProperty(this, "verbose", void 0); _defineProperty(this, "sanityChecks", void 0); _defineProperty(this, "lectureMapper", new LectureMapper()); _defineProperty(this, "remappedProcedures", {}); _defineProperty(this, "anchorsPrinted", {}); _defineProperty(this, "anchors", new Set()); _defineProperty(this, "codes", {}); _defineProperty(this, "procedures", null); _defineProperty(this, "code2pattern", new Code2Pattern(null, { "Procédure législative": new Code2Pattern("^(((/lecture/)+)|((/lecture/)+/CMP/(/lecture/)*))(/CC/)?(/PROM/)?(/AN-APPLI/)?$", { lecture: new Code2Pattern("^(/DEPOT/)?(/DPTLETTRECT/)?(/ETI/)?(/AVCE/)?(/DGVT/)?(/ACIN/)?(/MOTION/)*(/PROCACC/)?(/COM/)?((/DEBATS/)+)?(/RTRINI/)?$", { "lecture-COM": new Code2Pattern("^(/FOND/|/AVIS/)+$", { "lecture-COM-FOND": new Code2PatternComFond(), "lecture-COM-AVIS": new Code2PatternComFond() }), "lecture-DEBATS": new Code2Pattern("^(/SEANCE/)*((/MOTION/)?(/MOTION-VOTE/)+)?(/DEC/)?$", {}) }), CMP: new Code2Pattern("^(/DEPOT/|/SAISIE/){1,2}(/COM/)?(/DEC/)?(/DEBATS-AN//DEBATS-SN/)?", { "CMP-COM": new Code2Pattern("^(/NOMIN/)?(/RAPPORT-AN/|/RAPPORT-SN/){2}$", {}), "CMP-DEBATS-AN": new Code2Pattern("^(/SEANCE/)*(/DEC/)?$", {}), "CMP-DEBATS-SN": new Code2Pattern("^(/SEANCE/)*(/DEC/)?$", {}) }), CC: new Code2Pattern("^(/SAISIE/)+(/CONCLUSION/)?$", {}), PROM: new Code2Pattern("^(/PUB/)?$", {}), "AN-APPLI": new Code2Pattern("^(/RAPPORT/)?$", {}) }), "Allocution du Président de l'Assemblée nationale": new Code2Pattern("^/AN21/$", { AN21: new Code2Pattern("^(/APAN/)?$", {}) }), "Résolution Article 34-1": new Code2Pattern("^(/ANLUNI/)?$", { ANLUNI: new Code2Pattern("^(/DEPOT/)?(/DEBATS/)?(/RTRINI/)?$", { "ANLUNI-DEBATS": new Code2Pattern("^(/SEANCE/)+(/DEC/)?$", {}) }) }), Résolution: new Code2Pattern("^(/ANLUNI/)?(/CC/)?$", { ANLUNI: new Code2Pattern("^(/DEPOT/)?(/COM/)?(/DEBATS/|/RTRINI/)?$", { "ANLUNI-COM": new Code2Pattern("^(/CAE/)?(/FOND/)?$", { "ANLUNI-COM-FOND": new Code2PatternComFond(), "ANLUNI-COM-CAE": new Code2Pattern("^(/SAISIE/)?(/NOMIN/)?(/REUNION/)?(/RAPPORT/)?(/DEC/)?$", {}) }), "ANLUNI-DEBATS": new Code2Pattern("^(/SEANCE/)*(/DEC/)?$", {}) }), CC: new Code2Pattern("^(/SAISIE/)?(/CONCLUSION/)?$", {}) }), "Rapport d'information sans mission": new Code2Pattern("^(/AN20/)?(/EU/)?$", { AN20: new Code2Pattern("^(/RAPPORT/)?$", {}), EU: new Code2Pattern("^(/DEC/)+$", {}) }), "Mission d'information": new Code2Pattern("^(/AN20/)?$", { AN20: new Code2Pattern("^(/MISINF/)?$", { "AN20-MISINF": new Code2Pattern("^(/CREA/)?(/NOMIN/)?(/RAPPORT/)?$", {}) }) }), "Commission d'enquête": new Code2Pattern("^(/AN20/)?$", { AN20: new Code2Pattern("^(/COMENQ/)?$", { "AN20-COMENQ": new Code2Pattern("^(/CREA/)?(/NOMIN/)?(/RAPPORT/)?$", {}) }) }), "Engagement de la responsabilité gouvernementale": new Code2Pattern("^/AN21/$", { AN21: new Code2Pattern("^(((/MOTION/)*/DEBATS/)|(/DGVT/)){1,2}$", { "AN21-DEBATS": new Code2Pattern("^(/SEANCE/)*(/MOTION-VOTE/)*$", {}) }) }), "Motion référendaire": new Code2Pattern("^(/lecture/)+$", { lecture: new Code2Pattern("^(/DEPOT/)?(/COM/)?(/DEBATS/)?$", { "lecture-COM": new Code2Pattern("^(/FOND/)?$", { "lecture-COM-FOND": new Code2Pattern("^(/SAISIE/)?(/NOMIN/)*(/RAPPORT/)*$", {}) }), "lecture-DEBATS": new Code2Pattern("^(/DEC/)?$", {}) }) }), Immunité: new Code2Pattern("^(/ANLUNI/)+$", { ANLUNI: new Code2Pattern("^(/DEPOT/)?(/COM/)?(/DEBATS/)?(/RTRINI/)?$", { "ANLUNI-COM": new Code2Pattern("^(/FOND/)?$", { "ANLUNI-COM-FOND": new Code2Pattern("^(/SAISIE/)?(/NOMIN/)*(/RAPPORT/)*$", {}) }), "ANLUNI-DEBATS": new Code2Pattern("^(/SEANCE/)?(/DEC/)$", {}) }) }), "Responsabilité pénale du président de la république": new Code2Pattern("^/lecture/$", { lecture: new Code2Pattern("^(/DEPOT/)?(/RECBUREAU/)?$", {}) }), "Proposition de loi présentée en application de l'article 11 de la Constitution": new Code2Pattern("^/lecture/$", { lecture: new Code2Pattern("^(/DEPOT/)?$", {}) }) })); this.verbose = verbose; this.sanityChecks = sanityChecks; this.procedures = {}; this.code2pattern._match_count_++; } return _createClass(ActesDocumentation, [{ key: "walkFiles", value: function walkFiles(data, action) { var _iterator2 = _createForOfIteratorHelper((0, _file_systems.getFiles)(data)), _step2; try { for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) { var file = _step2.value; var dossier = (0, _file_systems.load)(file); var procedure = this.remapProcedure(dossier.procedureParlementaire.libelle); if (!(procedure in this.procedures)) this.procedures[procedure] = {}; action(this.procedures[procedure], dossier.actesLegislatifs, this.code2pattern[procedure], null); } } catch (err) { _iterator2.e(err); } finally { _iterator2.f(); } } }, { key: "collectFiles", value: function collectFiles(data) { var _this = this; this.walkFiles(data, function (_actes, actesLegislatifs, _c2p, _parent) { _this.collect(actesLegislatifs); }); } }, { key: "processFiles", value: function processFiles(data) { var _this2 = this; this.walkFiles(data, function (actes, actesLegislatifs, c2p, parent) { _this2.merge(actes, actesLegislatifs, c2p, parent); }); if (this.sanityChecks) this.validate(); } }, { key: "remapActes", value: function remapActes(actes) { var results = []; var _iterator3 = _createForOfIteratorHelper(actes), _step3; try { for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) { var acte = _step3.value; this.lectureMapper.remap(acte); // CC-SAISIE- suffix does not imply a hierarchy acte.codeActe = acte.codeActe.replace(/^CC-SAISIE.*/, "CC-SAISIE"); results.push(acte); } } catch (err) { _iterator3.e(err); } finally { _iterator3.f(); } return results; } }, { key: "collectActes", value: function collectActes(actes) { var results = []; var _iterator4 = _createForOfIteratorHelper(actes), _step4; try { for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) { var acte = _step4.value; this.lectureMapper.collect(acte); results.push(acte); } } catch (err) { _iterator4.e(err); } finally { _iterator4.f(); } return results; } }, { key: "remapProcedure", value: function remapProcedure(procedure) { var merge_procedures = new Map([["Proposition de loi ordinaire", "Procédure législative"], ["Projet de loi ordinaire", "Procédure législative"], ["Projet de ratification des traités et conventions", "Procédure législative"], ["Projet ou proposition de loi organique", "Procédure législative"], ["Projet ou proposition de loi constitutionnelle", "Procédure législative"], ["Projet de loi de finances de l'année", "Procédure législative"], ["Projet de loi de finances rectificative", "Procédure législative"], ["Projet de loi de financement de la sécurité sociale", "Procédure législative"]]); if (merge_procedures.has(procedure)) { this.remappedProcedures[procedure] = null; return merge_procedures.get(procedure); } else { return procedure; } } // return the codeActes in the same order they appear in the regexp }, { key: "orderedCodes", value: function orderedCodes(codes, c2p, parent) { codes = new Set(codes); if (!this.sanityChecks) return codes; var ordered = c2p["_pattern_"].match(new RegExp("/.*?/", "g")); ordered = ordered.map(function (x) { return x.replace(new RegExp("/(.*)/"), "$1"); }); if (parent != null) ordered = ordered.map(function (x) { return "".concat(parent, "-").concat(x); }); ordered = new Set(ordered); (0, _assert["default"])(eqSet(ordered, codes), "".concat(_toConsumableArray(ordered), " != ").concat(_toConsumableArray(codes))); return ordered; } }, { key: "validateChronology", value: function validateChronology(actesLegislatifs, c2p, parent) { var pattern = c2p["_pattern_"]; var sequence = actesLegislatifs.map(function (x) { return "/".concat(x.codeActe, "/").replace("/".concat(parent, "-"), "/"); }).join(""); (0, _assert["default"])(sequence.match(new RegExp(pattern)), "".concat(pattern, " does not match ").concat(sequence)); c2p._match_count_++; } }, { key: "mergeActe", value: function mergeActe(actes, acte, c2p, parent) { var code = acte.codeActe; var shortCode = code.replace(new RegExp("^".concat(parent, "-")), ""); shortCode = shortCode.replace(/-(AN|SN)$/, ""); this.codes[shortCode] = null; var name = acte.libelleActe.nomCanonique; if (!(code in actes)) { actes[code] = { type: acte.xsiType, name: new Set([name]), shortCode: shortCode, actes: {} }; } else { actes[code].name.add(name); } if ("actesLegislatifs" in acte) this.merge(actes[code].actes, acte.actesLegislatifs, c2p[code], code); } }, { key: "merge", value: function merge(actes, actesLegislatifs, c2p, parent) { var l = this.remapActes(actesLegislatifs); this.validateChronology(l, c2p, parent); var _iterator5 = _createForOfIteratorHelper(l), _step5; try { for (_iterator5.s(); !(_step5 = _iterator5.n()).done;) { var acte = _step5.value; this.mergeActe(actes, acte, c2p, parent); } } catch (err) { _iterator5.e(err); } finally { _iterator5.f(); } } }, { key: "collect", value: function collect(actesLegislatifs) { var _iterator6 = _createForOfIteratorHelper(this.collectActes(actesLegislatifs)), _step6; try { for (_iterator6.s(); !(_step6 = _iterator6.n()).done;) { var acte = _step6.value; if ("actesLegislatifs" in acte) this.collect(acte.actesLegislatifs); } } catch (err) { _iterator6.e(err); } finally { _iterator6.f(); } } }, { key: "validateLevel", value: function validateLevel(c2p, path) { (0, _assert["default"])(c2p._match_count_ > 0, "".concat(path, " is never used")); for (var _i3 = 0, _arr = Object.entries(c2p); _i3 < _arr.length; _i3++) { var _arr$_i = _slicedToArray(_arr[_i3], 2), key = _arr$_i[0], value = _arr$_i[1]; if (value != null && value.constructor.name == "Code2Pattern") this.validateLevel(value, path.concat([key])); } } }, { key: "validate", value: function validate() { this.validateLevel(this.code2pattern, []); } }, { key: "printEntry", value: function printEntry(sections, entry, codes) { var title = "`".concat(entry, "`__"); console.log(title); var underline = new Array(title.length + 1).join(sections[0]); console.log(underline); console.log(codes); } }, { key: "addAnchors", value: function addAnchors(key) { if (key in this.anchorsPrinted) return; if (this.lectureMapper.has(key)) this.lectureMapper.mergeCodes(this.anchors, key);else this.anchors.add(key); } }, { key: "printAnchors", value: function printAnchors(key) { if (key in this.anchorsPrinted) return; this.anchorsPrinted[key] = null; if (this.lectureMapper.has(key)) this.lectureMapper.printAnchors(key);else console.log(".. _".concat(key, ":")); } }, { key: "getCodes", value: function getCodes(key, shortCode) { if (key in this.anchorsPrinted) return "cf \\*".concat(shortCode, "\\*"); if (this.lectureMapper.has(key)) return this.lectureMapper.getCodes(key);else return key; } }, { key: "renameCMP", value: function renameCMP(key, name) { if (key.startsWith("CMP")) { if (key.endsWith("-SN")) return "".concat(name, " (S\xE9nat)");else if (key.endsWith("-AN")) return "".concat(name, " (Assembl\xE9e Nationale)");else return name; } else return name; } }, { key: "printLevel", value: function printLevel(actes, sections, c2p, parent) { var keys = this.orderedCodes(Object.keys(actes), c2p, parent); var _iterator7 = _createForOfIteratorHelper(keys), _step7; try { for (_iterator7.s(); !(_step7 = _iterator7.n()).done;) { var key = _step7.value; var value = actes[key]; var name = Array.from(value.name).join(", "); name = this.renameCMP(key, name); var codes = this.getCodes(key, value.shortCode); this.addAnchors(key); this.printAnchors(key); console.log(""); this.printEntry(sections, "".concat(name, " <").concat(value.shortCode, "TOC_>"), codes); console.log(""); if (Object.keys(value.actes).length > 0) this.printLevel(value.actes, sections.substring(1), c2p[key], key); } } catch (err) { _iterator7.e(err); } finally { _iterator7.f(); } } }, { key: "printCodes", value: function printCodes() { for (var _i4 = 0, _Object$keys = Object.keys(this.codes); _i4 < _Object$keys.length; _i4++) { var key = _Object$keys[_i4]; console.log(".. _".concat(key, "TOC: http://")); } } }, { key: "printAnchorsIndex", value: function printAnchorsIndex() { for (var _i5 = 0, _Array$from3 = Array.from(this.anchors); _i5 < _Array$from3.length; _i5++) { var code = _Array$from3[_i5]; console.log("* :ref:`".concat(code, " <").concat(code, ">`")); } } }, { key: "getAggregated", value: function getAggregated(procedure) { if (procedure == "Procédure législative") { var remapped = Object.keys(this.remappedProcedures).join(", "); return " (agr\xE9gation de ".concat(remapped, ")"); } else return ""; } }, { key: "print", value: function print() { this.anchorsPrinted = {}; for (var _i6 = 0, _arr2 = Object.entries(this.procedures); _i6 < _arr2.length; _i6++) { var _arr2$_i = _slicedToArray(_arr2[_i6], 2), key = _arr2$_i[0], actes = _arr2$_i[1]; var code = key.replace(/ +/g, "_"); this.codes[code] = null; var aggregated = this.getAggregated(key); var title = "`".concat(key, " <").concat(code, "TOC_>`__").concat(aggregated); console.log(title); var underline = new Array(title.length + 1).join("="); console.log(underline); this.printLevel(actes, "-~.'", this.code2pattern[key], null); } this.printCodes(); this.printAnchorsIndex(); } }]); }(); function main(argv) { var options = parseArgs(argv); if (options === null) return 1; var doc = new ActesDocumentation(!options["no-sanity-checks"], options.verbose); doc.collectFiles(options.data); doc.processFiles(options.data); doc.print(); return 0; } /* istanbul ignore if */ if (process.argv[1].endsWith("document_dossiers_legislatifs.ts")) process.exit(main(process.argv)); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_commandLineArgs","_interopRequireDefault","require","_commandLineUsage","_assert","_file_systems","_LectureMapping","e","__esModule","_slicedToArray","r","_arrayWithHoles","_iterableToArrayLimit","_unsupportedIterableToArray","_nonIterableRest","TypeError","l","t","Symbol","iterator","n","i","u","a","f","o","call","next","Object","done","push","value","length","Array","isArray","_toConsumableArray","_arrayWithoutHoles","_iterableToArray","_nonIterableSpread","from","_arrayLikeToArray","_callSuper","_getPrototypeOf","_possibleConstructorReturn","_isNativeReflectConstruct","Reflect","construct","constructor","apply","_typeof","_assertThisInitialized","ReferenceError","Boolean","prototype","valueOf","setPrototypeOf","getPrototypeOf","bind","__proto__","_inherits","create","writable","configurable","defineProperty","_setPrototypeOf","_defineProperties","enumerable","_toPropertyKey","key","_createClass","_classCallCheck","_defineProperty","_toPrimitive","toPrimitive","String","Number","_createForOfIteratorHelper","_n","F","s","toString","slice","name","test","parseArgs","argv","optionsDefinitions","description","defaultOption","multiple","type","sections","header","content","optionList","options","commandLineArgs","console","error","help","usage","commandLineUsage","warn","eqSet","as","bs","size","_iterator","_step","has","err","Code2Pattern","pattern","children","_pattern_","_match_count_","assign","Code2PatternComFond","_Code2Pattern2","LectureMapping","Set","add","acte","codes","codeActe","getType","libelleActe","nomCanonique","libelle","remap","types","mergeCodes","_i","_Array$from","c","printAnchors","_i2","_Array$from2","code","log","concat","getCodes","join","isLecture","match","codes_lecture_regexp","Error","map","replace","getCodeActe","RegExp","codes_lecture","LectureMapper","mapping","collect","undefined","lectures","ActesDocumentation","sanityChecks","verbose","arguments","lecture","CMP","CC","PROM","AN21","ANLUNI","Résolution","AN20","EU","Immunité","procedures","code2pattern","walkFiles","data","action","_iterator2","getFiles","_step2","file","dossier","load","procedure","remapProcedure","procedureParlementaire","actesLegislatifs","collectFiles","_this","_actes","_c2p","_parent","processFiles","_this2","actes","c2p","parent","merge","validate","remapActes","results","_iterator3","_step3","lectureMapper","collectActes","_iterator4","_step4","merge_procedures","Map","remappedProcedures","get","orderedCodes","ordered","x","assert","validateChronology","sequence","mergeActe","shortCode","xsiType","_iterator5","_step5","_iterator6","_step6","validateLevel","path","_i3","_arr","entries","_arr$_i","printEntry","entry","title","underline","addAnchors","anchorsPrinted","anchors","renameCMP","startsWith","endsWith","printLevel","keys","_iterator7","_step7","substring","printCodes","_i4","_Object$keys","printAnchorsIndex","_i5","_Array$from3","getAggregated","remapped","print","_i6","_arr2","_arr2$_i","aggregated","main","doc","process","exit"],"sources":["../../src/scripts/document_dossiers_legislatifs.ts"],"sourcesContent":["import commandLineArgs from \"command-line-args\"\nimport commandLineUsage from \"command-line-usage\"\nimport assert from \"assert\"\nimport { load, getFiles } from \"../file_systems\"\n\nfunction parseArgs(argv: string[]): any {\n  const optionsDefinitions = [\n    {\n      description: \"pathname to a JSON file or a glob pattern to JSON files\",\n      defaultOption: true,\n      multiple: true,\n      name: \"data\",\n      type: String,\n    },\n    {\n      name: \"no-sanity-checks\",\n      type: Boolean,\n      description: \"Do not perform sanity checks.\",\n    },\n    {\n      name: \"verbose\",\n      type: Boolean,\n      description: \"increase verbosity\",\n    },\n    {\n      name: \"help\",\n      description: \"Print this usage guide.\",\n    },\n  ]\n  const sections = [\n    {\n      header: \"Aide à la documentation du dossier législatif\",\n      content: \"Génère une hiérarchie des actes législatifs\",\n    },\n    {\n      header: \"Options\",\n      optionList: optionsDefinitions,\n    },\n  ]\n  const options = commandLineArgs(optionsDefinitions, {\n    argv: argv,\n  })\n  if (!(\"help\" in options) && !(\"data\" in options)) {\n    console.error(\"--data is mandatory\")\n    options.help = true\n  }\n  if (\"help\" in options) {\n    const usage = commandLineUsage(sections)\n    console.warn(usage)\n    return null\n  }\n  return options\n}\n\nfunction eqSet(as: Set<string>, bs: Set<string>): boolean {\n  if (as.size !== bs.size) return false\n  for (var a of as) if (!bs.has(a)) return false\n  return true\n}\n\nclass Code2Pattern {\n  _pattern_: any\n  _match_count_: number\n  constructor(pattern: any, children: any) {\n    this._pattern_ = pattern\n    this._match_count_ = 0\n    Object.assign(this, children)\n  }\n}\n\nclass Code2PatternComFond extends Code2Pattern {\n  constructor() {\n    super(\"^/SAISIE/(/NOMIN/)*(/REUNION/)*(/RAPPORT/)*$\", {})\n  }\n}\n\nclass LectureMapping {\n  libelle: any = {}\n  codes: any = new Set()\n\n  static codes_lecture: string[] = [\n    \"AN1\",\n    \"SN1\",\n    \"ANNLEC\",\n    \"SNNLEC\",\n    \"ANLDEF\",\n    \"AN2\",\n    \"SN2\",\n    \"SN3\",\n  ]\n  static codes_lecture_regexp: any = new RegExp(\n    \"^(?:\" + LectureMapping.codes_lecture.join(\"|\") + \")(-.*)?$\",\n  )\n\n  static isLecture(acte: any) {\n    return acte.codeActe.match(LectureMapping.codes_lecture_regexp)\n  }\n\n  static getType(acte: any) {\n    if (acte.codeActe.match(/^AN/)) return \"AN\"\n    else if (acte.codeActe.match(/^SN/)) return \"SN\"\n    else throw Error(`${acte.codeActe} does not start with AN or SN`)\n  }\n\n  static map(codeActe: any) {\n    return codeActe.replace(LectureMapping.codes_lecture_regexp, `lecture$1`)\n  }\n\n  static getCodeActe(acte: any) {\n    if (!LectureMapping.isLecture(acte)) return\n\n    return LectureMapping.map(acte.codeActe)\n  }\n\n  add(acte: any) {\n    this.codes.add(acte.codeActe)\n\n    const type = LectureMapping.getType(acte)\n\n    if (!(acte.libelleActe.nomCanonique in this.libelle))\n      this.libelle[acte.libelleActe.nomCanonique] = new Set()\n    this.libelle[acte.libelleActe.nomCanonique].add(type)\n  }\n\n  remap(acte: any, codeActe: string) {\n    acte.codeActe = codeActe\n\n    let types = this.libelle[acte.libelleActe.nomCanonique]\n    if (!(types.has(\"SN\") && types.has(\"AN\"))) {\n      if (types.has(\"SN\")) acte.libelleActe.nomCanonique += \" (Sénat)\"\n      else if (types.has(\"AN\"))\n        acte.libelleActe.nomCanonique += \" (Assemblée Nationale)\"\n    }\n  }\n\n  mergeCodes(codes: any) {\n    for (const c of Array.from(this.codes)) codes.add(c)\n  }\n\n  printAnchors() {\n    for (const code of Array.from(this.codes)) console.log(`.. _${code}:`)\n  }\n\n  getCodes() {\n    return Array.from(this.codes).join(\",\")\n  }\n}\n\nclass LectureMapper {\n  mapping: any = {}\n\n  has(codeActe: string) {\n    return codeActe in this.mapping\n  }\n\n  collect(acte: any) {\n    const codeActe = LectureMapping.getCodeActe(acte)\n    if (codeActe != undefined) {\n      let lectures = this.mapping\n      if (!(codeActe in lectures)) lectures[codeActe] = new LectureMapping()\n      lectures[codeActe].add(acte)\n    }\n  }\n\n  remap(acte: any) {\n    const codeActe = LectureMapping.getCodeActe(acte)\n    if (codeActe != undefined) this.mapping[codeActe].remap(acte, codeActe)\n  }\n\n  mergeCodes(codes: any, codeActe: string) {\n    this.mapping[codeActe].mergeCodes(codes)\n  }\n\n  printAnchors(codeActe: string) {\n    this.mapping[codeActe].printAnchors()\n  }\n\n  getCodes(codeActe: string) {\n    return this.mapping[codeActe].getCodes()\n  }\n}\n\nclass ActesDocumentation {\n  verbose: boolean\n  sanityChecks: boolean\n  lectureMapper: any = new LectureMapper()\n  remappedProcedures: any = {}\n  anchorsPrinted: any = {}\n  anchors: any = new Set()\n  codes: any = {}\n  procedures: any = null\n  code2pattern: any = new Code2Pattern(null, {\n    \"Procédure législative\": new Code2Pattern(\n      \"^(((/lecture/)+)|((/lecture/)+/CMP/(/lecture/)*))(/CC/)?(/PROM/)?(/AN-APPLI/)?$\",\n      {\n        lecture: new Code2Pattern(\n          \"^(/DEPOT/)?(/DPTLETTRECT/)?(/ETI/)?(/AVCE/)?(/DGVT/)?(/ACIN/)?(/MOTION/)*(/PROCACC/)?(/COM/)?((/DEBATS/)+)?(/RTRINI/)?$\",\n          {\n            \"lecture-COM\": new Code2Pattern(\"^(/FOND/|/AVIS/)+$\", {\n              \"lecture-COM-FOND\": new Code2PatternComFond(),\n              \"lecture-COM-AVIS\": new Code2PatternComFond(),\n            }),\n            \"lecture-DEBATS\": new Code2Pattern(\n              \"^(/SEANCE/)*((/MOTION/)?(/MOTION-VOTE/)+)?(/DEC/)?$\",\n              {},\n            ),\n          },\n        ),\n        CMP: new Code2Pattern(\n          \"^(/DEPOT/|/SAISIE/){1,2}(/COM/)?(/DEC/)?(/DEBATS-AN//DEBATS-SN/)?\",\n          {\n            \"CMP-COM\": new Code2Pattern(\n              \"^(/NOMIN/)?(/RAPPORT-AN/|/RAPPORT-SN/){2}$\",\n              {},\n            ),\n            \"CMP-DEBATS-AN\": new Code2Pattern(\"^(/SEANCE/)*(/DEC/)?$\", {}),\n            \"CMP-DEBATS-SN\": new Code2Pattern(\"^(/SEANCE/)*(/DEC/)?$\", {}),\n          },\n        ),\n        CC: new Code2Pattern(\"^(/SAISIE/)+(/CONCLUSION/)?$\", {}),\n        PROM: new Code2Pattern(\"^(/PUB/)?$\", {}),\n        \"AN-APPLI\": new Code2Pattern(\"^(/RAPPORT/)?$\", {}),\n      },\n    ),\n    \"Allocution du Président de l'Assemblée nationale\": new Code2Pattern(\n      \"^/AN21/$\",\n      {\n        AN21: new Code2Pattern(\"^(/APAN/)?$\", {}),\n      },\n    ),\n    \"Résolution Article 34-1\": new Code2Pattern(\"^(/ANLUNI/)?$\", {\n      ANLUNI: new Code2Pattern(\"^(/DEPOT/)?(/DEBATS/)?(/RTRINI/)?$\", {\n        \"ANLUNI-DEBATS\": new Code2Pattern(\"^(/SEANCE/)+(/DEC/)?$\", {}),\n      }),\n    }),\n    Résolution: new Code2Pattern(\"^(/ANLUNI/)?(/CC/)?$\", {\n      ANLUNI: new Code2Pattern(\"^(/DEPOT/)?(/COM/)?(/DEBATS/|/RTRINI/)?$\", {\n        \"ANLUNI-COM\": new Code2Pattern(\"^(/CAE/)?(/FOND/)?$\", {\n          \"ANLUNI-COM-FOND\": new Code2PatternComFond(),\n          \"ANLUNI-COM-CAE\": new Code2Pattern(\n            \"^(/SAISIE/)?(/NOMIN/)?(/REUNION/)?(/RAPPORT/)?(/DEC/)?$\",\n            {},\n          ),\n        }),\n        \"ANLUNI-DEBATS\": new Code2Pattern(\"^(/SEANCE/)*(/DEC/)?$\", {}),\n      }),\n      CC: new Code2Pattern(\"^(/SAISIE/)?(/CONCLUSION/)?$\", {}),\n    }),\n    \"Rapport d'information sans mission\": new Code2Pattern(\n      \"^(/AN20/)?(/EU/)?$\",\n      {\n        AN20: new Code2Pattern(\"^(/RAPPORT/)?$\", {}),\n        EU: new Code2Pattern(\"^(/DEC/)+$\", {}),\n      },\n    ),\n    \"Mission d'information\": new Code2Pattern(\"^(/AN20/)?$\", {\n      AN20: new Code2Pattern(\"^(/MISINF/)?$\", {\n        \"AN20-MISINF\": new Code2Pattern(\n          \"^(/CREA/)?(/NOMIN/)?(/RAPPORT/)?$\",\n          {},\n        ),\n      }),\n    }),\n    \"Commission d'enquête\": new Code2Pattern(\"^(/AN20/)?$\", {\n      AN20: new Code2Pattern(\"^(/COMENQ/)?$\", {\n        \"AN20-COMENQ\": new Code2Pattern(\n          \"^(/CREA/)?(/NOMIN/)?(/RAPPORT/)?$\",\n          {},\n        ),\n      }),\n    }),\n    \"Engagement de la responsabilité gouvernementale\": new Code2Pattern(\n      \"^/AN21/$\",\n      {\n        AN21: new Code2Pattern(\"^(((/MOTION/)*/DEBATS/)|(/DGVT/)){1,2}$\", {\n          \"AN21-DEBATS\": new Code2Pattern(\"^(/SEANCE/)*(/MOTION-VOTE/)*$\", {}),\n        }),\n      },\n    ),\n    \"Motion référendaire\": new Code2Pattern(\"^(/lecture/)+$\", {\n      lecture: new Code2Pattern(\"^(/DEPOT/)?(/COM/)?(/DEBATS/)?$\", {\n        \"lecture-COM\": new Code2Pattern(\"^(/FOND/)?$\", {\n          \"lecture-COM-FOND\": new Code2Pattern(\n            \"^(/SAISIE/)?(/NOMIN/)*(/RAPPORT/)*$\",\n            {},\n          ),\n        }),\n        \"lecture-DEBATS\": new Code2Pattern(\"^(/DEC/)?$\", {}),\n      }),\n    }),\n    Immunité: new Code2Pattern(\"^(/ANLUNI/)+$\", {\n      ANLUNI: new Code2Pattern(\"^(/DEPOT/)?(/COM/)?(/DEBATS/)?(/RTRINI/)?$\", {\n        \"ANLUNI-COM\": new Code2Pattern(\"^(/FOND/)?$\", {\n          \"ANLUNI-COM-FOND\": new Code2Pattern(\n            \"^(/SAISIE/)?(/NOMIN/)*(/RAPPORT/)*$\",\n            {},\n          ),\n        }),\n        \"ANLUNI-DEBATS\": new Code2Pattern(\"^(/SEANCE/)?(/DEC/)$\", {}),\n      }),\n    }),\n    \"Responsabilité pénale du président de la république\": new Code2Pattern(\n      \"^/lecture/$\",\n      {\n        lecture: new Code2Pattern(\"^(/DEPOT/)?(/RECBUREAU/)?$\", {}),\n      },\n    ),\n    \"Proposition de loi présentée en application de l'article 11 de la Constitution\":\n      new Code2Pattern(\"^/lecture/$\", {\n        lecture: new Code2Pattern(\"^(/DEPOT/)?$\", {}),\n      }),\n  })\n\n  constructor(sanityChecks: boolean, verbose: boolean = false) {\n    this.verbose = verbose\n    this.sanityChecks = sanityChecks\n    this.procedures = {}\n    this.code2pattern._match_count_++\n  }\n\n  walkFiles(data: string[], action: any) {\n    for (const file of getFiles(data)) {\n      const dossier = load(file)\n      let procedure: string = this.remapProcedure(\n        dossier.procedureParlementaire.libelle,\n      )\n      if (!(procedure in this.procedures)) this.procedures[procedure] = {}\n      action(\n        this.procedures[procedure],\n        dossier.actesLegislatifs,\n        this.code2pattern[procedure],\n        null,\n      )\n    }\n  }\n\n  collectFiles(data: string[]) {\n    this.walkFiles(\n      data,\n      (_actes: any, actesLegislatifs: any, _c2p: any, _parent: string) => {\n        this.collect(actesLegislatifs)\n      },\n    )\n  }\n\n  processFiles(data: string[]) {\n    this.walkFiles(\n      data,\n      (actes: any, actesLegislatifs: any, c2p: any, parent: string) => {\n        this.merge(actes, actesLegislatifs, c2p, parent)\n      },\n    )\n    if (this.sanityChecks) this.validate()\n  }\n\n  remapActes(actes: any): any {\n    let results = []\n    for (const acte of actes) {\n      this.lectureMapper.remap(acte)\n\n      // CC-SAISIE- suffix does not imply a hierarchy\n      acte.codeActe = acte.codeActe.replace(/^CC-SAISIE.*/, \"CC-SAISIE\")\n\n      results.push(acte)\n    }\n    return results\n  }\n\n  collectActes(actes: any): any {\n    let results = []\n    for (const acte of actes) {\n      this.lectureMapper.collect(acte)\n\n      results.push(acte)\n    }\n    return results\n  }\n\n  remapProcedure(procedure: string): string {\n    const merge_procedures: Map<string, any> = new Map([\n      [\"Proposition de loi ordinaire\", \"Procédure législative\"],\n      [\"Projet de loi ordinaire\", \"Procédure législative\"],\n      [\n        \"Projet de ratification des traités et conventions\",\n       