-
Notifications
You must be signed in to change notification settings - Fork 7.9k
Constify char* arguments of APIs #5676
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
@@ -52,13 +52,12 @@ | |||
#define ZEND_LOGO_DATA_URI "" | |||
|
|||
BEGIN_EXTERN_C() | |||
PHPAPI zend_string *php_info_html_esc(char *string); | |||
PHPAPI void php_info_html_esc_write(char *string, int str_len); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I can not find any implementation of php_info_html_esc_write
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The definition of php_info_html_esc_write()
has been removed in PHP 5.4, so the declaration can be removed as well.
while (ss) { | ||
space = strchr(ss, '+'); | ||
if (space) { | ||
*space = '\0'; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Notice: the original implementation used a hack way so I made some changes here
@@ -260,12 +260,11 @@ PHPAPI int php_session_register_serializer(const char *name, | |||
zend_string *(*encode)(PS_SERIALIZER_ENCODE_ARGS), | |||
int (*decode)(PS_SERIALIZER_DECODE_ARGS)); | |||
|
|||
PHPAPI void php_session_set_id(char *id); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I can not find any implementation of php_session_set_id
} | ||
|
||
#else |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Notice: missing function implementations here, so I made some changes
Build failure on AppVeyor:
|
The deeper code is a bit more complicated so I just convert these pointers to char* now |
I think the following would do: ext/standard/mail.c | 2 +-
win32/sendmail.c | 8 ++++----
win32/sendmail.h | 6 +++---
3 files changed, 8 insertions(+), 8 deletions(-)
diff --git a/ext/standard/mail.c b/ext/standard/mail.c
index 61454a4930..b13acc82b7 100644
--- a/ext/standard/mail.c
+++ b/ext/standard/mail.c
@@ -501,7 +501,7 @@ PHPAPI int php_mail(const char *to, const char *subject, const char *message, co
if (!sendmail_path) {
#ifdef PHP_WIN32
/* handle old style win smtp sending */
- if (TSendMail(INI_STR("SMTP"), &tsm_err, &tsm_errmsg, hdr, (char *) subject, (char *) to, (char *) message, NULL, NULL, NULL) == FAILURE) {
+ if (TSendMail(INI_STR("SMTP"), &tsm_err, &tsm_errmsg, hdr, subject, to, message, NULL, NULL, NULL) == FAILURE) {
if (tsm_errmsg) {
php_error_docref(NULL, E_WARNING, "%s", tsm_errmsg);
efree(tsm_errmsg);
diff --git a/win32/sendmail.c b/win32/sendmail.c
index 281c343533..67253a3b79 100644
--- a/win32/sendmail.c
+++ b/win32/sendmail.c
@@ -177,7 +177,7 @@ static zend_string *php_win32_mail_trim_header(char *header)
// See SendText() for additional args!
//********************************************************************/
PHPAPI int TSendMail(char *host, int *error, char **error_message,
- char *headers, char *Subject, char *mailTo, char *data,
+ char *headers, const char *Subject, const char *mailTo, const char *data,
char *mailCc, char *mailBcc, char *mailRPath)
{
int ret;
@@ -352,7 +352,7 @@ PHPAPI char *GetSMErrorText(int index)
// Author/Date: jcar 20/9/96
// History:
//*******************************************************************/
-static int SendText(char *RPath, char *Subject, char *mailTo, char *mailCc, char *mailBcc, char *data,
+static int SendText(char *RPath, const char *Subject, const char *mailTo, char *mailCc, char *mailBcc, const char *data,
char *headers, char *headers_lc, char **error_message)
{
int res;
@@ -633,7 +633,7 @@ static int SendText(char *RPath, char *Subject, char *mailTo, char *mailCc, char
return (SUCCESS);
}
-static int addToHeader(char **header_buffer, const char *specifier, char *string)
+static int addToHeader(char **header_buffer, const char *specifier, const char *string)
{
*header_buffer = erealloc(*header_buffer, strlen(*header_buffer) + strlen(specifier) + strlen(string) + 1);
sprintf(*header_buffer + strlen(*header_buffer), specifier, string);
@@ -651,7 +651,7 @@ static int addToHeader(char **header_buffer, const char *specifier, char *string
// Author/Date: jcar 20/9/96
// History:
//********************************************************************/
-static int PostHeader(char *RPath, char *Subject, char *mailTo, char *xheaders)
+static int PostHeader(char *RPath, const char *Subject, const char *mailTo, char *xheaders)
{
/* Print message header according to RFC 822 */
/* Return-path, Received, Date, From, Subject, Sender, To, cc */
diff --git a/win32/sendmail.h b/win32/sendmail.h
index bb502cb7dd..a35851acf8 100644
--- a/win32/sendmail.h
+++ b/win32/sendmail.h
@@ -33,15 +33,15 @@
PHPAPI int TSendMail(char *smtpaddr, int *returnerror, char **error_message,
- char *RPath, char *Subject, char *mailTo, char *data,
+ char *RPath, const char *Subject, const char *mailTo, const char *data,
char *mailCc, char *mailBcc, char *mailRPath);
PHPAPI void TSMClose(void);
-static int SendText(char *RPath, char *Subject, char *mailTo, char *mailCc, char *mailBcc, char *data,
+static int SendText(char *RPath, const char *Subject, const char *mailTo, char *mailCc, char *mailBcc, const char *data,
char *headers, char *headers_lc, char **error_message);
PHPAPI char *GetSMErrorText(int index);
static int MailConnect();
-static int PostHeader(char *RPath, char *Subject, char *mailTo, char *xheaders);
+static int PostHeader(char *RPath, const char *Subject, const char *mailTo, char *xheaders);
static int Post(LPCSTR msg);
static int Ack(char **server_response);
static unsigned long GetAddr(LPSTR szHost); |
@cmb69 Thank you, I am a bit lazy 🤪 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nice work!
{ | ||
timelib_time *parsed_time; | ||
timelib_error_container *error = NULL; | ||
int error2; | ||
zend_long retval; | ||
|
||
parsed_time = timelib_strtotime(string, strlen(string), &error, DATE_TIMEZONEDB, php_date_parse_tzfile_wrapper); | ||
parsed_time = timelib_strtotime((char *) string, strlen(string), &error, DATE_TIMEZONEDB, php_date_parse_tzfile_wrapper); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could you please also submit a PR to https://github.com/derickr/timelib, so we can drop these const casts in the future?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I did not change it because I was worried whether this modification will affect other projects
but I will try to submit a PR soon
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Added TODO
comment
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@nikic @derickr done: derickr/timelib#82
3594d84
to
3cdfe9c
Compare
3dbddc3
to
df2a329
Compare
dcab466
to
406d58d
Compare
compilation passed |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Wow, this has really blown up!
@@ -805,7 +805,7 @@ PHP_METHOD(Phar, webPhar) | |||
|
|||
sapi_header_op(SAPI_HEADER_REPLACE, &ctr); | |||
sapi_send_headers(); | |||
efree(ctr.line); | |||
efree((void *) ctr.line); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The ctr.line
related changes look a bit dubious to me. Do we gain anything by making it const char?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
it only receives a read-only string in most cases
size_t len = 0; | ||
|
||
ZEND_PARSE_PARAMETERS_START(0, 1) | ||
Z_PARAM_OPTIONAL | ||
Z_PARAM_STRING(ctr.line, len) | ||
Z_PARAM_STRING(line, len) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This makes me wonder why the Z_PARAM_STRING target is char **
and not const char **
. Maybe we should change that as well (but separately -- it may have larger fallout).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I couldn't agree more, that's what I thought a long time ago
but if we change it, it may break many PECL extensions. and we can't reflect it is read-only when we use Z_PARAM_STR
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, I'm not sure what to do about this one. With the old zend_parse_parameters API, it was possible to use both const char and char, because it simply wasn't validated. With Z_PARAM_STRING it is, and the wrong one has been originally used :(
For the zend_string APIs, I don't think "const" concept makes a lot of sense, because semantics are determined by copy-on-write. Effectively zend_string is "always" const (apart from refcount changes).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think it may be appropriate to fix it in PHP8 because we already have a lot of BC breaks 🤪...
No description provided.