]> hackdaworld.org Git - my-code/api.git/commitdiff
modifications i forgot to commit
authorhackbard <hackbard>
Thu, 30 Nov 2006 10:49:05 +0000 (10:49 +0000)
committerhackbard <hackbard>
Thu, 30 Nov 2006 10:49:05 +0000 (10:49 +0000)
display/display.c
display/display.h
event/event.c
event/event.h

index 4f1fbb2fae822d6754d89d978d51220ea1c61056..fd53247732d42ba3dccc4021733cd03a004457f0 100644 (file)
@@ -134,6 +134,13 @@ int display_line(t_display *display,int X,int Y,int X_,int Y_,char sym) {
   return D_SUCCESS;
 }
 
+int display_hor_line(t_display *display,int Y,char sym) {
+
+  display_line(display,0,Y,display->max_x,Y,sym);
+
+  return D_SUCCESS;
+}
+
 int display_string(t_display *display,int x,int y,char *string,int len) {
 
   if(len>display->max_x-x) return D_INV_STRING_LEN;
index d8bd5460fd36b75aa6b5af1f5b06d29d5afd59b1..336e8b0d69fdb100727287dc55c5aba937e3be23 100644 (file)
@@ -35,6 +35,7 @@ int display_set_cursor(t_display *display,int x,int y);
 int display_clear_screen(t_display *display);
 int display_shutdown(t_display *display);
 int display_line(t_display *display,int X,int Y,int X_,int Y_,char sym);
+int display_hor_line(t_display *display,int Y,char sym);
 int display_string(t_display *display,int x,int y,char *string,int len);
 int display_string_vert(t_display *display,int x,int y,char *string,int len);
 
index 268516836c3c7af8f3d57694a860a0d4cb35b47b..fb3c82efb261cce36bca804be3661b492264a1d0 100644 (file)
@@ -30,6 +30,14 @@ int event_set_timeout(t_event *event,int sec,int usec) {
   return E_SUCCESS;
 }
 
+int event_set_immediately(t_event *event,unsigned char value) {
+
+  if(value==IMM_TRUE)
+    event->immediately=value;
+
+  return E_SUCCESS;
+}
+
 int event_math(int fd,t_event *event,char rw,char ar) {
 
   if(ar==ADD) {
@@ -65,7 +73,7 @@ int event_start(t_event *event,void *ptr,
     event->wfds=event->wfds_o;
     tv=event->timeout;
 
-    if((tv.tv_sec==0)&&(tv.tv_usec==0)) tv_ptr=NULL;
+    if((tv.tv_sec==0)&&(tv.tv_usec==0)&&(!(event->immediately))) tv_ptr=NULL;
     else tv_ptr=&tv;
 
     if((s_ret=select(event->maxfd+1,&(event->rfds),&(event->wfds),NULL,
index 1ea07599f1432b2500a550853e3d23e46abd9720..310c8667771f44740405f6f14fcb08b20f2db056 100644 (file)
 #define ADD 'a'
 #define REMOVE 'r'
 
+/* immediatley values */
+#define IMM_FALSE 0
+#define IMM_TRUE 1
+
 /* event specific variables */
 typedef struct s_event {
   int outfd;
@@ -36,12 +40,14 @@ typedef struct s_event {
   fd_set rfds,rfds_o;
   fd_set wfds,wfds_o;
   struct timeval timeout;
+  unsigned char immediately;
   unsigned char status;
 } t_event;
 
 /* function prototypes */
 int event_init(t_event *event,int outfd);
 int event_set_timeout(t_event *event,int sec,int usec);
+int event_set_immediately(t_event *event,unsigned char value);
 int event_math(int fd,t_event *event,char rw,char ar);
 int event_start(t_event *event,void *ptr,
                 int (*callback0)(t_event *event,void *ptr),