2013-02-16 02:27:21 +04:00
|
|
|
|
|
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
|
|
|
|
#ifndef mozilla_ipc_FileDescriptorUtils_h
|
|
|
|
#define mozilla_ipc_FileDescriptorUtils_h
|
|
|
|
|
2013-02-21 06:52:44 +04:00
|
|
|
#include "mozilla/Attributes.h"
|
2013-02-16 02:27:21 +04:00
|
|
|
#include "mozilla/ipc/FileDescriptor.h"
|
|
|
|
#include "nsIRunnable.h"
|
2014-05-13 21:13:00 +04:00
|
|
|
#include <stdio.h>
|
2013-02-16 02:27:21 +04:00
|
|
|
|
|
|
|
namespace mozilla {
|
|
|
|
namespace ipc {
|
|
|
|
|
|
|
|
// When Dispatch() is called (from main thread) this class arranges to close the
|
|
|
|
// provided FileDescriptor on one of the socket transport service threads (to
|
|
|
|
// avoid main thread I/O).
|
2013-02-21 06:52:44 +04:00
|
|
|
class CloseFileRunnable MOZ_FINAL : public nsIRunnable
|
2013-02-16 02:27:21 +04:00
|
|
|
{
|
|
|
|
typedef mozilla::ipc::FileDescriptor FileDescriptor;
|
|
|
|
|
|
|
|
FileDescriptor mFileDescriptor;
|
|
|
|
|
|
|
|
public:
|
2014-08-08 05:18:59 +04:00
|
|
|
explicit CloseFileRunnable(const FileDescriptor& aFileDescriptor)
|
2013-02-16 02:27:21 +04:00
|
|
|
#ifdef DEBUG
|
|
|
|
;
|
|
|
|
#else
|
|
|
|
: mFileDescriptor(aFileDescriptor)
|
|
|
|
{ }
|
|
|
|
#endif
|
|
|
|
|
2013-07-19 06:23:32 +04:00
|
|
|
NS_DECL_THREADSAFE_ISUPPORTS
|
2013-02-16 02:27:21 +04:00
|
|
|
NS_DECL_NSIRUNNABLE
|
|
|
|
|
|
|
|
void Dispatch();
|
|
|
|
|
|
|
|
private:
|
|
|
|
~CloseFileRunnable();
|
|
|
|
|
|
|
|
void CloseFile();
|
|
|
|
};
|
|
|
|
|
2014-05-13 21:13:00 +04:00
|
|
|
// On failure, FileDescriptorToFILE closes the given descriptor; on
|
|
|
|
// success, fclose()ing the returned FILE* will close the handle.
|
|
|
|
// This is meant for use with FileDescriptors received over IPC.
|
|
|
|
FILE* FileDescriptorToFILE(const FileDescriptor& aDesc,
|
|
|
|
const char* aOpenMode);
|
|
|
|
|
|
|
|
// FILEToFileDescriptor does not consume the given FILE*; it must be
|
|
|
|
// fclose()d as normal, and this does not invalidate the returned
|
|
|
|
// FileDescriptor.
|
|
|
|
FileDescriptor FILEToFileDescriptor(FILE* aStream);
|
|
|
|
|
2013-02-16 02:27:21 +04:00
|
|
|
} // namespace ipc
|
|
|
|
} // namespace mozilla
|
|
|
|
|
|
|
|
#endif // mozilla_ipc_FileDescriptorUtils_h
|