Ah, I see.  I like that even better :)
And I attached yet another patch that incorporates your idea.

Ilia

On Sat, Sep 27, 2008 at 2:20 AM, Alexey Zakhlestin <[EMAIL PROTECTED]>wrote:

> On Sat, Sep 27, 2008 at 12:04 PM, Ilia Cheishvili
> <[EMAIL PROTECTED]> wrote:
> > It definitely would be, and that's actually the way I would have
> preferred
> > to do it.  I didn't want to impact too much code, if that makes sense in
> > this case, but I'm glad that someone agrees :)
> > I have attached a patch to do exactly this.
>
> I was thinking other in another direction..
>
> case 'u':
> #ifdef HAVE_GETTIMEOFDAY
>    gettimeofday(&tp, &tz);
>    length = slprintf(buffer, 32, "%06d", (int) tp.tv_usec);
> #else
>    length = slprintf(buffer, 32, "%06d", (int) floor(t->f * 1000000));
> #endif
>    break;
>
>
> >
> > On Sat, Sep 27, 2008 at 1:40 AM, Alexey Zakhlestin <[EMAIL PROTECTED]>
> > wrote:
> >>
> >> On Sat, Sep 27, 2008 at 11:04 AM, Ilia Cheishvili
> >> <[EMAIL PROTECTED]> wrote:
> >> > Hi all,
> >> > This patch addresses the issue with the date() function.  When passing
> >> > in a
> >> > 'u', the date() function simply outputs six zeros.  To fix this, I
> added
> >> > a
> >> > gettimeofday() call that figures out what to display for microseconds.
> >> >  I am
> >> > including the headers and using the function with pre-processor
> >> > safeguards
> >> > as well.
> >> > Take a look :)
> >>
> >> Wouldn't it be better, to make gettimeofday() call only in case of 'u'?
> >>
> >>
> >> --
> >> Alexey Zakhlestin
> >> http://blog.milkfarmsoft.com/
> >
> >
>
>
>
> --
> Alexey Zakhlestin
> http://blog.milkfarmsoft.com/
>
Index: php_date.h
===================================================================
RCS file: /repository/php-src/ext/date/php_date.h,v
retrieving revision 1.17.2.11.2.3.2.9
diff -u -b -r1.17.2.11.2.3.2.9 php_date.h
--- php_date.h  18 Jul 2008 14:33:53 -0000      1.17.2.11.2.3.2.9
+++ php_date.h  27 Sep 2008 08:25:02 -0000
@@ -128,4 +128,6 @@
 PHPAPI void php_date_set_tzdb(timelib_tzdb *tzdb);
 PHPAPI timelib_tzinfo *get_timezone_info(TSRMLS_D);
 
+#define MICROSECONDS_PER_SECOND 1000000
+
 #endif /* PHP_DATE_H */
Index: php_date.c
===================================================================
RCS file: /repository/php-src/ext/date/php_date.c,v
retrieving revision 1.43.2.45.2.51.2.54
diff -u -b -r1.43.2.45.2.51.2.54 php_date.c
--- php_date.c  8 Aug 2008 22:07:07 -0000       1.43.2.45.2.51.2.54
+++ php_date.c  27 Sep 2008 08:25:02 -0000
@@ -30,6 +30,14 @@
 #include "zend_interfaces.h"
 #include "lib/timelib.h"
 #include <time.h>
+#ifdef PHP_WIN32
+#include "win32/time.h"
+#elif defined(NETWARE)
+#include <sys/timeval.h>
+#include <sys/time.h>
+#else
+#include <sys/time.h>
+#endif
 
 /* {{{ arginfo */
 static
@@ -1075,6 +1083,8 @@
        timelib_time_offset *offset = NULL;
        timelib_sll          isoweek, isoyear;
        int                  rfc_colon;
+       struct timeval tp = {0};
+       struct timezone tz = {0};
 
        if (!format_len) {
                return estrdup("");
@@ -1150,7 +1160,14 @@
                        case 'H': length = slprintf(buffer, 32, "%02d", (int) 
t->h); break;
                        case 'i': length = slprintf(buffer, 32, "%02d", (int) 
t->i); break;
                        case 's': length = slprintf(buffer, 32, "%02d", (int) 
t->s); break;
-                       case 'u': length = slprintf(buffer, 32, "%06d", (int) 
floor(t->f * 1000000)); break;
+                       case 'u':
+#ifdef HAVE_GETTIMEOFDAY
+                               gettimeofday(&tp, &tz);
+                               length = slprintf(buffer, 32, "%06d", (int) 
tp.tv_usec);
+#else
+                               length = slprintf(buffer, 32, "%06d", (int) 
floor(t->f * MICROSECONDS_PER_SECOND));
+#endif
+                               break;
 
                        /* timezone */
                        case 'I': length = slprintf(buffer, 32, "%d", localtime 
? offset->is_dst : 0); break;
-- 
PHP Internals - PHP Runtime Development Mailing List
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to