[BACK]Return to time.c CVS log [TXT][DIR] Up to [local] / OpenXM_contrib2 / asir2000 / builtin

Diff for /OpenXM_contrib2/asir2000/builtin/time.c between version 1.5 and 1.9

version 1.5, 2005/11/12 08:13:13 version 1.9, 2015/08/08 14:19:41
Line 45 
Line 45 
  * DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE,   * DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE,
  * PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE.   * PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE.
  *   *
  * $OpenXM: OpenXM_contrib2/asir2000/builtin/time.c,v 1.4 2005/11/12 08:10:56 noro Exp $   * $OpenXM: OpenXM_contrib2/asir2000/builtin/time.c,v 1.8 2011/05/11 06:03:53 ohara Exp $
 */  */
 #include "ca.h"  #include "ca.h"
 #include "parse.h"  #include "parse.h"
   #include <limits.h>
   
 void Ptime(), Pcputime(), Pcurrenttime(), Ptstart(), Ptstop();  void Ptime(), Pcputime(), Pcurrenttime(), Ptstart(), Ptstop();
   void Pdcurrenttime();
   
 struct ftab time_tab[] = {  struct ftab time_tab[] = {
         {"time",Ptime,0},          {"time",Ptime,0},
         {"cputime",Pcputime,1},          {"cputime",Pcputime,1},
         {"currenttime",Pcurrenttime,0},          {"currenttime",Pcurrenttime,0},
           {"dcurrenttime",Pdcurrenttime,0},
         {"tstart",Ptstart,0},          {"tstart",Ptstart,0},
         {"tstop",Ptstop,0},          {"tstop",Ptstop,0},
         {0,0,0},          {0,0,0},
Line 73  Q *rp;
Line 76  Q *rp;
         t = (int)get_current_time(); STOQ(t,*rp);          t = (int)get_current_time(); STOQ(t,*rp);
 }  }
   
   void Pdcurrenttime(rp)
   Real *rp;
   {
           double t;
   
           t = get_current_time(); MKReal(t,*rp);
   }
   
 void Ptstart(rp)  void Ptstart(rp)
 pointer *rp;  pointer *rp;
 {  {
Line 103  LIST *listp;
Line 114  LIST *listp;
         Real re,rg,rr;          Real re,rg,rr;
         NODE a,b,w,r;          NODE a,b,w,r;
         Q words;          Q words;
         long t;          size_t t;
         int u,l;          unsigned int u,l;
         N n;          N n;
         double rtime;          double rtime;
         double get_rtime();          double get_rtime();
   
         rtime = get_rtime(); MKReal(rtime,rr);          rtime = get_rtime(); MKReal(rtime,rr);
         t = get_allocwords();          t = get_allocwords();
 #if defined(LONG_IS_64BIT)          if(sizeof(size_t)>sizeof(int)) {
         u = t>>32; l = t&(0xffffffff);                  u = t>>(sizeof(int)*CHAR_BIT); l = t&(~0);
         if ( !u ) STOQ(l,words);                  if ( !u ) STOQ(l,words);
         else {                  else {
                 n = NALLOC(2); PL(n)=2; BD(n)[0] = l; BD(n)[1] = u;                          n = NALLOC(2); PL(n)=2; BD(n)[0] = l; BD(n)[1] = u;
                 NTOQ(n,1,words);                          NTOQ(n,1,words);
                   }
           }else {
                   STOQ(t,words);
         }          }
 #else  
         STOQ(t,words);  
 #endif  
         get_eg(&eg); MKReal(eg.exectime,re); MKReal(eg.gctime,rg);          get_eg(&eg); MKReal(eg.exectime,re); MKReal(eg.gctime,rg);
         MKNODE(r,rr,0); MKNODE(w,words,r); MKNODE(a,rg,w); MKNODE(b,re,a);          MKNODE(r,rr,0); MKNODE(w,words,r); MKNODE(a,rg,w); MKNODE(b,re,a);
         MKLIST(*listp,b);          MKLIST(*listp,b);
Line 140  double r;
Line 151  double r;
                 fprintf(stderr,"%.4gsec + gc : %.4gsec(%.4gsec)\n",e,g,r);                  fprintf(stderr,"%.4gsec + gc : %.4gsec(%.4gsec)\n",e,g,r);
         else          else
                 fprintf(stderr,"%.4gsec(%.4gsec)\n",e,r);                  fprintf(stderr,"%.4gsec(%.4gsec)\n",e,r);
   #if defined(__MINGW32__) || defined(__MINGW64__)
           fflush(stderr);
   #endif
 }  }

Legend:
Removed from v.1.5  
changed lines
  Added in v.1.9

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>