popen에서 에러메시지 출력 원천 봉쇄하려면

seeker의 이미지

   char strDir[100] = "/korea/sung/";
   char strPrefix[100] = "BF*.DAT";
   char strFileName[200];
   FILE *pp;
   snprintf( cmd , sizeof cmd , "ls -1rt %s%s|head -1 2>/dev/null" , strDir , strPrefix );
   if ( !( pp = popen( cmd , "r" ) ) ) return NULL;
   if ( !fgets( strFileName , sizeof strFileName , pp ) )
   {
      pclose( pp );
      return NULL;
   }
   strFileName[ strlen( strFileName ) - 1 ] = 0;
   pclose( pp );

이상과 같이 실행하면. BF*.DAT가 없을경우 다음
/korea/sung/BF*.DAT not found
와 같은 에러메시지가 나오는데요.
파일없을때 나오는 이에러메시지를 원천 봉쇄하고싶은데요.
어떻게 하면되는지요.

stoneshim의 이미지

popen()을 호출하기 전에 stderr fd를 close 하시면 될것 같습니다.

지금의 방식으로 사용하시려면

snprintf( cmd , sizeof cmd , "ls -1rt %s%s 2>/dev/null |head -1" , strDir , strPrefix );

이렇게 고쳐서 사용하시면 될것 같네요.

우리 모두 리얼리스트가 되자. 그러나 가슴에 이룰 수 없는 꿈을 가지자

seeker의 이미지

감사합니다. 그렇게 하니, 잘됩니다.

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.