Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(14)

Side by Side Diff: mojo/edk/platform/platform_handle.cc

Issue 1483823004: EDK: Move {platform_handle,scoped_platform_handle}.* to //mojo/edk/platform. (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: Created 5 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « mojo/edk/platform/platform_handle.h ('k') | mojo/edk/platform/scoped_platform_handle.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "mojo/edk/platform/platform_handle.h"
6
7 #include <assert.h>
8 #include <errno.h>
9 #include <unistd.h>
10
11 namespace mojo {
12 namespace platform {
13
14 void PlatformHandle::CloseIfNecessary() {
15 if (!is_valid())
16 return;
17
18 if (close(fd) != 0) {
19 // The possible errors are EBADF (which is very bad -- it indicates a bug in
20 // our code), EINTR, or EIO. On EINTR, don't retry |close()| (this is the
21 // correct behavior on Linux, and the only safe thing to do on Mac: see,
22 // e.g., http://crbug.com/269623). EIO is sad (it indicates potential data
23 // loss), but again there's nothing more to do.
24 assert(errno == EINTR || errno == EIO);
25 }
26 fd = -1;
27 }
28
29 } // namespace embedder
30 } // namespace mojo
OLDNEW
« no previous file with comments | « mojo/edk/platform/platform_handle.h ('k') | mojo/edk/platform/scoped_platform_handle.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698