diff options
| author | Zeev Suraski <zeev@php.net> | 1999-12-18 11:49:31 +0000 |
|---|---|---|
| committer | Zeev Suraski <zeev@php.net> | 1999-12-18 11:49:31 +0000 |
| commit | e18a883796f8fde5b38996aed4a733e1e2809791 (patch) | |
| tree | 1338ba2955717c8cc8e4629fa3bb7c3761e53f93 /ext/mcal/php_mcal.c | |
| parent | 3db6716761393269b79652764e651d351e0e5b4d (diff) | |
| download | php-git-e18a883796f8fde5b38996aed4a733e1e2809791.tar.gz | |
More php3_ cleanup
Diffstat (limited to 'ext/mcal/php_mcal.c')
| -rw-r--r-- | ext/mcal/php_mcal.c | 1644 |
1 files changed, 1644 insertions, 0 deletions
diff --git a/ext/mcal/php_mcal.c b/ext/mcal/php_mcal.c new file mode 100644 index 0000000000..ed4191e6e5 --- /dev/null +++ b/ext/mcal/php_mcal.c @@ -0,0 +1,1644 @@ +/* + +----------------------------------------------------------------------+ + | PHP HTML Embedded Scripting Language Version 3.0 | + +----------------------------------------------------------------------+ + | Copyright (c) 1997-1999 PHP Development Team (See Credits file) | + +----------------------------------------------------------------------+ + | This program is free software; you can redistribute it and/or modify | + | it under the terms of one of the following licenses: | + | | + | A) the GNU General Public License as published by the Free Software | + | Foundation; either version 2 of the License, or (at your option) | + | any later version. | + | | + | B) the PHP License as published by the PHP Development Team and | + | included in the distribution in the file: LICENSE | + | | + | This program is distributed in the hope that it will be useful, | + | but WITHOUT ANY WARRANTY; without even the implied warranty of | + | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | + | GNU General Public License for more details. | + | | + | You should have received a copy of both licenses referred to here. | + | If you did not, or have any questions about PHP licensing, please | + | contact core@php.net. | + +----------------------------------------------------------------------+ + | Authors: Mark Musone <musone@chek.com> | + +----------------------------------------------------------------------+ + */ + +#define MCAL1 + +#ifdef ERROR +#undef ERROR +#endif + +#include "php.h" +#ifndef ZEND_VERSION +#include "internal_functions.h" +#endif + +#if COMPILE_DL +#include "dl/phpdl.h" +#endif + +#if HAVE_MCAL + +#include <time.h> +#include <stdio.h> +#include <ctype.h> +#include <signal.h> +#include <stdarg.h> +#ifndef ZEND_VERSION +#include "php3_list.h" +#endif +#include "mcal.h" +#include "php_mcal.h" +#include "modules.h" +#if (WIN32|WINNT) +#include "winsock.h" +#endif +CALSTREAM *cal_open(); +CALSTREAM *cal_close_it (); +CALSTREAM *cal_close_full (); + + +typedef struct _php_mcal_le_struct { + CALSTREAM *mcal_stream; + long public; + CALEVENT *event; + long flags; +} pils; + + +typedef struct cal_list +{ +u_int32_t uid; +struct cal_list *next; +} cal_list_t; + +static cal_list_t *g_cal_list=NULL; +static cal_list_t *g_cal_list_end=NULL; +/* + * this array should be set up as: + * {"PHPScriptFunctionName",dllFunctionName,1} + */ + +function_entry mcal_functions[] = { +PHP_FE(mcal_open,NULL) +PHP_FE(mcal_close,NULL) +PHP_FE(mcal_popen,NULL) +PHP_FE(mcal_reopen,NULL) +PHP_FE(mcal_fetch_event,NULL) +PHP_FE(mcal_list_events,NULL) +PHP_FE(mcal_list_alarms,NULL) +PHP_FE(mcal_create_calendar,NULL) +PHP_FE(mcal_rename_calendar,NULL) +PHP_FE(mcal_delete_calendar,NULL) +PHP_FE(mcal_delete_event,NULL) +PHP_FE(mcal_store_event,NULL) +PHP_FE(mcal_snooze,NULL) +PHP_FE(mcal_event_set_category,NULL) +PHP_FE(mcal_event_set_title,NULL) +PHP_FE(mcal_event_set_description,NULL) +PHP_FE(mcal_event_set_start,NULL) +PHP_FE(mcal_event_set_end,NULL) +PHP_FE(mcal_event_set_alarm,NULL) +PHP_FE(mcal_event_set_class,NULL) +PHP_FE(mcal_is_leap_year,NULL) +PHP_FE(mcal_days_in_month,NULL) +PHP_FE(mcal_date_valid,NULL) +PHP_FE(mcal_time_valid,NULL) +PHP_FE(mcal_day_of_week,NULL) +PHP_FE(mcal_day_of_year,NULL) +PHP_FE(mcal_date_compare,NULL) +PHP_FE(mcal_event_init,NULL) +PHP_FE(mcal_next_recurrence,NULL) +PHP_FE(mcal_event_set_recur_daily,NULL) +PHP_FE(mcal_event_set_recur_weekly,NULL) +PHP_FE(mcal_event_set_recur_monthly_mday,NULL) +PHP_FE(mcal_event_set_recur_monthly_wday,NULL) +PHP_FE(mcal_event_set_recur_yearly,NULL) +PHP_FE(mcal_fetch_current_stream_event,NULL) + {NULL, NULL, NULL} +}; + +#ifdef ZEND_VERSION +zend_module_entry php_mcal_module_entry = { + CALVER, mcal_functions, PHP_MINIT(mcal), NULL, NULL, NULL, PHP_MINFO(mcal), 0, 0, 0, NULL +}; +#else +zend_module_entry php_mcal_module_entry = {"mcal", mcal_functions, PHP_MINIT_FUNCTION, NULL, NULL, NULL, PHP_MINFO_FUNCTION, 0, 0, 0, NULL}; +#endif + +#if COMPILE_DL +DLEXPORT zend_module_entry *get_module(void) { return &php_mcal_module_entry; } +#endif + +/* + I believe since this global is used ONLY within this module, + and nothing will link to this module, we can use the simple + thread local_ storage +*/ +int le_mcal; +char mcal_user[80]=""; +char mcal_password[80]=""; + +CALSTREAM *cal_close_it (pils *mcal_le_struct) +{ + CALSTREAM *ret; + ret = cal_close (mcal_le_struct->mcal_stream,0); + efree(mcal_le_struct); + return ret; +} + + +#ifdef ZEND_VERSION +PHP_MINFO_FUNCTION(mcal) +#else +void PHP_MINFO_FUNCTION(void) +#endif +{ + php_printf("Mcal Support enabled<br>"); + php_printf("<table>"); + php_printf("<tr><td>Mcal Version:</td>"); + php_printf("<td>%s</td>",CALVER); + php_printf("</tr></table>"); +} + +#ifdef ZEND_VERSION +PHP_MINIT_FUNCTION(mcal) +#else +int PHP_MINIT_FUNCTION(INIT_FUNC_ARGS) +#endif +{ + + le_mcal = register_list_destructors(cal_close_it,NULL); + + REGISTER_MAIN_LONG_CONSTANT("MCAL_SUNDAY",SUNDAY, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_MONDAY",MONDAY, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_TUESDAY",TUESDAY, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_WEDNESDAY",WEDNESDAY, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_THURSDAY",THURSDAY, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_FRIDAY",FRIDAY, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_SATURDAY",SATURDAY, CONST_PERSISTENT | CONST_CS); + + REGISTER_MAIN_LONG_CONSTANT("MCAL_JANUARY",JANUARY, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_FEBRUARY",FEBRUARY, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_MARCH",MARCH, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_APRIL",APRIL, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_MAY",MAY, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_JUNE",JUNE, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_JULY",JULY, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_AUGUST",AUGUST, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_SEPTEMBER",SEPTEMBER, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_OCTOBER",OCTOBER, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_NOVEMBER",NOVEMBER, CONST_PERSISTENT | CONST_CS); + + + REGISTER_MAIN_LONG_CONSTANT("MCAL_RECUR_NONE",RECUR_NONE, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_RECUR_DAILY",RECUR_DAILY, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_RECUR_WEEKLY",RECUR_WEEKLY, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_RECUR_MONTHLY_MDAY",RECUR_MONTHLY_MDAY, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_RECUR_MONTHLY_WDAY",RECUR_MONTHLY_WDAY, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_RECUR_YEARLY",RECUR_YEARLY, CONST_PERSISTENT | CONST_CS); + + + REGISTER_MAIN_LONG_CONSTANT("MCAL_M_SUNDAY",M_SUNDAY, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_M_MONDAY",M_MONDAY, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_M_TUESDAY",M_TUESDAY, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_M_WEDNESDAY",M_WEDNESDAY, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_M_THURSDAY",M_THURSDAY, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_M_FRIDAY",M_FRIDAY, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_M_SATURDAY",M_SATURDAY, CONST_PERSISTENT | CONST_CS); + + REGISTER_MAIN_LONG_CONSTANT("MCAL_M_WEEKDAYS",M_WEEKDAYS, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_M_WEEKEND",M_WEEKEND, CONST_PERSISTENT | CONST_CS); + REGISTER_MAIN_LONG_CONSTANT("MCAL_M_ALLDAYS",M_ALLDAYS, CONST_PERSISTENT | CONST_CS); + + + return SUCCESS; +} + + +static int add_assoc_object(pval *arg, char *key, pval tmp) +{ +#ifdef ZEND_VERSION + HashTable *symtable; + + if (arg->type == IS_OBJECT) { + symtable = arg->value.obj.properties; + } else { + symtable = arg->value.ht; + } + return zend_hash_update(symtable, key, strlen(key)+1, (void *) &tmp, sizeof(pval *), NULL); +#else + return zend_hash_update(arg->value.ht, key, strlen(key)+1, (void *) &tmp, sizeof(pval), NULL); +#endif +} + + +void php_mcal_do_open(INTERNAL_FUNCTION_PARAMETERS, int persistent) +{ + pval *calendar; + pval *user; + pval *passwd; + pval *options; + CALSTREAM *mcal_stream; + pils *mcal_le_struct; + long flags=0; + int ind; + int myargc=ARG_COUNT(ht); + + + if (myargc <3 || myargc >4 || getParameters(ht, myargc, &calendar,&user,&passwd,&options) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_string(calendar); + convert_to_string(user); + convert_to_string(passwd); + strcpy(mcal_user,user->value.str.val); + strcpy(mcal_password,passwd->value.str.val); + if(myargc ==4) { + convert_to_long(options); + flags=options->value.lval; + php_printf("option is: %d\n",options->value.lval); + } + mcal_stream = cal_open(NULL,calendar->value.str.val,0); + if (!mcal_stream) { + php_error(E_WARNING,"Couldn't open stream %s\n",calendar->value.str.val); + RETURN_FALSE; + } + + mcal_le_struct = emalloc(sizeof(pils)); + mcal_le_struct->mcal_stream = mcal_stream; + mcal_le_struct->event=calevent_new(); + + ind = zend_list_insert(mcal_le_struct, le_mcal); + RETURN_LONG(ind); +} + + + + +/* {{{ proto int mcal_close(int stream_id [, int options]) + Close an MCAL stream */ +void PHP_FUNCTION(mcal_close) +{ + pval *options, *streamind; + int ind, ind_type; + pils *mcal_le_struct=NULL; + int myargcount=ARG_COUNT(ht); + long flags = 0; + + if (myargcount < 1 || myargcount > 2 || getParameters(ht, myargcount, &streamind, &options) == FAILURE) { + WRONG_PARAM_COUNT; + } + convert_to_long(streamind); + ind = streamind->value.lval; + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + if(myargcount==2) { + convert_to_long(options); + flags = options->value.lval; + mcal_le_struct->flags = flags; + } + zend_list_delete(ind); + RETURN_TRUE; +} +/* }}} */ + + + + + + + + +/* {{{ proto int mcal_open(string calendar, string user, string password [, int options]) + Open an MCAL stream to a calendar */ +void PHP_FUNCTION(mcal_open) +{ + php_mcal_do_open(INTERNAL_FUNCTION_PARAM_PASSTHRU, 0); +} +/* }}} */ + + +/* {{{ proto int mcal_reopen(int stream_id, string calendar [, int options]) + Reopen MCAL stream to new calendar */ +void PHP_FUNCTION(mcal_reopen) +{ + pval *streamind; + pval *calendar; + pval *options; + CALSTREAM *mcal_stream=NULL; + pils *mcal_le_struct; + int ind, ind_type; + long flags=0; + long cl_flags=0; + int myargc=ARG_COUNT(ht); + + if (myargc<2 || myargc>3 || getParameters(ht,myargc,&streamind, &calendar, &options) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + ind = streamind->value.lval; + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + + convert_to_string(calendar); + if(myargc == 3) { + convert_to_long(options); + flags = options->value.lval; + mcal_le_struct->flags = cl_flags; + } + if (mcal_stream == NULL) { + php_error(E_WARNING,"Couldn't re-open stream\n"); + RETURN_FALSE; + } + RETURN_TRUE; +} +/* }}} */ + + +/* {{{ proto int mcal_expunge(int stream_id) + Delete all messages marked for deletion */ +void PHP_FUNCTION(mcal_expunge) +{ + pval *streamind; + int ind, ind_type; + pils *mcal_le_struct; + + if (ARG_COUNT(ht) != 1 || getParameters(ht, 1, &streamind) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + +/* cal_expunge (mcal_le_struct->mcal_stream); +*/ + RETURN_TRUE; +} +/* }}} */ + +/* {{{ proto int mcal_fetch_event(int stream_id,int eventid, [int options]) + Fetch an event*/ +void PHP_FUNCTION(mcal_fetch_event) +{ + pval *streamind,*eventid,*options=NULL; + int ind, ind_type; + pils *mcal_le_struct=NULL; + CALEVENT *myevent; + int myargcount=ARG_COUNT(ht); + + if (myargcount < 1 || myargcount > 3 || getParameters(ht, myargcount, &streamind, &eventid,&options) == FAILURE) { + WRONG_PARAM_COUNT; + } + convert_to_long(streamind); + convert_to_long(eventid); + ind = streamind->value.lval; + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + if(myargcount==3) { + convert_to_long(options); + } + cal_fetch(mcal_le_struct->mcal_stream,eventid->value.lval,&myevent); + if(myevent == NULL) + { + RETURN_FALSE; + } + calevent_free(mcal_le_struct->event); + mcal_le_struct->event=myevent; + make_event_object(return_value,mcal_le_struct->event); + +} +/* }}} */ + +/* {{{ proto object mcal_fetch_current_stream_event(int stream_id) + Fetch the current event stored in the stream's event structure*/ +void PHP_FUNCTION(mcal_fetch_current_stream_event) +{ + pval *streamind; + int ind, ind_type; + pils *mcal_le_struct=NULL; + int myargcount=ARG_COUNT(ht); + + if (myargcount != 1 || getParameters(ht, myargcount, &streamind) == FAILURE) { + WRONG_PARAM_COUNT; + } + convert_to_long(streamind); + ind = streamind->value.lval; + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + make_event_object(return_value,mcal_le_struct->event); + +} +/* }}} */ + + + +void make_event_object(pval *mypvalue,CALEVENT *event) +{ + pval start,end,recurend; + object_init(mypvalue); + add_property_long(mypvalue,"id",event->id); + add_property_long(mypvalue,"public",event->public); + object_init(&start); + + if(event->start.has_date) + { + add_property_long(&start,"year",event->start.year); + add_property_long(&start,"month",event->start.mon); + add_property_long(&start,"mday",event->start.mday); + } + if(event->start.has_time) + { + add_property_long(&start,"hour",event->start.hour); + add_property_long(&start,"min",event->start.min); + add_property_long(&start,"sec",event->start.sec); + } + + + add_assoc_object(mypvalue, "start",start); + + object_init(&end); + if(event->end.has_date) + { + add_property_long(&end,"year",event->end.year); + add_property_long(&end,"month",event->end.mon); + add_property_long(&end,"mday",event->end.mday); + } + if(event->end.has_time) + { + add_property_long(&end,"hour",event->end.hour); + add_property_long(&end,"min",event->end.min); + add_property_long(&end,"sec",event->end.sec); + } + add_assoc_object(mypvalue, "end",end); + + + if (event->category) + add_property_string(mypvalue,"category",event->category,1); + if (event->title) + add_property_string(mypvalue,"title",event->title,1); + if (event->description) + add_property_string(mypvalue,"description",event->description,1); + add_property_long(mypvalue,"alarm",event->alarm); + add_property_long(mypvalue,"recur_type",event->recur_type); + add_property_long(mypvalue,"recur_interval",event->recur_interval); + object_init(&recurend); + if(event->recur_enddate.has_date) + { + add_property_long(&recurend,"year",event->recur_enddate.year); + add_property_long(&recurend,"month",event->recur_enddate.mon); + add_property_long(&recurend,"mday",event->recur_enddate.mday); + } + if(event->recur_enddate.has_time) + { + add_property_long(&recurend,"hour",event->recur_enddate.hour); + add_property_long(&recurend,"min",event->recur_enddate.min); + add_property_long(&recurend,"sec",event->recur_enddate.sec); + } + add_assoc_object(mypvalue, "recur_enddate",recurend); + add_property_long(mypvalue,"recur_data",event->recur_data.weekly_wday); +} + + + +/* {{{ proto array mcal_list_events(int stream_id,object begindate, [object enddate]) + Returns list of UIDs for that day or range of days */ +void PHP_FUNCTION(mcal_list_events) +{ + pval *streamind,*startyear,*startmonth,*startday; + pval *endyear,*endmonth,*endday; +#ifdef ZEND_VERSION + pval **pvalue; +#else + pval *pvalue; +#endif + int ind, ind_type; + pils *mcal_le_struct; + cal_list_t *my_cal_list; + int myargc; + datetime_t startdate=DT_INIT; + datetime_t enddate=DT_INIT; + myargc=ARG_COUNT(ht); + if ((myargc !=1 && myargc !=7)|| getParameters(ht,myargc,&streamind,&startyear,&startmonth,&startday,&endyear,&endmonth,&endday) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + + /* Initialize return array */ + if (array_init(return_value) == FAILURE) { + RETURN_FALSE; + } + + + if(myargc ==7) + { + convert_to_long(startyear); + convert_to_long(startmonth); + convert_to_long(startday); + convert_to_long(endyear); + convert_to_long(endmonth); + convert_to_long(endday); + dt_setdate(&startdate,startyear->value.lval,startmonth->value.lval,startday->value.lval); + dt_setdate(&enddate,endyear->value.lval,endmonth->value.lval,endday->value.lval); + } + else + { + startdate=mcal_le_struct->event->start; + enddate=mcal_le_struct->event->end; + } + + g_cal_list=NULL; + cal_search_range(mcal_le_struct->mcal_stream,&startdate,&enddate); + my_cal_list=g_cal_list; + while(my_cal_list != NULL) + { + add_next_index_long(return_value,my_cal_list->uid); + my_cal_list=my_cal_list->next; + free(g_cal_list); + g_cal_list=my_cal_list; + } +} +/* }}} */ + + +/* {{{ proto string mcal_create_calendar(int stream_id, string calendar) + Create a new calendar*/ + +void PHP_FUNCTION(mcal_create_calendar) +{ + pval *streamind, *calendar; + int ind, ind_type; + pils *mcal_le_struct; + int myargc=ARG_COUNT(ht); + if (myargc <1 || myargc > 2 || getParameters(ht,myargc,&streamind,&calendar) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + convert_to_string(calendar); + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } +/* + if (mcal_create(mcal_le_struct->mcal_stream,calendar->value.str.val)) + { + RETURN_TRUE; + } + else + { + RETURN_FALSE; + } +*/ +} +/* }}} */ + + +/* {{{ proto string mcal_rename(int stream_id, string src_calendar, string dest_calendar) + Rename a calendar*/ +void PHP_FUNCTION(mcal_rename_calendar) +{ + pval *streamind, *src_calendar,*dest_calendar; + int ind, ind_type; + pils *mcal_le_struct; + int myargc=ARG_COUNT(ht); + if (myargc <2 || myargc > 3 || getParameters(ht,myargc,&streamind,&src_calendar,&dest_calendar) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + convert_to_string(src_calendar); + convert_to_string(dest_calendar); + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } +/* + if(mcal_rename(mcal_le_struct->mcal_stream,src_calendar->value.str.val,dest_calendar->value.str.val)) {RETURN_TRUE;} + else {RETURN_FALSE; } +*/ +} +/* }}} */ + + + + +/* {{{ proto int mcal_reopen(int stream_id, array date, array time) + list alarms for a given time */ +void PHP_FUNCTION(mcal_list_alarms) +{ + pval *streamind, *year,*month,*day,*hour,*min,*sec; +#ifdef ZEND_VERSION + pval **pvalue; +#else + pval *pvalue; +#endif + datetime_t mydate=DT_INIT; + int ind, ind_type; + pils *mcal_le_struct; + cal_list_t *my_cal_list; + int myargc=ARG_COUNT(ht); + if (myargc != 1 || myargc !=7 || getParameters(ht,myargc,&streamind,&year,&month,&day,&hour,&min,&sec) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + + if (array_init(return_value) == FAILURE) { + RETURN_FALSE; + } + + if(myargc ==7) + { + convert_to_long(year); + convert_to_long(month); + convert_to_long(day); + convert_to_long(hour); + convert_to_long(min); + convert_to_long(sec); + dt_setdate(&mydate,year->value.lval,month->value.lval,day->value.lval); + dt_settime(&mydate,hour->value.lval,min->value.lval,sec->value.lval); + } + else + { + mydate=mcal_le_struct->event->start; + } + g_cal_list=NULL; + cal_search_alarm(mcal_le_struct->mcal_stream,&mydate); + my_cal_list=g_cal_list; + while(my_cal_list != NULL) + { + add_next_index_long(return_value,my_cal_list->uid); + my_cal_list=my_cal_list->next; + free(g_cal_list); + g_cal_list=my_cal_list; + } +} +/* }}} */ + + +/* {{{ proto string mcal_delete_calendar(int stream_id, string calendar) + Delete calendar*/ +void PHP_FUNCTION(mcal_delete_calendar) +{ + pval *streamind, *calendar; + int ind, ind_type; + pils *mcal_le_struct; + int myargc=ARG_COUNT(ht); + if (myargc <1 || myargc > 2 || getParameters(ht,myargc,&streamind,&calendar) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + convert_to_string(calendar); + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + + /* if (mcal_delete_calendar(mcal_le_struct->mcal_stream,calendar->value.str.val)) + { + RETURN_TRUE; + } + else + { + RETURN_FALSE; + } + */ +} +/* }}} */ + + +/* {{{ proto string mcal_delete_event(int stream_id, int uid) + Delete event*/ +void PHP_FUNCTION(mcal_delete_event) +{ + pval *streamind, *uid; + int ind, ind_type; + pils *mcal_le_struct; + int myargc=ARG_COUNT(ht); + if (myargc <1 || myargc > 2 || getParameters(ht,myargc,&streamind,&uid) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + convert_to_long(uid); + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + if (cal_remove(mcal_le_struct->mcal_stream,uid->value.lval)) + { + RETURN_TRUE; + } + else + { + RETURN_FALSE; + } +} +/* }}} */ + + +void PHP_FUNCTION(mcal_popen){ +} + + +/* {{{ proto string mcal_store_event(int stream_id, object event) + Store an event*/ +void PHP_FUNCTION(mcal_store_event) +{ + pval *streamind,*storeobject; + int ind, ind_type; + pils *mcal_le_struct; + int myargc; + unsigned long uid; + CALEVENT *myevent; + myargc=ARG_COUNT(ht); + if (myargc !=1 || getParameters(ht,myargc,&streamind) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + + + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + + /* Initialize return array */ + if (array_init(return_value) == FAILURE) { + RETURN_FALSE; + } + myevent=mcal_le_struct->event; + cal_append(mcal_le_struct->mcal_stream,"INBOX",&uid,myevent); + calevent_free(myevent); + RETURN_LONG(uid); +} +/* }}} */ + + +/* {{{ proto string mcal_snooze(int stream_id, int uid) + Snooze an alarm*/ +void PHP_FUNCTION(mcal_snooze) +{ + pval *streamind,*uid; + int ind, ind_type; + pils *mcal_le_struct; + int myargc; + myargc=ARG_COUNT(ht); + if (myargc !=2 || getParameters(ht,myargc,&streamind,&uid) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + convert_to_long(uid); + + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + + if(cal_snooze(mcal_le_struct->mcal_stream,uid->value.lval)) + { + RETURN_TRUE; + } + else + { + RETURN_FALSE; + } + + +} +/* }}} */ + + +/* {{{ proto string mcal_event_set_category(int stream_id, string category) + attach a category to an event*/ +void PHP_FUNCTION(mcal_event_set_category) +{ + pval *streamind,*category; + int ind, ind_type; + pils *mcal_le_struct; + int myargc; + myargc=ARG_COUNT(ht); + if (myargc !=2 || getParameters(ht,myargc,&streamind,&category) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + convert_to_string(category); + + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + mcal_le_struct->event->category=strdup(category->value.str.val); +} + /* }}} */ + +/* {{{ proto string mcal_event_set_title(int stream_id, string title) + attach a title to an event*/ +void PHP_FUNCTION(mcal_event_set_title) +{ + pval *streamind,*title; + int ind, ind_type; + pils *mcal_le_struct; + int myargc; + myargc=ARG_COUNT(ht); + if (myargc !=2 || getParameters(ht,myargc,&streamind,&title) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + convert_to_string(title); + + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + mcal_le_struct->event->title=strdup(title->value.str.val); +} + /* }}} */ + +/* {{{ proto string mcal_event_set_description(int stream_id, string description) + attach a description to an event*/ +void PHP_FUNCTION(mcal_event_set_description) +{ + pval *streamind,*description; + int ind, ind_type; + pils *mcal_le_struct; + int myargc; + myargc=ARG_COUNT(ht); + if (myargc !=2 || getParameters(ht,myargc,&streamind,&description) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + convert_to_string(description); + + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + mcal_le_struct->event->description=strdup(description->value.str.val); +} + /* }}} */ + +/* {{{ proto string mcal_event_set_start(int stream_id, int year,int month, int day, [[[int hour],int min],int sec]) + attach a start datetime to an event*/ +void PHP_FUNCTION(mcal_event_set_start) +{ + pval *streamind,*year,*month,*date,*hour,*min,*sec; + int ind, ind_type; + int myhour=0,mymin=0,mysec=0; + pils *mcal_le_struct; + int myargc; + myargc=ARG_COUNT(ht); + if (myargc <4 || getParameters(ht,myargc,&streamind,&year,&month,&date,&hour,&min,&sec) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + convert_to_long(year); + convert_to_long(month); + convert_to_long(date); + if(myargc > 4) convert_to_long(hour); + if(myargc > 5) convert_to_long(min); + if(myargc > 6) convert_to_long(sec); + + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + + + dt_setdate(&(mcal_le_struct->event->start),year->value.lval,month->value.lval,date->value.lval); + + if(myargc > 4) myhour=hour->value.lval; + if(myargc > 5) mymin=min->value.lval; + if(myargc > 6) mysec=sec->value.lval; + if(myargc >4) dt_settime(&(mcal_le_struct->event->start),myhour,mymin,mysec); + +} + /* }}} */ + +/* {{{ proto string mcal_event_set_end(int stream_id, int year,int month, int day, [[[int hour],int min],int sec]) + attach an end datetime to an event*/ +void PHP_FUNCTION(mcal_event_set_end) +{ + pval *streamind,*year,*month,*date,*hour,*min,*sec; + int ind, ind_type; + int myhour,mymin,mysec; + pils *mcal_le_struct; + int myargc; + myargc=ARG_COUNT(ht); + if (myargc <4 || getParameters(ht,myargc,&streamind,&year,&month,&date,&hour,&min,&sec) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + convert_to_long(year); + convert_to_long(month); + convert_to_long(date); + if(myargc > 4) convert_to_long(hour); + if(myargc > 5) convert_to_long(min); + if(myargc > 6) convert_to_long(sec); + + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + + + dt_setdate(&(mcal_le_struct->event->end),year->value.lval,month->value.lval,date->value.lval); + + if(myargc > 4) myhour=hour->value.lval; + if(myargc > 5) mymin=min->value.lval; + if(myargc > 6) mysec=sec->value.lval; + if(myargc >4) dt_settime(&(mcal_le_struct->event->end),myhour,mymin,mysec); +} + /* }}} */ + +/* {{{ proto int mcal_event_set_alarm(int stream_id, int alarm) + add an alarm to the streams global event */ +void PHP_FUNCTION(mcal_event_set_alarm) +{ + pval *streamind,*alarm; + int ind, ind_type; + pils *mcal_le_struct; + int myargc; + myargc=ARG_COUNT(ht); + if (myargc !=2 || getParameters(ht,myargc,&streamind,&alarm) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + convert_to_long(alarm); + + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + mcal_le_struct->event->alarm=alarm->value.lval; +} + /* }}} */ + +/* {{{ proto int mcal_event_init(int stream_id) + initialize a streams global event */ +void PHP_FUNCTION(mcal_event_init) +{ + pval *streamind; + int ind, ind_type; + pils *mcal_le_struct; + int myargc; + myargc=ARG_COUNT(ht); + if (myargc !=1 || getParameters(ht,myargc,&streamind) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + php_mcal_event_init(mcal_le_struct); +} + /* }}} */ + +void php_mcal_event_init(struct _php_mcal_le_struct *mystruct) +{ + calevent_free(mystruct->event); + mystruct->event=calevent_new(); +} + + +/* {{{ proto int mcal_event_set_class(int stream_id, int class) + add an class to the streams global event */ +void PHP_FUNCTION(mcal_event_set_class) +{ + pval *streamind,*class; + int ind, ind_type; + pils *mcal_le_struct; + int myargc; + myargc=ARG_COUNT(ht); + if (myargc !=2 || getParameters(ht,myargc,&streamind,&class) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + convert_to_long(class); + + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + mcal_le_struct->event->public=class->value.lval; +} + /* }}} */ + + + +/* {{{ proto bool mcal_is_leap_year(int year) + returns true if year is a leap year, false if not */ +void PHP_FUNCTION(mcal_is_leap_year) +{ + pval *year; + int myargc; + myargc=ARG_COUNT(ht); + if (myargc !=1 || getParameters(ht,myargc,&year) == FAILURE) { + WRONG_PARAM_COUNT; + } + convert_to_long(year); + if(isleapyear(year->value.lval)) + { + RETURN_TRUE; + } + else + { + RETURN_FALSE; + } +} +/* }}} */ + +/* {{{ proto int mcal_days_in_month(int month,bool leap_year) + returns the number of days in the given month, needs to know if the year is a leap year or not */ +void PHP_FUNCTION(mcal_days_in_month) +{ + pval *month,*leap; + int myargc; + myargc=ARG_COUNT(ht); + if (myargc !=2 || getParameters(ht,myargc,&month,&leap) == FAILURE) { + WRONG_PARAM_COUNT; + } + convert_to_long(month); + convert_to_long(leap); + convert_to_boolean(leap); + RETURN_LONG(daysinmonth(month->value.lval,leap->value.lval)); +} +/* }}} */ + + +/* {{{ proto bool mcal_date_valid(int year,int month,int day) + returns true if the date is a valid date */ +void PHP_FUNCTION(mcal_date_valid) +{ + pval *year,*month,*day; + int myargc; + myargc=ARG_COUNT(ht); + if (myargc !=3 || getParameters(ht,myargc,&year,&month,&day) == FAILURE) { + WRONG_PARAM_COUNT; + } + convert_to_long(year); + convert_to_long(month); + convert_to_long(day); + if(datevalid(year->value.lval,month->value.lval,day->value.lval)) + { + RETURN_TRUE; + } + else + { + RETURN_FALSE; + } +} + +/* }}} */ + + +/* {{{ proto bool mcal_time_valid(int hour,int min,int sec) + returns true if the time is a valid time */ +void PHP_FUNCTION(mcal_time_valid) +{ + pval *hour,*min,*sec; + int myargc; + myargc=ARG_COUNT(ht); + if (myargc !=3 || getParameters(ht,myargc,&hour,&min,&sec) == FAILURE) { + WRONG_PARAM_COUNT; + } + convert_to_long(hour); + convert_to_long(min); + convert_to_long(sec); + if(timevalid(hour->value.lval,min->value.lval,sec->value.lval)) + { + RETURN_TRUE; + } + else + { + RETURN_FALSE; + } +} +/* }}} */ + +/* {{{ proto int mcal_day_of_week(int year,int month,int day) + returns the day of the week of the given date */ +void PHP_FUNCTION(mcal_day_of_week) +{ + pval *year,*month,*day; + int myargc; + datetime_t mydate; + myargc=ARG_COUNT(ht); + if (myargc !=3 || getParameters(ht,myargc,&year,&month,&day) == FAILURE) { + WRONG_PARAM_COUNT; + } + convert_to_long(year); + convert_to_long(month); + convert_to_long(day); + dt_init(&mydate); + dt_setdate(&mydate,year->value.lval,month->value.lval, day->value.lval); + + RETURN_LONG(dt_dayofweek(&mydate)); +} +/* }}} */ + +/* {{{ proto int mcal_day_of_year(int year,int month,int day) + returns the day of the year of the given date */ +void PHP_FUNCTION(mcal_day_of_year) +{ + pval *year,*month,*day; + int myargc; + datetime_t mydate; + myargc=ARG_COUNT(ht); + if (myargc !=3 || getParameters(ht,myargc,&year,&month,&day) == FAILURE) { + WRONG_PARAM_COUNT; + } + convert_to_long(year); + convert_to_long(month); + convert_to_long(day); + dt_init(&mydate); + dt_setdate(&mydate,year->value.lval,month->value.lval, day->value.lval); + + RETURN_LONG(dt_dayofyear(&mydate)); +} + + + + +/* {{{ proto int mcal_day_of_week(int ayear,int amonth,int aday,int byear,int bmonth,int bday) + returns <0, 0, >0 if a<b, a==b, a>b respectively */ +void PHP_FUNCTION(mcal_date_compare) +{ + pval *ayear,*amonth,*aday; + pval *byear,*bmonth,*bday; + int myargc; + datetime_t myadate,mybdate; + myargc=ARG_COUNT(ht); + if (myargc !=6 || getParameters(ht,myargc,&ayear,&amonth,&aday,&byear,&bmonth,&bday) == FAILURE) { + WRONG_PARAM_COUNT; + } + convert_to_long(ayear); + convert_to_long(amonth); + convert_to_long(aday); + convert_to_long(byear); + convert_to_long(bmonth); + convert_to_long(bday); + dt_init(&myadate); + dt_init(&mybdate); + dt_setdate(&myadate,ayear->value.lval,amonth->value.lval, aday->value.lval); + dt_setdate(&mybdate,byear->value.lval,bmonth->value.lval, bday->value.lval); + + RETURN_LONG(dt_compare(&myadate,&mybdate)); +} + + +/* }}} */ + + +/* {{{ proto object mcal_next_recurrence(int stream_id, int weekstart,array next) + returns an object filled with the next date the event occurs, on or + after the supplied date. Returns empty date field if event does not + occur or something is invalid. + */ +void PHP_FUNCTION(mcal_next_recurrence) +{ + pval *streamind,*weekstart,*next,*pvalue; + int ind, ind_type; + pils *mcal_le_struct; + int myargc; + datetime_t mydate; + CALEVENT *myevent=NULL; + myargc=ARG_COUNT(ht); + if (myargc !=3 || getParameters(ht,myargc,&streamind,&weekstart,&next) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + convert_to_long(weekstart); + convert_to_array(next); + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + + + if(zend_hash_find(next->value.ht,"year",sizeof("year"),(void **) &pvalue)== SUCCESS){ + + convert_to_long(pvalue); + mydate.year=(pvalue)->value.lval; + } + if(zend_hash_find(next->value.ht,"month",sizeof("month"),(void **) &pvalue)== SUCCESS){ + + convert_to_long(pvalue); + mydate.mon=(pvalue)->value.lval; + } + if(zend_hash_find(next->value.ht,"mday",sizeof("mday"),(void **) &pvalue)== SUCCESS){ + + convert_to_long(pvalue); + mydate.mday=(pvalue)->value.lval; + } + if(zend_hash_find(next->value.ht,"hour",sizeof("hour"),(void **) &pvalue)== SUCCESS){ + + convert_to_long(pvalue); + mydate.hour=(pvalue)->value.lval; + } + if(zend_hash_find(next->value.ht,"min",sizeof("min"),(void **) &pvalue)== SUCCESS){ + + convert_to_long(pvalue); + mydate.min=(pvalue)->value.lval; + } + if(zend_hash_find(next->value.ht,"sec",sizeof("sec"),(void **) &pvalue)== SUCCESS){ + + convert_to_long(pvalue); + mydate.sec=(pvalue)->value.lval; + + } + + calevent_next_recurrence(mcal_le_struct->event,&mydate,weekstart->value.lval); + object_init(return_value); + if(mydate.has_date) + { + add_property_long(return_value,"year",mydate.year); + add_property_long(return_value,"month",mydate.mon); + add_property_long(return_value,"mday",mydate.mday); + } + if(mydate.has_time) + { + add_property_long(return_value,"hour",mydate.hour); + add_property_long(return_value,"min",mydate.min); + add_property_long(return_value,"sec",mydate.sec); + } +} + /* }}} */ + + + +/* {{{ proto string mcal_event_set_recur_daily(int stream_id,int year,int month,int day,int hour,int min,int sec,int interval + create a daily recurrence */ +void PHP_FUNCTION(mcal_event_set_recur_daily) +{ + pval *streamind,*year,*month,*day,*hour,*min,*sec,*interval; + int ind, ind_type; + pils *mcal_le_struct; + int myargc; + datetime_t endtime=DT_INIT; + myargc=ARG_COUNT(ht); + if (myargc !=8 || getParameters(ht,myargc,&streamind,&year,&month,&day,&hour,&min,&sec,&interval) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + convert_to_long(year); + convert_to_long(month); + convert_to_long(day); + convert_to_long(hour); + convert_to_long(min); + convert_to_long(sec); + convert_to_long(interval); + + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + dt_setdate(&endtime,year->value.lval,month->value.lval,day->value.lval); + dt_settime(&endtime,hour->value.lval,min->value.lval,sec->value.lval); + calevent_recur_daily(mcal_le_struct->event, &endtime, + interval->value.lval); + +} + /* }}} */ + +/* {{{ proto string mcal_event_set_recur_weekly(int stream_id,int year,int month,int day,int hour,int min,int sec,int interval, int weekdays) +create a weekly recurrence */ +void PHP_FUNCTION(mcal_event_set_recur_weekly) +{ + pval *streamind,*year,*month,*day,*hour,*min,*sec,*interval,*weekdays; + int ind, ind_type; + pils *mcal_le_struct; + int myargc; + datetime_t endtime=DT_INIT; + myargc=ARG_COUNT(ht); + if (myargc !=4 || getParameters(ht,myargc,&streamind,&year,&month,&day,&hour,&min,&sec,&interval,&weekdays) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + convert_to_long(year); + convert_to_long(month); + convert_to_long(day); + convert_to_long(hour); + convert_to_long(min); + convert_to_long(sec); + convert_to_long(interval); + convert_to_long(weekdays); + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + dt_setdate(&endtime,year->value.lval,month->value.lval,day->value.lval); + dt_settime(&endtime,hour->value.lval,min->value.lval,sec->value.lval); + calevent_recur_weekly(mcal_le_struct->event, &endtime, + interval->value.lval,weekdays->value.lval); + +} + /* }}} */ + +/* {{{ proto string mcal_event_set_recur_monthly_mday(int stream_id,int year,int month,int day,int hour,int min,int sec,int interval) + create a monthly by day recurrence */ +void PHP_FUNCTION(mcal_event_set_recur_monthly_mday) +{ + pval *streamind,*year,*month,*day,*hour,*min,*sec,*interval; + int ind, ind_type; + pils *mcal_le_struct; + int myargc; + datetime_t endtime=DT_INIT; + myargc=ARG_COUNT(ht); + if (myargc !=8 || getParameters(ht,myargc,&streamind,&year,&month,&day,&hour,&min,&sec,&interval) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + convert_to_long(year); + convert_to_long(month); + convert_to_long(day); + convert_to_long(hour); + convert_to_long(min); + convert_to_long(sec); + convert_to_long(interval); + + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + dt_setdate(&endtime,year->value.lval,month->value.lval,day->value.lval); + dt_settime(&endtime,hour->value.lval,min->value.lval,sec->value.lval); + calevent_recur_monthly_mday(mcal_le_struct->event, &endtime, + interval->value.lval); + +} + /* }}} */ + +/* {{{ proto string mcal_event_set_recur_monthly_wday(int stream_id,int year,int month,int day,int hour,int min,int sec,int interval) + create a monthy by week recurrence */ +void PHP_FUNCTION(mcal_event_set_recur_monthly_wday) +{ + pval *streamind,*year,*month,*day,*hour,*min,*sec,*interval; + int ind, ind_type; + pils *mcal_le_struct; + int myargc; + datetime_t endtime=DT_INIT; + myargc=ARG_COUNT(ht); + if (myargc !=8 || getParameters(ht,myargc,&streamind,&year,&month,&day,&hour,&min,&sec,&interval) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + convert_to_long(year); + convert_to_long(month); + convert_to_long(day); + convert_to_long(hour); + convert_to_long(min); + convert_to_long(sec); + convert_to_long(interval); + + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + dt_setdate(&endtime,year->value.lval,month->value.lval,day->value.lval); + dt_settime(&endtime,hour->value.lval,min->value.lval,sec->value.lval); + calevent_recur_monthly_wday(mcal_le_struct->event, &endtime, + interval->value.lval); + +} + /* }}} */ + +/* {{{ proto string mcal_event_set_recur_yearly(int stream_id,int year,int month,int day,int hour,int min,int sec,int interval) + create a yearly recurrence */ +void PHP_FUNCTION(mcal_event_set_recur_yearly) +{ + pval *streamind,*year,*month,*day,*hour,*min,*sec,*interval; + int ind, ind_type; + pils *mcal_le_struct; + int myargc; + datetime_t endtime=DT_INIT; + myargc=ARG_COUNT(ht); + if (myargc !=8 || getParameters(ht,myargc,&streamind,&year,&month,&day,&hour,&min,&sec,&interval) == FAILURE) { + WRONG_PARAM_COUNT; + } + + convert_to_long(streamind); + convert_to_long(year); + convert_to_long(month); + convert_to_long(day); + convert_to_long(hour); + convert_to_long(min); + convert_to_long(sec); + convert_to_long(interval); + + ind = streamind->value.lval; + + mcal_le_struct = (pils *)zend_list_find(ind, &ind_type); + + if (!mcal_le_struct ) { + php_error(E_WARNING, "Unable to find stream pointer"); + RETURN_FALSE; + } + dt_setdate(&endtime,year->value.lval,month->value.lval,day->value.lval); + dt_settime(&endtime,hour->value.lval,min->value.lval,sec->value.lval); + calevent_recur_yearly(mcal_le_struct->event, &endtime, + interval->value.lval); + +} + /* }}} */ + + +/* Interfaces to callbacks */ + + + +void cc_searched (unsigned long cal_uid) +{ + if(g_cal_list==NULL) + { + g_cal_list=malloc(sizeof(struct cal_list)); + g_cal_list->uid=cal_uid; + g_cal_list->next=NULL; + g_cal_list_end=g_cal_list; + } + else + { + g_cal_list_end->next=malloc(sizeof(struct cal_list)); + g_cal_list_end=g_cal_list_end->next; + g_cal_list_end->uid=cal_uid; + g_cal_list_end->next=NULL; + } +} + + + + + + +void cc_appended(u_int32_t uid) +{ + +} + + +void cc_fetched(const CALEVENT *event) +{ + +} + + +void cc_login(const char **user, const char **pwd) +{ + +*user=mcal_user; +*pwd=mcal_password; +} + + +void cc_vlog(const char *fmt,va_list ap) +{ +} +void cc_vdlog(const char *fmt,va_list ap) +{ +} + +#endif + + +/* + * Local_ variables: + * tab-width: 4 + * c-basic-offset: 4 + * End: + */ + + |
