mirror of
https://github.com/php-win-ext/pecl-expect.git
synced 2026-03-24 05:02:05 +01:00
Compare commits
5 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
f6251794c5 | ||
|
|
2246eef8d7 | ||
|
|
50ecf39bfd | ||
|
|
41baa86ee3 | ||
|
|
c206870203 |
@@ -13,10 +13,6 @@ if test "$PHP_EXPECT" != "no"; then
|
||||
fi
|
||||
done
|
||||
|
||||
if test -z "$LIBEXPECT_DIR"; then
|
||||
AC_MSG_ERROR(expect extension requires libexpect version >= 5.43.0)
|
||||
fi
|
||||
|
||||
PHP_ADD_LIBRARY_WITH_PATH(expect, $LIBEXPECT_DIR/lib, EXPECT_SHARED_LIBADD)
|
||||
PHP_ADD_INCLUDE($LIBEXPECT_DIR/include)
|
||||
|
||||
|
||||
34
expect.c
34
expect.c
@@ -19,6 +19,8 @@
|
||||
/* $ Id: $ */
|
||||
|
||||
#include "php_expect.h"
|
||||
#include <string.h>
|
||||
#include <errno.h>
|
||||
|
||||
/* {{{ expect_functions[] */
|
||||
function_entry expect_functions[] = {
|
||||
@@ -80,11 +82,19 @@ static PHP_INI_MH(OnSetExpectLogUser)
|
||||
static PHP_INI_MH(OnSetExpectLogFile)
|
||||
{
|
||||
if (new_value_length > 0) {
|
||||
exp_logfile = fopen (new_value, "a");
|
||||
if (!exp_logfile) {
|
||||
php_error_docref (NULL TSRMLS_CC, E_ERROR, "could not open log file for writting");
|
||||
php_stream *stream = php_stream_open_wrapper (new_value, "a", 0, NULL);
|
||||
if (!stream) {
|
||||
php_error_docref (NULL TSRMLS_CC, E_ERROR, "could not open log file for writing");
|
||||
return FAILURE;
|
||||
}
|
||||
stream->flags |= PHP_STREAM_FLAG_NO_SEEK;
|
||||
if (php_stream_cast(stream, PHP_STREAM_AS_STDIO, (void **) &exp_logfile, REPORT_ERRORS) != SUCCESS) {
|
||||
return FAILURE;
|
||||
}
|
||||
exp_logfile_all = 1;
|
||||
} else {
|
||||
exp_logfile = NULL;
|
||||
exp_logfile_all = 0;
|
||||
}
|
||||
return SUCCESS;
|
||||
}
|
||||
@@ -164,6 +174,7 @@ PHP_FUNCTION(expect_popen)
|
||||
if (!stream) {
|
||||
RETURN_FALSE;
|
||||
}
|
||||
stream->flags |= PHP_STREAM_FLAG_NO_SEEK;
|
||||
php_stream_to_zval(stream, return_value);
|
||||
}
|
||||
/* }}} */
|
||||
@@ -187,9 +198,8 @@ PHP_FUNCTION(expect_expectl)
|
||||
}
|
||||
|
||||
php_stream_from_zval (stream, &z_stream);
|
||||
if (php_stream_cast (stream, PHP_STREAM_AS_FD, (void*)&fd, 1) != SUCCESS || fd < 0) {
|
||||
php_error_docref (NULL TSRMLS_CC, E_ERROR, "couldn't cast expect stream to a file descriptor");
|
||||
return;
|
||||
if (php_stream_cast (stream, PHP_STREAM_AS_FD, (void*)&fd, REPORT_ERRORS) != SUCCESS || fd < 0) {
|
||||
return;
|
||||
}
|
||||
|
||||
argc = zend_hash_num_elements (Z_ARRVAL_P(z_cases));
|
||||
@@ -255,10 +265,10 @@ PHP_FUNCTION(expect_expectl)
|
||||
|
||||
key = exp_expectv (fd, ecases);
|
||||
|
||||
int exp_match_len = exp_match_end - exp_match + 1;
|
||||
int exp_match_len = exp_match_end - exp_match;
|
||||
if (z_match && exp_match && exp_match_len > 0) {
|
||||
char *tmp = (char *)emalloc (sizeof(char) * exp_match_len);
|
||||
strlcpy (tmp, exp_match, exp_match_len);
|
||||
char *tmp = (char *)emalloc (sizeof(char) * (exp_match_len + 1));
|
||||
strlcpy (tmp, exp_match, exp_match_len + 1);
|
||||
zval_dtor (z_match);
|
||||
array_init(z_match);
|
||||
add_index_string(z_match, 0, tmp, 1);
|
||||
@@ -271,9 +281,9 @@ PHP_FUNCTION(expect_expectl)
|
||||
and add matching substring to matches array */
|
||||
for (i = 1; i <= 9; i++) {
|
||||
if (matchedcase.re->startp[i] != NULL) {
|
||||
int sub_match_len = matchedcase.re->endp[i] - matchedcase.re->startp[i] + 1;
|
||||
char *sub_match = (char *)emalloc (sizeof(char) * sub_match_len);
|
||||
strlcpy (sub_match, matchedcase.re->startp[i], sub_match_len);
|
||||
int sub_match_len = matchedcase.re->endp[i] - matchedcase.re->startp[i];
|
||||
char *sub_match = (char *)emalloc (sizeof(char) * (sub_match_len + 1));
|
||||
strlcpy (sub_match, matchedcase.re->startp[i], sub_match_len + 1);
|
||||
add_next_index_string(z_match, sub_match, 1);
|
||||
efree (sub_match);
|
||||
}
|
||||
|
||||
@@ -21,26 +21,43 @@
|
||||
#include "php.h"
|
||||
#include "php_expect.h"
|
||||
#include "php_streams.h"
|
||||
#include <sys/wait.h>
|
||||
|
||||
php_stream *php_expect_stream_opener (php_stream_wrapper *wrapper, char *command, char *mode, int options,
|
||||
php_stream *php_expect_stream_open (php_stream_wrapper *wrapper, char *command, char *mode, int options,
|
||||
char **opened_command, php_stream_context *context STREAMS_DC TSRMLS_DC)
|
||||
{
|
||||
FILE *fp;
|
||||
|
||||
if (strncasecmp("expect://", command, sizeof("expect://")-1) == 0) {
|
||||
command += sizeof("expect://")-1;
|
||||
}
|
||||
|
||||
if ((fp = exp_popen(command)) != NULL) {
|
||||
return php_stream_fopen_from_pipe (fp, "");
|
||||
php_stream* stream = php_stream_fopen_from_pipe (fp, mode);
|
||||
zval *z_pid;
|
||||
MAKE_STD_ZVAL (z_pid);
|
||||
ZVAL_LONG (z_pid, exp_pid);
|
||||
stream->wrapperdata = z_pid;
|
||||
return stream;
|
||||
}
|
||||
|
||||
return NULL;
|
||||
}
|
||||
|
||||
static int php_expect_stream_close (php_stream_wrapper *wrapper, php_stream *stream TSRMLS_DC)
|
||||
{
|
||||
zval* z_pid = stream->wrapperdata;
|
||||
int s = 0;
|
||||
waitpid (Z_LVAL_P(z_pid), &s, 0);
|
||||
zval_ptr_dtor (&z_pid);
|
||||
stream->wrapperdata = NULL;
|
||||
return s;
|
||||
}
|
||||
/* }}} */
|
||||
|
||||
|
||||
static php_stream_wrapper_ops php_expect_wrapper_ops = {
|
||||
php_expect_stream_opener,
|
||||
NULL, /* close */
|
||||
php_expect_stream_open,
|
||||
php_expect_stream_close, /* close */
|
||||
NULL, /* stat */
|
||||
NULL, /* stat_url */
|
||||
NULL, /* opendir */
|
||||
|
||||
@@ -14,11 +14,10 @@
|
||||
</maintainers>
|
||||
|
||||
<release>
|
||||
<version>0.2.1</version>
|
||||
<date>2006-07-04</date>
|
||||
<version>0.2.4</version>
|
||||
<date>2007-10-20</date>
|
||||
<state>beta</state>
|
||||
<notes>1) Support returning match substrings in array.
|
||||
2) Fix missing null-termination in returned match string.
|
||||
<notes>Fixed #12268 (Capturing output via exp_loguser from within PHP / Apache)
|
||||
</notes>
|
||||
</release>
|
||||
|
||||
|
||||
Reference in New Issue
Block a user