From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Date: Tue, 3 Jun 2003 13:15:06 +0400 From: Stanislav Ievlev To: devel@altlinux.ru Subject: Re: [devel] I: temporary file handling: C coding guideline Message-ID: <20030603091506.GB12966@basalt.office.altlinux.org> References: <20030603081729.GB13299@basalt.office.altlinux.org> Mime-Version: 1.0 Content-Type: text/plain; charset=koi8-r Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <20030603081729.GB13299@basalt.office.altlinux.org> Sender: devel-admin@altlinux.ru Errors-To: devel-admin@altlinux.ru X-BeenThere: devel@altlinux.ru X-Mailman-Version: 2.0.9 Precedence: bulk Reply-To: devel@altlinux.ru List-Unsubscribe: , List-Id: List-Post: List-Help: List-Subscribe: , List-Archive: Archived-At: List-Archive: List-Post: On Tue, Jun 03, 2003 at 12:17:29PM +0400, Dmitry V. Levin wrote: > Greetings! > > Я планирую добавить "C coding guideline" в дополнение к нынешнему shell > coding guideline из SPP: > > #define _GNU_SOURCE > > #include > #include > #include > #include > #include > > ... > char *fname; > int fd; > FILE *fp; > > if (asprintf (&fname, "%s/progname.XXXXXX", getenv ("TMPDIR") ?: P_tmpdir) < 0) > error (EXIT_FAILURE, errno, "asprintf"); > > if ((fd = mkstemp (fname)) < 0) > error (EXIT_FAILURE, errno, "mkstemp: %s", fname); > > if (unlink (fname) < 0) > error (EXIT_FAILURE, errno, "unlink: %s", fname); > > if ((fp = fdopen (fd, "w+")) == NULL) > error (EXIT_FAILURE, errno, "fdopen: %s", fname); > > ... > > if (fclose (fp)) > error (EXIT_FAILURE, errno, "fclose: %s", fname); > > free (fname); > fname = NULL; > > Комментарии приветствуются. Хочется man-page по asprintf. Я тут не очень понял про коды возврата. 0 это тоже будет ошибкой в данном случае? Ещё надо бы наверное portable вариант без gcc-змов. Это потребуется всем мантейнерам которые захотят убедить авторов в своём патче. > > > -- > ldv