OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #import "ios/web/navigation/navigation_manager_storage_builder.h" | 5 #import "ios/web/navigation/navigation_manager_storage_builder.h" |
6 | 6 |
7 #include "base/logging.h" | 7 #include "base/logging.h" |
8 #include "base/mac/foundation_util.h" | 8 #include "base/mac/foundation_util.h" |
9 #import "ios/web/navigation/crw_session_controller.h" | 9 #import "ios/web/navigation/crw_session_controller.h" |
| 10 #import "ios/web/navigation/crw_session_controller+private_constructors.h" |
10 #import "ios/web/navigation/crw_session_entry.h" | 11 #import "ios/web/navigation/crw_session_entry.h" |
11 #import "ios/web/navigation/navigation_item_impl.h" | 12 #import "ios/web/navigation/navigation_item_impl.h" |
12 #import "ios/web/navigation/navigation_item_storage_builder.h" | 13 #import "ios/web/navigation/navigation_item_storage_builder.h" |
13 #include "ios/web/navigation/navigation_manager_impl.h" | 14 #include "ios/web/navigation/navigation_manager_impl.h" |
14 #import "ios/web/public/crw_navigation_manager_storage.h" | 15 #import "ios/web/public/crw_navigation_manager_storage.h" |
15 | 16 |
16 // CRWSessionController's readonly properties redefined as readwrite. These | 17 // CRWSessionController's readonly properties redefined as readwrite. These |
17 // will be removed and NavigationManagerImpl's ivars will be written directly | 18 // will be removed and NavigationManagerImpl's ivars will be written directly |
18 // as this functionality moves from CRWSessionController to | 19 // as this functionality moves from CRWSessionController to |
19 // NavigationManagerImpl; | 20 // NavigationManagerImpl; |
20 @interface CRWSessionController (ExposedForSerialization) | 21 @interface CRWSessionController (ExposedForSerialization) |
21 @property(nonatomic, readwrite, retain) NSString* tabId; | 22 @property(nonatomic, readwrite, retain) NSString* tabId; |
22 @property(nonatomic, readwrite, copy) NSString* openerId; | 23 @property(nonatomic, readwrite, copy) NSString* openerId; |
23 @property(nonatomic, readwrite, getter=isOpenedByDOM) BOOL openedByDOM; | 24 @property(nonatomic, readwrite, getter=isOpenedByDOM) BOOL openedByDOM; |
24 @property(nonatomic, readwrite, assign) NSInteger openerNavigationIndex; | 25 @property(nonatomic, readwrite, assign) NSInteger openerNavigationIndex; |
25 @property(nonatomic, readwrite, assign) NSInteger currentNavigationIndex; | |
26 @property(nonatomic, readwrite, assign) NSInteger previousNavigationIndex; | 26 @property(nonatomic, readwrite, assign) NSInteger previousNavigationIndex; |
27 @property(nonatomic, readwrite, retain) NSArray* entries; | |
28 @property(nonatomic, readwrite, retain) | 27 @property(nonatomic, readwrite, retain) |
29 CRWSessionCertificatePolicyManager* sessionCertificatePolicyManager; | 28 CRWSessionCertificatePolicyManager* sessionCertificatePolicyManager; |
30 @end | 29 @end |
31 | 30 |
32 namespace web { | 31 namespace web { |
33 | 32 |
34 CRWNavigationManagerStorage* | 33 CRWNavigationManagerStorage* |
35 NavigationManagerStorageBuilder::BuildSerialization( | 34 NavigationManagerStorageBuilder::BuildSerialization( |
36 NavigationManagerImpl* navigation_manager) const { | 35 NavigationManagerImpl* navigation_manager) const { |
37 DCHECK(navigation_manager); | 36 DCHECK(navigation_manager); |
(...skipping 10 matching lines...) Expand all Loading... |
48 serialized_navigation_manager.currentNavigationIndex = | 47 serialized_navigation_manager.currentNavigationIndex = |
49 session_controller.currentNavigationIndex; | 48 session_controller.currentNavigationIndex; |
50 serialized_navigation_manager.previousNavigationIndex = | 49 serialized_navigation_manager.previousNavigationIndex = |
51 session_controller.previousNavigationIndex; | 50 session_controller.previousNavigationIndex; |
52 serialized_navigation_manager.lastVisitedTimestamp = | 51 serialized_navigation_manager.lastVisitedTimestamp = |
53 session_controller.lastVisitedTimestamp; | 52 session_controller.lastVisitedTimestamp; |
54 serialized_navigation_manager.sessionCertificatePolicyManager = | 53 serialized_navigation_manager.sessionCertificatePolicyManager = |
55 session_controller.sessionCertificatePolicyManager; | 54 session_controller.sessionCertificatePolicyManager; |
56 NSMutableArray* entries = [[NSMutableArray alloc] init]; | 55 NSMutableArray* entries = [[NSMutableArray alloc] init]; |
57 NavigationItemStorageBuilder item_storage_builder; | 56 NavigationItemStorageBuilder item_storage_builder; |
58 for (CRWSessionEntry* entry in session_controller.entries) { | 57 for (size_t index = 0; index < session_controller.items.size(); ++index) { |
59 [entries addObject:item_storage_builder.BuildSerialization( | 58 [entries addObject:item_storage_builder.BuildSerialization( |
60 entry.navigationItemImpl)]; | 59 session_controller.items[index].get())]; |
61 } | 60 } |
62 serialized_navigation_manager.entries = entries; | 61 serialized_navigation_manager.entries = entries; |
63 return serialized_navigation_manager; | 62 return serialized_navigation_manager; |
64 } | 63 } |
65 | 64 |
66 std::unique_ptr<NavigationManagerImpl> | 65 std::unique_ptr<NavigationManagerImpl> |
67 NavigationManagerStorageBuilder::BuildNavigationManagerImpl( | 66 NavigationManagerStorageBuilder::BuildNavigationManagerImpl( |
68 CRWNavigationManagerStorage* navigation_manager_serialization) const { | 67 CRWNavigationManagerStorage* navigation_manager_serialization) const { |
69 DCHECK(navigation_manager_serialization); | 68 DCHECK(navigation_manager_serialization); |
| 69 web::ScopedNavigationItemList items; |
| 70 NavigationItemStorageBuilder item_storage_builder; |
| 71 NSArray* item_storages = navigation_manager_serialization.entries; |
| 72 for (CRWNavigationItemStorage* item_storage in item_storages) { |
| 73 std::unique_ptr<NavigationItemImpl> item_impl = |
| 74 item_storage_builder.BuildNavigationItemImpl(item_storage); |
| 75 items.push_back(std::move(item_impl)); |
| 76 } |
| 77 NSUInteger currentIndex = |
| 78 navigation_manager_serialization.currentNavigationIndex; |
70 base::scoped_nsobject<CRWSessionController> session_controller( | 79 base::scoped_nsobject<CRWSessionController> session_controller( |
71 [[CRWSessionController alloc] init]); | 80 [[CRWSessionController alloc] initWithNavigationItems:std::move(items) |
| 81 currentIndex:currentIndex |
| 82 browserState:nullptr]); |
72 [session_controller setTabId:navigation_manager_serialization.tabID]; | 83 [session_controller setTabId:navigation_manager_serialization.tabID]; |
73 [session_controller setOpenerId:navigation_manager_serialization.openerID]; | 84 [session_controller setOpenerId:navigation_manager_serialization.openerID]; |
74 [session_controller | 85 [session_controller |
75 setOpenedByDOM:navigation_manager_serialization.openedByDOM]; | 86 setOpenedByDOM:navigation_manager_serialization.openedByDOM]; |
76 [session_controller setOpenerNavigationIndex:navigation_manager_serialization | 87 [session_controller setOpenerNavigationIndex:navigation_manager_serialization |
77 .openerNavigationIndex]; | 88 .openerNavigationIndex]; |
78 [session_controller | 89 [session_controller |
79 setWindowName:navigation_manager_serialization.windowName]; | 90 setWindowName:navigation_manager_serialization.windowName]; |
80 [session_controller setCurrentNavigationIndex:navigation_manager_serialization | |
81 .currentNavigationIndex]; | |
82 [session_controller | 91 [session_controller |
83 setPreviousNavigationIndex:navigation_manager_serialization | 92 setPreviousNavigationIndex:navigation_manager_serialization |
84 .previousNavigationIndex]; | 93 .previousNavigationIndex]; |
85 [session_controller setLastVisitedTimestamp:navigation_manager_serialization | 94 [session_controller setLastVisitedTimestamp:navigation_manager_serialization |
86 .lastVisitedTimestamp]; | 95 .lastVisitedTimestamp]; |
87 [session_controller | 96 [session_controller |
88 setSessionCertificatePolicyManager:navigation_manager_serialization | 97 setSessionCertificatePolicyManager:navigation_manager_serialization |
89 .sessionCertificatePolicyManager]; | 98 .sessionCertificatePolicyManager]; |
90 NavigationItemStorageBuilder item_storage_builder; | |
91 NSArray* item_storages = navigation_manager_serialization.entries; | |
92 NSMutableArray* entries = [[NSMutableArray alloc] init]; | |
93 for (CRWNavigationItemStorage* item_storage in item_storages) { | |
94 std::unique_ptr<NavigationItemImpl> item_impl = | |
95 item_storage_builder.BuildNavigationItemImpl(item_storage); | |
96 std::unique_ptr<NavigationItem> item(item_impl.release()); | |
97 [entries addObject:[[CRWSessionEntry alloc] | |
98 initWithNavigationItem:std::move(item)]]; | |
99 } | |
100 [session_controller setEntries:entries]; | |
101 std::unique_ptr<NavigationManagerImpl> navigation_manager( | 99 std::unique_ptr<NavigationManagerImpl> navigation_manager( |
102 new NavigationManagerImpl()); | 100 new NavigationManagerImpl()); |
103 navigation_manager->SetSessionController(session_controller); | 101 navigation_manager->SetSessionController(session_controller); |
104 return navigation_manager; | 102 return navigation_manager; |
105 } | 103 } |
106 | 104 |
107 } // namespace web | 105 } // namespace web |
OLD | NEW |