// Copyright (C) 2008 The Android Open Source Project // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License 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.google.gerrit.reviewdb; import com.google.gwtorm.client.Access; import com.google.gwtorm.client.OrmException; import com.google.gwtorm.client.PrimaryKey; import com.google.gwtorm.client.Query; import com.google.gwtorm.client.ResultSet; public interface PatchLineCommentAccess extends Access<PatchLineComment, PatchLineComment.Key> { @PrimaryKey("key") PatchLineComment get(PatchLineComment.Key id) throws OrmException; @Query("WHERE key.patchKey.patchSetId.changeId = ?") ResultSet<PatchLineComment> byChange(Change.Id id) throws OrmException; @Query("WHERE key.patchKey = ? AND status = '" + PatchLineComment.STATUS_PUBLISHED + "' ORDER BY lineNbr,writtenOn") ResultSet<PatchLineComment> published(Patch.Key patch) throws OrmException; @Query("WHERE key.patchKey.patchSetId.changeId = ?" + " AND key.patchKey.fileName = ? AND status = '" + PatchLineComment.STATUS_PUBLISHED + "' ORDER BY lineNbr,writtenOn") ResultSet<PatchLineComment> published(Change.Id id, String file) throws OrmException; @Query("WHERE key.patchKey.patchSetId = ? AND status = '" + PatchLineComment.STATUS_PUBLISHED + "'") ResultSet<PatchLineComment> published(PatchSet.Id patchset) throws OrmException; @Query("WHERE key.patchKey.patchSetId = ? AND status = '" + PatchLineComment.STATUS_DRAFT + "' AND author = ? ORDER BY key.patchKey,lineNbr,writtenOn") ResultSet<PatchLineComment> draft(PatchSet.Id patchset, Account.Id author) throws OrmException; @Query("WHERE key.patchKey = ? AND status = '" + PatchLineComment.STATUS_DRAFT + "' AND author = ? ORDER BY lineNbr,writtenOn") ResultSet<PatchLineComment> draft(Patch.Key patch, Account.Id author) throws OrmException; @Query("WHERE key.patchKey.patchSetId.changeId = ?" + " AND key.patchKey.fileName = ? AND author = ? AND status = '" + PatchLineComment.STATUS_DRAFT + "' ORDER BY lineNbr,writtenOn") ResultSet<PatchLineComment> draft(Change.Id id, String file, Account.Id author) throws OrmException; @Query("WHERE status = '" + PatchLineComment.STATUS_DRAFT + "' AND author = ?") ResultSet<PatchLineComment> draftByAuthor(Account.Id author) throws OrmException; }