Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(993)

Side by Side Diff: ppapi/shared_impl/flash_clipboard_format_registry.cc

Issue 11225021: Move flash clipboard to the new proxy and add custom format support (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: . Created 8 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "ppapi/shared_impl/flash_clipboard_format_registry.h"
6
7 #include <cctype>
8
9 namespace ppapi {
10
11 namespace {
12
13 // These values are chosen arbitrarily. Flash will never exceed these but if
14 // the interface becomes public, we can reconsider these.
15 const size_t kMaxNumFormats = 10;
16 const size_t kMaxFormatNameLength = 50;
17
18 // All formats in PP_Flash_Clipboard_Format should be added here.
19 const PP_Flash_Clipboard_Format kPredefinedFormats[] = {
20 PP_FLASH_CLIPBOARD_FORMAT_INVALID,
21 PP_FLASH_CLIPBOARD_FORMAT_PLAINTEXT,
22 PP_FLASH_CLIPBOARD_FORMAT_HTML,
23 PP_FLASH_CLIPBOARD_FORMAT_RTF
24 };
25
26 // The first custom format ID will be the ID after that max value in
27 // PP_Flash_Clipboard_Format.
28 const size_t kFirstCustomFormat = arraysize(kPredefinedFormats);
29
30 // Checks the validity of the given format name.
31 bool IsValidFormatName(const std::string& format_name) {
32 if (format_name.empty() || format_name.length() > kMaxFormatNameLength)
33 return false;
34 return true;
35 }
36
37 } // namespace
38
39 FlashClipboardFormatRegistry::FlashClipboardFormatRegistry() {
40 }
41
42 FlashClipboardFormatRegistry::~FlashClipboardFormatRegistry() {
43 }
44
45 uint32_t FlashClipboardFormatRegistry::RegisterFormat(
46 const std::string& format_name) {
47 if (!IsValidFormatName(format_name) ||
48 custom_formats_.size() > kMaxNumFormats) {
49 return PP_FLASH_CLIPBOARD_FORMAT_INVALID;
50 }
51 uint32_t key = kFirstCustomFormat + custom_formats_.size();
52 custom_formats_[key] = format_name;
53 return key;
54 }
55
56 void FlashClipboardFormatRegistry::SetRegisteredFormat(
57 const std::string& format_name,
58 uint32_t format) {
59 custom_formats_[format] = format_name;
60 }
61
62 bool FlashClipboardFormatRegistry::IsFormatRegistered(uint32_t format) const {
63 return custom_formats_.find(format) != custom_formats_.end();
64 }
65
66 std::string FlashClipboardFormatRegistry::GetFormatName(
67 uint32_t format) const {
68 FormatMap::const_iterator it = custom_formats_.find(format);
69 if (it == custom_formats_.end())
70 return std::string();
71 return it->second;
72 }
73
74 uint32_t FlashClipboardFormatRegistry::GetFormatID(
75 const std::string& format_name) const {
76 for (FormatMap::const_iterator it = custom_formats_.begin();
77 it != custom_formats_.end(); ++it) {
78 if (it->second == format_name)
79 return it->first;
80 }
81 return PP_FLASH_CLIPBOARD_FORMAT_INVALID;
82 }
83
84 // static
85 bool FlashClipboardFormatRegistry::IsValidPredefinedFormat(uint32_t format) {
86 if (format == PP_FLASH_CLIPBOARD_FORMAT_INVALID)
87 return false;
88 return format < kFirstCustomFormat;
89 }
90
91 } // namespace ppapi
OLDNEW
« no previous file with comments | « ppapi/shared_impl/flash_clipboard_format_registry.h ('k') | ppapi/shared_impl/ppb_flash_shared.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698