1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59
  
     | 
    
      // RUN: %check_clang_tidy %s android-cloexec-epoll-create1 %t
#define __O_CLOEXEC 3
#define EPOLL_CLOEXEC __O_CLOEXEC
#define TEMP_FAILURE_RETRY(exp) \
  ({                            \
    int _rc;                    \
    do {                        \
      _rc = (exp);              \
    } while (_rc == -1);        \
  })
extern "C" int epoll_create1(int flags);
void a() {
  epoll_create1(0);
  // CHECK-MESSAGES: :[[@LINE-1]]:18: warning: 'epoll_create1' should use EPOLL_CLOEXEC where possible [android-cloexec-epoll-create1]
  // CHECK-FIXES: epoll_create1(EPOLL_CLOEXEC);
  TEMP_FAILURE_RETRY(epoll_create1(0));
  // CHECK-MESSAGES: :[[@LINE-1]]:37: warning: 'epoll_create1'
  // CHECK-FIXES: TEMP_FAILURE_RETRY(epoll_create1(EPOLL_CLOEXEC));
}
void f() {
  epoll_create1(3);
  // CHECK-MESSAGES: :[[@LINE-1]]:18: warning: 'epoll_create1'
  // CHECK-FIXES: epoll_create1(EPOLL_CLOEXEC);
  TEMP_FAILURE_RETRY(epoll_create1(3));
  // CHECK-MESSAGES: :[[@LINE-1]]:37: warning: 'epoll_create1'
  // CHECK-FIXES: TEMP_FAILURE_RETRY(epoll_create1(EPOLL_CLOEXEC));
  int flag = 0;
  epoll_create1(EPOLL_CLOEXEC);
  TEMP_FAILURE_RETRY(epoll_create1(EPOLL_CLOEXEC));
}
namespace i {
int epoll_create1(int flags);
void d() {
  epoll_create1(0);
  TEMP_FAILURE_RETRY(epoll_create1(0));
}
} // namespace i
void e() {
  epoll_create1(EPOLL_CLOEXEC);
  TEMP_FAILURE_RETRY(epoll_create1(EPOLL_CLOEXEC));
}
class G {
public:
  int epoll_create1(int flags);
  void d() {
    epoll_create1(EPOLL_CLOEXEC);
    TEMP_FAILURE_RETRY(epoll_create1(EPOLL_CLOEXEC));
  }
};
 
     |