| Left: | ||
| Right: |
| LEFT | RIGHT |
|---|---|
| 1 /* | 1 /* |
| 2 * This file is part of Adblock Plus <https://adblockplus.org/>, | 2 * This file is part of Adblock Plus <https://adblockplus.org/>, |
| 3 * Copyright (C) 2006-present eyeo GmbH | 3 * Copyright (C) 2006-present eyeo GmbH |
| 4 * | 4 * |
| 5 * Adblock Plus is free software: you can redistribute it and/or modify | 5 * Adblock Plus is free software: you can redistribute it and/or modify |
| 6 * it under the terms of the GNU General Public License version 3 as | 6 * it under the terms of the GNU General Public License version 3 as |
| 7 * published by the Free Software Foundation. | 7 * published by the Free Software Foundation. |
| 8 * | 8 * |
| 9 * Adblock Plus is distributed in the hope that it will be useful, | 9 * Adblock Plus is distributed in the hope that it will be useful, |
| 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of | 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 46 const char* filename, int line) | 46 const char* filename, int line) |
| 47 { | 47 { |
| 48 if (tryCatch) | 48 if (tryCatch) |
| 49 CheckTryCatch(isolate, *tryCatch); | 49 CheckTryCatch(isolate, *tryCatch); |
| 50 if (value.IsEmpty()) | 50 if (value.IsEmpty()) |
| 51 throw AdblockPlus::JsError("Empty value at ", filename, line); | 51 throw AdblockPlus::JsError("Empty value at ", filename, line); |
| 52 return value.ToLocalChecked(); | 52 return value.ToLocalChecked(); |
| 53 } | 53 } |
| 54 | 54 |
| 55 #define CHECKED_TO_LOCAL_WITH_TRY_CATCH(isolate, value, tryCatch) \ | 55 #define CHECKED_TO_LOCAL_WITH_TRY_CATCH(isolate, value, tryCatch) \ |
| 56 AdblockPlus::Utils::CheckedToLocal(isolate, value, &tryCatch, __FILE__, __LI NE__) | 56 AdblockPlus::Utils::CheckedToLocal((isolate), (value), &(tryCatch), __FILE__ , __LINE__) |
|
sergei
2018/08/06 12:18:30
I wonder whether we should use all macro arguments
hub
2018/08/06 13:25:48
I'll do that. It is safer.
| |
| 57 | 57 |
| 58 #define CHECKED_TO_LOCAL(isolate, value) \ | 58 #define CHECKED_TO_LOCAL(isolate, value) \ |
| 59 AdblockPlus::Utils::CheckedToLocal(isolate, value, nullptr, __FILE__, __LINE __) | 59 AdblockPlus::Utils::CheckedToLocal((isolate), (value), nullptr, __FILE__, __ LINE__) |
| 60 | 60 |
| 61 std::string FromV8String(v8::Isolate* isolate, const v8::Local<v8::Value>& v alue); | 61 std::string FromV8String(v8::Isolate* isolate, const v8::Local<v8::Value>& v alue); |
| 62 StringBuffer StringBufferFromV8String(v8::Isolate* isolate, const v8::Local< v8::Value>& value); | 62 StringBuffer StringBufferFromV8String(v8::Isolate* isolate, const v8::Local< v8::Value>& value); |
| 63 v8::MaybeLocal<v8::String> ToV8String(v8::Isolate* isolate, const std::strin g& str); | 63 v8::MaybeLocal<v8::String> ToV8String(v8::Isolate* isolate, const std::strin g& str); |
| 64 v8::MaybeLocal<v8::String> StringBufferToV8String(v8::Isolate* isolate, cons t StringBuffer& bytes); | 64 v8::MaybeLocal<v8::String> StringBufferToV8String(v8::Isolate* isolate, cons t StringBuffer& bytes); |
| 65 void ThrowExceptionInJS(v8::Isolate* isolate, const std::string& str); | 65 void ThrowExceptionInJS(v8::Isolate* isolate, const std::string& str); |
| 66 | 66 |
| 67 // Code for templated function has to be in a header file, can't be in .cpp | 67 // Code for templated function has to be in a header file, can't be in .cpp |
| 68 template<class T> | 68 template<class T> |
| 69 T TrimString(const T& text) | 69 T TrimString(const T& text) |
| 70 { | 70 { |
| 71 // Via http://stackoverflow.com/questions/216823/whats-the-best-way-to-tri m-stdstring | 71 // Via http://stackoverflow.com/questions/216823/whats-the-best-way-to-tri m-stdstring |
| 72 T trimmed(text); | 72 T trimmed(text); |
| 73 trimmed.erase(trimmed.begin(), std::find_if(trimmed.begin(), trimmed.end() , std::not1(std::ptr_fun<int, int>(std::isspace)))); | 73 trimmed.erase(trimmed.begin(), std::find_if(trimmed.begin(), trimmed.end() , std::not1(std::ptr_fun<int, int>(std::isspace)))); |
| 74 trimmed.erase(std::find_if(trimmed.rbegin(), trimmed.rend(), std::not1(std ::ptr_fun<int, int>(std::isspace))).base(), trimmed.end()); | 74 trimmed.erase(std::find_if(trimmed.rbegin(), trimmed.rend(), std::not1(std ::ptr_fun<int, int>(std::isspace))).base(), trimmed.end()); |
| 75 return trimmed; | 75 return trimmed; |
| 76 } | 76 } |
| 77 #ifdef _WIN32 | 77 #ifdef _WIN32 |
| 78 std::wstring ToUtf16String(const std::string& str); | 78 std::wstring ToUtf16String(const std::string& str); |
| 79 std::string ToUtf8String(const std::wstring& str); | 79 std::string ToUtf8String(const std::wstring& str); |
| 80 std::wstring CanonizeUrl(const std::wstring& url); | 80 std::wstring CanonizeUrl(const std::wstring& url); |
| 81 #endif | 81 #endif |
| 82 } | 82 } |
| 83 } | 83 } |
| 84 | 84 |
| 85 #endif | 85 #endif |
| LEFT | RIGHT |