//////////////////////////////////////////////////////////////////////////////// /// @brief V8 utility functions /// /// @file /// /// DISCLAIMER /// /// Copyright 2004-2013 triAGENS GmbH, Cologne, Germany /// /// Licensed under the Apache License, Version 2.0 (the "License"); /// you may not use this file except in compliance with the License. /// You may obtain a copy of the License at /// /// http://www.apache.org/licenses/LICENSE-2.0 /// /// Unless required by applicable law or agreed to in writing, software /// distributed under the License is distributed on an "AS IS" BASIS, /// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. /// See the License for the specific language governing permissions and /// limitations under the License. /// /// Copyright holder is triAGENS GmbH, Cologne, Germany /// /// @author Dr. Frank Celler /// @author Copyright 2011-2013, triAGENS GmbH, Cologne, Germany //////////////////////////////////////////////////////////////////////////////// #ifndef TRIAGENS_V8_V8_UTILS_H #define TRIAGENS_V8_V8_UTILS_H 1 #include "V8/v8-globals.h" #include "BasicsC/json.h" // ----------------------------------------------------------------------------- // --SECTION-- GENERAL // ----------------------------------------------------------------------------- // ----------------------------------------------------------------------------- // --SECTION-- public classes // ----------------------------------------------------------------------------- //////////////////////////////////////////////////////////////////////////////// /// @addtogroup V8Utils /// @{ //////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////// /// @brief Converts an object to a UTF-8-encoded and normalized character array. //////////////////////////////////////////////////////////////////////////////// class TRI_Utf8ValueNFC { public: TRI_Utf8ValueNFC (TRI_memory_zone_t* memoryZone, v8::Handle obj); ~TRI_Utf8ValueNFC (); char* operator* () { return _str; } const char* operator* () const { return _str; } size_t length () const { return _length; } private: char* _str; size_t _length; TRI_memory_zone_t* _memoryZone; // Disallow copying and assigning. TRI_Utf8ValueNFC(const TRI_Utf8ValueNFC&); void operator=(const TRI_Utf8ValueNFC&); }; //////////////////////////////////////////////////////////////////////////////// /// @} //////////////////////////////////////////////////////////////////////////////// // ----------------------------------------------------------------------------- // --SECTION-- public constants // ----------------------------------------------------------------------------- //////////////////////////////////////////////////////////////////////////////// /// @addtogroup V8Utils /// @{ //////////////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////////// /// @brief temporary path //////////////////////////////////////////////////////////////////////////////// static std::string TempPath; /////////////////////////////////////////////////////////////////////////////// /// @brief slot for a type //////////////////////////////////////////////////////////////////////////////// static int const SLOT_CLASS_TYPE = 0; //////////////////////////////////////////////////////////////////////////////// /// @brief slot for a "C++ class" //////////////////////////////////////////////////////////////////////////////// static int const SLOT_CLASS = 1; //////////////////////////////////////////////////////////////////////////////// /// @} //////////////////////////////////////////////////////////////////////////////// // ----------------------------------------------------------------------------- // --SECTION-- public functions // ----------------------------------------------------------------------------- //////////////////////////////////////////////////////////////////////////////// /// @addtogroup V8Utils /// @{ //////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////// /// @brief unwraps a C++ class given a v8::Object //////////////////////////////////////////////////////////////////////////////// template static T* TRI_UnwrapClass (v8::Handle obj, int32_t type) { if (obj->InternalFieldCount() <= SLOT_CLASS) { return 0; } if (obj->GetInternalField(SLOT_CLASS_TYPE)->Int32Value() != type) { return 0; } return static_cast(v8::Handle::Cast(obj->GetInternalField(SLOT_CLASS))->Value()); } //////////////////////////////////////////////////////////////////////////////// /// @brief adds attributes to array //////////////////////////////////////////////////////////////////////////////// void TRI_AugmentObject (v8::Handle, TRI_json_t const*); //////////////////////////////////////////////////////////////////////////////// /// @brief reports an exception //////////////////////////////////////////////////////////////////////////////// std::string TRI_StringifyV8Exception (v8::TryCatch*); //////////////////////////////////////////////////////////////////////////////// /// @brief prints an exception and stacktrace //////////////////////////////////////////////////////////////////////////////// void TRI_LogV8Exception (v8::TryCatch*); //////////////////////////////////////////////////////////////////////////////// /// @brief reads a file into the current context //////////////////////////////////////////////////////////////////////////////// bool TRI_ExecuteGlobalJavaScriptFile (char const*); //////////////////////////////////////////////////////////////////////////////// /// @brief reads all files from a directory into the current context //////////////////////////////////////////////////////////////////////////////// bool TRI_ExecuteGlobalJavaScriptDirectory (char const*); //////////////////////////////////////////////////////////////////////////////// /// @brief executes a file in a local context //////////////////////////////////////////////////////////////////////////////// bool TRI_ExecuteLocalJavaScriptFile (char const*); //////////////////////////////////////////////////////////////////////////////// /// @brief executes all files from a directory in a local context //////////////////////////////////////////////////////////////////////////////// bool TRI_ExecuteLocalJavaScriptDirectory (char const*); //////////////////////////////////////////////////////////////////////////////// /// @brief parses a file //////////////////////////////////////////////////////////////////////////////// bool TRI_ParseJavaScriptFile (char const*); //////////////////////////////////////////////////////////////////////////////// /// @brief executes a string within a V8 context, optionally print the result //////////////////////////////////////////////////////////////////////////////// v8::Handle TRI_ExecuteJavaScriptString (v8::Handle context, v8::Handle source, v8::Handle name, bool printResult); //////////////////////////////////////////////////////////////////////////////// /// @brief creates an error in a javascript object, based on error number only //////////////////////////////////////////////////////////////////////////////// v8::Handle TRI_CreateErrorObject (int errorNumber); //////////////////////////////////////////////////////////////////////////////// /// @brief creates an error in a javascript object, using supplied text //////////////////////////////////////////////////////////////////////////////// v8::Handle TRI_CreateErrorObject (int errorNumber, std::string const& message); //////////////////////////////////////////////////////////////////////////////// /// @brief creates an error in a javascript object //////////////////////////////////////////////////////////////////////////////// v8::Handle TRI_CreateErrorObject (int errorNumber, std::string const& message, bool autoPrepend); //////////////////////////////////////////////////////////////////////////////// /// @brief normalize a v8 object //////////////////////////////////////////////////////////////////////////////// v8::Handle TRI_normalize_V8_Obj (v8::Handle obj); //////////////////////////////////////////////////////////////////////////////// /// @brief creates the path list // /// The spilt has been modified -- only except semicolon, previously we excepted /// a colon as well. So as not to break existing configurations, we only make /// the modification for windows version -- since there isn't one yet! //////////////////////////////////////////////////////////////////////////////// v8::Handle TRI_V8PathList (std::string const& modules); //////////////////////////////////////////////////////////////////////////////// /// @brief stores the V8 utils function inside the global variable //////////////////////////////////////////////////////////////////////////////// void TRI_InitV8Utils (v8::Handle, std::string const& modules, std::string const& nodes, std::string const& tempPath); //////////////////////////////////////////////////////////////////////////////// /// @} //////////////////////////////////////////////////////////////////////////////// #endif // Local Variables: // mode: outline-minor // outline-regexp: "/// @brief\\|/// {@inheritDoc}\\|/// @addtogroup\\|/// @page\\|// --SECTION--\\|/// @\\}" // End: