From f94d8ed9326ffcc3365715423da044c43cb3b848 Mon Sep 17 00:00:00 2001 From: bridiver Date: Mon, 17 Jul 2017 13:17:17 -0700 Subject: [PATCH] use shared mem ipc to transfer history and bookmarks to about pages fix #10024 --- app/browser/tabs.js | 6 ++++-- js/about/bookmarks.js | 3 ++- js/about/history.js | 3 ++- 3 files changed, 8 insertions(+), 4 deletions(-) diff --git a/app/browser/tabs.js b/app/browser/tabs.js index 68a1134fdd7..06743fc16dc 100644 --- a/app/browser/tabs.js +++ b/app/browser/tabs.js @@ -199,13 +199,15 @@ const updateAboutDetails = (tab, tabValue) => { } else if (location === 'about:bookmarks') { const bookmarksData = getBookmarksData(appState) if (bookmarksData.bookmarks) { - tab.send(messages.BOOKMARKS_UPDATED, bookmarksData) + const handle = muon.shared_memory.create(bookmarksData) + tab.sendShared(messages.BOOKMARKS_UPDATED, handle) } } else if (location === 'about:history') { if (!history) { appActions.populateHistory() } else { - tab.send(messages.HISTORY_UPDATED, history.toJS()) + const handle = muon.shared_memory.create(history.toJS()) + tab.sendShared(messages.HISTORY_UPDATED, handle) } tab.send(messages.SETTINGS_UPDATED, appSettings.toJS()) } else if (location === 'about:extensions' && extensions) { diff --git a/js/about/bookmarks.js b/js/about/bookmarks.js index e0de03a3634..32ea4046491 100644 --- a/js/about/bookmarks.js +++ b/js/about/bookmarks.js @@ -389,7 +389,8 @@ class AboutBookmarks extends React.Component { selectedFolderId: 0, search: '' } - ipc.on(messages.BOOKMARKS_UPDATED, (e, detail) => { + ipc.on(messages.BOOKMARKS_UPDATED, (e, handle) => { + const detail = handle.memory() this.setState({ bookmarks: Immutable.fromJS((detail && detail.bookmarks) || {}), bookmarkFolders: Immutable.fromJS((detail && detail.bookmarkFolders) || {}) diff --git a/js/about/history.js b/js/about/history.js index 20836ea2693..534c1e6e969 100644 --- a/js/about/history.js +++ b/js/about/history.js @@ -143,7 +143,8 @@ class AboutHistory extends React.Component { selection: Immutable.Set(), updatedStamp: undefined } - ipc.on(messages.HISTORY_UPDATED, (e, detail) => { + ipc.on(messages.HISTORY_UPDATED, (e, handle) => { + const detail = handle.memory() const aboutHistory = Immutable.fromJS(detail || {}) const updatedStamp = aboutHistory.get('updatedStamp') // Only update if the data has changed.