// Copyright (c) 2012 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. #ifndef UI_BASE_DRAGDROP_MAC_DND_UTIL_H_ #define UI_BASE_DRAGDROP_MAC_DND_UTIL_H_ #import #include #include "base/strings/string16.h" #include "ui/base/ui_base_export.h" class GURL; namespace ui { // Dummy data type that Chrome places in dragging pasteboards. There is never // any data associated with this type; it's only used to ensure that Chrome // supports any drag initiated inside of Chrome, whether or not data has been // associated with it. UI_BASE_EXPORT extern NSString* const kChromeDragDummyPboardType; // Mail.app and TextEdit accept drags that have both HTML and image flavors on // them, but don't process them correctly . Therefore, // if there is an image flavor, don't put the HTML data on as HTML, but rather // put it on as this Chrome-only flavor. External apps won't see HTML but // Chrome will know enough to read it as HTML. UI_BASE_EXPORT extern NSString* const kChromeDragImageHTMLPboardType; // Populates the |url| and |title| with URL data in |pboard|. There may be more // than one, but we only handle dropping the first. |url| must not be |NULL|; // |title| is an optional parameter. Returns |YES| if URL data was obtained from // the pasteboard, |NO| otherwise. If |convert_filenames| is |YES|, the function // will also attempt to convert filenames in |pboard| to file URLs. UI_BASE_EXPORT BOOL PopulateURLAndTitleFromPasteboard(GURL* url, base::string16* title, NSPasteboard* pboard, BOOL convert_filenames); } // namespace ui #endif // UI_BASE_DRAGDROP_MAC_DND_UTIL_H_