1
    2
    3
    4
    5
    6
    7
    8
    9
   10
   11
   12
   13
   14
   15
   16
   17
   18
   19
   20
   21
   22
   23
   24
   25
   26
   27
   28
   29
   30
   31
   32
   33
   34
   35
   36
   37
   38
   39
   40
   41
   42
   43
   44
   45
   46

ipc / ipc_platform_file_attachment_posix.h [blame]

// Copyright 2015 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef IPC_IPC_PLATFORM_FILE_ATTACHMENT_POSIX_H_
#define IPC_IPC_PLATFORM_FILE_ATTACHMENT_POSIX_H_

#include "base/files/platform_file.h"
#include "base/files/scoped_file.h"
#include "ipc/ipc_message_attachment.h"
#include "ipc/ipc_message_support_export.h"

namespace IPC {
namespace internal {

// A platform file that is sent over |Channel| as a part of |Message|.
// PlatformFileAttachment optionally owns the file and |owning_| is set in that
// case. Also, |file_| is not cleared even after the ownership is taken.
// Some old clients require this strange behavior.
class IPC_MESSAGE_SUPPORT_EXPORT PlatformFileAttachment
    : public MessageAttachment {
 public:
  // Non-owning constructor
  explicit PlatformFileAttachment(base::PlatformFile file);
  // Owning constructor
  explicit PlatformFileAttachment(base::ScopedFD file);

  Type GetType() const override;
  base::PlatformFile TakePlatformFile();

  base::PlatformFile file() const { return file_; }
  bool Owns() const { return owning_.is_valid(); }

 private:
  ~PlatformFileAttachment() override;

  base::PlatformFile file_;
  base::ScopedFD owning_;
};

base::PlatformFile GetPlatformFile(scoped_refptr<MessageAttachment> attachment);

}  // namespace internal
}  // namespace IPC

#endif  // IPC_IPC_PLATFORM_FILE_ATTACHMENT_POSIX_H_