X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/b4aa79afea0c26718af8880c3ee8fea63eb21563..6a9812501258df26b7c487e50744b91abe8ebe39:/cycript.hpp?ds=sidebyside diff --git a/cycript.hpp b/cycript.hpp index 132c299..3f4b1c7 100644 --- a/cycript.hpp +++ b/cycript.hpp @@ -1,4 +1,4 @@ -/* Cycript - Remove Execution Server and Disassembler +/* Cycript - Inlining/Optimizing JavaScript Compiler * Copyright (C) 2009 Jay Freeman (saurik) */ @@ -40,20 +40,35 @@ #ifndef CYCRIPT_HPP #define CYCRIPT_HPP -#ifdef __OBJC__ -#include -#endif +#include +#include +#include -#include -#include +#include "String.hpp" -#include +void CYInitializeStatic(); -JSGlobalContextRef CYGetJSContext(); -const char *CYPoolCYONString(apr_pool_t *pool, JSContextRef context, JSValueRef value, JSValueRef *exception); -void CYSetArgs(int argc, const char *argv[]); -void CYSetProperty(JSContextRef context, JSObjectRef object, JSStringRef name, JSValueRef value); -JSObjectRef CYGetGlobalObject(JSContextRef context); -JSStringRef CYCopyJSString(const char *value); +bool CYRecvAll_(int socket, uint8_t *data, size_t size); +bool CYSendAll_(int socket, const uint8_t *data, size_t size); + +void CYNumerify(std::ostringstream &str, double value); +void CYStringify(std::ostringstream &str, const char *data, size_t size); + +double CYCastDouble(const char *value, size_t size); +double CYCastDouble(const char *value); + +extern "C" void CYHandleClient(apr_pool_t *pool, int socket); + +template +bool CYRecvAll(int socket, Type_ *data, size_t size) { + return CYRecvAll_(socket, reinterpret_cast(data), size); +} + +template +bool CYSendAll(int socket, const Type_ *data, size_t size) { + return CYSendAll_(socket, reinterpret_cast(data), size); +} + +apr_pool_t *CYGetGlobalPool(); #endif/*CYCRIPT_HPP*/