From 762212fabe7cd4d53431f99b3b9bc2357a935899 Mon Sep 17 00:00:00 2001 From: Abdelilah El Aissaoui Date: Wed, 17 May 2023 21:01:21 +0200 Subject: [PATCH] Stashes now show (unstaged) untracked files Fixes #88 --- .../viewmodels/CommitChangesViewModel.kt | 28 +++++++++++++++++-- .../gitnuro/viewmodels/MenuViewModel.kt | 1 - 2 files changed, 25 insertions(+), 4 deletions(-) diff --git a/src/main/kotlin/com/jetpackduba/gitnuro/viewmodels/CommitChangesViewModel.kt b/src/main/kotlin/com/jetpackduba/gitnuro/viewmodels/CommitChangesViewModel.kt index e8259d0..35fbd91 100644 --- a/src/main/kotlin/com/jetpackduba/gitnuro/viewmodels/CommitChangesViewModel.kt +++ b/src/main/kotlin/com/jetpackduba/gitnuro/viewmodels/CommitChangesViewModel.kt @@ -5,6 +5,7 @@ import androidx.compose.foundation.lazy.LazyListState import androidx.compose.ui.text.input.TextFieldValue import com.jetpackduba.gitnuro.extensions.delayedStateChange import com.jetpackduba.gitnuro.extensions.filePath +import com.jetpackduba.gitnuro.extensions.fullData import com.jetpackduba.gitnuro.extensions.lowercaseContains import com.jetpackduba.gitnuro.git.RefreshType import com.jetpackduba.gitnuro.git.TabState @@ -63,15 +64,36 @@ class CommitChangesViewModel @Inject constructor( // Check if it's a different commit before resetting everything if ( state is CommitChangesState.Loading || - state is CommitChangesState.Loaded && state.commit != commit + state is CommitChangesState.Loaded //&& state.commit != commit ) { delayedStateChange( delayMs = MIN_TIME_IN_MS_TO_SHOW_LOAD, onDelayTriggered = { _commitChangesState.value = CommitChangesState.Loading } ) { - val changes = getCommitDiffEntriesUseCase(git, commit) + val fullCommit = commit.fullData(git.repository) - _commitChangesState.value = CommitChangesState.Loaded(commit, changes, changes) + if (fullCommit != null) { + val changes = getCommitDiffEntriesUseCase(git, fullCommit).toMutableList() + + if (fullCommit.parentCount == 3) { + val untrackedFilesCommit = + fullCommit.parents?.firstOrNull { + val parentCommit = it.fullData(git.repository) ?: return@firstOrNull false + + parentCommit.fullMessage.startsWith("untracked files on") && parentCommit.parentCount == 0 + } + + if (untrackedFilesCommit != null) { + val untrackedFilesChanges = getCommitDiffEntriesUseCase(git, untrackedFilesCommit) + + if(untrackedFilesChanges.all { it.changeType == DiffEntry.ChangeType.ADD }) { // All files should be new + changes.addAll(untrackedFilesChanges) + } + } + } + + _commitChangesState.value = CommitChangesState.Loaded(commit, changes, changes) + } } _showSearch.value = false diff --git a/src/main/kotlin/com/jetpackduba/gitnuro/viewmodels/MenuViewModel.kt b/src/main/kotlin/com/jetpackduba/gitnuro/viewmodels/MenuViewModel.kt index 7645892..f753bcd 100644 --- a/src/main/kotlin/com/jetpackduba/gitnuro/viewmodels/MenuViewModel.kt +++ b/src/main/kotlin/com/jetpackduba/gitnuro/viewmodels/MenuViewModel.kt @@ -58,7 +58,6 @@ class MenuViewModel @Inject constructor( fun stash() = tabState.safeProcessing( refreshType = RefreshType.UNCOMMITED_CHANGES_AND_LOG, ) { git -> - stageUntrackedFileUseCase(git) stashChangesUseCase(git, null) }