File:  [parser3project] / parser3 / src / classes / void.C
Revision 1.15: download - view: text, annotated - select for diffs - revision graph
Fri Feb 8 07:27:41 2002 UTC (24 years, 5 months ago) by paf
Branches: MAIN
CVS tags: HEAD
2002

/** @file
	Parser: @b VOID parser class.

	Copyright (c) 2001, 2002 ArtLebedev Group (http://www.artlebedev.com)
	Author: Alexander Petrosyan <paf@design.ru> (http://paf.design.ru)

	$Id: void.C,v 1.15 2002/02/08 07:27:41 paf Exp $
*/

#include "classes.h"
#include "pa_request.h"
#include "pa_vint.h"
#include "pa_vdouble.h"
#include "pa_vvoid.h"
#include "pa_sql_connection.h"

// defines

#define VOID_CLASS_NAME "void"

// class

class MVoid : public Methoded {
public:
	MVoid(Pool& pool);
public: // Methoded
	bool used_directly() { return true; }
};

// methods

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) {
	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
class Void_sql_event_handlers : public SQL_Driver_query_event_handlers {
public:
	Void_sql_event_handlers(Pool& apool, const String& astatement_string) :
		pool(apool), statement_string(astatement_string) {
	}
	void add_column(void *ptr, size_t size) { /* ignore */ }
	void before_rows() {
		// there are some result rows, which is wrong
		throw Exception(0, 0,
			&statement_string,
			"must return nothing");
	}
	void add_row() { /* never */ }
	void add_row_cell(void *ptr, size_t size) { /* never */ }

private:
	Pool& pool;
	const String& statement_string;
};
#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");

	Temp_lang temp_lang(r, String::UL_SQL);
	const String& statement_string=r.process(statement).as_string();
	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) {
	set_name(*NEW String(pool(), VOID_CLASS_NAME));


	// ^void.int[] 
	// ^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

Methoded *void_class;

// creator

Methoded *MVoid_create(Pool& pool) {
	return void_class=new(pool) MVoid(pool);
}

E-mail: