]> git.saurik.com Git - cycript.git/blobdiff - cycript.hpp
Better version checking for bison, flex, and gperf that falls through to other versio...
[cycript.git] / cycript.hpp
index 132c2992f6b24a35d0c28843d81d18ed5cab896d..3f4b1c7b0302d79261c85b6aa94d833ace3e8801 100644 (file)
@@ -1,4 +1,4 @@
-/* Cycript - Remove Execution Server and Disassembler
+/* Cycript - Inlining/Optimizing JavaScript Compiler
  * Copyright (C) 2009  Jay Freeman (saurik)
 */
 
 #ifndef CYCRIPT_HPP
 #define CYCRIPT_HPP
 
-#ifdef __OBJC__
-#include <Foundation/Foundation.h>
-#endif
+#include <apr_pools.h>
+#include <sig/types.hpp>
+#include <sstream>
 
-#include <JavaScriptCore/JavaScript.h>
-#include <JavaScriptCore/JSStringRefCF.h>
+#include "String.hpp"
 
-#include <apr-1/apr_pools.h>
+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 <typename Type_>
+bool CYRecvAll(int socket, Type_ *data, size_t size) {
+    return CYRecvAll_(socket, reinterpret_cast<uint8_t *>(data), size);
+}
+
+template <typename Type_>
+bool CYSendAll(int socket, const Type_ *data, size_t size) {
+    return CYSendAll_(socket, reinterpret_cast<const uint8_t *>(data), size);
+}
+
+apr_pool_t *CYGetGlobalPool();
 
 #endif/*CYCRIPT_HPP*/