| OLD | NEW |
| 1 #include <AdblockPlus.h> | 1 #include <AdblockPlus.h> |
| 2 #include <functional> | 2 #include <functional> |
| 3 #include <vector> | 3 #include <vector> |
| 4 #include <Windows.h> | 4 #include <Windows.h> |
| 5 | 5 |
| 6 #include "../shared/AutoHandle.h" | 6 #include "../shared/AutoHandle.h" |
| 7 #include "../shared/Communication.h" | 7 #include "../shared/Communication.h" |
| 8 #include "../shared/Dictionary.h" | 8 #include "../shared/Dictionary.h" |
| 9 #include "../shared/Utils.h" | 9 #include "../shared/Utils.h" |
| 10 #include "../shared/Version.h" | 10 #include "../shared/Version.h" |
| (...skipping 127 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 138 } | 138 } |
| 139 case Communication::PROC_REMOVE_FILTER: | 139 case Communication::PROC_REMOVE_FILTER: |
| 140 { | 140 { |
| 141 std::string text; | 141 std::string text; |
| 142 request >> text; | 142 request >> text; |
| 143 filterEngine->GetFilter(text)->RemoveFromList(); | 143 filterEngine->GetFilter(text)->RemoveFromList(); |
| 144 break; | 144 break; |
| 145 } | 145 } |
| 146 case Communication::PROC_SET_PREF: | 146 case Communication::PROC_SET_PREF: |
| 147 { | 147 { |
| 148 std::string prefName = ""; | 148 std::string prefName; |
| 149 std::string prefValue = ""; | |
| 150 request >> prefName; | 149 request >> prefName; |
| 151 request >> prefValue; | 150 |
| 152 filterEngine->SetPref(prefName, filterEngine->GetJsEngine()->NewValue(pr
efValue)); | 151 Communication::ValueType valueType = request.GetType(); |
| 152 switch (valueType) |
| 153 { |
| 154 case Communication::TYPE_STRING: |
| 155 { |
| 156 std::string prefValue; |
| 157 request >> prefValue; |
| 158 filterEngine->SetPref(prefName, filterEngine->GetJsEngine()->NewValu
e(prefValue)); |
| 159 break; |
| 160 } |
| 161 case Communication::TYPE_INT64: |
| 162 { |
| 163 int64_t prefValue; |
| 164 request >> prefValue; |
| 165 filterEngine->SetPref(prefName, filterEngine->GetJsEngine()->NewValu
e(prefValue)); |
| 166 break; |
| 167 } |
| 168 case Communication::TYPE_INT32: |
| 169 { |
| 170 int prefValue; |
| 171 request >> prefValue; |
| 172 filterEngine->SetPref(prefName, filterEngine->GetJsEngine()->NewValu
e(prefValue)); |
| 173 break; |
| 174 } |
| 175 case Communication::TYPE_BOOL: |
| 176 { |
| 177 bool prefValue; |
| 178 request >> prefValue; |
| 179 filterEngine->SetPref(prefName, filterEngine->GetJsEngine()->NewValu
e(prefValue)); |
| 180 break; |
| 181 } |
| 182 default: |
| 183 break; |
| 184 } |
| 153 break; | 185 break; |
| 154 } | 186 } |
| 155 case Communication::PROC_GET_PREF: | 187 case Communication::PROC_GET_PREF: |
| 156 { | 188 { |
| 157 std::string name; | 189 std::string name; |
| 158 request >> name; | 190 request >> name; |
| 159 | 191 |
| 160 AdblockPlus::JsValuePtr valuePtr = filterEngine->GetPref(name); | 192 AdblockPlus::JsValuePtr valuePtr = filterEngine->GetPref(name); |
| 161 if ((valuePtr->IsNull()) || (!valuePtr->IsString())) | 193 if (valuePtr->IsNull() || valuePtr->IsUndefined()) |
| 162 response << 0; | |
| 163 else | |
| 164 { | 194 { |
| 165 response << 1; | 195 // Report no success |
| 196 response << false; |
| 197 break; |
| 198 } |
| 199 |
| 200 // Report success |
| 201 response << true; |
| 202 |
| 203 if (valuePtr->IsBool()) |
| 204 { |
| 205 response << valuePtr->AsBool(); |
| 206 } |
| 207 else if (valuePtr->IsNumber()) |
| 208 { |
| 209 response << valuePtr->AsInt(); |
| 210 } |
| 211 else if (valuePtr->IsString()) |
| 212 { |
| 166 response << valuePtr->AsString(); | 213 response << valuePtr->AsString(); |
| 167 } | 214 } |
| 168 break; | 215 break; |
| 169 } | 216 } |
| 170 | 217 |
| 171 } | 218 } |
| 172 return response; | 219 return response; |
| 173 } | 220 } |
| 174 | 221 |
| 175 DWORD WINAPI ClientThread(LPVOID param) | 222 DWORD WINAPI ClientThread(LPVOID param) |
| (...skipping 96 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 272 } | 319 } |
| 273 catch (std::runtime_error e) | 320 catch (std::runtime_error e) |
| 274 { | 321 { |
| 275 DebugException(e); | 322 DebugException(e); |
| 276 return 1; | 323 return 1; |
| 277 } | 324 } |
| 278 } | 325 } |
| 279 | 326 |
| 280 return 0; | 327 return 0; |
| 281 } | 328 } |
| OLD | NEW |