summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ext/com/conversion.c32
-rw-r--r--ext/rpc/com/conversion.c32
2 files changed, 52 insertions, 12 deletions
diff --git a/ext/com/conversion.c b/ext/com/conversion.c
index 358314f132..cd947fb72d 100644
--- a/ext/com/conversion.c
+++ b/ext/com/conversion.c
@@ -631,14 +631,34 @@ PHPAPI int php_variant_to_pval(VARIANT *var_arg, pval *pval_arg, int codepage TS
break;
case VT_BSTR:
- if (V_ISBYREF(var_arg)) {
- Z_STRVAL_P(pval_arg) = php_OLECHAR_to_char(*V_BSTRREF(var_arg), &Z_STRLEN_P(pval_arg), codepage TSRMLS_CC);
+ if (V_ISBYREF(var_arg))
+ {
+ if (*V_BSTR(var_arg))
+ {
+ Z_STRVAL_P(pval_arg) = php_OLECHAR_to_char(*V_BSTRREF(var_arg), &Z_STRLEN_P(pval_arg), codepage TSRMLS_CC);
+ Z_TYPE_P(pval_arg) = IS_STRING;
+ }
+ else
+ {
+ ZVAL_NULL(pval_arg);
+ Z_TYPE_P(pval_arg) = IS_NULL;
+ }
efree(V_BSTRREF(var_arg));
- } else {
- Z_STRVAL_P(pval_arg) = php_OLECHAR_to_char(V_BSTR(var_arg), &Z_STRLEN_P(pval_arg), codepage TSRMLS_CC);
+ }
+ else
+ {
+ if (V_BSTR(var_arg))
+ {
+ Z_STRVAL_P(pval_arg) = php_OLECHAR_to_char(V_BSTR(var_arg), &Z_STRLEN_P(pval_arg), codepage TSRMLS_CC);
+ Z_TYPE_P(pval_arg) = IS_STRING;
+ }
+ else
+ {
+ ZVAL_NULL(pval_arg);
+ Z_TYPE_P(pval_arg) = IS_NULL;
+ }
}
- Z_TYPE_P(pval_arg) = IS_STRING;
break;
case VT_DATE: {
@@ -844,4 +864,4 @@ static void comval_to_variant(pval *pval_arg, VARIANT *var_arg TSRMLS_DC)
}
}
-#endif /* PHP_WIN32 */ \ No newline at end of file
+#endif /* PHP_WIN32 */
diff --git a/ext/rpc/com/conversion.c b/ext/rpc/com/conversion.c
index 358314f132..cd947fb72d 100644
--- a/ext/rpc/com/conversion.c
+++ b/ext/rpc/com/conversion.c
@@ -631,14 +631,34 @@ PHPAPI int php_variant_to_pval(VARIANT *var_arg, pval *pval_arg, int codepage TS
break;
case VT_BSTR:
- if (V_ISBYREF(var_arg)) {
- Z_STRVAL_P(pval_arg) = php_OLECHAR_to_char(*V_BSTRREF(var_arg), &Z_STRLEN_P(pval_arg), codepage TSRMLS_CC);
+ if (V_ISBYREF(var_arg))
+ {
+ if (*V_BSTR(var_arg))
+ {
+ Z_STRVAL_P(pval_arg) = php_OLECHAR_to_char(*V_BSTRREF(var_arg), &Z_STRLEN_P(pval_arg), codepage TSRMLS_CC);
+ Z_TYPE_P(pval_arg) = IS_STRING;
+ }
+ else
+ {
+ ZVAL_NULL(pval_arg);
+ Z_TYPE_P(pval_arg) = IS_NULL;
+ }
efree(V_BSTRREF(var_arg));
- } else {
- Z_STRVAL_P(pval_arg) = php_OLECHAR_to_char(V_BSTR(var_arg), &Z_STRLEN_P(pval_arg), codepage TSRMLS_CC);
+ }
+ else
+ {
+ if (V_BSTR(var_arg))
+ {
+ Z_STRVAL_P(pval_arg) = php_OLECHAR_to_char(V_BSTR(var_arg), &Z_STRLEN_P(pval_arg), codepage TSRMLS_CC);
+ Z_TYPE_P(pval_arg) = IS_STRING;
+ }
+ else
+ {
+ ZVAL_NULL(pval_arg);
+ Z_TYPE_P(pval_arg) = IS_NULL;
+ }
}
- Z_TYPE_P(pval_arg) = IS_STRING;
break;
case VT_DATE: {
@@ -844,4 +864,4 @@ static void comval_to_variant(pval *pval_arg, VARIANT *var_arg TSRMLS_DC)
}
}
-#endif /* PHP_WIN32 */ \ No newline at end of file
+#endif /* PHP_WIN32 */