| Index: pdf/out_of_process_instance.cc
|
| diff --git a/pdf/out_of_process_instance.cc b/pdf/out_of_process_instance.cc
|
| index 169a4403498a21b2a2eb9dac16f5c88ff5e022f8..a365871cdbe67efc4f8064ce0cbffd86e4b81e43 100644
|
| --- a/pdf/out_of_process_instance.cc
|
| +++ b/pdf/out_of_process_instance.cc
|
| @@ -140,9 +140,13 @@ const char kJSGetSelectedTextType[] = "getSelectedText";
|
| const char kJSGetSelectedTextReplyType[] = "getSelectedTextReply";
|
| const char kJSSelectedText[] = "selectedText";
|
|
|
| -// List of named destinations (Plugin -> Page)
|
| -const char kJSSetNamedDestinationsType[] = "setNamedDestinations";
|
| -const char kJSNamedDestinations[] = "namedDestinations";
|
| +// Get the named destinations (Page -> Plugin)
|
| +const char KJSGetNamedDestinationType[] = "getNamedDestination";
|
| +const char KJSGetNamedDestination[] = "namedDestination";
|
| +const char KJSGetNavigationUrl[] = "navigationUrl";
|
| +// Reply with page number of named destination (Plugin -> Page)
|
| +const char kJSGetNamedDestinationReplyType[] = "getNamedDestinationReply";
|
| +const char kJSNamedDestinationPageNumber[] = "namedDestinationPageNumber";
|
|
|
| const int kFindResultCooldownMs = 100;
|
|
|
| @@ -476,6 +480,18 @@ void OutOfProcessInstance::HandleMessage(const pp::Var& message) {
|
| reply.Set(pp::Var(kType), pp::Var(kJSGetSelectedTextReplyType));
|
| reply.Set(pp::Var(kJSSelectedText), selected_text);
|
| PostMessage(reply);
|
| + } else if (type == KJSGetNamedDestinationType &&
|
| + dict.Get(pp::Var(KJSGetNamedDestination)).is_string()) {
|
| + int page_number = engine_->GetNamedDestinationPage(
|
| + dict.Get(pp::Var(KJSGetNamedDestination)).AsString());
|
| + pp::VarDictionary reply;
|
| + reply.Set(pp::Var(kType), pp::Var(kJSGetNamedDestinationReplyType));
|
| + if (dict.Get(pp::Var(KJSGetNavigationUrl)).is_string())
|
| + reply.Set(pp::Var(KJSGetNavigationUrl),
|
| + dict.Get(pp::Var(KJSGetNavigationUrl)));
|
| + if (page_number >= 0)
|
| + reply.Set(pp::Var(kJSNamedDestinationPageNumber), page_number);
|
| + PostMessage(reply);
|
| } else {
|
| NOTREACHED();
|
| }
|
| @@ -1091,14 +1107,6 @@ void OutOfProcessInstance::DocumentLoadComplete(int page_count) {
|
| OnGeometryChanged(0, 0);
|
| }
|
|
|
| - pp::VarDictionary named_destinations_message;
|
| - pp::VarDictionary named_destinations = engine_->GetNamedDestinations();
|
| - named_destinations_message.Set(pp::Var(kType),
|
| - pp::Var(kJSSetNamedDestinationsType));
|
| - named_destinations_message.Set(pp::Var(kJSNamedDestinations),
|
| - pp::Var(named_destinations));
|
| - PostMessage(named_destinations_message);
|
| -
|
| pp::VarDictionary bookmarks_message;
|
| bookmarks_message.Set(pp::Var(kType), pp::Var(kJSBookmarksType));
|
| bookmarks_message.Set(pp::Var(kJSBookmarks), engine_->GetBookmarks());
|
|
|