arelle-release 2.37.47__py3-none-any.whl → 2.37.48__py3-none-any.whl

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.

Potentially problematic release.


This version of arelle-release might be problematic. Click here for more details.

Files changed (94) hide show
  1. arelle/CntlrCmdLine.py +5 -1
  2. arelle/ModelObjectFactory.py +18 -2
  3. arelle/_version.py +2 -2
  4. {arelle_release-2.37.47.dist-info → arelle_release-2.37.48.dist-info}/METADATA +1 -1
  5. {arelle_release-2.37.47.dist-info → arelle_release-2.37.48.dist-info}/RECORD +9 -94
  6. arelle/archive/CustomLogger.py +0 -43
  7. arelle/archive/LoadEFMvalidate.py +0 -32
  8. arelle/archive/LoadSavePreLbCsv.py +0 -26
  9. arelle/archive/LoadValidate.cs +0 -31
  10. arelle/archive/LoadValidate.py +0 -36
  11. arelle/archive/LoadValidateCmdLine.java +0 -69
  12. arelle/archive/LoadValidatePostedZip.java +0 -57
  13. arelle/archive/LoadValidateWebService.java +0 -34
  14. arelle/archive/SaveTableToExelle.py +0 -140
  15. arelle/archive/TR3toTR4.py +0 -88
  16. arelle/archive/plugin/ESEF_2022/__init__.py +0 -47
  17. arelle/archive/plugin/bigInstance.py +0 -394
  18. arelle/archive/plugin/cmdWebServerExtension.py +0 -43
  19. arelle/archive/plugin/crashTest.py +0 -38
  20. arelle/archive/plugin/functionsXmlCreation.py +0 -106
  21. arelle/archive/plugin/hello_i18n.pot +0 -26
  22. arelle/archive/plugin/hello_i18n.py +0 -32
  23. arelle/archive/plugin/importTestChild1.py +0 -21
  24. arelle/archive/plugin/importTestChild2.py +0 -22
  25. arelle/archive/plugin/importTestGrandchild1.py +0 -21
  26. arelle/archive/plugin/importTestGrandchild2.py +0 -21
  27. arelle/archive/plugin/importTestImported1.py +0 -23
  28. arelle/archive/plugin/importTestImported11.py +0 -22
  29. arelle/archive/plugin/importTestParent.py +0 -48
  30. arelle/archive/plugin/instanceInfo.py +0 -306
  31. arelle/archive/plugin/loadFromOIM-2018.py +0 -1282
  32. arelle/archive/plugin/locale/fr/LC_MESSAGES/hello_i18n.po +0 -25
  33. arelle/archive/plugin/objectmaker.py +0 -285
  34. arelle/archive/plugin/packagedImportTest/__init__.py +0 -47
  35. arelle/archive/plugin/packagedImportTest/importTestChild1.py +0 -21
  36. arelle/archive/plugin/packagedImportTest/importTestChild2.py +0 -22
  37. arelle/archive/plugin/packagedImportTest/importTestGrandchild1.py +0 -21
  38. arelle/archive/plugin/packagedImportTest/importTestGrandchild2.py +0 -21
  39. arelle/archive/plugin/packagedImportTest/importTestImported1.py +0 -24
  40. arelle/archive/plugin/packagedImportTest/importTestImported11.py +0 -21
  41. arelle/archive/plugin/packagedImportTest/subdir/importTestImported111.py +0 -21
  42. arelle/archive/plugin/packagedImportTest/subdir/subsubdir/importTestImported1111.py +0 -21
  43. arelle/archive/plugin/sakaCalendar.py +0 -215
  44. arelle/archive/plugin/saveInstanceInfoset.py +0 -121
  45. arelle/archive/plugin/sphinx/FormulaGenerator.py +0 -823
  46. arelle/archive/plugin/sphinx/SphinxContext.py +0 -404
  47. arelle/archive/plugin/sphinx/SphinxEvaluator.py +0 -783
  48. arelle/archive/plugin/sphinx/SphinxMethods.py +0 -1287
  49. arelle/archive/plugin/sphinx/SphinxParser.py +0 -1093
  50. arelle/archive/plugin/sphinx/SphinxValidator.py +0 -163
  51. arelle/archive/plugin/sphinx/US-GAAP Ratios Example.xsr +0 -52
  52. arelle/archive/plugin/sphinx/__init__.py +0 -285
  53. arelle/archive/plugin/streamingExtensions.py +0 -335
  54. arelle/archive/plugin/updateTableLB.py +0 -242
  55. arelle/archive/plugin/validate/SBRnl/CustomLoader.py +0 -19
  56. arelle/archive/plugin/validate/SBRnl/DTS.py +0 -305
  57. arelle/archive/plugin/validate/SBRnl/Dimensions.py +0 -357
  58. arelle/archive/plugin/validate/SBRnl/Document.py +0 -799
  59. arelle/archive/plugin/validate/SBRnl/Filing.py +0 -467
  60. arelle/archive/plugin/validate/SBRnl/__init__.py +0 -75
  61. arelle/archive/plugin/validate/SBRnl/config.xml +0 -26
  62. arelle/archive/plugin/validate/SBRnl/sbr-nl-taxonomies.xml +0 -754
  63. arelle/archive/plugin/validate/USBestPractices.py +0 -570
  64. arelle/archive/plugin/validate/USCorpAction.py +0 -557
  65. arelle/archive/plugin/validate/USSecTagging.py +0 -337
  66. arelle/archive/plugin/validate/XDC/__init__.py +0 -77
  67. arelle/archive/plugin/validate/XDC/config.xml +0 -20
  68. arelle/archive/plugin/validate/XFsyntax/__init__.py +0 -64
  69. arelle/archive/plugin/validate/XFsyntax/xf.py +0 -2227
  70. arelle/archive/plugin/validate/calc2.py +0 -536
  71. arelle/archive/plugin/validateSchemaLxml.py +0 -156
  72. arelle/archive/plugin/validateTableInfoset.py +0 -52
  73. arelle/archive/us-gaap-dei-docType-extraction-frm.xml +0 -90
  74. arelle/archive/us-gaap-dei-ratio-cash-frm.xml +0 -150
  75. arelle/examples/plugin/formulaSuiteConverter.py +0 -212
  76. arelle/examples/plugin/functionsCustom.py +0 -59
  77. arelle/examples/plugin/hello_dolly.py +0 -64
  78. arelle/examples/plugin/multi.py +0 -58
  79. arelle/examples/plugin/rssSaveOim.py +0 -96
  80. arelle/examples/plugin/validate/XYZ/DisclosureSystems.py +0 -2
  81. arelle/examples/plugin/validate/XYZ/PluginValidationDataExtension.py +0 -10
  82. arelle/examples/plugin/validate/XYZ/ValidationPluginExtension.py +0 -50
  83. arelle/examples/plugin/validate/XYZ/__init__.py +0 -75
  84. arelle/examples/plugin/validate/XYZ/resources/config.xml +0 -16
  85. arelle/examples/plugin/validate/XYZ/rules/__init__.py +0 -0
  86. arelle/examples/plugin/validate/XYZ/rules/rules01.py +0 -110
  87. arelle/examples/plugin/validate/XYZ/rules/rules02.py +0 -59
  88. arelle/scripts-macOS/startWebServer.command +0 -3
  89. arelle/scripts-unix/startWebServer.sh +0 -1
  90. arelle/scripts-windows/startWebServer.bat +0 -5
  91. {arelle_release-2.37.47.dist-info → arelle_release-2.37.48.dist-info}/WHEEL +0 -0
  92. {arelle_release-2.37.47.dist-info → arelle_release-2.37.48.dist-info}/entry_points.txt +0 -0
  93. {arelle_release-2.37.47.dist-info → arelle_release-2.37.48.dist-info}/licenses/LICENSE.md +0 -0
  94. {arelle_release-2.37.47.dist-info → arelle_release-2.37.48.dist-info}/top_level.txt +0 -0
@@ -1,215 +0,0 @@
1
- #! /usr/bin/env python
2
- # -*- coding: utf-8 -*-
3
- # Calendar Program
4
- # Copyright 2008 Santhosh Thottingal <santhosh.thottingal@gmail.com>
5
- # http://www.smc.org.in
6
- #####
7
- # Arelle modification: interfaces to allow operation as a run-time user-discretion plug in
8
- # Hindi month names
9
- #
10
- # Note that this plug-in is LGPL-v3 and not Apache-2 see http://www.apache.org/licenses/GPL-compatibility.html
11
- #####
12
- #
13
- # This program is free software; you can redistribute it and/or modify
14
- # it under the terms of the GNU Lesser General Public License as published by
15
- # the Free Software Foundation; either version 3 of the License, or
16
- # (at your option) any later version.
17
- #
18
- # This program is distributed in the hope that it will be useful,
19
- # but WITHOUT ANY WARRANTY; without even the implied warranty of
20
- # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21
- # GNU Library General Public License for more details.
22
- #
23
- # You should have received a copy of the GNU Lesser General Public License
24
- # along with this program; if not, write to the Free Software
25
- # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
26
- #
27
- # If you find any bugs or have any suggestions email: santhosh.thottingal@gmail.com
28
-
29
- import math
30
- class SakaCalendar:
31
- JULIAN_EPOCH = 1721425.5
32
- SAKA_MONTH_NAMES= ["Chaitra", "Vaisakha", "Jyaishta", "Asadha", "Sravana", "Bhadra","Aswina", "Kartiak", "Agrahayana","Pausa","Magha","Phalguna"]
33
- SAKA_WEEK_NAMES= ["Ravivar", "Somavar", "Mangalvar", "Budhvar", "Sukhravar", "Guruvar","Sanivar"]
34
- IE = 0
35
- # The only practical difference from a Gregorian calendar is that years
36
- #are numbered since the Saka Era. A couple of overrides will
37
- #take care of that....
38
- # Starts in 78 AD,
39
- INDIAN_ERA_START = 78
40
- # The Indian year starts 80 days later than the Gregorian year.
41
- INDIAN_YEAR_START = 80
42
- def get_month_length(self, extendedYear, month):
43
- if month < 0 or month > 11:
44
- extendedYear += month/12 # floorDivide(month, 12, remainder)
45
- month = month%12
46
- if self.is_gregorian_leap(extendedYear + self.INDIAN_ERA_START) and month == 0:
47
- return 31
48
- if month >= 1 and month <=5 :
49
- return 31
50
- return 30
51
-
52
-
53
- """
54
- This routine converts an Indian date to the corresponding Julian date
55
- @param year The year in Saka Era according to Indian calendar.
56
- @param month The month according to Indian calendar (between 1 to 12)
57
- @param date The date in month
58
- """
59
- def saka_to_julian_date(self,year,month, date):
60
- gyear = year + self.INDIAN_ERA_START
61
- if self.is_gregorian_leap(gyear) :
62
- leapMonth = 31
63
- start = self.gregorian_to_julian_date(gyear, 3, 21)
64
- else :
65
- leapMonth = 30
66
- start = self.gregorian_to_julian_date(gyear, 3, 22)
67
- if month == 1 :
68
- jd = start + (date - 1)
69
- else:
70
- jd = start + leapMonth
71
- m = month - 2
72
- m = m if m <= 5 else 5
73
- jd += m * 31
74
- if month >= 8 :
75
- m = month - 7
76
- jd += m * 30
77
- jd += date - 1
78
- return jd
79
-
80
-
81
- """
82
- The following function is not needed for basic calendar functioning.
83
- This routine converts a gregorian date to the corresponding Julian date"
84
- @param year The year in standard Gregorian calendar (AD/BC) .
85
- @param month The month according to Gregorian calendar (between 0 to 11)
86
- @param date The date in month
87
- """
88
- def gregorian_to_julian_date(self, year, month, date) :
89
- jd = ((self.JULIAN_EPOCH - 1) +
90
- (365 * (year - 1)) +
91
- math.floor((year - 1) / 4) +
92
- (-math.floor((year - 1) / 100)) +
93
- math.floor((year - 1) / 400) +
94
- math.floor((((367 * month) - 362) / 12) +
95
- ( 0 if (month <= 2) else -1 if self.is_gregorian_leap(year) else -2) ) +
96
- date)
97
-
98
- return jd
99
-
100
-
101
- """
102
- The following function is not needed for basic calendar functioning.
103
- This routine converts a julian day (jd) to the corresponding date in Gregorian calendar"
104
- @param jd The Julian date in Julian Calendar which is to be converted to Indian date"
105
- """
106
- def julian_date_to_gregorian(self, jd) :
107
- julianDate=[None, None,None]
108
- wjd = math.floor(jd - 0.5) + 0.5
109
- depoch = wjd - self.JULIAN_EPOCH
110
- quadricent = math.floor(depoch / 146097)
111
- dqc = depoch % 146097
112
- cent = math.floor(dqc / 36524)
113
- dcent = dqc % 36524
114
- quad = math.floor(dcent / 1461)
115
- dquad = dcent % 1461
116
- yindex = math.floor(dquad / 365)
117
- year = int((quadricent * 400) + (cent * 100) + (quad * 4) + yindex)
118
- if not ((cent == 4) or (yindex == 4)) :
119
- year+=1
120
- yearday = wjd - self.gregorian_to_julian_date(year, 1, 1)
121
- leapadj = ( 0 if (wjd < self.gregorian_to_julian_date(year, 3, 1)) else 1 if self.is_gregorian_leap(year) else 2)
122
- month = int(math.floor((((yearday + leapadj) * 12) + 373) / 367))
123
- day = int((wjd - self.gregorian_to_julian_date(year, month, 1)) + 1)
124
- julianDate[0] = year
125
- julianDate[1] = month
126
- julianDate[2] = day
127
- return julianDate
128
-
129
-
130
- """
131
- The following function is not needed for basic calendar functioning.
132
- This routine checks if the Gregorian year is a leap year"
133
- @param year The year in Gregorian Calendar
134
- """
135
- def is_gregorian_leap(self,year):
136
- return ((year % 4) == 0) and (not(((year % 100) == 0) and ((year % 400) != 0)))
137
-
138
- def gregorian_to_saka_date(self, gregorianDay):
139
- indDate=[None,None,None]
140
- IndianYear = gregorianDay[0] - self.INDIAN_ERA_START # Year in Saka era
141
- jdAtStartOfGregYear = self. gregorian_to_julian_date(gregorianDay[0], 1, 1) # JD at start of Gregorian year
142
- julianDay = self.gregorian_to_julian_date( gregorianDay[0], gregorianDay[1], gregorianDay[2])
143
- yday = int(julianDay - jdAtStartOfGregYear) # Day number in Gregorian year (starting from 0)
144
- if yday < self.INDIAN_YEAR_START :
145
- # Day is at the end of the preceding Saka year
146
- IndianYear -= 1
147
- leapMonth = 31 if self.is_gregorian_leap(gregorianDay[0] - 1) else 30 # Days in leapMonth this year, previous Gregorian year
148
- yday += leapMonth + (31 * 5) + (30 * 3) + 10
149
- else:
150
- leapMonth = 31 if self.is_gregorian_leap(gregorianDay[0]) else 30 # Days in leapMonth this year
151
- yday -= self.INDIAN_YEAR_START
152
- if yday < leapMonth :
153
- IndianMonth = 0
154
- IndianDayOfMonth = yday + 1
155
- else :
156
- mday = yday - leapMonth
157
- if mday < (31 * 5) :
158
- IndianMonth = int(math.floor(mday / 31) + 1)
159
- IndianDayOfMonth = (mday % 31) + 1
160
- else :
161
- mday -= 31 * 5
162
- IndianMonth = int(math.floor(mday / 30)) + 6
163
- IndianDayOfMonth = (mday % 30) + 1
164
-
165
- #Month is 0 based.converting it to 1 based
166
- if IndianMonth == 12 :
167
- IndianMonth = 1
168
- else :
169
- IndianMonth = IndianMonth +1
170
- indDate[0]=IndianYear
171
- indDate[1]=IndianMonth
172
- indDate[2]=IndianDayOfMonth
173
- return indDate
174
- def get_month_name(self, month_index):
175
- return self.SAKA_MONTH_NAMES[month_index-1]
176
- def get_week_name(self, week_index) :
177
- return self.SAKA_WEEK_NAMES[week_index-1]
178
-
179
- # Arelle modifications follow this comment. They do not modify the behavior of the original module.
180
-
181
- def gregorianToSaka(gregorianDateArray):
182
- if (not isinstance(gregorianDateArray, (tuple,list)) or
183
- len(gregorianDateArray) != 3):
184
- raise ValueError("sakaCalendar:Invalid argument, must be tuple or list of yr,mo,day: {}".format(gregorianDateArray))
185
- return SakaCalendar().gregorian_to_saka_date(gregorianDateArray)
186
-
187
- def sakaToGregorian(sakaDateArray):
188
- if (not isinstance(sakaDateArray, (tuple,list)) or
189
- len(sakaDateArray) != 3):
190
- raise ValueError("sakaCalendar:Invalid argument, must be tuple or list of yr,mo,day: {}".format(sakaDateArray))
191
- sakaCal = SakaCalendar()
192
- sakaYr = sakaDateArray[0]
193
- sakaMo = sakaDateArray[1]
194
- sakaDay = sakaDateArray[2]
195
- # validate date
196
- if (not isinstance(sakaDateArray, (tuple,list)) or
197
- len(sakaDateArray) != 3 or
198
- not 1 <= sakaYr <= 9999 or
199
- not 1 <= sakaMo <= 12 or
200
- not 1 <= sakaDay <= sakaCal.get_month_length(sakaYr, sakaMo)):
201
- raise ValueError("sakaCalendar:InvalidDate: {} {} {}".format(sakaYr, sakaMo, sakaDay))
202
- # convert to gregorian calendar
203
- return sakaCal.julian_date_to_gregorian(sakaCal.saka_to_julian_date(sakaYr, sakaMo, sakaDay))
204
-
205
- __pluginInfo__ = {
206
- 'name': 'Saka Calendar',
207
- 'version': '1.0',
208
- 'description': "India National Calendar date validation and conversion. ",
209
- 'license': 'LGPL-v3',
210
- 'author': 'Santhosh Thottingal',
211
- 'copyright': '(c) Copyright 2008 Santhosh Thottingal <santhosh.thottingal@gmail.com>.',
212
- # classes of mount points (required)
213
- 'SakaCalendar.FromGregorian': gregorianToSaka,
214
- 'SakaCalendar.ToGregorian': sakaToGregorian,
215
- }
@@ -1,121 +0,0 @@
1
- '''
2
- Save Instance Infoset is an example of a plug-in to both GUI menu and command line/web service
3
- that will save facts decorated with ptv:periodType, ptv:balance, ptv:decimals and ptv:precision (inferred).
4
-
5
- See COPYRIGHT.md for copyright information.
6
- '''
7
- from arelle.Version import authorLabel, copyrightLabel
8
-
9
- def generateInstanceInfoset(dts, instanceInfosetFile):
10
- if dts.fileSource.isArchive:
11
- return
12
- import os, io
13
- from arelle import XmlUtil, XbrlConst
14
- from arelle.ValidateXbrlCalcs import inferredPrecision, inferredDecimals
15
-
16
- XmlUtil.setXmlns(dts.modelDocument, "ptv", "http://www.xbrl.org/2003/ptv")
17
-
18
- numFacts = 0
19
-
20
- for fact in dts.facts:
21
- try:
22
- if fact.concept.periodType:
23
- fact.set("{http://www.xbrl.org/2003/ptv}periodType", fact.concept.periodType)
24
- if fact.concept.balance:
25
- fact.set("{http://www.xbrl.org/2003/ptv}balance", fact.concept.balance)
26
- if fact.isNumeric and not fact.isNil:
27
- fact.set("{http://www.xbrl.org/2003/ptv}decimals", str(inferredDecimals(fact)))
28
- fact.set("{http://www.xbrl.org/2003/ptv}precision", str(inferredPrecision(fact)))
29
- numFacts += 1
30
- except Exception as err:
31
- dts.error("saveInfoset.exception",
32
- _("Facts exception %(fact)s %(value)s %(error)s."),
33
- modelObject=fact, fact=fact.qname, value=fact.effectiveValue, error = err)
34
-
35
- fh = open(instanceInfosetFile, "w", encoding="utf-8")
36
- XmlUtil.writexml(fh, dts.modelDocument.xmlDocument, encoding="utf-8")
37
- fh.close()
38
-
39
- dts.info("info:saveInstanceInfoset",
40
- _("Instance infoset of %(entryFile)s has %(numberOfFacts)s facts in infoset file %(infosetOutputFile)s."),
41
- modelObject=dts,
42
- entryFile=dts.uri, numberOfFacts=numFacts, infosetOutputFile=instanceInfosetFile)
43
-
44
- def saveInstanceInfosetMenuEntender(cntlr, menu):
45
- # Extend menu with an item for the save infoset plugin
46
- menu.add_command(label="Save infoset",
47
- underline=0,
48
- command=lambda: saveInstanceInfosetMenuCommand(cntlr) )
49
-
50
- def saveInstanceInfosetMenuCommand(cntlr):
51
- # save Infoset menu item has been invoked
52
- from arelle.ModelDocument import Type
53
- if cntlr.modelManager is None or cntlr.modelManager.modelXbrl is None or cntlr.modelManager.modelXbrl.modelDocument.type != Type.INSTANCE:
54
- cntlr.addToLog("No instance loaded.")
55
- return
56
-
57
- # get file name into which to save log file while in foreground thread
58
- instanceInfosetFile = cntlr.uiFileDialog("save",
59
- title=_("arelle - Save instance infoset file"),
60
- initialdir=cntlr.config.setdefault("infosetFileDir","."),
61
- filetypes=[(_("Infoset file .xml"), "*.xml")],
62
- defaultextension=".xml")
63
- if not instanceInfosetFile:
64
- return False
65
- import os
66
- cntlr.config["infosetFileDir"] = os.path.dirname(instanceInfosetFile)
67
- cntlr.saveConfig()
68
-
69
- try:
70
- generateInstanceInfoset(cntlr.modelManager.modelXbrl, instanceInfosetFile)
71
- except Exception as ex:
72
- dts = cntlr.modelManager.modelXbrl
73
- dts.error("exception",
74
- _("Instance infoset generation exception: %(error)s"), error=ex,
75
- modelXbrl=dts,
76
- exc_info=True)
77
-
78
- def saveInstanceInfosetCommandLineOptionExtender(parser):
79
- # extend command line options with a save DTS option
80
- parser.add_option("--save-instance-infoset",
81
- action="store",
82
- dest="instanceInfosetFile",
83
- help=_("Save instance infoset in specified file, or to send testcase infoset out files to out directory specify 'generateOutFiles'."))
84
-
85
- def saveInstanceInfosetCommandLineXbrlLoaded(cntlr, options, modelXbrl, *args, **kwargs):
86
- # extend XBRL-loaded run processing for this option
87
- from arelle.ModelDocument import Type
88
- if getattr(options, "instanceInfosetFile", None) and options.infosetFile == "generateOutFiles" and modelXbrl.modelDocument.type in (Type.TESTCASESINDEX, Type.TESTCASE):
89
- cntlr.modelManager.generateInfosetOutFiles = True
90
-
91
- def saveInstanceInfosetCommandLineXbrlRun(cntlr, options, modelXbrl, *args, **kwargs):
92
- # extend XBRL-loaded run processing for this option
93
- if getattr(options, "instanceInfosetFile", None) and options.instanceInfosetFile != "generateOutFiles":
94
- if cntlr.modelManager is None or cntlr.modelManager.modelXbrl is None:
95
- cntlr.addToLog("No taxonomy loaded.")
96
- return
97
- generateInstanceInfoset(cntlr.modelManager.modelXbrl, options.instanceInfosetFile)
98
-
99
- def validateInstanceInfoset(dts, instanceInfosetFile):
100
- if getattr(dts.modelManager, 'generateInfosetOutFiles', False):
101
- generateInstanceInfoset(dts,
102
- # normalize file to instance
103
- dts.modelManager.cntlr.webCache.normalizeUrl(instanceInfosetFile, dts.uri))
104
-
105
-
106
- __pluginInfo__ = {
107
- 'name': 'Save Instance Infoset (PTV)',
108
- 'version': '0.9',
109
- 'description': "This plug-in adds a feature to output an instance \"ptv\" infoset. "
110
- "(Does not offset infoset hrefs and schemaLocations for directory offset from DTS.) "
111
- "The ptv infoset is the source instance with facts having ptv:periodType, ptv:balance (where applicable), ptv:decimals and ptv:precision (inferred). ",
112
- 'license': 'Apache-2',
113
- 'author': authorLabel,
114
- 'copyright': copyrightLabel,
115
- # classes of mount points (required)
116
- 'CntlrWinMain.Menu.Tools': saveInstanceInfosetMenuEntender,
117
- 'CntlrCmdLine.Options': saveInstanceInfosetCommandLineOptionExtender,
118
- 'CntlrCmdLine.Xbrl.Loaded': saveInstanceInfosetCommandLineXbrlLoaded,
119
- 'CntlrCmdLine.Xbrl.Run': saveInstanceInfosetCommandLineXbrlRun,
120
- 'Validate.Infoset': validateInstanceInfoset,
121
- }