// v8_utils.h /* Copyright 2009 10gen Inc. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License, version 3, * as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . * * As a special exception, the copyright holders give permission to link the * code of portions of this program with the OpenSSL library under certain * conditions as described in each individual source file and distribute * linked combinations including the program with the OpenSSL library. You * must comply with the GNU Affero General Public License in all respects * for all of the code used other than as permitted herein. If you modify * file(s) with this exception, you may extend this exception to your * version of the file(s), but you are not obligated to do so. If you do not * wish to do so, delete this exception statement from your version. If you * delete this exception statement from all source files in the program, * then also delete it in the license file. */ #pragma once #include #include #include #include #include #include #include namespace mongo { #define jsassert(x,msg) uassert(16664, (msg), (x)) #define argumentCheck(mustBeTrue, errorMessage) \ if (!(mustBeTrue)) { \ return v8AssertionException((errorMessage)); \ } std::ostream& operator<<(std::ostream& s, const v8::Handle& o); std::ostream& operator<<(std::ostream& s, const v8::Handle* try_catch); /** Simple v8 object to string conversion helper */ std::string toSTLString(const v8::Handle& o); /** Like toSTLString but doesn't allocate a new std::string * * This owns the string's memory so you need to be careful not to let the * converted StringDatas outlive the V8Scope object. These rules are the * same as converting from a std::string into a StringData. * * Safe: * void someFunction(StringData argument); * v8::Handle aString; * * someFunction(V8String(aString)); // passing down stack as temporary * * V8String named (aString); * someFunction(named); // passing up stack as named value * * StringData sd = named; // scope of sd is less than named * * Unsafe: * StringData _member; * * StringData returningFunction() { * StringData sd = V8String(aString); // sd outlives the temporary * * V8String named(aString) * _member = named; // _member outlives named scope * * return V8String(aString); // passing up stack * } */ class V8String { public: explicit V8String(const v8::Handle& o) :_str(o) { massert(16686, "error converting js type to Utf8Value", *_str); } operator StringData () const { return StringData(*_str, _str.length()); } private: v8::String::Utf8Value _str; }; /** Get the properties of an object (and it's prototype) as a comma-delimited string */ std::string v8ObjectToString(const v8::Handle& o); class V8Scope; void installFork(V8Scope* scope, v8::Handle& global, v8::Handle& context); /** Throw a V8 exception from Mongo callback code; message text will be preceded by "Error: ". * Note: this function should be used for text that did not originate from the JavaScript * engine. Errors from the JavaScript engine will already have a prefix such as * ReferenceError, TypeError or SyntaxError. * Note: call only from a native function called from JavaScript (a callback). * The V8 ThrowException routine will note a JavaScript exception that will be * "thrown" in JavaScript when we return from the native function. * Note: it's required to return immediately to V8's execution control without calling any * V8 API functions. In this state, an empty handle may (will) be returned. * @param errorMessage Error message text. * @return Empty handle to be returned from callback function. */ v8::Handle v8AssertionException(const char* errorMessage); v8::Handle v8AssertionException(const std::string& errorMessage); }