Подтвердить что ты не робот

Как перечислить все файлы в репозитории в Mercurial (hg)?

Есть ли команда в mercurial, которая будет перечислять все файлы, находящиеся в настоящее время под контролем источника?

Я могу сделать dir /s, чтобы перечислить все файлы в моей папке и подпапках, но я понятия не имел, которые были добавлены в мой репозиторий. У меня есть множество исключенных типов файлов и папок, и я хочу проверить, что ни один из них не был добавлен до того, как я установил их в моем файле .hgignore.

4b9b3361

Ответ 1

hg status --all отобразит все файлы в дереве с буквой, обозначающей ее статус: M для изменения, C для очистки (принадлежит hg) и я для игнорирования.

Для только проигнорированных файлов используйте hg status -i. Для просто файлов, которые будут добавлены при следующем фиксации, используйте hg status -a. Они показывают только то, что вам нужно знать, и не требуют сканирования большого списка файлов.

Ответ 2

Вы также можете проверить команду hg locate. Я использую его вместе с опцией -I, когда я хочу ограничить файлы определенным каталогом.

Перечислить все файлы в вашем репозитории:

hg locate

Из каталога репозитория ( "root" ):

hg locate -I dir/sub_dir/dir_of_interest

Путь, переданный в -I, должен изменяться в зависимости от каталога, в котором вы запускаете команду. Если вы запустите команду из каталога dir в приведенном выше примере, вам нужно будет изменить свой аргумент, чтобы найти:

hg locate -I sub_dir/dir_of_interest

Список выходных файлов останется таким же, показывая полный путь к файлу в репозитории.

Попробуйте hg help -v locate для получения дополнительной информации.

Ответ 3

hg manifest будут перечислены только файлы в репозитории, а hg status --all отобразит все файлы в структуре репозитория и включит маркер, для которого отслеживаются, а какие нет.

Ответ 4

Листинг Только проигнорированные или добавленные файлы

Чтобы перечислить только файлы игнорируются, выполните: hg status -i.

Только для добавленных файлов выполните hg status -a.

Если вам не нравится печатать много, вы можете сократить их до hg sta -i и hg sta -a.

Эти два использования status более просты, чем locate, и предоставят вам конкретные состояния файлов, которые вас беспокоят, поэтому он значительно меньше подвержен ошибкам.

Подробнее о hg status

Чтобы перечислить все файлы в Mercurial repo, выполните следующие действия: hg status --all.

При их перечислении файлам будет предоставлен префикс:

  M = modified
  A = added
  R = removed
  C = clean
  ! = missing (deleted by non-hg command, but still tracked)
  ? = not tracked
  I = ignored

Если вы хотите перечислить только файлы в папке, вы можете указать путь:

  • hg st --all MyFolder - все файлы в MyFolder
  • hg sta -i MyFolder - просто проигнорированные файлы в MyFolder.

Как и -i для "Игнорируется" и -a для "Добавлен", доступны другие флаги, чтобы перечислять только файлы, имеющие определенный статус.

Получение help

Прочитайте другой очень полезный ответ здесь для подробного объяснения команды status. У него есть голоса, потому что автор попытался показать, что вы можете обнаружить все вышеперечисленное, запросив Mercurial о команде status следующим образом:

hg help status

Вы можете попросить Mercurial рассказать вам о каких-либо командах, подобных этому. И если вам нужен список команд Mercurial, введите hg help.

Ответ 5

C:\>hg help -v status
hg status [OPTION]... [FILE]...

aliases: st

show changed files in the working directory

    Show status of files in the repository. If names are given, only files
    that match are shown. Files that are clean or ignored or the source of a
    copy/move operation, are not listed unless -c/--clean, -i/--ignored,
    -C/--copies or -A/--all are given. Unless options described with "show
    only ..." are given, the options -mardu are used.

    Option -q/--quiet hides untracked (unknown and ignored) files unless
    explicitly requested with -u/--unknown or -i/--ignored.

    NOTE: status may appear to disagree with diff if permissions have changed
    or a merge has occurred. The standard diff format does not report
    permission changes and diff only reports changes relative to one merge
    parent.

    If one revision is given, it is used as the base revision. If two
    revisions are given, the differences between them are shown. The --change
    option can also be used as a shortcut to list the changed files of a
    revision from its first parent.

    The codes used to show the status of files are:

      M = modified
      A = added
      R = removed
      C = clean
      ! = missing (deleted by non-hg command, but still tracked)
      ? = not tracked
      I = ignored
        = origin of the previous file listed as A (added)

options:

 -A --all             show status of all files
 -m --modified        show only modified files
 -a --added           show only added files
 -r --removed         show only removed files
 -d --deleted         show only deleted (but tracked) files
 -c --clean           show only files without changes
 -u --unknown         show only unknown (not tracked) files
 -i --ignored         show only ignored files
 -n --no-status       hide status prefix
 -C --copies          show source of copied files
 -0 --print0          end filenames with NUL, for use with xargs
    --rev             show difference from revision
    --change          list the changed files of a revision
 -I --include         include names matching the given patterns
 -X --exclude         exclude names matching the given patterns

global options:
 -R --repository      repository root directory or name of overlay bundle file
    --cwd             change working directory
 -y --noninteractive  do not prompt, assume 'yes' for any required answers
 -q --quiet           suppress output
 -v --verbose         enable additional output
    --config          set/override config option (use 'section.name=value')
    --debug           enable debugging output
    --debugger        start debugger
    --encoding        set the charset encoding (default: cp1252)
    --encodingmode    set the charset encoding mode (default: strict)
    --traceback       always print a traceback on exception
    --time            time how long the command takes
    --profile         print command execution profile
    --version         output version information and exit
 -h --help            display help and exit