Class: Google::Apis::RemotebuildexecutionV2::BuildBazelRemoteExecutionV2Directory
- Inherits:
-
Object
- Object
- Google::Apis::RemotebuildexecutionV2::BuildBazelRemoteExecutionV2Directory
- Includes:
- Core::Hashable, Core::JsonObjectSupport
- Defined in:
- generated/google/apis/remotebuildexecution_v2/classes.rb,
generated/google/apis/remotebuildexecution_v2/representations.rb,
generated/google/apis/remotebuildexecution_v2/representations.rb
Overview
A Directory represents a directory node in a file tree, containing zero or
more children FileNodes,
DirectoryNodes and
SymlinkNodes.
Each Node contains its name in the directory, either the digest of its
content (either a file blob or a Directory proto) or a symlink target, as
well as possibly some metadata about the file or directory.
In order to ensure that two equivalent directory trees hash to the same
value, the following restrictions MUST be obeyed when constructing a
a Directory:
- Every child in the directory must have a path of exactly one segment. Multiple levels of directory hierarchy may not be collapsed.
- Each child in the directory must have a unique path segment (file name).
- The files, directories and symlinks in the directory must each be sorted
in lexicographical order by path. The path strings must be sorted by code
point, equivalently, by UTF-8 bytes.
A
Directorythat obeys the restrictions is said to be in canonical form. As an example, the following could be used for a file namedbarand a directory namedfoowith an executable file namedbaz(hashes shortened for readability):json // (Directory proto) ` files: [ ` name: "bar", digest: ` hash: "4a73bc9d03...", size: 65534 ` ` ], directories: [ ` name: "foo", digest: ` hash: "4cf2eda940...", size: 43 ` ` ] ` // (Directory proto with hash "4cf2eda940..." and size 43) ` files: [ ` name: "baz", digest: ` hash: "b2c941073e...", size: 1294, `, is_executable: true ` ] `
Instance Attribute Summary collapse
-
#directories ⇒ Array<Google::Apis::RemotebuildexecutionV2::BuildBazelRemoteExecutionV2DirectoryNode>
The subdirectories in the directory.
-
#files ⇒ Array<Google::Apis::RemotebuildexecutionV2::BuildBazelRemoteExecutionV2FileNode>
The files in the directory.
-
#symlinks ⇒ Array<Google::Apis::RemotebuildexecutionV2::BuildBazelRemoteExecutionV2SymlinkNode>
The symlinks in the directory.
Instance Method Summary collapse
-
#initialize(**args) ⇒ BuildBazelRemoteExecutionV2Directory
constructor
A new instance of BuildBazelRemoteExecutionV2Directory.
-
#update!(**args) ⇒ Object
Update properties of this object.
Methods included from Core::JsonObjectSupport
Methods included from Core::Hashable
Constructor Details
#initialize(**args) ⇒ BuildBazelRemoteExecutionV2Directory
Returns a new instance of BuildBazelRemoteExecutionV2Directory
949 950 951 |
# File 'generated/google/apis/remotebuildexecution_v2/classes.rb', line 949 def initialize(**args) update!(**args) end |
Instance Attribute Details
#directories ⇒ Array<Google::Apis::RemotebuildexecutionV2::BuildBazelRemoteExecutionV2DirectoryNode>
The subdirectories in the directory.
Corresponds to the JSON property directories
937 938 939 |
# File 'generated/google/apis/remotebuildexecution_v2/classes.rb', line 937 def directories @directories end |
#files ⇒ Array<Google::Apis::RemotebuildexecutionV2::BuildBazelRemoteExecutionV2FileNode>
The files in the directory.
Corresponds to the JSON property files
942 943 944 |
# File 'generated/google/apis/remotebuildexecution_v2/classes.rb', line 942 def files @files end |
#symlinks ⇒ Array<Google::Apis::RemotebuildexecutionV2::BuildBazelRemoteExecutionV2SymlinkNode>
The symlinks in the directory.
Corresponds to the JSON property symlinks
947 948 949 |
# File 'generated/google/apis/remotebuildexecution_v2/classes.rb', line 947 def symlinks @symlinks end |
Instance Method Details
#update!(**args) ⇒ Object
Update properties of this object
954 955 956 957 958 |
# File 'generated/google/apis/remotebuildexecution_v2/classes.rb', line 954 def update!(**args) @directories = args[:directories] if args.key?(:directories) @files = args[:files] if args.key?(:files) @symlinks = args[:symlinks] if args.key?(:symlinks) end |