ID: 39522
Updated by: [EMAIL PROTECTED]
Reported By: phoemix at harmless dot hu
-Status: Open
+Status: Feedback
Bug Type: Compile Failure
Operating System: freebsd6, linux (but irrelevant)
PHP Version: 5.2.0
New Comment:
We have several C++ extensions in PECL and I'm happen to be the author
of one. And I didn't/don't see any problems with C++ and PHP headers,
even on FreeBSD.
Please elaborate and show what exactly is wrong before posting a patch
for a bug which is not reproducible.
Previous Comments:
------------------------------------------------------------------------
[2006-11-15 07:35:47] phoemix at harmless dot hu
Description:
------------
(the php version is irrelevant, i just couldn't pick that for the
"compile failure" type. i had it on 4.x and on 5.x both"
create a new extensions, have a C++ source file, and include some php
headers. it will fail on two points.
1) C++ doesn't support "long long". lot's of architectures has stdint.h
(i think it's C99). that should be used instead of "long long"-ing
manually.
2) C++ prohobits havint a trailing coma at the end of an enum's last
member.
i have created a patch for the FreeBSD ports system. the errors are in
snprintf.h and in php_stream_filter_api.h/.
--- patch follows ---
diff -ur php-5.2.0-orig/main/snprintf.h php-5.2.0/main/snprintf.h
--- php-5.2.0-orig/main/snprintf.h Sun Jan 1 13:50:17 2006
+++ php-5.2.0/main/snprintf.h Tue Nov 14 14:23:31 2006
@@ -120,8 +120,14 @@
#else
# define WIDE_INT long
#endif
+#ifdef __FreeBSD__
+#include <stdint.h>
+typedef int64_t wide_int;
+typedef uint64_t u_wide_int;
+#else
typedef WIDE_INT wide_int;
typedef unsigned WIDE_INT u_wide_int;
+#endif
typedef int bool_int;
diff -ur php-5.2.0-orig/main/streams/php_stream_filter_api.h
php-5.2.0/main/streams/php_stream_filter_api.h
--- php-5.2.0-orig/main/streams/php_stream_filter_api.h Sun Jan 1
13:50:18 2006
+++ php-5.2.0/main/streams/php_stream_filter_api.h Tue Nov 14
14:24:33 2006
@@ -62,7 +62,7 @@
typedef enum {
PSFS_ERR_FATAL, /* error in data stream */
PSFS_FEED_ME, /* filter needs more data; stop processing
chain until more is available */
- PSFS_PASS_ON, /* filter generated output buckets; pass them
on to next in chain */
+ PSFS_PASS_ON /* filter generated output buckets; pass them
on to next in chain */
} php_stream_filter_status_t;
/* Buckets API. */
Reproduce code:
---------------
create a new extensions, have a C++ source file, and include some php
headers. it will fail on two points.
Expected result:
----------------
a clean compilation.
Actual result:
--------------
i don't have the error output yet, since my local version is fixed
manually.
------------------------------------------------------------------------
--
Edit this bug report at http://bugs.php.net/?id=39522&edit=1