├── .gitignore
├── .jshintrc
├── CONTRIBUTING.md
├── LICENSE
├── LICENSE.txt
├── Readme.md
├── about.css
├── about.js
├── about.xhtml
├── bootstrap.js
├── build.py
├── chrome.manifest
├── de
└── about.dtd
├── defaults
└── preferences
│ └── prefs.js
├── en-US
└── about.dtd
├── fr
└── about.dtd
├── install.rdf
├── ja
└── about.dtd
├── loader.jsm
├── loading.gif
├── main.js
├── sdk
├── cothreads.js
├── logging.js
├── observers.js
├── preferences.js
├── request.js
├── strings.js
├── timers.js
└── windows.js
├── sv-SE
└── about.dtd
├── zh-CN
└── about.dtd
└── zh-TW
└── about.dtd
/.gitignore:
--------------------------------------------------------------------------------
1 | *.xpi
2 |
--------------------------------------------------------------------------------
/.jshintrc:
--------------------------------------------------------------------------------
1 | {
2 | "browser": true,
3 | "curly": true,
4 | "esnext": true,
5 | "freeze": true,
6 | "globalstrict": true,
7 | "moz": true,
8 | "noarg": true,
9 | "nonbsp": true,
10 | "strict": true,
11 | "undef": true,
12 | "unused": true,
13 | "validthis": true,
14 | "maxlen": 80,
15 | "predef": ["Components", "Cc", "Ci", "Cr", "Cu", "require", "log",
16 | "LOG_DEBUG", "LOG_ERROR", "LOG_INFO", "prefs", "lazyRequire",
17 | "lazy", "Services", "Instances", "XPCOMUtils", "exports",
18 | "reportError", "ADDON", "unload", "BASE_PATH", "Iterator",
19 | "globalPrefs", "weak"]
20 | }
21 |
--------------------------------------------------------------------------------
/CONTRIBUTING.md:
--------------------------------------------------------------------------------
1 | # Contributing
2 |
3 | First of all, thanks for considering contributing code or other resources.
4 | Much appreciated!
5 |
6 | ## Submitting issues
7 |
8 | Please try to keep your texts short, but still include enough detail for other
9 | people to understand and **reproduce** your issue.
10 | E.g. if a bug affects a particular version, mention the version number. It might
11 | be also helpful to talk a bit about your environment, like operating system and
12 | platform (x86, x86_64, arm).
13 |
14 | For bugs or feature requests provide:
15 |
16 | - Sensible, but short summary/title.
17 | - Description of the actual behavior, preferably with detailed steps to
18 | reproduce the issue.
19 | - Description of the expected behavior.
20 | - If you know about older versions that worked correctly, mention that as well.
21 |
22 | Be polite, even if your issue does not (initially) get a lot of attention,
23 | or project maintainers close it as invalid/wontfix/etc.
24 |
25 | If you already diagnosed an issue and found the root cause, and feel like
26 | spending some extra time coding up a fix, then please don't hesitate to file a
27 | pull request instead of an issue. Project maintainers will love you.
28 |
29 | ### Bad
30 |
31 | > There is a bug in your software. When I click the button, it crashes.
32 |
33 | ### Better
34 |
35 | > Crash in version 1.0 when clicking Print button
36 | >
37 | > Hey, I'm using your software in version 1.0 on a Windows 7 (64-bit) system
38 | > along with FooBar Browser version 13.0. Unfortunately, it crashes when I
39 | > click on the Print button. This didn't happen in version 0.9.
40 | >
41 | > 1. Open document xyz
42 | > 2. Click Print button
43 | > 3. The application becomes unresponsive and has to be killed manually.
44 | >
45 | > I expect the application to print the document and then to continue working
46 | > normally.
47 |
48 | ## Submitting code and/or documentation
49 |
50 | - Your code should look and feel like the other code in the project, e.g. it
51 | should try to mimic/abide by the existing code formatting style and API
52 | design decisions.
53 | - If you plan to implement or revise a major feature/major API, or
54 | *break things* (for the better) in general, then please file an issue or
55 | pull request early. That way the project maintainers might suggest changes
56 | early and/or refine/reject ideas before you spend a lot time writing code that
57 | won't be merged in the current form.
58 | - Please provide (unit) tests, where appropriate and feasible.
59 | - Please use pull requests and avoid *plain* patches, etc.
60 | - Your commits should include at the very least an exploratory in plain English.
61 | Feel free to make use additional long messages current version control systems
62 | support, in particular if your commit is anything more than a simple bugfix.
63 | - Try to use gender-neutral language. Why? For four good reasons:
64 | - It is more inclusive and should work well-enough for all people.
65 | - It doesn't cost you anything, really, and no, it does not infringe upon your
66 | rights. It is easy enough to do, at least, in the English language.
67 | - Most importantly: because this file tells you to ;)
68 |
69 | ## Copyrights and License
70 |
71 | Any new code you submit **must be licensed** under the same license as the
72 | project license.
73 | Exception to this rule are only third-party libraries, which have to be
74 | licensed under a compatible license nonetheless and may **not** make the whole
75 | project less permissive.
76 | E.g. you may **not** submit code that uses plain GPL in a derivative way in a
77 | project otherwise licensed under a more permissive license such as the
78 | BSD/MIT/GPL licenses.
79 |
80 | You retain your copyright, or may assign it to the project/project maintainer.
81 | However, you must of course own the copyright or have the permission from the
82 | owners before submitting code. Work-for-hire-laws can be complicated.
83 |
84 | ## Enforcement
85 |
86 | The points outlined in this document are more guidelines than
87 | rules-set-in-stone.
88 |
89 | If in doubt, **the project maintainer(s) make the final decision**.
90 |
--------------------------------------------------------------------------------
/LICENSE:
--------------------------------------------------------------------------------
1 | Mozilla Public License Version 2.0
2 | ==================================
3 |
4 | 1. Definitions
5 | --------------
6 |
7 | 1.1. "Contributor"
8 | means each individual or legal entity that creates, contributes to
9 | the creation of, or owns Covered Software.
10 |
11 | 1.2. "Contributor Version"
12 | means the combination of the Contributions of others (if any) used
13 | by a Contributor and that particular Contributor's Contribution.
14 |
15 | 1.3. "Contribution"
16 | means Covered Software of a particular Contributor.
17 |
18 | 1.4. "Covered Software"
19 | means Source Code Form to which the initial Contributor has attached
20 | the notice in Exhibit A, the Executable Form of such Source Code
21 | Form, and Modifications of such Source Code Form, in each case
22 | including portions thereof.
23 |
24 | 1.5. "Incompatible With Secondary Licenses"
25 | means
26 |
27 | (a) that the initial Contributor has attached the notice described
28 | in Exhibit B to the Covered Software; or
29 |
30 | (b) that the Covered Software was made available under the terms of
31 | version 1.1 or earlier of the License, but not also under the
32 | terms of a Secondary License.
33 |
34 | 1.6. "Executable Form"
35 | means any form of the work other than Source Code Form.
36 |
37 | 1.7. "Larger Work"
38 | means a work that combines Covered Software with other material, in
39 | a separate file or files, that is not Covered Software.
40 |
41 | 1.8. "License"
42 | means this document.
43 |
44 | 1.9. "Licensable"
45 | means having the right to grant, to the maximum extent possible,
46 | whether at the time of the initial grant or subsequently, any and
47 | all of the rights conveyed by this License.
48 |
49 | 1.10. "Modifications"
50 | means any of the following:
51 |
52 | (a) any file in Source Code Form that results from an addition to,
53 | deletion from, or modification of the contents of Covered
54 | Software; or
55 |
56 | (b) any new file in Source Code Form that contains any Covered
57 | Software.
58 |
59 | 1.11. "Patent Claims" of a Contributor
60 | means any patent claim(s), including without limitation, method,
61 | process, and apparatus claims, in any patent Licensable by such
62 | Contributor that would be infringed, but for the grant of the
63 | License, by the making, using, selling, offering for sale, having
64 | made, import, or transfer of either its Contributions or its
65 | Contributor Version.
66 |
67 | 1.12. "Secondary License"
68 | means either the GNU General Public License, Version 2.0, the GNU
69 | Lesser General Public License, Version 2.1, the GNU Affero General
70 | Public License, Version 3.0, or any later versions of those
71 | licenses.
72 |
73 | 1.13. "Source Code Form"
74 | means the form of the work preferred for making modifications.
75 |
76 | 1.14. "You" (or "Your")
77 | means an individual or a legal entity exercising rights under this
78 | License. For legal entities, "You" includes any entity that
79 | controls, is controlled by, or is under common control with You. For
80 | purposes of this definition, "control" means (a) the power, direct
81 | or indirect, to cause the direction or management of such entity,
82 | whether by contract or otherwise, or (b) ownership of more than
83 | fifty percent (50%) of the outstanding shares or beneficial
84 | ownership of such entity.
85 |
86 | 2. License Grants and Conditions
87 | --------------------------------
88 |
89 | 2.1. Grants
90 |
91 | Each Contributor hereby grants You a world-wide, royalty-free,
92 | non-exclusive license:
93 |
94 | (a) under intellectual property rights (other than patent or trademark)
95 | Licensable by such Contributor to use, reproduce, make available,
96 | modify, display, perform, distribute, and otherwise exploit its
97 | Contributions, either on an unmodified basis, with Modifications, or
98 | as part of a Larger Work; and
99 |
100 | (b) under Patent Claims of such Contributor to make, use, sell, offer
101 | for sale, have made, import, and otherwise transfer either its
102 | Contributions or its Contributor Version.
103 |
104 | 2.2. Effective Date
105 |
106 | The licenses granted in Section 2.1 with respect to any Contribution
107 | become effective for each Contribution on the date the Contributor first
108 | distributes such Contribution.
109 |
110 | 2.3. Limitations on Grant Scope
111 |
112 | The licenses granted in this Section 2 are the only rights granted under
113 | this License. No additional rights or licenses will be implied from the
114 | distribution or licensing of Covered Software under this License.
115 | Notwithstanding Section 2.1(b) above, no patent license is granted by a
116 | Contributor:
117 |
118 | (a) for any code that a Contributor has removed from Covered Software;
119 | or
120 |
121 | (b) for infringements caused by: (i) Your and any other third party's
122 | modifications of Covered Software, or (ii) the combination of its
123 | Contributions with other software (except as part of its Contributor
124 | Version); or
125 |
126 | (c) under Patent Claims infringed by Covered Software in the absence of
127 | its Contributions.
128 |
129 | This License does not grant any rights in the trademarks, service marks,
130 | or logos of any Contributor (except as may be necessary to comply with
131 | the notice requirements in Section 3.4).
132 |
133 | 2.4. Subsequent Licenses
134 |
135 | No Contributor makes additional grants as a result of Your choice to
136 | distribute the Covered Software under a subsequent version of this
137 | License (see Section 10.2) or under the terms of a Secondary License (if
138 | permitted under the terms of Section 3.3).
139 |
140 | 2.5. Representation
141 |
142 | Each Contributor represents that the Contributor believes its
143 | Contributions are its original creation(s) or it has sufficient rights
144 | to grant the rights to its Contributions conveyed by this License.
145 |
146 | 2.6. Fair Use
147 |
148 | This License is not intended to limit any rights You have under
149 | applicable copyright doctrines of fair use, fair dealing, or other
150 | equivalents.
151 |
152 | 2.7. Conditions
153 |
154 | Sections 3.1, 3.2, 3.3, and 3.4 are conditions of the licenses granted
155 | in Section 2.1.
156 |
157 | 3. Responsibilities
158 | -------------------
159 |
160 | 3.1. Distribution of Source Form
161 |
162 | All distribution of Covered Software in Source Code Form, including any
163 | Modifications that You create or to which You contribute, must be under
164 | the terms of this License. You must inform recipients that the Source
165 | Code Form of the Covered Software is governed by the terms of this
166 | License, and how they can obtain a copy of this License. You may not
167 | attempt to alter or restrict the recipients' rights in the Source Code
168 | Form.
169 |
170 | 3.2. Distribution of Executable Form
171 |
172 | If You distribute Covered Software in Executable Form then:
173 |
174 | (a) such Covered Software must also be made available in Source Code
175 | Form, as described in Section 3.1, and You must inform recipients of
176 | the Executable Form how they can obtain a copy of such Source Code
177 | Form by reasonable means in a timely manner, at a charge no more
178 | than the cost of distribution to the recipient; and
179 |
180 | (b) You may distribute such Executable Form under the terms of this
181 | License, or sublicense it under different terms, provided that the
182 | license for the Executable Form does not attempt to limit or alter
183 | the recipients' rights in the Source Code Form under this License.
184 |
185 | 3.3. Distribution of a Larger Work
186 |
187 | You may create and distribute a Larger Work under terms of Your choice,
188 | provided that You also comply with the requirements of this License for
189 | the Covered Software. If the Larger Work is a combination of Covered
190 | Software with a work governed by one or more Secondary Licenses, and the
191 | Covered Software is not Incompatible With Secondary Licenses, this
192 | License permits You to additionally distribute such Covered Software
193 | under the terms of such Secondary License(s), so that the recipient of
194 | the Larger Work may, at their option, further distribute the Covered
195 | Software under the terms of either this License or such Secondary
196 | License(s).
197 |
198 | 3.4. Notices
199 |
200 | You may not remove or alter the substance of any license notices
201 | (including copyright notices, patent notices, disclaimers of warranty,
202 | or limitations of liability) contained within the Source Code Form of
203 | the Covered Software, except that You may alter any license notices to
204 | the extent required to remedy known factual inaccuracies.
205 |
206 | 3.5. Application of Additional Terms
207 |
208 | You may choose to offer, and to charge a fee for, warranty, support,
209 | indemnity or liability obligations to one or more recipients of Covered
210 | Software. However, You may do so only on Your own behalf, and not on
211 | behalf of any Contributor. You must make it absolutely clear that any
212 | such warranty, support, indemnity, or liability obligation is offered by
213 | You alone, and You hereby agree to indemnify every Contributor for any
214 | liability incurred by such Contributor as a result of warranty, support,
215 | indemnity or liability terms You offer. You may include additional
216 | disclaimers of warranty and limitations of liability specific to any
217 | jurisdiction.
218 |
219 | 4. Inability to Comply Due to Statute or Regulation
220 | ---------------------------------------------------
221 |
222 | If it is impossible for You to comply with any of the terms of this
223 | License with respect to some or all of the Covered Software due to
224 | statute, judicial order, or regulation then You must: (a) comply with
225 | the terms of this License to the maximum extent possible; and (b)
226 | describe the limitations and the code they affect. Such description must
227 | be placed in a text file included with all distributions of the Covered
228 | Software under this License. Except to the extent prohibited by statute
229 | or regulation, such description must be sufficiently detailed for a
230 | recipient of ordinary skill to be able to understand it.
231 |
232 | 5. Termination
233 | --------------
234 |
235 | 5.1. The rights granted under this License will terminate automatically
236 | if You fail to comply with any of its terms. However, if You become
237 | compliant, then the rights granted under this License from a particular
238 | Contributor are reinstated (a) provisionally, unless and until such
239 | Contributor explicitly and finally terminates Your grants, and (b) on an
240 | ongoing basis, if such Contributor fails to notify You of the
241 | non-compliance by some reasonable means prior to 60 days after You have
242 | come back into compliance. Moreover, Your grants from a particular
243 | Contributor are reinstated on an ongoing basis if such Contributor
244 | notifies You of the non-compliance by some reasonable means, this is the
245 | first time You have received notice of non-compliance with this License
246 | from such Contributor, and You become compliant prior to 30 days after
247 | Your receipt of the notice.
248 |
249 | 5.2. If You initiate litigation against any entity by asserting a patent
250 | infringement claim (excluding declaratory judgment actions,
251 | counter-claims, and cross-claims) alleging that a Contributor Version
252 | directly or indirectly infringes any patent, then the rights granted to
253 | You by any and all Contributors for the Covered Software under Section
254 | 2.1 of this License shall terminate.
255 |
256 | 5.3. In the event of termination under Sections 5.1 or 5.2 above, all
257 | end user license agreements (excluding distributors and resellers) which
258 | have been validly granted by You or Your distributors under this License
259 | prior to termination shall survive termination.
260 |
261 | ************************************************************************
262 | * *
263 | * 6. Disclaimer of Warranty *
264 | * ------------------------- *
265 | * *
266 | * Covered Software is provided under this License on an "as is" *
267 | * basis, without warranty of any kind, either expressed, implied, or *
268 | * statutory, including, without limitation, warranties that the *
269 | * Covered Software is free of defects, merchantable, fit for a *
270 | * particular purpose or non-infringing. The entire risk as to the *
271 | * quality and performance of the Covered Software is with You. *
272 | * Should any Covered Software prove defective in any respect, You *
273 | * (not any Contributor) assume the cost of any necessary servicing, *
274 | * repair, or correction. This disclaimer of warranty constitutes an *
275 | * essential part of this License. No use of any Covered Software is *
276 | * authorized under this License except under this disclaimer. *
277 | * *
278 | ************************************************************************
279 |
280 | ************************************************************************
281 | * *
282 | * 7. Limitation of Liability *
283 | * -------------------------- *
284 | * *
285 | * Under no circumstances and under no legal theory, whether tort *
286 | * (including negligence), contract, or otherwise, shall any *
287 | * Contributor, or anyone who distributes Covered Software as *
288 | * permitted above, be liable to You for any direct, indirect, *
289 | * special, incidental, or consequential damages of any character *
290 | * including, without limitation, damages for lost profits, loss of *
291 | * goodwill, work stoppage, computer failure or malfunction, or any *
292 | * and all other commercial damages or losses, even if such party *
293 | * shall have been informed of the possibility of such damages. This *
294 | * limitation of liability shall not apply to liability for death or *
295 | * personal injury resulting from such party's negligence to the *
296 | * extent applicable law prohibits such limitation. Some *
297 | * jurisdictions do not allow the exclusion or limitation of *
298 | * incidental or consequential damages, so this exclusion and *
299 | * limitation may not apply to You. *
300 | * *
301 | ************************************************************************
302 |
303 | 8. Litigation
304 | -------------
305 |
306 | Any litigation relating to this License may be brought only in the
307 | courts of a jurisdiction where the defendant maintains its principal
308 | place of business and such litigation shall be governed by laws of that
309 | jurisdiction, without reference to its conflict-of-law provisions.
310 | Nothing in this Section shall prevent a party's ability to bring
311 | cross-claims or counter-claims.
312 |
313 | 9. Miscellaneous
314 | ----------------
315 |
316 | This License represents the complete agreement concerning the subject
317 | matter hereof. If any provision of this License is held to be
318 | unenforceable, such provision shall be reformed only to the extent
319 | necessary to make it enforceable. Any law or regulation which provides
320 | that the language of a contract shall be construed against the drafter
321 | shall not be used to construe this License against a Contributor.
322 |
323 | 10. Versions of the License
324 | ---------------------------
325 |
326 | 10.1. New Versions
327 |
328 | Mozilla Foundation is the license steward. Except as provided in Section
329 | 10.3, no one other than the license steward has the right to modify or
330 | publish new versions of this License. Each version will be given a
331 | distinguishing version number.
332 |
333 | 10.2. Effect of New Versions
334 |
335 | You may distribute the Covered Software under the terms of the version
336 | of the License under which You originally received the Covered Software,
337 | or under the terms of any subsequent version published by the license
338 | steward.
339 |
340 | 10.3. Modified Versions
341 |
342 | If you create software not governed by this License, and you want to
343 | create a new license for such software, you may create and use a
344 | modified version of this License if you rename the license and remove
345 | any references to the name of the license steward (except to note that
346 | such modified license differs from this License).
347 |
348 | 10.4. Distributing Source Code Form that is Incompatible With Secondary
349 | Licenses
350 |
351 | If You choose to distribute Source Code Form that is Incompatible With
352 | Secondary Licenses under the terms of this version of the License, the
353 | notice described in Exhibit B of this License must be attached.
354 |
355 | Exhibit A - Source Code Form License Notice
356 | -------------------------------------------
357 |
358 | This Source Code Form is subject to the terms of the Mozilla Public
359 | License, v. 2.0. If a copy of the MPL was not distributed with this
360 | file, You can obtain one at http://mozilla.org/MPL/2.0/.
361 |
362 | If it is not possible or desirable to put the notice in a particular
363 | file, then You may include the notice in a location (such as a LICENSE
364 | file in a relevant directory) where a recipient would be likely to look
365 | for such a notice.
366 |
367 | You may add additional accurate notices of copyright ownership.
368 |
369 | Exhibit B - "Incompatible With Secondary Licenses" Notice
370 | ---------------------------------------------------------
371 |
372 | This Source Code Form is "Incompatible With Secondary Licenses", as
373 | defined by the Mozilla Public License, v. 2.0.
374 |
--------------------------------------------------------------------------------
/LICENSE.txt:
--------------------------------------------------------------------------------
1 | Mozilla Public License Version 2.0
2 | ==================================
3 |
4 | See: http://www.mozilla.org/MPL/2.0/index.txt
5 | Or see: LICENSE file in the repository
6 |
--------------------------------------------------------------------------------
/Readme.md:
--------------------------------------------------------------------------------
1 | about:addons-memory
2 | ===
3 |
4 | Provides an about:addons-memory page, listing the memory usage of all active add-ons
5 |
6 | This extension is based on [ExtSDK](https://github.com/nmaier/extsdk/)
7 |
--------------------------------------------------------------------------------
/about.css:
--------------------------------------------------------------------------------
1 | @import url(chrome://global/skin/about.css);
2 |
3 | html {
4 | font-family: message-box, sans-serif;
5 | font-size: 16px;
6 | }
7 | body {
8 | max-width: 950px;
9 | }
10 | @media (max-width: 900px) {
11 | html {
12 | padding: 0;
13 | margin: 0;
14 | font-size: 12px;
15 | }
16 | body {
17 | width: -moz-calc(100% - 3em);
18 | max-width: -moz-calc(100% - 3em);
19 | margin: 0;
20 | border: 0;
21 | }
22 | }
23 |
24 | table {
25 | border-collapse: collapse;
26 | width: 100%;
27 | text-align: left;
28 | }
29 | thead tr,
30 | tbody tr:not(:last-child) {
31 | border-bottom: 1px dotted black;
32 | }
33 |
34 | tr.disabled {
35 | opacity: 0.6;
36 | }
37 |
38 | td, th {
39 | padding: 1ex;
40 | }
41 |
42 | th[title] {
43 | cursor: help;
44 | }
45 | th:not(:last-child),
46 | td:not(:last-child) {
47 | border-right: 1px dotted darkgray;
48 | }
49 |
50 | td > p {
51 | padding: 0;
52 | margin: 0;
53 | }
54 | .loading {
55 | height: 96px;
56 | background: url(loading.gif) no-repeat center center;
57 | }
58 |
59 | .total,
60 | .name {
61 | font-weight: bold;
62 | }
63 | .id {
64 | font-size: smaller;
65 | font-style: italic;
66 | color: gray;
67 | }
68 | .id:hover {
69 | color: black;
70 | }
71 |
72 | sup {
73 | padding-left: 1ex;
74 | padding-right: 1em;
75 | }
76 | sup > a {
77 | text-decoration: none;
78 | }
79 |
80 | figure.icon {
81 | float: left;
82 | margin: 0;
83 | padding: 0;
84 | }
85 | div.icon {
86 | width: 64px;
87 | height: 64px;
88 | margin: 0;
89 | padding: 0;
90 | padding-right: 1em;
91 | display: table-cell;
92 | text-align: center;
93 | vertical-align: middle;
94 | }
95 | .icon > img {
96 | margin: 0;
97 | padding: 0;
98 | min-width: 32px;
99 | min-height: 32px;
100 | max-width: 64px;
101 | max-height: 64px;
102 | }
103 |
104 | th#memory {
105 | width: 6em;
106 | }
107 | th#bar {
108 | width: 10em;
109 | }
110 |
111 | th:not([id]) {
112 | width: 3em;
113 | }
114 |
115 | .remark {
116 | color: red;
117 | font-size: small;
118 | }
119 |
120 | .bar {
121 | height: 1.5em;
122 | background: navy;
123 | }
124 |
--------------------------------------------------------------------------------
/about.js:
--------------------------------------------------------------------------------
1 | /* This Source Code Form is subject to the terms of the Mozilla Public
2 | * License, v. 2.0. If a copy of the MPL was not distributed with this file,
3 | * You can obtain one at http://mozilla.org/MPL/2.0/. */
4 | "use strict";
5 |
6 | const {
7 | classes: Cc,
8 | interfaces: Ci,
9 | utils: Cu,
10 | results: Cr,
11 | Constructor, ctor
12 | } = Components;
13 |
14 | const {Services} = Cu.import("resource://gre/modules/Services.jsm", {});
15 |
16 | const ChromeRegistry = Cc["@mozilla.org/chrome/chrome-registry;1"].getService(Ci.nsIChromeRegistry);
17 | const MemoryReporterManager = Cc["@mozilla.org/memory-reporter-manager;1"].getService(Ci.nsIMemoryReporterManager);
18 | const ResProtoHandler = Services.io.getProtocolHandler("resource").QueryInterface(Ci.nsIResProtocolHandler);
19 | const MainThread = Services.tm.mainThread;
20 | const NOFRAC = {maximumFractionDigits: 0};
21 | const ONEFRAC = {maximumFractionDigits: 1};
22 | const TWOFRAC = {maximumFractionDigits: 2};
23 | const THREEFRAC = {maximumFractionDigits: 3};
24 |
25 | function _(id) {
26 | return document.body.getAttribute("data-" + id);
27 | }
28 |
29 | function runSoon(f) MainThread.dispatch(f, 0);
30 | function minimizeMemoryUsage(callback) {
31 | function notify(i) {
32 | Services.obs.notifyObservers(null, "memory-pressure", "heap-minimize");
33 | if (--i) {
34 | runSoon(notify.bind(null, i));
35 | }
36 | else if (callback) {
37 | runSoon(callback);
38 | }
39 | }
40 | if ("minimizeMemoryUsage" in MemoryReporterManager) {
41 | MemoryReporterManager.minimizeMemoryUsage(callback);
42 | }
43 | else {
44 | notify(3);
45 | }
46 | }
47 |
48 | function formatBytes(b) {
49 | if (b < 900) {
50 | return b.toLocaleString(undefined, NOFRAC) + " bytes";
51 | }
52 | b /= 1024;
53 | if (b < 900) {
54 | return b.toLocaleString(undefined, ONEFRAC) + " KB";
55 | }
56 | b /= 1024;
57 | if (b < 900) {
58 | return b.toLocaleString(undefined, TWOFRAC) + " MB";
59 | }
60 | b /= 1024;
61 | return b.toLocaleString(undefined, THREEFRAC) + " GB";
62 | }
63 |
64 | function sortResults(a, b) {
65 | // size descending
66 | let rv = b.bytes - a.bytes;
67 | if (!rv) {
68 | // else name ascending
69 | rv = a.name < b.name ? -1 : 1;
70 | }
71 | return rv;
72 | }
73 |
74 | const resolveAboutURI = (function() {
75 | let resolved = new Map();
76 | return function resolveAboutURI(uri) {
77 | let mod = uri.path.replace(/#\?.*$/i, "");
78 | let rv = resolved.get(mod);
79 | if (!rv) {
80 | let c = Services.io.newChannelFromURI(uri);
81 | rv = c.URI.clone();
82 | if (rv.equals(uri)) {
83 | throw new Error("cannot resolve about URI");
84 | }
85 | resolved.set(mod, rv);
86 | }
87 | return rv;
88 | };
89 | })();
90 |
91 | function resolveURI(uri) {
92 | switch (uri.scheme) {
93 | case "jar":
94 | case "file":
95 | if (uri instanceof Ci.nsIJARURI) {
96 | return resolveURI(uri.JARFile);
97 | }
98 | return uri;
99 | case "chrome":
100 | return resolveURI(ChromeRegistry.convertChromeURL(uri));
101 | case "resource":
102 | return resolveURI(Services.io.newURI(ResProtoHandler.resolveURI(uri), null, null));
103 | case "about":
104 | if (uri.spec == "about:blank") {
105 | // hack: also map about:blank... to the app
106 | return resolveURI(resolveAboutURI(Services.io.newURI("about:memory", null, null)));
107 | }
108 | return resolveURI(resolveAboutURI(uri));
109 | case "view-source":
110 | return resolveURI(Services.io.newURI(uri.path, null, null));
111 | default:
112 | throw new Error("cannot handle");
113 | }
114 | }
115 |
116 | function $(id) document.getElementById(id);
117 | function $e(tag, attrs, text) {
118 | let e = document.createElement(tag);
119 | if (attrs) {
120 | for (let [k,v] in Iterator(attrs)) {
121 | e.setAttribute(k, v);
122 | }
123 | }
124 | if (text) {
125 | e.textContent = text;
126 | }
127 | return e;
128 | }
129 | function process(addons) {
130 | const known = [];
131 | const compartments = Object.create(null);;
132 | const re_jscompartment = /^explicit\/.*?(?:\/non-window-global|js-non-window)\/.*?\/compartment\((.*?)\)/;
133 | const re_windowobject = /^explicit\/(?:.*\/)?window-objects\/top\((.*?), id=\d+\)\/active\//;
134 | const re_worker = /^explicit\/(?:.*\/)?workers\/workers\(\)\/worker\((.*?), 0x[\da-f]+\)/;
135 | const re_explicit = /^explicit\//;
136 | const re_compartment = /^(\[System Principal\], )?(?:in.*?\?ownedBy=)?(.+?)(?: \(from: (.+?)(?::\d+)?)?$/;
137 | const re_schemes = /^(?:about|chrome|file|jar|resource)/;
138 | let rss = 0;
139 |
140 | function handleReport(process, path, kind, units, amount, description) {
141 | if (path == "resident") {
142 | rss = amount;
143 | return;
144 | }
145 | let m, spec;
146 | if (m = path.match(re_jscompartment)) {
147 | m = m[1].match(re_compartment);
148 | let syscomp = !!m[1];
149 | spec = m[2];
150 | if (m[3] && (!syscomp || !re_schemes.test(spec))) {
151 | spec = m[3].split(" -> ").pop();
152 | }
153 | }
154 | else if (m = path.match(re_windowobject)) {
155 | spec = m[1];
156 | }
157 | else if (m = path.match(re_worker)) {
158 | spec = m[1];
159 | }
160 |
161 | if (!spec) {
162 | return;
163 | }
164 | spec = spec.replace(/\\/g, "/").trim();
165 | try {
166 | if (spec in compartments) {
167 | compartments[spec] += amount;
168 | }
169 | else {
170 | compartments[spec] = amount;
171 | }
172 | }
173 | catch (ex) {
174 | console.error(spec.toSource(), ex);
175 | }
176 | }
177 |
178 | function mapSpecToAddon(spec, bytes) {
179 | if (/omni\.ja$|\.apk$/.test(spec)) {
180 | known[0].bytes += bytes;
181 | return true;
182 | }
183 | for (let [,k] in Iterator(known)) {
184 | if (spec.lastIndexOf(k.spec, 0) == 0) {
185 | k.bytes += bytes;
186 | return true;
187 | }
188 | }
189 | return false;
190 | }
191 |
192 | function process() {
193 | // map reports to addons
194 | for (let [c, b] in Iterator(compartments)) {
195 | try {
196 | let spec = resolveURI(Services.io.newURI(c, null, null)).spec;
197 | if (!mapSpecToAddon(spec, b)) {
198 | throw new Error("not an addon uri:" + spec);
199 | }
200 | }
201 | catch (ex) {
202 | console.warn("failed to map", c, ex);
203 | }
204 | }
205 |
206 | // construct table
207 | known.sort(sortResults);
208 | let maxAddonBytes = 0;
209 | let totalAddons = known.reduce(function(p, e) {
210 | maxAddonBytes = Math.max(maxAddonBytes, e.bytes);
211 | return e.bytes + p;
212 | }, 0);
213 |
214 | let fragment = document.createDocumentFragment();
215 | let noteid = 0;
216 | for (let [,k] in Iterator(known)) {
217 | let tr = $e("tr");
218 | if (!k.addon.isActive) {
219 | tr.className = "disabled";
220 | }
221 | let tdn = $e("td");
222 |
223 | let icon = k.addon.icon64URL || k.addon.iconURL || "chrome://mozapps/skin/extensions/extensionGeneric.svg";
224 | icon = $e("img", {"src": icon});
225 | let iconBox = $e("div", {"class": "icon"});
226 | let figure = $e("figure", {"class": "icon"});
227 | iconBox.appendChild(icon);
228 | figure.appendChild(iconBox);
229 | tdn.appendChild(figure);
230 |
231 | let footnotes;
232 | if (k.footnotes) {
233 | footnotes = document.createDocumentFragment();
234 | for (let [,note] in Iterator(k.footnotes)) {
235 | let id = ++noteid;
236 | let fn = $e("sup");
237 | // hack: need to construct the absolute uri ourselves in about:
238 | fn.appendChild($e("a", {"href": "about:addons-memory#fn_" + id}, id.toFixed(0)));
239 | footnotes.appendChild(fn);
240 | let text = $e("p", {"class": "fn", "id": "fn_" + id}, note);
241 | let anc = $e("sup", null, "[" + id + "] ");
242 | text.insertBefore(anc, text.firstChild);
243 | document.body.appendChild(text);
244 | }
245 | }
246 |
247 | let pname = $e("p", {"class": "name"});
248 | if (k.addon.homepageURL) {
249 | pname.appendChild($e("a", {"target":"_blank", "href": k.addon.homepageURL}, k.addon.name));
250 | }
251 | else {
252 | pname.textContent = k.addon.name;
253 | }
254 | if (footnotes) {
255 | pname.appendChild(footnotes);
256 | }
257 | tdn.appendChild(pname);
258 |
259 | tdn.appendChild($e("p", {"class": "creator"}, _("by") + " " + k.addon.creator));
260 | tdn.appendChild($e("p", {"class": "id"}, k.addon.id));
261 | tr.appendChild(tdn);
262 | tr.appendChild($e("td", {"data-value": k.bytes}, formatBytes(k.bytes)));
263 |
264 | let pa = k.bytes / totalAddons;
265 | let spa = (pa * 100.0).toLocaleString(undefined, ONEFRAC) + "%";
266 | let pe = k.bytes / rss;
267 | let spe = (pe * 100.0).toLocaleString(undefined, ONEFRAC) + "%";
268 | let scale = (k.bytes / maxAddonBytes * 100.0).toFixed(1) + "%";
269 |
270 | tr.appendChild($e("td", {"data-value": pa}, spa));
271 | tr.appendChild($e("td", {"data-value": pe}, spe));
272 | let progress = $e("div", {"class": "bar"});
273 | progress.style.width = scale;
274 | let tdp = $e("td");
275 | tdp.appendChild(progress);
276 | tr.appendChild(tdp);
277 | fragment.appendChild(tr);
278 | }
279 | let tr = $e("tr", {"class": "total"});
280 | tr.appendChild($e("td", null, "Total"));
281 | tr.appendChild($e("td", null, formatBytes(totalAddons)));
282 | tr.appendChild($e("td", null, "100%"));
283 | tr.appendChild($e("td", null, (totalAddons / rss * 100.0).toLocaleString(undefined, ONEFRAC) + "%"));
284 | fragment.appendChild(tr);
285 |
286 | $("tbody").appendChild(fragment);
287 |
288 | {
289 | let l = $("loading");
290 | l.parentNode.removeChild(l);
291 | }
292 | }
293 |
294 | try {
295 | // Forcefeed the "Application" add-on
296 | {
297 | let appuri = resolveURI(Services.io.newURI("about:config", null, null));
298 | let iconURL = "chrome://branding/content/icon64.png"
299 | try {
300 | if (!/omni\.ja|\.apk$/.test(appuri.spec)) {
301 | appuri.path = appuri.path.replace("chrome/toolkit/content/global/global.xul", "");
302 | }
303 | }
304 | catch (ex) {
305 | console.log("failed to get proper appuri; assuming omnijar");
306 | }
307 | if (/\.apk$/.test(appuri.spec)) {
308 | iconURL = "chrome://branding/content/favicon64.png"
309 | }
310 | let addon = {
311 | name: "Application",
312 | isActive: true,
313 | id: Services.appinfo.ID,
314 | creator: "Mozilla",
315 | iconURL: iconURL
316 | };
317 | try {
318 | let branding = Services.strings.createBundle("chrome://branding/locale/brand.properties");
319 | addon.name = branding.GetStringFromName("brandFullName");
320 | addon.creator = branding.GetStringFromName("vendorShortName");
321 | }
322 | catch (ex) {
323 | console.error("failed to get branding", ex);
324 | }
325 | known.push({
326 | addon: addon,
327 | base: appuri,
328 | spec: appuri.spec,
329 | bytes: 0,
330 | footnotes: [_("footnote-locations")]
331 | });
332 | }
333 |
334 | // process addons
335 | for (let [,a] in Iterator(addons)) {
336 | try {
337 | let base = resolveURI(a.getResourceURI(".").cloneIgnoringRef());
338 | let notes;
339 | if (a.id == "about-addons-memory@tn123.org") {
340 | notes = [_("footnote-thisaddon")];
341 | }
342 | known.push({
343 | addon: a,
344 | base: base,
345 | spec: base.spec,
346 | bytes: 0,
347 | footnotes: notes
348 | });
349 | }
350 | catch (ex) {
351 | console.warn("addon not supported", a.id);
352 | }
353 | }
354 |
355 | // process reports
356 | if ("nsIMemoryMultiReporter" in Ci) {
357 | console.log("taking uni");
358 | let e = MemoryReporterManager.enumerateReporters();
359 | while (e.hasMoreElements()) {
360 | let r = e.getNext();
361 | if (r instanceof Ci.nsIMemoryReporter) {
362 | handleReport(null, r.path, r.kind, r.units, r.amount);
363 | }
364 | }
365 | e = MemoryReporterManager.enumerateMultiReporters();
366 | while (e.hasMoreElements()) {
367 | let r = e.getNext();
368 | if (r instanceof Ci.nsIMemoryMultiReporter) {
369 | r.collectReports(handleReport, null);
370 | }
371 | }
372 | process();
373 | }
374 | else if ("enumerateReporters" in MemoryReporterManager) {
375 | console.log("taking no-uni");
376 | let e = MemoryReporterManager.enumerateReporters();
377 | while (e.hasMoreElements()) {
378 | let r = e.getNext();
379 | if (r instanceof Ci.nsIMemoryReporter) {
380 | r.collectReports(handleReport, null);
381 | }
382 | }
383 | process();
384 | }
385 | else {
386 | console.log("taking getReports");
387 | if (MemoryReporterManager.getReports.length == 5) {
388 | MemoryReporterManager.getReports(handleReport, null, process, null, false);
389 | }
390 | else {
391 | MemoryReporterManager.getReports(handleReport, null, process, null);
392 | }
393 | }
394 |
395 | }
396 | catch (ex) {
397 | console.error(ex);
398 | }
399 | }
400 |
401 | addEventListener("load", function load() {
402 | removeEventListener("load", load, false);
403 | Cu.import("resource://gre/modules/AddonManager.jsm", {}).AddonManager.getAllAddons(process);
404 | }, false);
405 |
406 | /* vim: set et ts=2 sw=2 : */
407 |
--------------------------------------------------------------------------------
/about.xhtml:
--------------------------------------------------------------------------------
1 |
2 |
4 | %aboutDTD;
5 |
6 | %defaboutDTD;
7 | ]>
8 |
9 |