mirror of
https://github.com/asterisk/asterisk.git
synced 2025-11-02 03:48:02 +00:00
move ast_carefulwrite from manager.c to utils.c so that cli.c and
res_agi.c no longer depend on manager.h (issue #6397, casper) git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@25026 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
32
manager.c
32
manager.c
@@ -168,38 +168,6 @@ static struct mansession {
|
||||
static struct manager_action *first_action = NULL;
|
||||
AST_MUTEX_DEFINE_STATIC(actionlock);
|
||||
|
||||
/*! If you are calling ast_carefulwrite, it is assumed that you are calling
|
||||
it on a file descriptor that _DOES_ have NONBLOCK set. This way,
|
||||
there is only one system call made to do a write, unless we actually
|
||||
have a need to wait. This way, we get better performance. */
|
||||
int ast_carefulwrite(int fd, char *s, int len, int timeoutms)
|
||||
{
|
||||
/* Try to write string, but wait no more than ms milliseconds
|
||||
before timing out */
|
||||
int res = 0;
|
||||
struct pollfd fds[1];
|
||||
while (len) {
|
||||
res = write(fd, s, len);
|
||||
if ((res < 0) && (errno != EAGAIN)) {
|
||||
return -1;
|
||||
}
|
||||
if (res < 0)
|
||||
res = 0;
|
||||
len -= res;
|
||||
s += res;
|
||||
res = 0;
|
||||
if (len) {
|
||||
fds[0].fd = fd;
|
||||
fds[0].events = POLLOUT;
|
||||
/* Wait until writable again */
|
||||
res = poll(fds, 1, timeoutms);
|
||||
if (res < 1)
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
return res;
|
||||
}
|
||||
|
||||
/*! authority_to_str: Convert authority code to string with serveral options */
|
||||
static char *authority_to_str(int authority, char *res, int reslen)
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user