/*
* Copyright (C) 2011 Apple Inc. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
* THE POSSIBILITY OF SUCH DAMAGE.
*/
#include "config.h"
#include "WebTextCheckerClient.h"
#include "ImmutableArray.h"
#include "WKAPICast.h"
#include "WKSharedAPICast.h"
#include "WebGrammarDetail.h"
#include "WebPageProxy.h"
#include <wtf/text/WTFString.h>
namespace WebKit {
bool WebTextCheckerClient::continuousSpellCheckingAllowed()
{
if (!m_client.continuousSpellCheckingAllowed)
return false;
return m_client.continuousSpellCheckingAllowed(m_client.clientInfo);
}
bool WebTextCheckerClient::continuousSpellCheckingEnabled()
{
if (!m_client.continuousSpellCheckingEnabled)
return false;
return m_client.continuousSpellCheckingEnabled(m_client.clientInfo);
}
void WebTextCheckerClient::setContinuousSpellCheckingEnabled(bool enabled)
{
if (!m_client.setContinuousSpellCheckingEnabled)
return;
m_client.setContinuousSpellCheckingEnabled(enabled, m_client.clientInfo);
}
bool WebTextCheckerClient::grammarCheckingEnabled()
{
if (!m_client.grammarCheckingEnabled)
return false;
return m_client.grammarCheckingEnabled(m_client.clientInfo);
}
void WebTextCheckerClient::setGrammarCheckingEnabled(bool enabled)
{
if (!m_client.setGrammarCheckingEnabled)
return;
m_client.setGrammarCheckingEnabled(enabled, m_client.clientInfo);
}
uint64_t WebTextCheckerClient::uniqueSpellDocumentTag(WebPageProxy* page)
{
if (!m_client.uniqueSpellDocumentTag)
return 0;
return m_client.uniqueSpellDocumentTag(toAPI(page), m_client.clientInfo);
}
void WebTextCheckerClient::closeSpellDocumentWithTag(uint64_t tag)
{
if (!m_client.closeSpellDocumentWithTag)
return;
m_client.closeSpellDocumentWithTag(tag, m_client.clientInfo);
}
void WebTextCheckerClient::checkSpellingOfString(uint64_t tag, const String& text, int32_t& misspellingLocation, int32_t& misspellingLength)
{
if (!m_client.checkSpellingOfString)
return;
m_client.checkSpellingOfString(tag, toAPI(text.impl()), &misspellingLocation, &misspellingLength, m_client.clientInfo);
}
void WebTextCheckerClient::checkGrammarOfString(uint64_t tag, const String& text, Vector<WebCore::GrammarDetail>& grammarDetails, int32_t& badGrammarLocation, int32_t& badGrammarLength)
{
if (!m_client.checkGrammarOfString)
return;
WKArrayRef wkGrammarDetailsRef = 0;
m_client.checkGrammarOfString(tag, toAPI(text.impl()), &wkGrammarDetailsRef, &badGrammarLocation, &badGrammarLength, m_client.clientInfo);
RefPtr<ImmutableArray> wkGrammarDetails = adoptRef(toImpl(wkGrammarDetailsRef));
size_t numGrammarDetails = wkGrammarDetails->size();
for (size_t i = 0; i < numGrammarDetails; ++i)
grammarDetails.append(wkGrammarDetails->at<WebGrammarDetail>(i)->grammarDetail());
}
bool WebTextCheckerClient::spellingUIIsShowing()
{
if (!m_client.spellingUIIsShowing)
return false;
return m_client.spellingUIIsShowing(m_client.clientInfo);
}
void WebTextCheckerClient::toggleSpellingUIIsShowing()
{
if (!m_client.toggleSpellingUIIsShowing)
return;
return m_client.toggleSpellingUIIsShowing(m_client.clientInfo);
}
void WebTextCheckerClient::updateSpellingUIWithMisspelledWord(uint64_t tag, const String& misspelledWord)
{
if (!m_client.updateSpellingUIWithMisspelledWord)
return;
m_client.updateSpellingUIWithMisspelledWord(tag, toAPI(misspelledWord.impl()), m_client.clientInfo);
}
void WebTextCheckerClient::updateSpellingUIWithGrammarString(uint64_t tag, const String& badGrammarPhrase, const WebCore::GrammarDetail& grammarDetail)
{
if (!m_client.updateSpellingUIWithGrammarString)
return;
m_client.updateSpellingUIWithGrammarString(tag, toAPI(badGrammarPhrase.impl()), toAPI(grammarDetail), m_client.clientInfo);
}
void WebTextCheckerClient::guessesForWord(uint64_t tag, const String& word, Vector<String>& guesses)
{
if (!m_client.guessesForWord)
return;
RefPtr<ImmutableArray> wkGuesses = adoptRef(toImpl(m_client.guessesForWord(tag, toAPI(word.impl()), m_client.clientInfo)));
size_t numGuesses = wkGuesses->size();
for (size_t i = 0; i < numGuesses; ++i)
guesses.append(wkGuesses->at<WebString>(i)->string());
}
void WebTextCheckerClient::learnWord(uint64_t tag, const String& word)
{
if (!m_client.learnWord)
return;
m_client.learnWord(tag, toAPI(word.impl()), m_client.clientInfo);
}
void WebTextCheckerClient::ignoreWord(uint64_t tag, const String& word)
{
if (!m_client.ignoreWord)
return;
m_client.ignoreWord(tag, toAPI(word.impl()), m_client.clientInfo);
}
} // namespace WebKit