Diff for /parser3/src/classes/void.C between versions 1.14 and 1.54

version 1.14, 2002/01/16 10:28:34 version 1.54, 2016/10/26 15:44:49
Line 1 Line 1
 /** @file  /** @file
         Parser: @b VOID parser class.          Parser: @b VOID parser class.
   
         Copyright (c) 2001 ArtLebedev Group (http://www.artlebedev.com)          Copyright (c) 2001-2015 Art. Lebedev Studio (http://www.artlebedev.com)
         Author: Alexander Petrosyan <paf@design.ru> (http://paf.design.ru)          Author: Alexandr Petrosian <paf@design.ru> (http://paf.design.ru)
   
         $Id$  
 */  */
   
 #include "classes.h"  #include "classes.h"
   #include "pa_vmethod_frame.h"
   
 #include "pa_request.h"  #include "pa_request.h"
 #include "pa_vint.h"  
 #include "pa_vdouble.h"  
 #include "pa_vvoid.h"  #include "pa_vvoid.h"
 #include "pa_sql_connection.h"  #include "pa_sql_connection.h"
   
 // defines  volatile const char * IDENT_VOID_C="$Id$";
   
   // externs
   
 #define VOID_CLASS_NAME "void"  extern String sql_bind_name;
   
 // class  // class
   
 class MVoid : public Methoded {  class MVoid: public Methoded {
 public:  public:
         MVoid(Pool& pool);          MVoid();
 public: // Methoded  
         bool used_directly() { return true; }  
 };  };
   
 // methods  // void is inherited from string, thus global variable declared in string.C
   
 static void _int(Request& r, const String&, MethodParams *params) {  
         Pool& pool=r.pool();  
         VVoid *vvoid=static_cast<VVoid *>(r.self);  
         r.write_no_lang(*new(pool) VInt(pool,   
                 params->size()==0?vvoid->as_int():params->as_int(0, "default must be int", r)));  
 }  
   
 static void _double(Request& r, const String&, MethodParams *params) {  // methods
         Pool& pool=r.pool();  
         VVoid *vvoid=static_cast<VVoid *>(r.self);  
         r.write_no_lang(*new(pool) VDouble(pool,   
                 params->size()==0?vvoid->as_double():params->as_double(0, "default must be double", r)));  
 }  
   
 #ifndef DOXYGEN  #ifndef DOXYGEN
 class Void_sql_event_handlers : public SQL_Driver_query_event_handlers {  class Void_sql_event_handlers: public SQL_Driver_query_event_handlers {
           const String& statement_string;
 public:  public:
         Void_sql_event_handlers(Pool& apool, const String& astatement_string) :          Void_sql_event_handlers(const String& astatement_string): statement_string(astatement_string) {}
                 pool(apool), statement_string(astatement_string) {          bool add_column(SQL_Error& /*error*/, const char* /*str*/, size_t /*length*/) { /* ignore */ return false; }
         }          bool before_rows(SQL_Error& error) {
         void add_column(void *ptr, size_t size) { /* ignore */ }  
         void before_rows() {  
                 // there are some result rows, which is wrong                  // there are some result rows, which is wrong
                 throw Exception(0, 0,                  error=SQL_Error(PARSER_RUNTIME,
                         &statement_string,                          /*statement_string,*/
                         "must return nothing");                          "must return nothing");
                   return true;
         }          }
         void add_row() { /* never */ }          bool add_row(SQL_Error& /*error*/) { /* never */ return false; }
         void add_row_cell(void *ptr, size_t size) { /* never */ }          bool add_row_cell(SQL_Error& /*error*/, const char* /*str*/, size_t /*length*/) { /* never */ return false; }
   
 private:  
         Pool& pool;  
         const String& statement_string;  
 };  };
 #endif  #endif
 static void _sql(Request& r, const String& method_name, MethodParams *params) {  
         Pool& pool=r.pool();  
   
         Value& statement=params->as_junction(0, "statement must be code");  extern int marshal_binds(HashStringValue& hash, SQL_Driver::Placeholder*& placeholders);
   extern void unmarshal_bind_updates(HashStringValue& hash, int placeholder_count, SQL_Driver::Placeholder* placeholders);
   
         Temp_lang temp_lang(r, String::UL_SQL);  static void _sql(Request& r, MethodParams& params) {
         const String& statement_string=r.process(statement).as_string();          Value& statement=params.as_junction(0, "statement must be code");
         const char *statement_cstr=  
                 statement_string.cstr(String::UL_UNSPECIFIED, r.connection(&method_name));  
         Void_sql_event_handlers handlers(pool, statement_string);  
         try {  
                 r.connection(&method_name)->query(  
                         statement_cstr, 0, 0,  
                         handlers);  
         } catch(const Exception& e) {  
                 // more specific source [were url]  
                 throw Exception(e.type(), e.code(),  
                         &statement_string,   
                         "%s", e.comment());  
         }  
 }  
   
 // constructor  
   
 MVoid::MVoid(Pool& apool) : Methoded(apool) {          HashStringValue* bind=0;
         set_name(*NEW String(pool(), VOID_CLASS_NAME));          if(params.count()>1)
                   if(HashStringValue* options=params.as_hash(1, "sql options")) {
                           int valid_options=0;
                           if(Value* vbind=options->get(sql_bind_name)) {
                                   valid_options++;
                                   bind=vbind->get_hash();
                           }
                           if(valid_options!=options->count())
                                   throw Exception(PARSER_RUNTIME, 0, CALLED_WITH_INVALID_OPTION);
                   }
   
           SQL_Driver::Placeholder* placeholders=0;
           uint placeholders_count=0;
           if(bind)
                   placeholders_count=marshal_binds(*bind, placeholders);
   
           const String& statement_string=r.process_to_string(statement);
           const char* statement_cstr=statement_string.untaint_cstr(String::L_SQL, r.connection());
   
           Void_sql_event_handlers handlers(statement_string);
           r.connection()->query(
                   statement_cstr, 
                   placeholders_count, placeholders,
                   0, SQL_NO_LIMIT,
                   handlers,
                   statement_string);
   
           if(bind)
         // ^void.int[]                   unmarshal_bind_updates(*bind, placeholders_count, placeholders);
         // ^void.int(default)  
         add_native_method("int", Method::CT_DYNAMIC, _int, 0, 1);  
   
         // ^void.double[]   
         // ^void.double(default)  
         add_native_method("double", Method::CT_DYNAMIC, _double, 0, 1);  
   
         // ^sql[query]  
         add_native_method("sql", Method::CT_STATIC, _sql, 1, 1);  
 }  }
   
 // global variable  // constructor
   
 Methoded *void_class;  MVoid::MVoid(): Methoded("void") {
           set_base(string_class);
   
 // creator          // ^void:sql{query}
           add_native_method("sql", Method::CT_STATIC, _sql, 1, 2);
   
 Methoded *MVoid_create(Pool& pool) {          // all other methods are inherinted from empty string
         return void_class=new(pool) MVoid(pool);  
 }  }

Removed from v.1.14  
changed lines
  Added in v.1.54


E-mail: