| OLD | NEW |
| 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/browser/content_exceptions_table_model.h" | 5 #include "chrome/browser/content_exceptions_table_model.h" |
| 6 | 6 |
| 7 #include "app/l10n_util.h" | 7 #include "app/l10n_util.h" |
| 8 #include "app/table_model_observer.h" | 8 #include "app/table_model_observer.h" |
| 9 #include "base/utf_string_conversions.h" | 9 #include "base/utf_string_conversions.h" |
| 10 #include "chrome/browser/host_content_settings_map.h" | 10 #include "chrome/browser/host_content_settings_map.h" |
| 11 #include "grit/generated_resources.h" | 11 #include "grit/generated_resources.h" |
| 12 | 12 |
| 13 ContentExceptionsTableModel::ContentExceptionsTableModel( | 13 ContentExceptionsTableModel::ContentExceptionsTableModel( |
| 14 HostContentSettingsMap* map, | 14 HostContentSettingsMap* map, |
| 15 HostContentSettingsMap* off_the_record_map, |
| 15 ContentSettingsType type) | 16 ContentSettingsType type) |
| 16 : map_(map), | 17 : map_(map), |
| 18 off_the_record_map_(off_the_record_map), |
| 17 content_type_(type), | 19 content_type_(type), |
| 18 observer_(NULL) { | 20 observer_(NULL) { |
| 19 // Load the contents. | 21 // Load the contents. |
| 20 map->GetSettingsForOneType(type, &entries_); | 22 map->GetSettingsForOneType(type, &entries_); |
| 23 if (off_the_record_map) |
| 24 off_the_record_map->GetSettingsForOneType(type, &off_the_record_entries_); |
| 21 } | 25 } |
| 22 | 26 |
| 23 void ContentExceptionsTableModel::AddException( | 27 void ContentExceptionsTableModel::AddException( |
| 24 const HostContentSettingsMap::Pattern& pattern, | 28 const HostContentSettingsMap::Pattern& pattern, |
| 25 ContentSetting setting) { | 29 ContentSetting setting, |
| 26 entries_.push_back( | 30 bool is_off_the_record) { |
| 31 DCHECK(!is_off_the_record || off_the_record_map_); |
| 32 |
| 33 int insert_position = |
| 34 is_off_the_record ? RowCount() : static_cast<int>(entries_.size()); |
| 35 |
| 36 entries(is_off_the_record).push_back( |
| 27 HostContentSettingsMap::PatternSettingPair(pattern, setting)); | 37 HostContentSettingsMap::PatternSettingPair(pattern, setting)); |
| 28 map_->SetContentSetting(pattern, content_type_, setting); | 38 map(is_off_the_record)->SetContentSetting(pattern, content_type_, setting); |
| 29 if (observer_) | 39 if (observer_) |
| 30 observer_->OnItemsAdded(RowCount() - 1, 1); | 40 observer_->OnItemsAdded(insert_position, 1); |
| 31 } | 41 } |
| 32 | 42 |
| 33 void ContentExceptionsTableModel::RemoveException(int row) { | 43 void ContentExceptionsTableModel::RemoveException(int row) { |
| 34 const HostContentSettingsMap::PatternSettingPair& pair = entries_[row]; | 44 bool is_off_the_record = entry_is_off_the_record(row); |
| 35 map_->SetContentSetting(pair.first, content_type_, CONTENT_SETTING_DEFAULT); | 45 int position_to_delete = |
| 36 entries_.erase(entries_.begin() + row); | 46 is_off_the_record ? row - static_cast<int>(entries_.size()) : row; |
| 47 const HostContentSettingsMap::PatternSettingPair& pair = entry_at(row); |
| 48 |
| 49 map(is_off_the_record)->SetContentSetting( |
| 50 pair.first, content_type_, CONTENT_SETTING_DEFAULT); |
| 51 entries(is_off_the_record).erase( |
| 52 entries(is_off_the_record).begin() + position_to_delete); |
| 37 if (observer_) | 53 if (observer_) |
| 38 observer_->OnItemsRemoved(row, 1); | 54 observer_->OnItemsRemoved(row, 1); |
| 39 } | 55 } |
| 40 | 56 |
| 41 void ContentExceptionsTableModel::RemoveAll() { | 57 void ContentExceptionsTableModel::RemoveAll() { |
| 42 int old_row_count = RowCount(); | 58 int old_row_count = RowCount(); |
| 43 entries_.clear(); | 59 entries_.clear(); |
| 60 off_the_record_entries_.clear(); |
| 44 map_->ClearSettingsForOneType(content_type_); | 61 map_->ClearSettingsForOneType(content_type_); |
| 62 if (off_the_record_map_) |
| 63 off_the_record_map_->ClearSettingsForOneType(content_type_); |
| 45 if (observer_) | 64 if (observer_) |
| 46 observer_->OnItemsRemoved(0, old_row_count); | 65 observer_->OnItemsRemoved(0, old_row_count); |
| 47 } | 66 } |
| 48 | 67 |
| 49 int ContentExceptionsTableModel::IndexOfExceptionByPattern( | 68 int ContentExceptionsTableModel::IndexOfExceptionByPattern( |
| 50 const HostContentSettingsMap::Pattern& pattern) { | 69 const HostContentSettingsMap::Pattern& pattern, |
| 70 bool is_off_the_record) { |
| 71 DCHECK(!is_off_the_record || off_the_record_map_); |
| 72 |
| 73 int offset = |
| 74 is_off_the_record ? static_cast<int>(entries_.size()) : 0; |
| 75 |
| 51 // This is called on every key type in the editor. Move to a map if we end up | 76 // This is called on every key type in the editor. Move to a map if we end up |
| 52 // with lots of exceptions. | 77 // with lots of exceptions. |
| 53 for (size_t i = 0; i < entries_.size(); ++i) { | 78 for (size_t i = 0; i < entries(is_off_the_record).size(); ++i) { |
| 54 if (entries_[i].first == pattern) | 79 if (entries(is_off_the_record)[i].first == pattern) |
| 55 return static_cast<int>(i); | 80 return offset + static_cast<int>(i); |
| 56 } | 81 } |
| 57 return -1; | 82 return -1; |
| 58 } | 83 } |
| 59 | 84 |
| 60 int ContentExceptionsTableModel::RowCount() { | 85 int ContentExceptionsTableModel::RowCount() { |
| 61 return static_cast<int>(entries_.size()); | 86 return static_cast<int>(entries_.size() + off_the_record_entries_.size()); |
| 62 } | 87 } |
| 63 | 88 |
| 64 std::wstring ContentExceptionsTableModel::GetText(int row, int column_id) { | 89 std::wstring ContentExceptionsTableModel::GetText(int row, int column_id) { |
| 65 HostContentSettingsMap::PatternSettingPair entry = entries_[row]; | 90 HostContentSettingsMap::PatternSettingPair entry = entry_at(row); |
| 66 | 91 |
| 67 switch (column_id) { | 92 switch (column_id) { |
| 68 case IDS_EXCEPTIONS_PATTERN_HEADER: | 93 case IDS_EXCEPTIONS_PATTERN_HEADER: |
| 69 return UTF8ToWide(entry.first.AsString()); | 94 return UTF8ToWide(entry.first.AsString()); |
| 70 | 95 |
| 71 case IDS_EXCEPTIONS_ACTION_HEADER: | 96 case IDS_EXCEPTIONS_ACTION_HEADER: |
| 72 switch (entry.second) { | 97 switch (entry.second) { |
| 73 case CONTENT_SETTING_ALLOW: | 98 case CONTENT_SETTING_ALLOW: |
| 74 return l10n_util::GetString(IDS_EXCEPTIONS_ALLOW_BUTTON); | 99 return l10n_util::GetString(IDS_EXCEPTIONS_ALLOW_BUTTON); |
| 75 case CONTENT_SETTING_BLOCK: | 100 case CONTENT_SETTING_BLOCK: |
| 76 return l10n_util::GetString(IDS_EXCEPTIONS_BLOCK_BUTTON); | 101 return l10n_util::GetString(IDS_EXCEPTIONS_BLOCK_BUTTON); |
| 77 case CONTENT_SETTING_ASK: | 102 case CONTENT_SETTING_ASK: |
| 78 return l10n_util::GetString(IDS_EXCEPTIONS_ASK_BUTTON); | 103 return l10n_util::GetString(IDS_EXCEPTIONS_ASK_BUTTON); |
| 79 default: | 104 default: |
| 80 NOTREACHED(); | 105 NOTREACHED(); |
| 81 } | 106 } |
| 82 break; | 107 break; |
| 83 | 108 |
| 84 default: | 109 default: |
| 85 NOTREACHED(); | 110 NOTREACHED(); |
| 86 } | 111 } |
| 87 | 112 |
| 88 return std::wstring(); | 113 return std::wstring(); |
| 89 } | 114 } |
| 90 | 115 |
| 91 void ContentExceptionsTableModel::SetObserver(TableModelObserver* observer) { | 116 void ContentExceptionsTableModel::SetObserver(TableModelObserver* observer) { |
| 92 observer_ = observer; | 117 observer_ = observer; |
| 93 } | 118 } |
| OLD | NEW |