This file is indexed.

/usr/include/Poco/MongoDB/UpdateRequest.h is in libpoco-dev 1.8.0.1-1ubuntu4.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  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
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
//
// UpdateRequest.h
//
// Library: MongoDB
// Package: MongoDB
// Module:  UpdateRequest
//
// Definition of the UpdateRequest class.
//
// Copyright (c) 2012, Applied Informatics Software Engineering GmbH.
// and Contributors.
//
// SPDX-License-Identifier:	BSL-1.0
//


#ifndef MongoDB_UpdateRequest_INCLUDED
#define MongoDB_UpdateRequest_INCLUDED


#include "Poco/MongoDB/MongoDB.h"
#include "Poco/MongoDB/RequestMessage.h"
#include "Poco/MongoDB/Document.h"


namespace Poco {
namespace MongoDB {


class UpdateRequest: public RequestMessage
	/// This request is used to update a document in a database
	/// using the OP_UPDATE client request. 
{
public:
	enum Flags
	{
		UPDATE_DEFAULT = 0,
			/// If set, the database will insert the supplied object into the
			/// collection if no matching document is found.
			
		UPDATE_UPSERT = 1,
			/// If set, the database will update all matching objects in the collection.
			/// Otherwise only updates first matching doc.

		UPDATE_MULTIUPDATE = 2
			/// If set to, updates multiple documents that meet the query criteria.
			/// Otherwise only updates one document.
	};

	UpdateRequest(const std::string& collectionName, Flags flags = UPDATE_DEFAULT);
		/// Creates the UpdateRequest.
		///
		/// The full collection name is the concatenation of the database 
		/// name with the collection name, using a "." for the concatenation. For example, 
		/// for the database "foo" and the collection "bar", the full collection name is 
		/// "foo.bar".

	virtual ~UpdateRequest();
		/// Destroys the UpdateRequest.

	Document& selector();
		/// Returns the selector document.

	Document& update();
		/// Returns the document to update.

	Flags flags() const;
		/// Returns the flags

	void flags(Flags flags);
		/// Sets the flags

protected:
	void buildRequest(BinaryWriter& writer);

private:
	Flags       _flags;
	std::string _fullCollectionName;
	Document    _selector;
	Document    _update;
};


//
// inlines
//
inline UpdateRequest::Flags UpdateRequest::flags() const
{
	return _flags;
}


inline void UpdateRequest::flags(UpdateRequest::Flags flags)
{
	_flags = flags;
}


inline Document& UpdateRequest::selector()
{
	return _selector;
}


inline Document& UpdateRequest::update()
{
	return _update;
}


} } // namespace Poco::MongoDB


#endif // MongoDB_UpdateRequest_INCLUDED