arelle-release 2.37.47__py3-none-any.whl → 2.37.49__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 (100) hide show
  1. arelle/CntlrCmdLine.py +5 -1
  2. arelle/ModelObjectFactory.py +18 -2
  3. arelle/_version.py +2 -2
  4. arelle/plugin/validate/EDINET/Constants.py +6 -0
  5. arelle/plugin/validate/EDINET/PluginValidationDataExtension.py +134 -7
  6. arelle/plugin/validate/EDINET/Statement.py +139 -0
  7. arelle/plugin/validate/EDINET/rules/contexts.py +5 -10
  8. arelle/plugin/validate/EDINET/rules/edinet.py +89 -51
  9. arelle/plugin/validate/EDINET/rules/gfm.py +41 -0
  10. {arelle_release-2.37.47.dist-info → arelle_release-2.37.49.dist-info}/METADATA +3 -1
  11. {arelle_release-2.37.47.dist-info → arelle_release-2.37.49.dist-info}/RECORD +15 -99
  12. arelle/archive/CustomLogger.py +0 -43
  13. arelle/archive/LoadEFMvalidate.py +0 -32
  14. arelle/archive/LoadSavePreLbCsv.py +0 -26
  15. arelle/archive/LoadValidate.cs +0 -31
  16. arelle/archive/LoadValidate.py +0 -36
  17. arelle/archive/LoadValidateCmdLine.java +0 -69
  18. arelle/archive/LoadValidatePostedZip.java +0 -57
  19. arelle/archive/LoadValidateWebService.java +0 -34
  20. arelle/archive/SaveTableToExelle.py +0 -140
  21. arelle/archive/TR3toTR4.py +0 -88
  22. arelle/archive/plugin/ESEF_2022/__init__.py +0 -47
  23. arelle/archive/plugin/bigInstance.py +0 -394
  24. arelle/archive/plugin/cmdWebServerExtension.py +0 -43
  25. arelle/archive/plugin/crashTest.py +0 -38
  26. arelle/archive/plugin/functionsXmlCreation.py +0 -106
  27. arelle/archive/plugin/hello_i18n.pot +0 -26
  28. arelle/archive/plugin/hello_i18n.py +0 -32
  29. arelle/archive/plugin/importTestChild1.py +0 -21
  30. arelle/archive/plugin/importTestChild2.py +0 -22
  31. arelle/archive/plugin/importTestGrandchild1.py +0 -21
  32. arelle/archive/plugin/importTestGrandchild2.py +0 -21
  33. arelle/archive/plugin/importTestImported1.py +0 -23
  34. arelle/archive/plugin/importTestImported11.py +0 -22
  35. arelle/archive/plugin/importTestParent.py +0 -48
  36. arelle/archive/plugin/instanceInfo.py +0 -306
  37. arelle/archive/plugin/loadFromOIM-2018.py +0 -1282
  38. arelle/archive/plugin/locale/fr/LC_MESSAGES/hello_i18n.po +0 -25
  39. arelle/archive/plugin/objectmaker.py +0 -285
  40. arelle/archive/plugin/packagedImportTest/__init__.py +0 -47
  41. arelle/archive/plugin/packagedImportTest/importTestChild1.py +0 -21
  42. arelle/archive/plugin/packagedImportTest/importTestChild2.py +0 -22
  43. arelle/archive/plugin/packagedImportTest/importTestGrandchild1.py +0 -21
  44. arelle/archive/plugin/packagedImportTest/importTestGrandchild2.py +0 -21
  45. arelle/archive/plugin/packagedImportTest/importTestImported1.py +0 -24
  46. arelle/archive/plugin/packagedImportTest/importTestImported11.py +0 -21
  47. arelle/archive/plugin/packagedImportTest/subdir/importTestImported111.py +0 -21
  48. arelle/archive/plugin/packagedImportTest/subdir/subsubdir/importTestImported1111.py +0 -21
  49. arelle/archive/plugin/sakaCalendar.py +0 -215
  50. arelle/archive/plugin/saveInstanceInfoset.py +0 -121
  51. arelle/archive/plugin/sphinx/FormulaGenerator.py +0 -823
  52. arelle/archive/plugin/sphinx/SphinxContext.py +0 -404
  53. arelle/archive/plugin/sphinx/SphinxEvaluator.py +0 -783
  54. arelle/archive/plugin/sphinx/SphinxMethods.py +0 -1287
  55. arelle/archive/plugin/sphinx/SphinxParser.py +0 -1093
  56. arelle/archive/plugin/sphinx/SphinxValidator.py +0 -163
  57. arelle/archive/plugin/sphinx/US-GAAP Ratios Example.xsr +0 -52
  58. arelle/archive/plugin/sphinx/__init__.py +0 -285
  59. arelle/archive/plugin/streamingExtensions.py +0 -335
  60. arelle/archive/plugin/updateTableLB.py +0 -242
  61. arelle/archive/plugin/validate/SBRnl/CustomLoader.py +0 -19
  62. arelle/archive/plugin/validate/SBRnl/DTS.py +0 -305
  63. arelle/archive/plugin/validate/SBRnl/Dimensions.py +0 -357
  64. arelle/archive/plugin/validate/SBRnl/Document.py +0 -799
  65. arelle/archive/plugin/validate/SBRnl/Filing.py +0 -467
  66. arelle/archive/plugin/validate/SBRnl/__init__.py +0 -75
  67. arelle/archive/plugin/validate/SBRnl/config.xml +0 -26
  68. arelle/archive/plugin/validate/SBRnl/sbr-nl-taxonomies.xml +0 -754
  69. arelle/archive/plugin/validate/USBestPractices.py +0 -570
  70. arelle/archive/plugin/validate/USCorpAction.py +0 -557
  71. arelle/archive/plugin/validate/USSecTagging.py +0 -337
  72. arelle/archive/plugin/validate/XDC/__init__.py +0 -77
  73. arelle/archive/plugin/validate/XDC/config.xml +0 -20
  74. arelle/archive/plugin/validate/XFsyntax/__init__.py +0 -64
  75. arelle/archive/plugin/validate/XFsyntax/xf.py +0 -2227
  76. arelle/archive/plugin/validate/calc2.py +0 -536
  77. arelle/archive/plugin/validateSchemaLxml.py +0 -156
  78. arelle/archive/plugin/validateTableInfoset.py +0 -52
  79. arelle/archive/us-gaap-dei-docType-extraction-frm.xml +0 -90
  80. arelle/archive/us-gaap-dei-ratio-cash-frm.xml +0 -150
  81. arelle/examples/plugin/formulaSuiteConverter.py +0 -212
  82. arelle/examples/plugin/functionsCustom.py +0 -59
  83. arelle/examples/plugin/hello_dolly.py +0 -64
  84. arelle/examples/plugin/multi.py +0 -58
  85. arelle/examples/plugin/rssSaveOim.py +0 -96
  86. arelle/examples/plugin/validate/XYZ/DisclosureSystems.py +0 -2
  87. arelle/examples/plugin/validate/XYZ/PluginValidationDataExtension.py +0 -10
  88. arelle/examples/plugin/validate/XYZ/ValidationPluginExtension.py +0 -50
  89. arelle/examples/plugin/validate/XYZ/__init__.py +0 -75
  90. arelle/examples/plugin/validate/XYZ/resources/config.xml +0 -16
  91. arelle/examples/plugin/validate/XYZ/rules/__init__.py +0 -0
  92. arelle/examples/plugin/validate/XYZ/rules/rules01.py +0 -110
  93. arelle/examples/plugin/validate/XYZ/rules/rules02.py +0 -59
  94. arelle/scripts-macOS/startWebServer.command +0 -3
  95. arelle/scripts-unix/startWebServer.sh +0 -1
  96. arelle/scripts-windows/startWebServer.bat +0 -5
  97. {arelle_release-2.37.47.dist-info → arelle_release-2.37.49.dist-info}/WHEEL +0 -0
  98. {arelle_release-2.37.47.dist-info → arelle_release-2.37.49.dist-info}/entry_points.txt +0 -0
  99. {arelle_release-2.37.47.dist-info → arelle_release-2.37.49.dist-info}/licenses/LICENSE.md +0 -0
  100. {arelle_release-2.37.47.dist-info → arelle_release-2.37.49.dist-info}/top_level.txt +0 -0
@@ -1,306 +0,0 @@
1
- '''
2
- instanceInfo.py provides information about an XBRL instance
3
-
4
- See COPYRIGHT.md for copyright information.
5
-
6
- Operation with arelleCmdLine: --plugin instanceInfo -f entryUrl
7
-
8
- '''
9
- import sys, os, time, math, logging
10
- import regex as re
11
- from math import isnan
12
- from collections import defaultdict
13
- from arelle.ValidateXbrlCalcs import inferredDecimals, rangeValue
14
- from arelle import ModelDocument
15
- from arelle.ModelInstanceObject import ModelFact
16
- from arelle.Version import authorLabel, copyrightLabel
17
- from arelle.XbrlConst import xhtml
18
- from arelle.XmlUtil import ancestors, xmlstring
19
-
20
- memoryAtStartup = 0
21
- timeAtStart = 0
22
- styleIxHiddenPattern = re.compile(r"(.*[^\w]|^)-(sec|esef)-ix-hidden\s*:\s*([\w.-]+).*")
23
-
24
- def startup(cntlr, options, *args, **kwargs):
25
- global memoryAtStartup, timeAtStart
26
- memoryAtStartup = cntlr.memoryUsed
27
- timeAtStart = time.time()
28
-
29
-
30
-
31
- def showInfo(cntlr, options, modelXbrl, _entrypoint, *args, **kwargs):
32
- for url, doc in sorted(modelXbrl.urlDocs.items(), key=lambda i: i[0]):
33
- if not any(url.startswith(w) for w in ("https://xbrl.sec.gov/", "http://xbrl.sec.gov/", "http://xbrl.fasb.org/", "http://www.xbrl.org/",
34
- "http://xbrl.ifrs.org/", "http://www.esma.europa.eu/")):
35
- if os.path.exists(doc.filepath): # skip if in an archive or stream
36
- cntlr.addToLog("File {} size {:,}".format(doc.basename, os.path.getsize(doc.filepath)), messageCode="info", level=logging.DEBUG)
37
- cntlr.addToLog("Heap memory before loading {:,}".format(memoryAtStartup), messageCode="info", level=logging.DEBUG)
38
- cntlr.addToLog("Heap memory after loading {:,}".format(cntlr.memoryUsed), messageCode="info", level=logging.DEBUG)
39
- cntlr.addToLog("Time to load {:.2f} seconds".format(time.time() - timeAtStart), messageCode="info", level=logging.DEBUG)
40
- isInlineXbrl = modelXbrl.modelDocument.type in (ModelDocument.Type.INLINEXBRL, ModelDocument.Type.INLINEXBRLDOCUMENTSET)
41
- if isInlineXbrl:
42
- instanceType = "inline XBRL, number of documents {}".format(len(modelXbrl.ixdsHtmlElements))
43
- else:
44
- instanceType = "xBRL-XML"
45
- cntlr.addToLog("Instance type {}".format(instanceType), messageCode="info", level=logging.DEBUG)
46
- numContexts = len(modelXbrl.contexts)
47
- numLongContexts = 0
48
- bytesSaveableInline = 0
49
- bytesSaveableInlineWithCsv = 0
50
- frequencyOfDims = {}
51
- sumNumDims = 0
52
- distinctDurations = set()
53
- distinctInstants = set()
54
- shortContextIdLen = int(math.log10(numContexts or 1)) + 2 # if no contexts, use 1 for log function to work
55
- xbrlQnameCountInline = 0
56
- xbrlQnameCountInlineWithCsv = 0
57
- xbrlQnameLengthsInline = 0
58
- xbrlQnameLengthsInlineWithCsv = 0
59
- for c in modelXbrl.contexts.values():
60
- sumNumDims += len(c.qnameDims)
61
- for d in c.qnameDims.values():
62
- dimQname = str(d.dimensionQname)
63
- frequencyOfDims[dimQname] = frequencyOfDims.get(dimQname,0) + 1
64
- xbrlQnameCountInline += 1
65
- xbrlQnameCountInlineWithCsv += 1
66
- xbrlQnameLengthsInline += len(d.dimensionQname.localName)
67
- xbrlQnameLengthsInlineWithCsv += len(d.dimensionQname.localName)
68
- if c.isInstantPeriod:
69
- distinctInstants.add(c.instantDatetime)
70
- elif c.isStartEndPeriod:
71
- distinctDurations.add((c.startDatetime, c.endDatetime))
72
- if len(c.id) > shortContextIdLen:
73
- bytesSaveableInline += len(c.id) - shortContextIdLen
74
- bytesSaveableInlineWithCsv += len(c.id) - shortContextIdLen
75
- cntlr.addToLog("Number of contexts {:,}".format(numContexts), messageCode="info", level=logging.DEBUG)
76
- cntlr.addToLog("Number of distinct durations {:,}".format(len(distinctDurations)), messageCode="info", level=logging.DEBUG)
77
- cntlr.addToLog("Number of distinct instants {:,}".format(len(distinctInstants)), messageCode="info", level=logging.DEBUG)
78
- cntlr.addToLog("Avg number dimensions per contexts {:,.2f}".format(sumNumDims/numContexts if numContexts else 0), messageCode="info", level=logging.DEBUG)
79
- mostPopularDims = sorted(frequencyOfDims.items(), key=lambda i:"{:0>9},{}".format(999999999-i[1],i[0]))
80
- for dimName, count in mostPopularDims[0:3]:
81
- cntlr.addToLog("Dimension {} used in {:,} contexts".format(dimName, count), messageCode="info", level=logging.DEBUG)
82
-
83
- # analyze for tables which could be composed from CSV data
84
- tblFacts = defaultdict(set)
85
- tblNestedTables = defaultdict(set)
86
- factSize = {}
87
- for f in modelXbrl.factsInInstance:
88
- for tdElt in ancestors(f, xhtml, "td"):
89
- factSize[f] = len(xmlstring(tdElt,stripXmlns=True))
90
- break
91
- childTblElt = None
92
- for tblElt in ancestors(f, xhtml, "table"):
93
- tblFacts[tblElt].add(f)
94
- if childTblElt:
95
- tblNestedTables[tblElt].add(childTblElt)
96
-
97
- # find tables containing only numeric facts
98
- def tblNestedFactCount(tbl):
99
- c = len(tblFacts.get(tbl, ()))
100
- for nestedTbl in tblNestedTables.get(tbl,()):
101
- c += tblNestedFactCount(nestedTbl)
102
- return c
103
-
104
- factsInInstance = len(modelXbrl.factsInInstance)
105
- factsInTables = len(set.union(*(fset for fset in tblFacts.values())))
106
- cntlr.addToLog("Facts in instance: {:,}, facts in tables: {:,}".format(factsInInstance,factsInTables), messageCode="info", level=logging.DEBUG)
107
-
108
- numTblsEligible = 0
109
- numFactsEligible = 0
110
- bytesCsvSavings = 0
111
- factsEligibleForCsv = set()
112
- tablesWithEligibleFacts = set()
113
- if tblFacts and factSize:
114
- # find eligible tables, have facts and not nested tables with other facts
115
- for tbl, facts in tblFacts.items():
116
- if len(facts) == tblNestedFactCount(tbl):
117
- s = sum(factSize.get(f,0) for f in facts) - sum(len(str(f.value)) for f in facts)
118
- if s > 10000:
119
- numTblsEligible += 1
120
- bytesCsvSavings += s
121
- numFactsEligible += len(facts)
122
- factsEligibleForCsv |= facts
123
- tablesWithEligibleFacts.add(tbl)
124
- numFacts = 0
125
- numTableTextBlockFacts = 0
126
- lenTableTextBlockFacts = 0
127
- numTextBlockFacts = 0
128
- lenTextBlockFacts = 0
129
- distinctElementsInFacts = set()
130
- factsPerContext = {}
131
- factForConceptContextUnitHash = defaultdict(list)
132
- for f in modelXbrl.factsInInstance:
133
- context = f.context
134
- concept = f.concept
135
- distinctElementsInFacts.add(f.qname)
136
- numFacts += 1
137
- if f.qname.localName.endswith("TableTextBlock"):
138
- numTableTextBlockFacts += 1
139
- lenTableTextBlockFacts += len(f.xValue)
140
- elif f.qname.localName.endswith("TextBlock"):
141
- numTextBlockFacts += 1
142
- lenTextBlockFacts += len(f.xValue)
143
- if context is not None and concept is not None:
144
- factsPerContext[context.id] = factsPerContext.get(context.id,0) + 1
145
- factForConceptContextUnitHash[f.conceptContextUnitHash].append(f)
146
- bytesSaveableInline += len(context.id) - shortContextIdLen
147
- if f not in factsEligibleForCsv:
148
- bytesSaveableInlineWithCsv += len(context.id) - shortContextIdLen
149
-
150
-
151
- if numTblsEligible:
152
- cntlr.addToLog("Tables eligible for facts in CSV: {:,}, facts eligible for CSV: {:,}, bytes saveable by facts in CSV {:,}".format(numTblsEligible, numFactsEligible, bytesCsvSavings), messageCode="info", level=logging.DEBUG)
153
- else:
154
- cntlr.addToLog("No tables eligible for facts in CSV", messageCode="info", level=logging.DEBUG)
155
-
156
-
157
- mostPopularContexts = sorted(factsPerContext.items(), key=lambda i:"{:0>9},{}".format(999999999-i[1],i[0]))
158
- cntlr.addToLog("Number of facts {:,}".format(numFacts), messageCode="info", level=logging.DEBUG)
159
- cntlr.addToLog("Number of TableTextBlock facts {:,} avg len {:,.0f}".format(numTableTextBlockFacts, lenTableTextBlockFacts/numTableTextBlockFacts if numTableTextBlockFacts else 0), messageCode="info", level=logging.DEBUG)
160
- cntlr.addToLog("Number of TextBlock facts {:,} avg len {:,.0f}".format(numTextBlockFacts, lenTextBlockFacts/numTableTextBlockFacts if numTableTextBlockFacts else 0), messageCode="info", level=logging.DEBUG)
161
- cntlr.addToLog("Max number facts per context {:,}".format(mostPopularContexts[0][1] if mostPopularContexts else 0), messageCode="info", level=logging.DEBUG)
162
- cntlr.addToLog("Avg number facts per context {:,.2f}".format(sum([v for v in factsPerContext.values()])/numContexts if numContexts else 0), messageCode="info", level=logging.DEBUG)
163
- cntlr.addToLog("Distinct elements in facts {:,}".format(len(distinctElementsInFacts)), messageCode="info", level=logging.DEBUG)
164
- cntlr.addToLog("Number of bytes saveable context id of {} length is {:,}".format(shortContextIdLen, bytesSaveableInline), messageCode="info", level=logging.DEBUG)
165
- cntlr.addToLog("Excepting facts eligible for CSV, number of bytes saveable context id of {} length is {:,}".format(shortContextIdLen, bytesSaveableInlineWithCsv), messageCode="info", level=logging.DEBUG)
166
-
167
- aspectEqualFacts = defaultdict(list)
168
- decVals = {}
169
- numConsistentDupFacts = numInConsistentDupFacts = 0
170
- for hashEquivalentFacts in factForConceptContextUnitHash.values():
171
- if len(hashEquivalentFacts) > 1:
172
- for f in hashEquivalentFacts:
173
- aspectEqualFacts[(f.qname,f.contextID,f.unitID,
174
- f.xmlLang.lower() if f.concept.type.isWgnStringFactType else None)].append(f)
175
- for fList in aspectEqualFacts.values():
176
- f0 = fList[0]
177
- if f0.concept.isNumeric:
178
- if any(f.isNil for f in fList):
179
- _inConsistent = not all(f.isNil for f in fList)
180
- else: # not all have same decimals
181
- _d = inferredDecimals(f0)
182
- _v = f0.xValue
183
- _inConsistent = isnan(_v) # NaN is incomparable, always makes dups inconsistent
184
- decVals[_d] = _v
185
- aMax, bMin, _inclA, _inclB = rangeValue(_v, _d)
186
- for f in fList[1:]:
187
- _d = inferredDecimals(f)
188
- _v = f.xValue
189
- if isnan(_v):
190
- _inConsistent = True
191
- break
192
- if _d in decVals:
193
- _inConsistent |= _v != decVals[_d]
194
- else:
195
- decVals[_d] = _v
196
- a, b, _inclA, _inclB = rangeValue(_v, _d)
197
- if a > aMax: aMax = a
198
- if b < bMin: bMin = b
199
- if not _inConsistent:
200
- _inConsistent = (bMin < aMax)
201
- decVals.clear()
202
- else:
203
- _inConsistent = any(not f.isVEqualTo(f0) for f in fList[1:])
204
- if _inConsistent:
205
- numInConsistentDupFacts += 1
206
- else:
207
- numConsistentDupFacts += 1
208
-
209
- aspectEqualFacts.clear()
210
- cntlr.addToLog("Number of duplicate facts consistent {:,} inconsistent {:,}".format(numConsistentDupFacts, numInConsistentDupFacts), messageCode="info", level=logging.DEBUG)
211
-
212
- styleAttrCountsInline = {}
213
- styleAttrCountsInlineWithCsv = {}
214
- totalStyleLenInline = 0
215
- totalStyleLenInlineWithCsv = 0
216
- continuationElements = {}
217
- ixNsPrefix = "{http://www.xbrl.org/2013/inlineXBRL}"
218
- for ixdsHtmlRootElt in getattr(modelXbrl, "ixdsHtmlElements", ()): # ix root elements if inline
219
- for ixElt in ixdsHtmlRootElt.iterdescendants():
220
- inEligibleTableForCsv = any(p in tablesWithEligibleFacts for p in ixElt.iterancestors("{http://www.w3.org/1999/xhtml}table"))
221
- style = ixElt.get("style")
222
- ixEltTag = str(ixElt.tag)
223
- if style:
224
- styleAttrCountsInline[style] = styleAttrCountsInline.get(style,0) + 1
225
- if not inEligibleTableForCsv:
226
- styleAttrCountsInlineWithCsv[style] = styleAttrCountsInlineWithCsv.get(style,0) + 1
227
- if styleIxHiddenPattern.match(style) is None:
228
- totalStyleLenInline += len(style)
229
- if not inEligibleTableForCsv:
230
- totalStyleLenInlineWithCsv += len(style)
231
- if ixEltTag == "{http://www.xbrl.org/2013/inlineXBRL}continuation" and ixElt.id:
232
- continuationElements[ixElt.id] = ixElt
233
- if ixEltTag.startswith(ixNsPrefix):
234
- localName = ixEltTag[len(ixNsPrefix):]
235
- if localName == "continuation" and ixElt.id:
236
- continuationElements[ixElt.id] = ixElt
237
- elif localName in ("nonFraction", "nonNumeric", "fraction"):
238
- xbrlQnameCountInline += 1
239
- xbrlQnameLengthsInline += len(ixElt.qname.localName)
240
- if not inEligibleTableForCsv:
241
- xbrlQnameCountInlineWithCsv += 1
242
- xbrlQnameLengthsInlineWithCsv += len(ixElt.qname.localName)
243
- elif isinstance(ixElt, ModelFact):
244
- xbrlQnameCountInline += 2
245
- xbrlQnameLengthsInline += len(ixElt.qname.localName)
246
- if not inEligibleTableForCsv:
247
- xbrlQnameCountInlineWithCsv += 2
248
- xbrlQnameLengthsInlineWithCsv += len(ixElt.qname.localName)
249
-
250
- def locateContinuation(element, chain=None):
251
- contAt = element.get("continuedAt")
252
- if contAt:
253
- if contAt in continuationElements:
254
- if chain is None: chain = [element]
255
- contElt = continuationElements[contAt]
256
- if contElt not in chain:
257
- chain.append(contElt)
258
- element._continuationElement = contElt
259
- return locateContinuation(contElt, chain)
260
- elif chain: # end of chain
261
- return len(chain)
262
-
263
- numContinuations = 0
264
- maxLenLen = 0
265
- maxLenHops = 0
266
- maxHops = 0
267
- maxHopsLen = 0
268
- for f in modelXbrl.factsInInstance:
269
- if f.get("continuedAt"):
270
- numContinuations += 1
271
- _len = len(f.xValue)
272
- _hops = locateContinuation(f)
273
- if _hops > maxHops:
274
- maxHops = _hops
275
- maxHopsLen = _len
276
- if _len > maxLenLen:
277
- maxLenLen = _len
278
- maxLenHops = _hops
279
-
280
- cntlr.addToLog("Number of continuation facts {:,}".format(numContinuations), messageCode="info", level=logging.DEBUG)
281
- cntlr.addToLog("Longest continuation fact {:,} number of hops {:,}".format(maxLenLen, maxLenHops), messageCode="info", level=logging.DEBUG)
282
- cntlr.addToLog("Most continuation hops {:,} fact len {:,}".format(maxHops, maxHopsLen), messageCode="info", level=logging.DEBUG)
283
-
284
- numDupStyles = sum(1 for n in styleAttrCountsInline.values() if n > 1)
285
- bytesSaveableByCssInline = sum(len(s)*(n-1) for s,n in styleAttrCountsInline.items() if n > 1)
286
- cntlr.addToLog("Number of duplicate styles {:,}, bytes saveable by CSS {:,}, len of all non-ix-hidden @styles {:,}".format(numDupStyles, bytesSaveableByCssInline, totalStyleLenInline), messageCode="info", level=logging.DEBUG)
287
- cntlr.addToLog("Number of XBRL QNames {:,}, bytes saveable by EBA-style element names {:,}".format(xbrlQnameCountInline, xbrlQnameLengthsInline - (5*xbrlQnameCountInline)), messageCode="info", level=logging.DEBUG)
288
- numDupStyles = sum(1 for n in styleAttrCountsInlineWithCsv.values() if n > 1)
289
- bytesSaveableByCssInlineWithCsv = sum(len(s)*(n-1) for s,n in styleAttrCountsInlineWithCsv.items() if n > 1)
290
- cntlr.addToLog("Excepting facts eligible for CSV, number of duplicate styles {:,}, bytes saveable by CSS {:,}, len of all non-ix-hidden @styles {:,}".format(numDupStyles, bytesSaveableByCssInlineWithCsv, totalStyleLenInlineWithCsv), messageCode="info", level=logging.DEBUG)
291
- cntlr.addToLog("Excepting facts eligible for CSV, number of XBRL QNames {:,}, bytes saveable by EBA-style element names {:,}".format(xbrlQnameCountInlineWithCsv, xbrlQnameLengthsInlineWithCsv - (5*xbrlQnameCountInlineWithCsv)), messageCode="info", level=logging.DEBUG)
292
-
293
-
294
-
295
- __pluginInfo__ = {
296
- 'name': 'Instance Info',
297
- 'version': '1.0',
298
- 'description': "This plug-in displays instance information for sizing and performance issues.",
299
- 'license': 'Apache-2',
300
- 'author': authorLabel,
301
- 'copyright': copyrightLabel,
302
- 'import': ('inlineXbrlDocumentSet',),
303
- # classes of mount points (required)
304
- 'CntlrCmdLine.Filing.Start': startup,
305
- 'CntlrCmdLine.Xbrl.Loaded': showInfo
306
- }