const fs = require('fs') const { SourceMapConsumer } = require('source-map') const path = require('path') // // Utility to help check if sourcemaps are working // // searches `dist/chrome/inpage.js` for "new Error" statements // and prints their source lines using the sourcemaps. // if not working it may error or print minified garbage // start() async function start () { const rawBuild = fs.readFileSync(path.join(__dirname, '/../dist/chrome/', 'inpage.js') , 'utf8') const rawSourceMap = fs.readFileSync(path.join(__dirname, '/../dist/sourcemaps/', 'inpage.js.map'), 'utf8') const consumer = await new SourceMapConsumer(rawSourceMap) console.log('hasContentsOfAllSources:', consumer.hasContentsOfAllSources(), '\n') console.log('sources:') consumer.sources.map((sourcePath) => console.log(sourcePath)) console.log('\nexamining "new Error" statements:\n') const sourceLines = rawBuild.split('\n') sourceLines.map(line => indicesOf('new Error', line)) .forEach((errorIndices, lineIndex) => { // if (errorIndex === null) return console.log('line does not contain "new Error"') errorIndices.forEach((errorIndex) => { const position = { line: lineIndex + 1, column: errorIndex } const result = consumer.originalPositionFor(position) if (!result.source) return console.warn(`!! missing source for position: ${position}`) // filter out deps distributed minified without sourcemaps if (result.source === 'node_modules/browserify/node_modules/browser-pack/_prelude.js') return // minified mess if (result.source === 'node_modules/web3/dist/web3.min.js') return // minified mess const sourceContent = consumer.sourceContentFor(result.source) const sourceLines = sourceContent.split('\n') const line = sourceLines[result.line - 1] console.log(`\n========================== ${result.source} ====================================\n`) console.log(line) console.log(`\n==============================================================================\n`) }) }) } function indicesOf (substring, string) { var a = [] var i = -1 while ((i = string.indexOf(substring, i + 1)) >= 0) a.push(i) return a } 18Q4</option> <option value='2019Q1'>2019Q1</option> <option value='2019Q2'>2019Q2</option> <option value='2019Q3'>2019Q3</option> <option value='2019Q4'>2019Q4</option> <option value='2020Q1'>2020Q1</option> <option value='2020Q2'>2020Q2</option> <option value='2020Q3'>2020Q3</option> <option value='2020Q4'>2020Q4</option> <option value='2021Q1'>2021Q1</option> <option value='2021Q2'>2021Q2</option> <option value='2021Q3'>2021Q3</option> <option value='2021Q4'>2021Q4</option> <option value='2022Q1'>2022Q1</option> <option value='2022Q2'>2022Q2</option> <option value='2022Q3'>2022Q3</option> <option value='2022Q4'>2022Q4</option> <option value='2023Q1'>2023Q1</option> <option value='2023Q2'>2023Q2</option> <option value='2023Q3'>2023Q3</option> <option value='2023Q4'>2023Q4</option> <option value='2024Q1'>2024Q1</option> <option value='2024Q2'>2024Q2</option> <option value='2024Q3'>2024Q3</option> <option value='2024Q4'>2024Q4</option> <option value='2025Q1'>2025Q1</option> <option value='2025Q2'>2025Q2</option> <option value='2025Q3'>2025Q3</option> <option value='branches/2014Q1'>branches/2014Q1</option> <option value='branches/2014Q2'>branches/2014Q2</option> <option value='branches/2014Q3'>branches/2014Q3</option> <option value='branches/2014Q4'>branches/2014Q4</option> <option value='branches/2015Q1'>branches/2015Q1</option> <option value='branches/2015Q2'>branches/2015Q2</option> <option value='branches/2015Q3'>branches/2015Q3</option> <option value='branches/2015Q4'>branches/2015Q4</option> <option value='branches/2016Q1'>branches/2016Q1</option> <option value='branches/2016Q2'>branches/2016Q2</option> <option value='branches/2016Q3'>branches/2016Q3</option> <option value='branches/2016Q4'>branches/2016Q4</option> <option value='branches/2017Q1'>branches/2017Q1</option> <option value='branches/2017Q2'>branches/2017Q2</option> <option value='branches/2017Q3'>branches/2017Q3</option> <option value='branches/2017Q4'>branches/2017Q4</option> <option value='branches/2018Q1'>branches/2018Q1</option> <option value='branches/2018Q2'>branches/2018Q2</option> <option value='branches/2018Q3'>branches/2018Q3</option> <option value='branches/2018Q4'>branches/2018Q4</option> <option value='branches/2019Q1'>branches/2019Q1</option> <option value='branches/2019Q2'>branches/2019Q2</option> <option value='branches/2019Q3'>branches/2019Q3</option> <option value='branches/2019Q4'>branches/2019Q4</option> <option value='branches/2020Q1'>branches/2020Q1</option> <option value='branches/2020Q2'>branches/2020Q2</option> <option value='branches/2020Q3'>branches/2020Q3</option> <option value='branches/2020Q4'>branches/2020Q4</option> <option value='branches/2021Q1'>branches/2021Q1</option> <option value='branches/RELEASE_8_4_0'>branches/RELEASE_8_4_0</option> <option value='branches/RELENG_2_1_0'>branches/RELENG_2_1_0</option> <option value='branches/RELENG_2_2'>branches/RELENG_2_2</option> <option value='branches/RELENG_9_1_0'>branches/RELENG_9_1_0</option> <option value='branches/RELENG_9_2_0'>branches/RELENG_9_2_0</option> <option value='dependabot/npm_and_yarn/devel/electron4/files/eslint-utils-1.4.3'>dependabot/npm_and_yarn/devel/electron4/files/eslint-utils-1.4.3</option> <option value='dependabot/npm_and_yarn/devel/electron4/files/lodash-4.17.15'>dependabot/npm_and_yarn/devel/electron4/files/lodash-4.17.15</option> <option value='dependabot/npm_and_yarn/devel/electron4/files/lodash.merge-4.6.2'>dependabot/npm_and_yarn/devel/electron4/files/lodash.merge-4.6.2</option> <option value='dependabot/npm_and_yarn/devel/electron4/files/lodash.template-4.5.0'>dependabot/npm_and_yarn/devel/electron4/files/lodash.template-4.5.0</option> <option value='dependabot/npm_and_yarn/devel/electron4/files/minimist-1.2.2'>dependabot/npm_and_yarn/devel/electron4/files/minimist-1.2.2</option> <option value='dependabot/npm_and_yarn/devel/electron4/files/mixin-deep-1.3.2' selected='selected'>dependabot/npm_and_yarn/devel/electron4/files/mixin-deep-1.3.2</option> <option value='main'>main</option> <option value='master'>master</option> <option value='svn_head'>svn_head</option> </select> <input type='submit' value='switch'/></form></td></tr> <tr><td class='sub'>FreeBSD Ports (https://github.com/freebsd/freebsd-ports)</td><td class='sub right'></td></tr></table> <table class='tabs'><tr><td> <a href='/~lantw44/cgit/cgit.cgi/freebsd-ports/about/?h=dependabot/npm_and_yarn/devel/electron4/files/mixin-deep-1.3.2'>about</a><a href='/~lantw44/cgit/cgit.cgi/freebsd-ports/?h=dependabot/npm_and_yarn/devel/electron4/files/mixin-deep-1.3.2'>summary</a><a href='/~lantw44/cgit/cgit.cgi/freebsd-ports/refs/?h=dependabot/npm_and_yarn/devel/electron4/files/mixin-deep-1.3.2&id=e13c8eaa1ccadcaf3319c3f4fd2d3d6585555d58'>refs</a><a class='active' href='/~lantw44/cgit/cgit.cgi/freebsd-ports/log/archivers/quazip?h=dependabot/npm_and_yarn/devel/electron4/files/mixin-deep-1.3.2&showmsg=1'>log</a><a href='/~lantw44/cgit/cgit.cgi/freebsd-ports/tree/archivers/quazip?h=dependabot/npm_and_yarn/devel/electron4/files/mixin-deep-1.3.2&id=e13c8eaa1ccadcaf3319c3f4fd2d3d6585555d58'>tree</a><a href='/~lantw44/cgit/cgit.cgi/freebsd-ports/commit/archivers/quazip?h=dependabot/npm_and_yarn/devel/electron4/files/mixin-deep-1.3.2&id=e13c8eaa1ccadcaf3319c3f4fd2d3d6585555d58'>commit</a><a href='/~lantw44/cgit/cgit.cgi/freebsd-ports/diff/archivers/quazip?h=dependabot/npm_and_yarn/devel/electron4/files/mixin-deep-1.3.2&id=e13c8eaa1ccadcaf3319c3f4fd2d3d6585555d58'>diff</a><a href='/~lantw44/cgit/cgit.cgi/freebsd-ports/stats/archivers/quazip?h=dependabot/npm_and_yarn/devel/electron4/files/mixin-deep-1.3.2'>stats</a></td><td class='form'><form class='right' method='get' action='/~lantw44/cgit/cgit.cgi/freebsd-ports/log/archivers/quazip'> <input type='hidden' name='h' value='dependabot/npm_and_yarn/devel/electron4/files/mixin-deep-1.3.2'/><input type='hidden' name='id' value='e13c8eaa1ccadcaf3319c3f4fd2d3d6585555d58'/><input type='hidden' name='showmsg' value='1'/><select name='qt'> <option value='grep'>log msg</option> <option value='author'>author</option> <option value='committer'>committer</option> <option value='range'>range</option> </select> <input class='txt' type='search' size='10' name='q' value=''/> <input type='submit' value='search'/> </form> </td></tr></table> <div class='path'>path: <a href='/~lantw44/cgit/cgit.cgi/freebsd-ports/log/?h=dependabot/npm_and_yarn/devel/electron4/files/mixin-deep-1.3.2&id=e13c8eaa1ccadcaf3319c3f4fd2d3d6585555d58&showmsg=1'>root</a>/<a href='/~lantw44/cgit/cgit.cgi/freebsd-ports/log/archivers?h=dependabot/npm_and_yarn/devel/electron4/files/mixin-deep-1.3.2&id=e13c8eaa1ccadcaf3319c3f4fd2d3d6585555d58&showmsg=1'>archivers</a>/<a href='/~lantw44/cgit/cgit.cgi/freebsd-ports/log/archivers/quazip?h=dependabot/npm_and_yarn/devel/electron4/files/mixin-deep-1.3.2&id=e13c8eaa1ccadcaf3319c3f4fd2d3d6585555d58&showmsg=1'>quazip</a></div><div class='content'><table class='list nowrap'><tr class='nohover'><th></th><th class='left'>Commit message (<a href='/~lantw44/cgit/cgit.cgi/freebsd-ports/log/archivers/quazip?h=dependabot/npm_and_yarn/devel/electron4/files/mixin-deep-1.3.2&id=e13c8eaa1ccadcaf3319c3f4fd2d3d6585555d58'>Collapse</a>)</th><th class='left'>Author</th><th class='left'>Age</th><th class='left'>Files</th><th class='left'>Lines</th></tr> <tr class='logheader'><td class='commitgraph'>* </td><td class='logsubject'><a href='/~lantw44/cgit/cgit.cgi/freebsd-ports/commit/archivers/quazip?h=dependabot/npm_and_yarn/devel/electron4/files/mixin-deep-1.3.2&id=4a344e94972b109670f45f04efe4002b50981676'>Bump PORTREVISION for ports depending on the canonical version of GCC</a></td><td>gerald</td><td><span title='2019-07-27 04:46:53 +0800'>2019-07-27</span></td><td>1</td><td><span class='deletions'>-0</span>/<span class='insertions'>+1</span></td></tr> <tr class='nohover-highlight'><td class='commitgraph'><span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> </td> <td colspan='5' class='logmsg'> as defined in Mk/bsd.default-versions.mk which has moved from GCC 8.3 to GCC 9.1 under most circumstances now after revision 507371. This includes ports - with USE_GCC=yes or USE_GCC=any, - with USES=fortran, - using Mk/bsd.octave.mk which in turn features USES=fortran, and - with USES=compiler specifying openmp, nestedfct, c11, c++0x, c++11-lang, c++11-lib, c++14-lang, c++17-lang, or gcc-c++11-lib plus, everything INDEX-11 shows with a dependency on lang/gcc9 now. PR: 238330 </td></tr> <tr class='logheader'><td class='commitgraph'>* </td><td class='logsubject'><a href='/~lantw44/cgit/cgit.cgi/freebsd-ports/commit/archivers/quazip?h=dependabot/npm_and_yarn/devel/electron4/files/mixin-deep-1.3.2&id=5dfcd77fa6f74db01bcc8d71773c9dbac68b448c'>archivers/quazip: update to 0.8.1</a></td><td>tcberner</td><td><span title='2019-05-28 03:08:50 +0800'>2019-05-28</span></td><td>3</td><td><span class='deletions'>-12</span>/<span class='insertions'>+4</span></td></tr> <tr class='nohover-highlight'><td class='commitgraph'><span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> </td> <td colspan='5' class='logmsg'> - only change is the removed patch </td></tr> <tr class='logheader'><td class='commitgraph'>* </td><td class='logsubject'><a href='/~lantw44/cgit/cgit.cgi/freebsd-ports/commit/archivers/quazip?h=dependabot/npm_and_yarn/devel/electron4/files/mixin-deep-1.3.2&id=54d10b7adbf4a8fe94c7b39d56ef77869394366a'>archivers/quazip: update to 0.8</a></td><td>tcberner</td><td><span title='2019-05-26 00:18:34 +0800'>2019-05-26</span></td><td>3</td><td><span class='deletions'>-5</span>/<span class='insertions'>+13</span></td></tr> <tr class='nohover-highlight'><td class='commitgraph'><span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> </td> <td colspan='5' class='logmsg'> From the changelog: * Support for UTF-8 in file names and comments (Denis Zavorotnyy) * get/setOsCode(), get/setDefaultOsCode() * Fixed Z_STREAM_END handling in QuaZioDevic </td></tr> <tr class='logheader'><td class='commitgraph'>* </td><td class='logsubject'><a href='/~lantw44/cgit/cgit.cgi/freebsd-ports/commit/archivers/quazip?h=dependabot/npm_and_yarn/devel/electron4/files/mixin-deep-1.3.2&id=551ad2a1e96181840f2a578415d1de0f8a7ac129'>archivers/quazip: remove flavors (Qt4 deprecation)</a></td><td>tcberner</td><td><span title='2019-03-17 03:37:25 +0800'>2019-03-17</span></td><td>1</td><td><span class='deletions'>-18</span>/<span class='insertions'>+4</span></td></tr> <tr class='nohover-highlight'><td class='commitgraph'><span class='column1'>|</span> </td> <td colspan='5' class='logmsg'> </td></tr> <tr class='logheader'><td class='commitgraph'>* </td><td class='logsubject'><a href='/~lantw44/cgit/cgit.cgi/freebsd-ports/commit/archivers/quazip?h=dependabot/npm_and_yarn/devel/electron4/files/mixin-deep-1.3.2&id=0c123abc65c17a023a06fa03c2da7624f5a40a03'>Fix Qt5 symbol version scripts to put the catch-all clause first. When</a></td><td>tijl</td><td><span title='2019-01-16 19:13:44 +0800'>2019-01-16</span></td><td>1</td><td><span class='deletions'>-0</span>/<span class='insertions'>+1</span></td></tr> <tr class='nohover-highlight'><td class='commitgraph'><span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> </td> <td colspan='5' class='logmsg'> a symbol matches multiple clauses the last one takes precedence. If the catch-all is last it captures everything. In the case of Qt5 libraries this caused all symbols to have a Qt_5 label while some should have Qt_5_PRIVATE_API. This only affects lld because GNU ld always gives the catch-all lowest priority. Older versions of Qt5Webengine exported some memory allocation symbols from the bundled Chromium. Version 5.9 stopped exporting these [1] but the symbols were kept as weak wrappers for the standard allocation functions to maintain binary compatibility. [2][3] The problem is that the call to the standard function in these weak wrappers is only resolved to the standard function if there's a call to this standard function in other parts of Qt5Webengine, because only then is there a non-weak symbol that takes precedence over the weak one. If there's no such non-weak symbol the call in the weak wrapper resolves to the weak wrapper itself creating an infinite call loop that overflows the stack and causes a crash. Some of the allocation functions are variants of C++ new and delete and it probably depends on the compiler whether these variants are used in other parts of Qt5Webengine. Remove the weak wrappers (make them Linux specific). This isn't binary compatible but we are already breaking that with the changes to the symbol versions. [1] https://github.com/qt/qtwebengine/commit/5c2cbfccf9aafb547b0b30914c4056abd25942a4 [2] https://github.com/qt/qtwebengine/commit/2ed5054e3a800fa97c2c9e920ba1e6ea4b6ef2a5 [3] https://github.com/qt/qtwebengine/commit/009f5ebb4bd6e50188671e0815a5dae6afe39db5 Bump all ports that depend on Qt5. PR: 234070 Exp-run by: antoine Approved by: kde (adridg) </td></tr> <tr class='logheader'><td class='commitgraph'>* </td><td class='logsubject'><a href='/~lantw44/cgit/cgit.cgi/freebsd-ports/commit/archivers/quazip?h=dependabot/npm_and_yarn/devel/electron4/files/mixin-deep-1.3.2&id=ce45e421097560f024d4ef3eef1d1e5482029250'>archivers/quazip: upgrade to 0.7.6</a></td><td>tcberner</td><td><span title='2019-01-05 22:10:17 +0800'>2019-01-05</span></td><td>5</td><td><span class='deletions'>-35</span>/<span class='insertions'>+8</span></td></tr> <tr class='nohover-highlight'><td class='commitgraph'><span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> <span class='column1'>|</span> </td> <td colspan='5' class='logmsg'> - the project has moved to github. </td></tr> <tr class='logheader'><td class='commitgraph'>* </td><td class='logsubject'><a href='/~lantw44/cgit/cgit.cgi/freebsd-ports/commit/archivers/quazip?h=dependabot/npm_and_yarn/devel/electron4/files/mixin-deep-1.3.2&id=49081780dbf920e309ccc96ab737f85e04f46c66'>Change cmake default behaviour to outsource.</a></td><td>tcberner</td><td><span title='2018-12-26 04:25:39 +0800'>2018-12-26</span>