// Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file // for details. All rights reserved. Use of this source code is governed by a // BSD-style license that can be found in the LICENSE file. #ifndef RUNTIME_BIN_FDUTILS_H_ #define RUNTIME_BIN_FDUTILS_H_ #include "bin/builtin.h" #include "platform/globals.h" namespace dart { namespace bin { class FDUtils { public: static bool SetCloseOnExec(intptr_t fd); static bool SetNonBlocking(intptr_t fd); static bool SetBlocking(intptr_t fd); // Checks whether the file descriptor is blocking. If the function // returns true the value pointed to by is_blocking will be set to // the blocking state of the file descriptor. If the function // returns false the system call for checking the file descriptor // failed and the value pointed to by is_blocking is not modified. static bool IsBlocking(intptr_t fd, bool* is_blocking); static intptr_t AvailableBytes(intptr_t fd); // Reads the requested number of bytes from a file descriptor. This // function will only return on short reads if an error occours in // which case it returns -1 and errno is still valid. The file // descriptor must be in blocking mode. static ssize_t ReadFromBlocking(int fd, void* buffer, size_t count); // Writes the requested number of bytes to a file descriptor. This // function will only return on short writes if an error occours in // which case it returns -1 and errno is still valid. The file // descriptor must be in blocking mode. static ssize_t WriteToBlocking(int fd, const void* buffer, size_t count); // Closes fd without modifying errno. static void SaveErrorAndClose(intptr_t fd); private: DISALLOW_ALLOCATION(); DISALLOW_IMPLICIT_CONSTRUCTORS(FDUtils); }; } // namespace bin } // namespace dart #endif // RUNTIME_BIN_FDUTILS_H_