Closed charlag closed 3 years ago
Hi! :D
Is source-map-error
a private branch? Can't seem to find it. :)
Sorry, I forgot to push it. Now it should be there. Works with any worker code that is processed somehow (by default it gives source map via URL I think)
There seems to be almost no information online about Workers and source maps. I have honestly no idea why //#sourceMappingURL
is not working inside a worker, it seems like it should.
Is there any examples of this working with other tools or anything? I could be mistaken, but this might just be a browser devtools issue, quite possible they just haven't implemented source maps for workers.
You can try our main repo: https://github.com/tutao/tutanota on master it's still homebrew build system with just calling babel and inline source maps and it works? I also couldn't find more info so I couldn't be more helpful but I thought it might have to do something with nollup:// scheme.
(or you can open https://mail.tutanota.com)
The deployed app is using external source map files. nollup:///
works fine when using //#sourceURL
, Set a breakpoint in the worker, and run the following in the console:
eval('console.log("worker!");\
//# sourceURL=nollup:///hello');
So it's probably something to do with sourceMappingURL not allowing inline source maps inside a worker, or it doesn't like data URIs...
Hm debug build or the app from repo I mentioned above uses inline source maps but what you've shown is very interesting too...
For that build I mentioned, we don't use eval
. That's one big difference I can think of.
Here's what source map looks like:
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["WorkerImpl.js"],"names":["self","Logger","WorkerImpl","browserData","ProgrammingError","workerScope","_queue","Queue","nativeApp","setWorkerQueue","_newEntropy","_lastEntropyUpdate","Date","getTime","setCommands","testEcho","message","Promise","resolve","msg","args","testError","errorTypes","CryptoError","NotAuthenticatedError","ErrorType","errorType","reject","generateSignupKeys","locator","customer","apply","signup","createContactFormUserGroupData","createContactFormUser","createSession","login","createExternalSession","loadExternalPasswordChannels","sendExternalPasswordSms","reset","resumeSession","deleteSession","changePassword","deleteAccount","createMailFolder","mail","createMailDraft","createDraft","updateMailDraft","updateDraft","sendMailDraft","sendDraft","readAvailableCustomerStorage","readUsedCustomerStorage","restRequest","Object","assign","createAuthHeaders","restClient","request","entityRequest","cache","serviceRequest","_service","downloadFileContent","file","downloadFileContentNative","addMailAlias","mailAddress","setMailAliasStatus","isMailAddressAvailable","getAliasCounters","changeUserPassword","userManagement","changeAdminFlag","updateAdminship","switchFreeToPremiumGroup","switchPremiumToFreeGroup","updatePaymentData","downloadInvoice","readUsedUserStorage","deleteUser","getPrice","bookingFacade","getCurrentPrice","loadCustomerServerProperties","addSpamRule","editSpamRule","createUser","readUsedGroupStorage","groupManagement","createMailGroup","createLocalAdminGroup","addUserToGroup","removeUserFromGroup","deactivateGroup","loadContactFormByPath","loadContactForm","addDomain","removeDomain","setCatchAllGroup","uploadCertificate","deleteCertificate","generateTotpSecret","getTotpVerifier","then","totp","generateSecret","generateTotpCode","generateTotp","search","enableMailIndexing","indexer","disableMailIndexing","extendMailIndex","cancelMailIndexing","readCounterValue","counters","cancelCreateSession","entropy","addEntropy","tryReconnectEventBus","eventBusClient","tryReconnect","generateSsePushIdentifer","decryptUserPassword","closeEventBus","close","getMoreSearchResults","return","getRecoveryCode","getRecoverCode","createRecoveryCode","recoverLogin","resetSecondFactors","takeOverDeletedAddress","resetSession","createCalendarEvent","calendar","updateCalendarEvent","resolveSessionKey","sk","addCalendar","scheduleAlarmsForNewDevice","loadAlarmEvents","getDomainValidationRecord","visibilityChange","onVisibilityChanged","getLog","global","logger","getEntries","sendGroupInvitation","share","acceptGroupInvitation","rejectGroupInvitation","checkMailForPhishing","getEventByUid","onPossiblyUnhandledRejection","sendError","e","onerror","source","lineno","colno","error","console","Error","err","lineNumber","columnNumber","fileName","TotpVerifier","random","reduce","sum","value","now","storeEntropy","data","eventOwnerGroupId","postMessage","Request","progressPercentage","fromCallback","setTimeout","cb","state","log","update","totalWork","reference","status"],"mappings":"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","file":"WorkerImpl.js","sourcesContent":["// @flow\nimport {errorToObj, Queue, Request} from \"../common/WorkerProtocol\"\nimport {CryptoError} from \"../common/error/CryptoError\"\nimport {bookingFacade} from \"./facades/BookingFacade\"\nimport {NotAuthenticatedError} from \"../common/error/RestError\"\nimport {ProgrammingError} from \"../common/error/ProgrammingError\"\nimport {initLocator, locator, resetLocator} from \"./WorkerLocator\"\nimport {_service} from \"./rest/ServiceRestClient\"\nimport {random} from \"./crypto/Randomizer\"\nimport {assertWorkerOrNode, isMainOrNode} from \"../Env\"\nimport {nativeApp} from \"../../native/NativeWrapper\"\nimport {TotpVerifier} from \"./crypto/TotpVerifier\"\nimport type {EntropySrcEnum} from \"../common/TutanotaConstants\"\nimport {loadContactForm} from \"./facades/ContactFormFacade\"\nimport {keyToBase64} from \"./crypto/CryptoUtils\"\nimport {aes256RandomKey} from \"./crypto/Aes\"\nimport type {BrowserData} from \"../../misc/ClientConstants\"\nimport type {InfoMessage} from \"../common/CommonTypes\"\nimport {resolveSessionKey} from \"./crypto/CryptoFacade\"\nimport {Logger, replaceNativeLogger} from \"../common/Logger\"\nimport {downcast} from \"../common/utils/Utils\"\nimport type {ContactFormAccountReturn} from \"../entities/tutanota/ContactFormAccountReturn\"\nimport type {PaymentDataServicePutReturn} from \"../entities/sys/PaymentDataServicePutReturn\"\nimport type {EntityUpdate} from \"../entities/sys/EntityUpdate\"\nimport type {WebsocketCounterData} from \"../entities/sys/WebsocketCounterData\"\nimport {LazyLoaded} from \"../common/utils/LazyLoaded\"\nimport type {ProgressMonitorId} from \"../common/utils/ProgressMonitor\";\nimport type {WebsocketLeaderStatus} from \"../entities/sys/WebsocketLeaderStatus\"\n\nassertWorkerOrNode()\n\nif (typeof self !== \"undefined\") {\n\treplaceNativeLogger(self, new Logger())\n}\n\nexport class WorkerImpl {\n\n\t_queue: Queue;\n\t_newEntropy: number;\n\t_lastEntropyUpdate: number;\n\n\tconstructor(self: ?DedicatedWorkerGlobalScope, browserData: BrowserData) {\n\t\tif (browserData == null) {\n\t\t\tthrow new ProgrammingError(\"Browserdata is not passed\")\n\t\t}\n\t\tconst workerScope = self\n\t\tthis._queue = new Queue(workerScope)\n\t\tnativeApp.setWorkerQueue(this._queue)\n\t\tthis._newEntropy = -1\n\t\tthis._lastEntropyUpdate = new Date().getTime()\n\n\t\tinitLocator(this, browserData);\n\n\t\tthis._queue.setCommands({\n\t\t\ttestEcho: (message: any) => Promise.resolve({msg: \">>> \" + message.args[0].msg}),\n\t\t\ttestError: (message: any) => {\n\t\t\t\tconst errorTypes = {\n\t\t\t\t\tProgrammingError,\n\t\t\t\t\tCryptoError,\n\t\t\t\t\tNotAuthenticatedError\n\t\t\t\t}\n\t\t\t\tlet ErrorType = errorTypes[message.args[0].errorType]\n\t\t\t\treturn Promise.reject(new ErrorType(`wtf: ${message.args[0].errorType}`))\n\t\t\t},\n\t\t\tgenerateSignupKeys: (message: Request) => {\n\t\t\t\treturn locator.customer.generateSignupKeys.apply(locator.customer, message.args)\n\t\t\t},\n\t\t\tsignup: (message: Request) => {\n\t\t\t\treturn locator.customer.signup.apply(locator.customer, message.args)\n\t\t\t},\n\t\t\tcreateContactFormUserGroupData: (message: Request) => {\n\t\t\t\treturn locator.customer.createContactFormUserGroupData.apply(locator.customer, message.args)\n\t\t\t},\n\t\t\tcreateContactFormUser: (message: Request): Promise<ContactFormAccountReturn> => {\n\t\t\t\treturn locator.customer.createContactFormUser.apply(locator.customer, message.args)\n\t\t\t},\n\t\t\tcreateSession: (message: Request) => {\n\t\t\t\treturn locator.login.createSession.apply(locator.login, message.args)\n\t\t\t},\n\t\t\tcreateExternalSession: (message: Request) => {\n\t\t\t\treturn locator.login.createExternalSession.apply(locator.login, message.args)\n\t\t\t},\n\t\t\tloadExternalPasswordChannels: (message: Request) => {\n\t\t\t\treturn locator.login.loadExternalPasswordChannels.apply(locator.login, message.args)\n\t\t\t},\n\t\t\tsendExternalPasswordSms: (message: Request) => {\n\t\t\t\treturn locator.login.sendExternalPasswordSms.apply(locator.login, message.args)\n\t\t\t},\n\t\t\treset: (message: Request) => {\n\t\t\t\treturn resetLocator()\n\t\t\t},\n\t\t\tresumeSession: (message: Request) => {\n\t\t\t\treturn locator.login.resumeSession.apply(locator.login, message.args)\n\t\t\t},\n\t\t\tdeleteSession: (message: Request) => {\n\t\t\t\treturn locator.login.deleteSession.apply(locator.login, message.args)\n\t\t\t},\n\t\t\tchangePassword: (message: Request) => {\n\t\t\t\treturn locator.login.changePassword.apply(locator.login, message.args)\n\t\t\t},\n\t\t\tdeleteAccount: (message: Request) => {\n\t\t\t\treturn locator.login.deleteAccount.apply(locator.login, message.args)\n\t\t\t},\n\t\t\tcreateMailFolder: (message: Request) => {\n\t\t\t\treturn locator.mail.createMailFolder.apply(locator.mail, message.args)\n\t\t\t},\n\t\t\tcreateMailDraft: (message: Request) => {\n\t\t\t\treturn locator.mail.createDraft.apply(locator.mail, message.args)\n\t\t\t},\n\t\t\tupdateMailDraft: (message: Request) => {\n\t\t\t\treturn locator.mail.updateDraft.apply(locator.mail, message.args)\n\t\t\t},\n\t\t\tsendMailDraft: (message: Request) => {\n\t\t\t\treturn locator.mail.sendDraft.apply(locator.mail, message.args)\n\t\t\t},\n\t\t\treadAvailableCustomerStorage: (message: Request) => {\n\t\t\t\treturn locator.customer.readAvailableCustomerStorage.apply(locator.customer, message.args)\n\t\t\t},\n\t\t\treadUsedCustomerStorage: (message: Request) => {\n\t\t\t\treturn locator.customer.readUsedCustomerStorage.apply(locator.customer, message.args)\n\t\t\t},\n\t\t\trestRequest: (message: Request) => {\n\t\t\t\tmessage.args[3] = Object.assign(locator.login.createAuthHeaders(), message.args[3])\n\t\t\t\treturn locator.restClient.request.apply(locator.restClient, message.args)\n\t\t\t},\n\t\t\tentityRequest: (message: Request) => {\n\t\t\t\treturn locator.cache.entityRequest.apply(locator.cache, message.args)\n\t\t\t},\n\t\t\tserviceRequest: (message: Request) => {\n\t\t\t\treturn _service.apply(null, message.args)\n\t\t\t},\n\t\t\tdownloadFileContent: (message: Request) => {\n\t\t\t\treturn locator.file.downloadFileContent.apply(locator.file, message.args)\n\t\t\t},\n\t\t\tdownloadFileContentNative: (message: Request) => {\n\t\t\t\treturn locator.file.downloadFileContentNative.apply(locator.file, message.args)\n\t\t\t},\n\t\t\taddMailAlias: (message: Request) => {\n\t\t\t\treturn locator.mailAddress.addMailAlias.apply(locator.mailAddress, message.args)\n\t\t\t},\n\t\t\tsetMailAliasStatus: (message: Request) => {\n\t\t\t\treturn locator.mailAddress.setMailAliasStatus.apply(locator.mailAddress, message.args)\n\t\t\t},\n\t\t\tisMailAddressAvailable: (message: Request) => {\n\t\t\t\treturn locator.mailAddress.isMailAddressAvailable.apply(locator.mailAddress, message.args)\n\t\t\t},\n\t\t\tgetAliasCounters: (message: Request) => {\n\t\t\t\treturn locator.mailAddress.getAliasCounters.apply(locator.mailAddress, message.args)\n\t\t\t},\n\t\t\tchangeUserPassword: (message: Request) => {\n\t\t\t\treturn locator.userManagement.changeUserPassword.apply(locator.userManagement, message.args)\n\t\t\t},\n\t\t\tchangeAdminFlag: (message: Request) => {\n\t\t\t\treturn locator.userManagement.changeAdminFlag.apply(locator.userManagement, message.args)\n\t\t\t},\n\t\t\tupdateAdminship: (message: Request) => {\n\t\t\t\treturn locator.userManagement.updateAdminship.apply(locator.userManagement, message.args)\n\t\t\t},\n\t\t\tswitchFreeToPremiumGroup(message: Request): Promise<void> {\n\t\t\t\treturn locator.customer.switchFreeToPremiumGroup.apply(locator.customer, message.args)\n\t\t\t},\n\t\t\tswitchPremiumToFreeGroup(message: Request): Promise<void> {\n\t\t\t\treturn locator.customer.switchPremiumToFreeGroup.apply(locator.customer, message.args)\n\t\t\t},\n\t\t\tupdatePaymentData(message: Request): Promise<PaymentDataServicePutReturn> {\n\t\t\t\treturn locator.customer.updatePaymentData.apply(locator.customer, message.args)\n\t\t\t},\n\t\t\tdownloadInvoice(message: Request): Promise<DataFile> {\n\t\t\t\treturn locator.customer.downloadInvoice.apply(locator.customer, message.args)\n\t\t\t},\n\t\t\treadUsedUserStorage: (message: Request) => {\n\t\t\t\treturn locator.userManagement.readUsedUserStorage.apply(locator.userManagement, message.args)\n\t\t\t},\n\t\t\tdeleteUser: (message: Request) => {\n\t\t\t\treturn locator.userManagement.deleteUser.apply(locator.userManagement, message.args)\n\t\t\t},\n\t\t\tgetPrice: (message: Request) => {\n\t\t\t\treturn bookingFacade.getPrice.apply(bookingFacade, message.args)\n\t\t\t},\n\t\t\tgetCurrentPrice: (message: Request) => {\n\t\t\t\treturn bookingFacade.getCurrentPrice()\n\t\t\t},\n\n\t\t\tloadCustomerServerProperties: (message: Request) => {\n\t\t\t\treturn locator.customer.loadCustomerServerProperties.apply(locator.customer, message.args)\n\t\t\t},\n\t\t\taddSpamRule: (message: Request) => {\n\t\t\t\treturn locator.customer.addSpamRule(...message.args)\n\t\t\t},\n\t\t\teditSpamRule: (message: Request) => {\n\t\t\t\treturn locator.customer.editSpamRule(...message.args)\n\t\t\t},\n\t\t\tcreateUser: (message: Request) => {\n\t\t\t\treturn locator.userManagement.createUser.apply(locator.userManagement, message.args)\n\t\t\t},\n\t\t\treadUsedGroupStorage: (message: Request) => {\n\t\t\t\treturn locator.groupManagement.readUsedGroupStorage.apply(locator.groupManagement, message.args)\n\t\t\t},\n\t\t\tcreateMailGroup: (message: Request) => {\n\t\t\t\treturn locator.groupManagement.createMailGroup.apply(locator.groupManagement, message.args)\n\t\t\t},\n\t\t\tcreateLocalAdminGroup: (message: Request) => {\n\t\t\t\treturn locator.groupManagement.createLocalAdminGroup.apply(locator.groupManagement, message.args)\n\t\t\t},\n\t\t\taddUserToGroup: (message: Request) => {\n\t\t\t\treturn locator.groupManagement.addUserToGroup.apply(locator.groupManagement, message.args)\n\t\t\t},\n\t\t\tremoveUserFromGroup: (message: Request) => {\n\t\t\t\treturn locator.groupManagement.removeUserFromGroup.apply(locator.groupManagement, message.args)\n\t\t\t},\n\t\t\tdeactivateGroup: (message: Request) => {\n\t\t\t\treturn locator.groupManagement.deactivateGroup.apply(locator.groupManagement, message.args)\n\t\t\t},\n\t\t\tloadContactFormByPath: (message: Request) => {\n\t\t\t\treturn loadContactForm.apply(null, message.args)\n\t\t\t},\n\t\t\taddDomain: (message: Request) => {\n\t\t\t\treturn locator.customer.addDomain.apply(locator.customer, message.args)\n\t\t\t},\n\t\t\tremoveDomain: (message: Request) => {\n\t\t\t\treturn locator.customer.removeDomain.apply(locator.customer, message.args)\n\t\t\t},\n\t\t\tsetCatchAllGroup: (message: Request) => {\n\t\t\t\treturn locator.customer.setCatchAllGroup.apply(locator.customer, message.args)\n\t\t\t},\n\t\t\tuploadCertificate: (message: Request) => {\n\t\t\t\treturn locator.customer.uploadCertificate.apply(locator.customer, message.args)\n\t\t\t},\n\t\t\tdeleteCertificate: (message: Request) => {\n\t\t\t\treturn locator.customer.deleteCertificate.apply(locator.customer, message.args)\n\t\t\t},\n\t\t\tgenerateTotpSecret: (message: Request) => {\n\t\t\t\treturn this.getTotpVerifier().then(totp => totp.generateSecret.apply(totp, message.args))\n\t\t\t},\n\t\t\tgenerateTotpCode: (message: Request) => {\n\t\t\t\treturn this.getTotpVerifier().then(totp => totp.generateTotp.apply(totp, message.args))\n\t\t\t},\n\t\t\tsearch: (message: Request) => {\n\t\t\t\treturn locator.search.search.apply(locator.search, message.args)\n\t\t\t},\n\t\t\tenableMailIndexing: (message: Request) => {\n\t\t\t\treturn locator.indexer.enableMailIndexing()\n\t\t\t},\n\t\t\tdisableMailIndexing: (message: Request) => {\n\t\t\t\treturn locator.indexer.disableMailIndexing()\n\t\t\t},\n\n\t\t\textendMailIndex: (message: Request) => {\n\t\t\t\treturn locator.indexer.extendMailIndex.apply(locator.indexer, message.args)\n\t\t\t},\n\t\t\tcancelMailIndexing: (message: Request) => {\n\t\t\t\treturn locator.indexer.cancelMailIndexing()\n\t\t\t},\n\t\t\treadCounterValue: (message: Request) => {\n\t\t\t\treturn locator.counters.readCounterValue.apply(locator.counters, message.args)\n\t\t\t},\n\t\t\tcancelCreateSession: (message: Request) => {\n\t\t\t\tlocator.login.cancelCreateSession()\n\t\t\t\treturn Promise.resolve()\n\t\t\t},\n\t\t\tentropy: (message: Request) => {\n\t\t\t\treturn this.addEntropy(message.args[0])\n\t\t\t},\n\t\t\ttryReconnectEventBus(message: Request) {\n\t\t\t\tlocator.eventBusClient.tryReconnect.apply(locator.eventBusClient, message.args)\n\t\t\t\treturn Promise.resolve()\n\t\t\t},\n\t\t\tgenerateSsePushIdentifer: () => {\n\t\t\t\treturn Promise.resolve(keyToBase64(aes256RandomKey()))\n\t\t\t},\n\t\t\tdecryptUserPassword: (message: Request) => {\n\t\t\t\treturn locator.login.decryptUserPassword.apply(locator.login, message.args)\n\t\t\t},\n\t\t\tcloseEventBus: (message: Request) => {\n\t\t\t\tlocator.eventBusClient.close(message.args[0])\n\t\t\t\treturn Promise.resolve()\n\t\t\t},\n\t\t\tgetMoreSearchResults: (message: Request) => {\n\t\t\t\treturn locator.search.getMoreSearchResults.apply(locator.search, message.args).return(message.args[0])\n\t\t\t},\n\t\t\tgetRecoveryCode: (message: Request) => {\n\t\t\t\treturn locator.login.getRecoverCode.apply(locator.login, message.args)\n\t\t\t},\n\t\t\tcreateRecoveryCode: (message: Request) => {\n\t\t\t\treturn locator.login.createRecoveryCode.apply(locator.login, message.args)\n\t\t\t},\n\t\t\trecoverLogin: (message: Request) => {\n\t\t\t\treturn locator.login.recoverLogin.apply(locator.login, message.args)\n\t\t\t},\n\t\t\tresetSecondFactors: (message: Request) => {\n\t\t\t\treturn locator.login.resetSecondFactors.apply(locator.login, message.args)\n\t\t\t},\n\t\t\ttakeOverDeletedAddress: (message: Request) => {\n\t\t\t\treturn locator.login.takeOverDeletedAddress.apply(locator.login, message.args)\n\t\t\t},\n\t\t\tresetSession: () => locator.login.reset(),\n\t\t\tcreateCalendarEvent: (message: Request) => {\n\t\t\t\treturn locator.calendar.createCalendarEvent.apply(locator.calendar, message.args)\n\t\t\t},\n\t\t\tupdateCalendarEvent: (message: Request) => {\n\t\t\t\treturn locator.calendar.updateCalendarEvent.apply(locator.calendar, message.args)\n\t\t\t},\n\t\t\tresolveSessionKey: (message: Request) => {\n\t\t\t\treturn resolveSessionKey.apply(null, message.args).then(sk => sk ? keyToBase64(sk) : null)\n\t\t\t},\n\t\t\taddCalendar: (message: Request) => {\n\t\t\t\treturn locator.calendar.addCalendar.apply(locator.calendar, message.args)\n\t\t\t},\n\t\t\tscheduleAlarmsForNewDevice: (message: Request) => {\n\t\t\t\treturn locator.calendar.scheduleAlarmsForNewDevice(...message.args)\n\t\t\t},\n\t\t\tloadAlarmEvents: (message: Request) => {\n\t\t\t\treturn locator.calendar.loadAlarmEvents(...message.args)\n\t\t\t},\n\t\t\tgetDomainValidationRecord: (message: Request) => {\n\t\t\t\treturn locator.customer.getDomainValidationRecord(...message.args)\n\t\t\t},\n\t\t\tvisibilityChange: (message: Request) => {\n\t\t\t\tlocator.indexer.onVisibilityChanged(...message.args)\n\t\t\t\treturn Promise.resolve()\n\t\t\t},\n\t\t\tgetLog: () => {\n\t\t\t\tconst global = downcast(self)\n\t\t\t\tif (global.logger) {\n\t\t\t\t\treturn Promise.resolve(global.logger.getEntries())\n\t\t\t\t} else {\n\t\t\t\t\treturn Promise.resolve([])\n\t\t\t\t}\n\t\t\t},\n\t\t\tsendGroupInvitation: (message: Request) => {\n\t\t\t\treturn locator.share.sendGroupInvitation(...message.args)\n\t\t\t},\n\t\t\tacceptGroupInvitation: (message: Request) => {\n\t\t\t\treturn locator.share.acceptGroupInvitation(...message.args)\n\t\t\t},\n\t\t\trejectGroupInvitation: (message: Request) => {\n\t\t\t\treturn locator.share.rejectGroupInvitation(...message.args)\n\t\t\t},\n\t\t\tcheckMailForPhishing: (message: Request) => {\n\t\t\t\treturn locator.mail.checkMailForPhishing(...message.args)\n\t\t\t},\n\t\t\tgetEventByUid: (message: Request) => {\n\t\t\t\treturn locator.calendar.getEventByUid(...message.args)\n\t\t\t},\n\t\t})\n\n\t\t// only register oncaught error handler if we are in the *real* worker scope\n\t\t// Otherwise uncaught error handler might end up in an infinite loop for test cases.\n\t\tif (workerScope && !isMainOrNode()) {\n\t\t\tPromise.onPossiblyUnhandledRejection(e => {\n\t\t\t\tthis.sendError(e)\n\t\t\t})\n\n\t\t\tworkerScope.onerror = (e: string | Event, source, lineno, colno, error) => {\n\t\t\t\tconsole.error(\"workerImpl.onerror\", e, source, lineno, colno, error)\n\t\t\t\tif (error instanceof Error) {\n\t\t\t\t\tthis.sendError(error)\n\t\t\t\t} else {\n\t\t\t\t\tconst err = new Error(e)\n\t\t\t\t\terr.lineNumber = lineno\n\t\t\t\t\terr.columnNumber = colno\n\t\t\t\t\terr.fileName = source\n\t\t\t\t\tthis.sendError(err)\n\t\t\t\t}\n\t\t\t\treturn true\n\t\t\t}\n\t\t}\n\t}\n\n\tgetTotpVerifier(): Promise<TotpVerifier> {\n\t\treturn Promise.resolve(new TotpVerifier())\n\t}\n\n\t/**\n\t * Adds entropy to the randomizer. Updated the stored entropy for a user when enough entropy has been collected.\n\t * @param entropy\n\t * @returns {Promise.<void>}\n\t */\n\taddEntropy(entropy: {source: EntropySrcEnum, entropy: number, data: number}[]): Promise<void> {\n\t\ttry {\n\t\t\treturn random.addEntropy(entropy)\n\t\t} finally {\n\t\t\tthis._newEntropy = this._newEntropy + entropy.reduce((sum, value) => value.entropy + sum, 0)\n\t\t\tlet now = new Date().getTime()\n\t\t\tif (this._newEntropy > 5000 && (now - this._lastEntropyUpdate) > 1000 * 60 * 5) {\n\t\t\t\tthis._lastEntropyUpdate = now\n\t\t\t\tthis._newEntropy = 0\n\t\t\t\tlocator.login.storeEntropy()\n\t\t\t}\n\t\t}\n\t}\n\n\tentityEventsReceived(data: EntityUpdate[], eventOwnerGroupId: Id): Promise<void> {\n\t\treturn this._queue.postMessage(new Request(\"entityEvent\", [data, eventOwnerGroupId]))\n\t}\n\n\tsendError(e: Error): Promise<void> {\n\t\treturn this._queue.postMessage(new Request(\"error\", [errorToObj(e)]))\n\t}\n\n\tsendProgress(progressPercentage: number): Promise<void> {\n\t\treturn this._queue.postMessage(new Request(\"progress\", [progressPercentage])).then(() => {\n\t\t\t// the worker sometimes does not send the request if it does not get time\n\t\t\treturn Promise.fromCallback(cb => {\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tcb()\n\t\t\t\t}, 0)\n\t\t\t})\n\t\t})\n\t}\n\n\tsendIndexState(state: SearchIndexStateInfo): Promise<void> {\n\t\treturn this._queue.postMessage(new Request(\"updateIndexState\", [state]))\n\t}\n\n\tupdateWebSocketState(state: WsConnectionState): Promise<void> {\n\t\tconsole.log(\"ws displayed state: \", state)\n\t\treturn this._queue.postMessage(new Request(\"updateWebSocketState\", [state]))\n\t}\n\n\tupdateCounter(update: WebsocketCounterData): Promise<void> {\n\t\treturn this._queue.postMessage(new Request(\"counterUpdate\", [update]))\n\t}\n\n\tinfoMessage(message: InfoMessage): Promise<void> {\n\t\treturn this._queue.postMessage(new Request(\"infoMessage\", [message]))\n\t}\n\n\tcreateProgressMonitor(totalWork: number): Promise<ProgressMonitorId> {\n\t\treturn this._queue.postMessage(new Request(\"createProgressMonitor\", [totalWork]))\n\t}\n\n\tprogressWorkDone(reference: ProgressMonitorId, totalWork: number): Promise<void> {\n\t\treturn this._queue.postMessage(new Request(\"progressWorkDone\", [reference, totalWork]))\n\t}\n\n\tupdateLeaderStatus(status: WebsocketLeaderStatus): Promise<void> {\n\t\treturn this._queue.postMessage(new Request(\"updateLeaderStatus\", [status]))\n\t}\n\n}\n\n\n"]}
and here it is decoded:
Yup, it seems ot be eval
, if I replace build/worker.js in the project above with just
console.log("worker!");
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndvcmtlci5qcyJdLCJuYW1lcyI6WyJjb25zb2xlIiwibG9nIl0sIm1hcHBpbmdzIjoiQUFBQUEsT0FBTyxDQUFDQyxHQUFSLENBQVksU0FBWiIsInNvdXJjZXNDb250ZW50IjpbImNvbnNvbGUubG9nKFwid29ya2VyIVwiKSJdLCJmaWxlIjoiL2hvbWUvaXZrL2Rldi9ub2xsdXAtYnVnL3dvcmtlci5qcyIsInNvdXJjZVJvb3QiOiJub2xsdXA6Ly8vIn0=
then it works
:thinking:
Either browser does not support eval + source map in workers or something is not escaped somehow but then it shouldn't break only in the worker
I've made a test with Webpack and it works there with eval-source-map
or just eval
So with Webpack eval inline source maps work fine?
What's the difference between Nollup's generated map and Webpack's then I wonder...
here's webpack vs nollup
{"version":3,"file":"./src/worker.js.js","sources":["webpack://test-webpack/./src/worker.js?dd00"],"sourcesContent":["console.log(\"worker\")\n"],"mappings":"AAAA;","sourceRoot":""}
{"version":3,"sources":["worker.js"],"names":["console","log"],"mappings":"AAAAA,OAAO,CAACC,GAAR,CAAY,SAAZ","sourcesContent":["console.log(\"worker!\")"],"file":"/home/ivk/dev/nollup-bug/worker.js","sourceRoot":"nollup:///"}
EDIT: that's after I removed double source map URL which was there for some reason for webpack
I tried modifying CodeGenerator.js
to try mimic what Webpack is outputting, and that doesn't work. I'm really stumped on this one.
if (map) {
map.sourceRoot = '';
map.sources[map.sources.length - 1] = sourcePath;
map.file = './src/' + map.sources[0] + '.js';
map.sources = map.sources.map(p => 'webpack://test-webpack/./src/' + p);
code += `\\\n${ConvertSourceMap.fromObject(map).toComment()}`;
} else {
code += `\\\n//# sourceURL=${sourcePath}`;
}
I think adding //# sourceURL=nollup-int:///worker.js
manually worked for me?
Are you able to modify CodeGenerator.js and reproduce?
Let me try
Like so:
code += `\\n${ConvertSourceMap.fromObject(map).toComment()}\\n//# sourceURL=nollup-int://${filePath}`;
EDIT: remove double .js
(notice slashes difference, it was broken I think)
Nicely done! I don't understand why this works, but adding it doesn't seem to break anything as far as I can tell. Will need to do some testing on this further and see if it impacts anything else. Would appreciate it if you could do the same from your end on your full project and see if locally making the modification to Nollup ensures none of your source maps are broken.
code += `\\\n${ConvertSourceMap.fromObject(map).toComment()}\\n//# sourceURL=nollup-int://${filePath}`;
Keep the three slashes at the beginning, because it addresses a few issues regarding source code comments. :)
will do! I'm also puzzled by why we must assign sourceURL to it but oh well. I think filePath is not a good choice as Firefox trips and removes all of them if you try to acces it so maybe it should be a relative path instead.
Regarding slashes: it produces this:
eval('console.log("worker!");\
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndvcmtlci5qcyJdLCJuYW1lcyI6WyJjb25zb2xlIiwibG9nIl0sIm1hcHBpbmdzIjoiQUFBQUEsT0FBTyxDQUFDQyxHQUFSLENBQVksU0FBWiIsInNvdXJjZXNDb250ZW50IjpbImNvbnNvbGUubG9nKFwid29ya2VyIVwiKSJdLCJmaWxlIjoiL2hvbWUvaXZrL2Rldi9ub2xsdXAtYnVnL3dvcmtlci5qcyIsInNvdXJjZVJvb3QiOiJub2xsdXA6Ly8vIn0=\n//# sourceURL=nollup-int:///home/ivk/dev/nollup-bug/worker.js');
which doesn't look correct but maybe I'm wrong. webpack does it with '\n' inside the string
also it should be triple slash after nollup-int
if we are to follow webpack here
Works fine in Firefox for me?
As yes you're right, mixing up a different issue in my head. The reason for the extra slash is to keep the eval output clean so it's easier to read through. Webpacks puts the entire eval code into a single line, which can cause a crash for the devtools, so by ensuring lines are as minimal as possible it reduces the odds of a crash.
And yes, that's something I noticed too, the absolute path just so happens to add the third slash on *nix systems.
I see! I would do it like
//# sourceURL=nollup-int:///${sourcePath}
I think?
Will need to test it and see. Should be able to more thoroughly check it out later on this evening. :)
Of course, thanks a lot with assisting on this! Now I can fork it and it's not rush at all
Released in 0.14.3
🙂
Thanks a lot!
I get a lot of warning now with this, why?
I'm using https://github.com/rixo/svelte-template-hot by the amazing @rixo.
Not entirely sure how that's happening as a result of this change. But usually those happen because the library has relative paths to a source map included in the library. Nollup doesn't try to remove those comments. In the case of @urql/core, it has the following inside it:
//# sourceMappingURL=urql-core.mjs.map
I'm not sure how that would have worked before though. As far as I understand, other bundlers like Webpack would still show the same warning message. There's a plugin for this in Webpack, I suppose something similar would be needed here: https://webpack.js.org/loaders/source-map-loader/
Are we using https://www.npmjs.com/package/rollup-plugin-sourcemaps, @PepsRyuu?
That sounds like it would resolve the issue, but that's up the developer to include the plugin in their project.
:( @rixo should we add https://www.npmjs.com/package/rollup-plugin-sourcemaps?
Hi again! It might be a problem with my configuration but I can't get source maps to work with a worker, neither FF nor Chrome.
no matter which files are imported in worker part, none of them are visible under "nollup://" nor can be found.
Please excuse me if it's my fault but so far it seemed that nollup ignores sourceMap value which I pass so I don't think I have much control.