/* * Copyright 2018-2023 Amazon.com, Inc. or its affiliates. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with * the License. A copy of the License is located at * * http://aws.amazon.com/apache2.0 * * or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR * CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions * and limitations under the License. */ package com.amazonaws.services.codecommit.model; import java.io.Serializable; import javax.annotation.Generated; import com.amazonaws.protocol.StructuredPojo; import com.amazonaws.protocol.ProtocolMarshaller; /** *
* A file to be added, updated, or deleted as part of a commit. *
* * @see AWS API * Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class FileMetadata implements Serializable, Cloneable, StructuredPojo { /** ** The full path to the file to be added or updated, including the name of the file. *
*/ private String absolutePath; /** ** The blob ID that contains the file information. *
*/ private String blobId; /** ** The extrapolated file mode permissions for the file. Valid values include EXECUTABLE and NORMAL. *
*/ private String fileMode; /** ** The full path to the file to be added or updated, including the name of the file. *
* * @param absolutePath * The full path to the file to be added or updated, including the name of the file. */ public void setAbsolutePath(String absolutePath) { this.absolutePath = absolutePath; } /** ** The full path to the file to be added or updated, including the name of the file. *
* * @return The full path to the file to be added or updated, including the name of the file. */ public String getAbsolutePath() { return this.absolutePath; } /** ** The full path to the file to be added or updated, including the name of the file. *
* * @param absolutePath * The full path to the file to be added or updated, including the name of the file. * @return Returns a reference to this object so that method calls can be chained together. */ public FileMetadata withAbsolutePath(String absolutePath) { setAbsolutePath(absolutePath); return this; } /** ** The blob ID that contains the file information. *
* * @param blobId * The blob ID that contains the file information. */ public void setBlobId(String blobId) { this.blobId = blobId; } /** ** The blob ID that contains the file information. *
* * @return The blob ID that contains the file information. */ public String getBlobId() { return this.blobId; } /** ** The blob ID that contains the file information. *
* * @param blobId * The blob ID that contains the file information. * @return Returns a reference to this object so that method calls can be chained together. */ public FileMetadata withBlobId(String blobId) { setBlobId(blobId); return this; } /** ** The extrapolated file mode permissions for the file. Valid values include EXECUTABLE and NORMAL. *
* * @param fileMode * The extrapolated file mode permissions for the file. Valid values include EXECUTABLE and NORMAL. * @see FileModeTypeEnum */ public void setFileMode(String fileMode) { this.fileMode = fileMode; } /** ** The extrapolated file mode permissions for the file. Valid values include EXECUTABLE and NORMAL. *
* * @return The extrapolated file mode permissions for the file. Valid values include EXECUTABLE and NORMAL. * @see FileModeTypeEnum */ public String getFileMode() { return this.fileMode; } /** ** The extrapolated file mode permissions for the file. Valid values include EXECUTABLE and NORMAL. *
* * @param fileMode * The extrapolated file mode permissions for the file. Valid values include EXECUTABLE and NORMAL. * @return Returns a reference to this object so that method calls can be chained together. * @see FileModeTypeEnum */ public FileMetadata withFileMode(String fileMode) { setFileMode(fileMode); return this; } /** ** The extrapolated file mode permissions for the file. Valid values include EXECUTABLE and NORMAL. *
* * @param fileMode * The extrapolated file mode permissions for the file. Valid values include EXECUTABLE and NORMAL. * @return Returns a reference to this object so that method calls can be chained together. * @see FileModeTypeEnum */ public FileMetadata withFileMode(FileModeTypeEnum fileMode) { this.fileMode = fileMode.toString(); return this; } /** * Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be * redacted from this string using a placeholder value. * * @return A string representation of this object. * * @see java.lang.Object#toString() */ @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("{"); if (getAbsolutePath() != null) sb.append("AbsolutePath: ").append(getAbsolutePath()).append(","); if (getBlobId() != null) sb.append("BlobId: ").append(getBlobId()).append(","); if (getFileMode() != null) sb.append("FileMode: ").append(getFileMode()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof FileMetadata == false) return false; FileMetadata other = (FileMetadata) obj; if (other.getAbsolutePath() == null ^ this.getAbsolutePath() == null) return false; if (other.getAbsolutePath() != null && other.getAbsolutePath().equals(this.getAbsolutePath()) == false) return false; if (other.getBlobId() == null ^ this.getBlobId() == null) return false; if (other.getBlobId() != null && other.getBlobId().equals(this.getBlobId()) == false) return false; if (other.getFileMode() == null ^ this.getFileMode() == null) return false; if (other.getFileMode() != null && other.getFileMode().equals(this.getFileMode()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getAbsolutePath() == null) ? 0 : getAbsolutePath().hashCode()); hashCode = prime * hashCode + ((getBlobId() == null) ? 0 : getBlobId().hashCode()); hashCode = prime * hashCode + ((getFileMode() == null) ? 0 : getFileMode().hashCode()); return hashCode; } @Override public FileMetadata clone() { try { return (FileMetadata) super.clone(); } catch (CloneNotSupportedException e) { throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e); } } @com.amazonaws.annotation.SdkInternalApi @Override public void marshall(ProtocolMarshaller protocolMarshaller) { com.amazonaws.services.codecommit.model.transform.FileMetadataMarshaller.getInstance().marshall(this, protocolMarshaller); } }