safe_write/read: take void* buffer for generic use
if using one of unsigned or signed char for the function prototype, one gets nasty warnings when using it with the other type. the only proper solution is to put void* into the prototype, and then specialize the pointer inside the function using an automatic variable. for exactly this reason, libc functions like read(), write(), etc use void* too.
This commit is contained in:
parent
e9e0f0b4f0
commit
9bb699628f
@ -32,10 +32,11 @@
|
||||
* Write the buffer to the socket. If an EINTR occurs, pick up and try
|
||||
* again. Keep sending until the buffer has been sent.
|
||||
*/
|
||||
ssize_t safe_write (int fd, const char *buffer, size_t count)
|
||||
ssize_t safe_write (int fd, const void *buf, size_t count)
|
||||
{
|
||||
ssize_t len;
|
||||
size_t bytestosend;
|
||||
const char *buffer = buf;
|
||||
|
||||
assert (fd >= 0);
|
||||
assert (buffer != NULL);
|
||||
@ -67,7 +68,7 @@ ssize_t safe_write (int fd, const char *buffer, size_t count)
|
||||
* Matched pair for safe_write(). If an EINTR occurs, pick up and try
|
||||
* again.
|
||||
*/
|
||||
ssize_t safe_read (int fd, char *buffer, size_t count)
|
||||
ssize_t safe_read (int fd, void *buffer, size_t count)
|
||||
{
|
||||
ssize_t len;
|
||||
|
||||
|
@ -21,8 +21,8 @@
|
||||
#ifndef TINYPROXY_NETWORK_H
|
||||
#define TINYPROXY_NETWORK_H
|
||||
|
||||
extern ssize_t safe_write (int fd, const char *buffer, size_t count);
|
||||
extern ssize_t safe_read (int fd, char *buffer, size_t count);
|
||||
extern ssize_t safe_write (int fd, const void *buf, size_t count);
|
||||
extern ssize_t safe_read (int fd, void *buf, size_t count);
|
||||
|
||||
extern int write_message (int fd, const char *fmt, ...);
|
||||
extern ssize_t readline (int fd, char **whole_buffer);
|
||||
|
Loading…
Reference in New Issue
Block a user