mirror of
https://github.com/encounter/engine.git
synced 2026-03-30 11:09:55 -07:00
e3fe2a2fcc
Users should use the corresponding methods dealing with InterfacePtrInfo<>. BUG=None TEST=None R=jamesr@chromium.org Review URL: https://codereview.chromium.org/1118843003
114 lines
3.2 KiB
C++
114 lines
3.2 KiB
C++
// Copyright 2014 The Chromium Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#include "sky/engine/config.h"
|
|
#include "sky/engine/core/html/HTMLIFrameElement.h"
|
|
|
|
#include "gen/sky/core/HTMLNames.h"
|
|
#include "sky/engine/core/frame/LocalFrame.h"
|
|
#include "sky/engine/core/html/parser/HTMLParserIdioms.h"
|
|
#include "sky/engine/core/loader/FrameLoaderClient.h"
|
|
#include "sky/engine/core/rendering/RenderIFrame.h"
|
|
#include "sky/engine/tonic/mojo_converter.h"
|
|
|
|
namespace blink {
|
|
|
|
PassRefPtr<HTMLIFrameElement> HTMLIFrameElement::create(Document& document)
|
|
{
|
|
return adoptRef(new HTMLIFrameElement(document));
|
|
}
|
|
|
|
HTMLIFrameElement::HTMLIFrameElement(Document& document)
|
|
: HTMLElement(HTMLNames::iframeTag, document),
|
|
m_contentView(nullptr)
|
|
{
|
|
}
|
|
|
|
HTMLIFrameElement::~HTMLIFrameElement()
|
|
{
|
|
if (m_contentView)
|
|
m_contentView->RemoveObserver(this);
|
|
}
|
|
|
|
void HTMLIFrameElement::insertedInto(ContainerNode* insertionPoint)
|
|
{
|
|
HTMLElement::insertedInto(insertionPoint);
|
|
if (insertionPoint->inDocument()) {
|
|
if (LocalFrame* frame = document().frame()) {
|
|
m_contentView = frame->loaderClient()->createChildFrame();
|
|
m_contentView->AddObserver(this);
|
|
}
|
|
navigateView();
|
|
}
|
|
}
|
|
|
|
void HTMLIFrameElement::removedFrom(ContainerNode* insertionPoint)
|
|
{
|
|
HTMLElement::removedFrom(insertionPoint);
|
|
if (m_contentView)
|
|
m_contentView->Destroy();
|
|
}
|
|
|
|
void HTMLIFrameElement::parseAttribute(const QualifiedName& name, const AtomicString& value)
|
|
{
|
|
if (name == HTMLNames::srcAttr) {
|
|
navigateView();
|
|
} else {
|
|
HTMLElement::parseAttribute(name, value);
|
|
}
|
|
}
|
|
|
|
RenderObject* HTMLIFrameElement::createRenderer(RenderStyle* style)
|
|
{
|
|
return new RenderIFrame(this);
|
|
}
|
|
|
|
void HTMLIFrameElement::OnViewDestroyed(mojo::View* view)
|
|
{
|
|
DCHECK_EQ(view, m_contentView);
|
|
m_contentView = nullptr;
|
|
}
|
|
|
|
PassRefPtr<DartValue> HTMLIFrameElement::takeServicesHandle(DartState*)
|
|
{
|
|
return DartValue::Create();
|
|
}
|
|
|
|
PassRefPtr<DartValue> HTMLIFrameElement::takeExposedServicesHandle(DartState*)
|
|
{
|
|
return DartValue::Create();
|
|
}
|
|
|
|
void HTMLIFrameElement::embedViewManagerClient(RefPtr<DartValue> client)
|
|
{
|
|
if (!m_contentView)
|
|
return;
|
|
|
|
mojo::ScopedMessagePipeHandle handle = DartConverter<mojo::ScopedMessagePipeHandle>::FromDart(client->dart_value());
|
|
mojo::ViewManagerClientPtr client_ptr = mojo::MakeProxy(
|
|
mojo::InterfacePtrInfo<mojo::ViewManagerClient>(handle.Pass(), 0u));
|
|
m_contentView->Embed(client_ptr.Pass());
|
|
}
|
|
|
|
void HTMLIFrameElement::navigateView()
|
|
{
|
|
if (!m_contentView)
|
|
return;
|
|
|
|
String urlString = stripLeadingAndTrailingHTMLSpaces(getAttribute(HTMLNames::srcAttr));
|
|
if (urlString.isEmpty())
|
|
urlString = blankURL().string();
|
|
|
|
KURL url = document().completeURL(urlString);
|
|
|
|
mojo::MessagePipe exposedServicesPipe;
|
|
m_exposedServices = exposedServicesPipe.handle0.Pass();
|
|
|
|
m_contentView->Embed(mojo::String::From(url.string().utf8().data()),
|
|
mojo::GetProxy(&m_services),
|
|
mojo::MakeProxy(mojo::InterfacePtrInfo<mojo::ServiceProvider>(exposedServicesPipe.handle1.Pass(), 0u)));
|
|
}
|
|
|
|
}
|