1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
|
/*
* Copyright (C) 2006, 2007 Apple Inc.
* Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies).
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public License
* along with this library; see the file COPYING.LIB. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
#include "config.h"
#include "SearchPopupMenuWin.h"
#include <wtf/text/AtomicString.h>
#if USE(CF)
#include <wtf/RetainPtr.h>
#endif
namespace WebCore {
SearchPopupMenuWin::SearchPopupMenuWin(PopupMenuClient* client)
: m_popup(adoptRef(new PopupMenuWin(client)))
{
}
PopupMenu* SearchPopupMenuWin::popupMenu()
{
return m_popup.get();
}
bool SearchPopupMenuWin::enabled()
{
#if USE(CF)
return true;
#else
return false;
#endif
}
#if USE(CF)
static RetainPtr<CFStringRef> autosaveKey(const String& name)
{
return String("com.apple.WebKit.searchField:" + name).createCFString();
}
#endif
void SearchPopupMenuWin::saveRecentSearches(const AtomicString& name, const Vector<RecentSearch>& searchItems)
{
if (name.isEmpty())
return;
#if USE(CF)
RetainPtr<CFMutableArrayRef> items;
size_t size = searchItems.size();
if (size) {
items = adoptCF(CFArrayCreateMutable(0, size, &kCFTypeArrayCallBacks));
for (size_t i = 0; i < size; ++i)
CFArrayAppendValue(items.get(), searchItems[i].string.createCFString().get());
}
CFPreferencesSetAppValue(autosaveKey(name).get(), items.get(), kCFPreferencesCurrentApplication);
CFPreferencesAppSynchronize(kCFPreferencesCurrentApplication);
#endif
}
void SearchPopupMenuWin::loadRecentSearches(const AtomicString& name, Vector<RecentSearch>& searchItems)
{
if (name.isEmpty())
return;
#if USE(CF)
searchItems.clear();
RetainPtr<CFArrayRef> items = adoptCF(reinterpret_cast<CFArrayRef>(CFPreferencesCopyAppValue(autosaveKey(name).get(), kCFPreferencesCurrentApplication)));
if (!items || CFGetTypeID(items.get()) != CFArrayGetTypeID())
return;
size_t size = CFArrayGetCount(items.get());
for (size_t i = 0; i < size; ++i) {
CFStringRef item = (CFStringRef)CFArrayGetValueAtIndex(items.get(), i);
if (CFGetTypeID(item) == CFStringGetTypeID()) {
// We are choosing not to use or store search times on Windows at this time, so for now it's OK to use a "distant past" time as a placeholder.
searchItems.append({ String{ item }, std::chrono::system_clock::time_point::min() });
}
}
#endif
}
}
|