diff options
-rw-r--r-- | chrome/browser/gtk/download_item_gtk.cc | 27 | ||||
-rw-r--r-- | chrome/browser/gtk/download_item_gtk.h | 6 |
2 files changed, 28 insertions, 5 deletions
diff --git a/chrome/browser/gtk/download_item_gtk.cc b/chrome/browser/gtk/download_item_gtk.cc index 63cea8e..e709590 100644 --- a/chrome/browser/gtk/download_item_gtk.cc +++ b/chrome/browser/gtk/download_item_gtk.cc @@ -185,7 +185,8 @@ DownloadItemGtk::DownloadItemGtk(DownloadShelfGtk* parent_shelf, download_model_(download_model), bounding_widget_(parent_shelf->GetRightBoundingWidget()), dangerous_prompt_(NULL), - icon_(NULL) { + icon_(NULL), + creation_time_(base::Time::Now()) { InitNineBoxes(); LoadIcon(); @@ -380,6 +381,13 @@ void DownloadItemGtk::OnDownloadUpdated(DownloadItem* download) { dangerous_prompt_ = NULL; } + if (download->full_path() != icon_filepath_) { + // Turns out the file path is "unconfirmed %d.download" for dangerous + // downloads. When the download is confirmed, the file is renamed on + // another thread, so reload the icon if the download filename changes. + LoadIcon(); + } + switch (download->state()) { case DownloadItem::REMOVING: parent_shelf_->RemoveDownloadItem(this); // This will delete us! @@ -487,8 +495,10 @@ void DownloadItemGtk::OnLoadIconComplete(IconManager::Handle handle, } void DownloadItemGtk::LoadIcon() { + icon_consumer_.CancelAllRequests(); IconManager* im = g_browser_process->icon_manager(); - im->LoadIcon(get_download()->full_path(), + icon_filepath_ = get_download()->full_path(); + im->LoadIcon(icon_filepath_, IconLoader::SMALL, &icon_consumer_, NewCallback(this, &DownloadItemGtk::OnLoadIconComplete)); } @@ -622,9 +632,11 @@ gboolean DownloadItemGtk::OnExpose(GtkWidget* widget, GdkEventExpose* e, // static void DownloadItemGtk::OnClick(GtkWidget* widget, DownloadItemGtk* item) { + UMA_HISTOGRAM_LONG_TIMES("clickjacking.open_download", + base::Time::Now() - item->creation_time_); + DownloadItem* download = item->get_download(); - // TODO(estade): add clickjacking histogram stuff. if (download->state() == DownloadItem::IN_PROGRESS) { download->set_open_when_complete( !download->open_when_complete()); @@ -653,7 +665,9 @@ gboolean DownloadItemGtk::OnProgressAreaExpose(GtkWidget* widget, download_util::SMALL); } - // TODO(estade): draw a default icon if |icon_| is null. + // |icon_| may be NULL if it is still loading. If the file is an unrecognized + // type then we will get back a generic system icon. Hence there is no need to + // use the chromium-specific default download item icon. if (download_item->icon_) { const int offset = download_util::kSmallProgressIconOffset; canvas.DrawBitmapInt(*download_item->icon_, @@ -713,9 +727,10 @@ gboolean DownloadItemGtk::OnDangerousPromptExpose(GtkWidget* widget, } // static -// TODO(estade): here and below, add clickjacking histogram code. void DownloadItemGtk::OnDangerousAccept(GtkWidget* button, DownloadItemGtk* item) { + UMA_HISTOGRAM_LONG_TIMES("clickjacking.save_download", + base::Time::Now() - item->creation_time_); item->get_download()->manager()->DangerousDownloadValidated( item->get_download()); } @@ -723,6 +738,8 @@ void DownloadItemGtk::OnDangerousAccept(GtkWidget* button, // static void DownloadItemGtk::OnDangerousDecline(GtkWidget* button, DownloadItemGtk* item) { + UMA_HISTOGRAM_LONG_TIMES("clickjacking.discard_download", + base::Time::Now() - item->creation_time_); if (item->get_download()->state() == DownloadItem::IN_PROGRESS) item->get_download()->Cancel(true); item->get_download()->Remove(true); diff --git a/chrome/browser/gtk/download_item_gtk.h b/chrome/browser/gtk/download_item_gtk.h index 9fd94c9..32c928f 100644 --- a/chrome/browser/gtk/download_item_gtk.h +++ b/chrome/browser/gtk/download_item_gtk.h @@ -11,6 +11,7 @@ #include "app/animation.h" #include "base/scoped_ptr.h" +#include "base/time.h" #include "chrome/browser/download/download_manager.h" #include "chrome/browser/icon_manager.h" #include "chrome/common/notification_observer.h" @@ -189,9 +190,14 @@ class DownloadItemGtk : public DownloadItem::Observer, // The file icon for the download. May be null. SkBitmap* icon_; + // The last download file path for which we requested an icon. + FilePath icon_filepath_; NotificationRegistrar registrar_; + // The time at which we were insantiated. + base::Time creation_time_; + // For canceling an in progress icon request. CancelableRequestConsumerT<int, 0> icon_consumer_; }; |