summaryrefslogtreecommitdiff
path: root/main/astfd.c
diff options
context:
space:
mode:
authorTilghman Lesher <tilghman@meg.abyt.es>2012-04-23 16:08:33 +0000
committerTilghman Lesher <tilghman@meg.abyt.es>2012-04-23 16:08:33 +0000
commitf03d56a84d252330dab075f51db44f4ebb440b48 (patch)
tree401c2c819be1b5f4b092929f08bb77efaed3ebfb /main/astfd.c
parentceefcf883923da7f37ec6515b2ecfc545c75e53f (diff)
On some platforms, O_RDONLY is not a flag to be checked, but merely the absence of O_RDWR and O_WRONLY.
The POSIX specification does not mandate how these 3 flags must be specified, only that one of the three must be specified in every call. ........ Merged revisions 363209 from http://svn.asterisk.org/svn/asterisk/branches/1.8 ........ Merged revisions 363212 from http://svn.asterisk.org/svn/asterisk/branches/10 git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@363215 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'main/astfd.c')
-rw-r--r--main/astfd.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/main/astfd.c b/main/astfd.c
index 90ded390f..8aead62fd 100644
--- a/main/astfd.c
+++ b/main/astfd.c
@@ -95,7 +95,11 @@ int __ast_fdleak_open(const char *file, int line, const char *func, const char *
flags & O_NONBLOCK ? "|O_NONBLOCK" : "",
flags & O_TRUNC ? "|O_TRUNC" : "",
flags & O_RDWR ? "|O_RDWR" : "",
+#if O_RDONLY == 0
+ !(flags & (O_WRONLY | O_RDWR)) ? "|O_RDONLY" : "",
+#else
flags & O_RDONLY ? "|O_RDONLY" : "",
+#endif
flags & O_WRONLY ? "|O_WRONLY" : "",
"");
flags &= ~(O_CREAT | O_APPEND | O_EXCL | O_NONBLOCK | O_TRUNC | O_RDWR | O_RDONLY | O_WRONLY);