É uma ótima pergunta, e eu estava procurando por algo assim também, mas tenho certeza de que não há nada como isso já incorporado ao Nautilus,
mas se você puder usar algum script, poderá adaptar o Nautilus file Notes
com relativa facilidade para fazer algo semelhante. Seria necessário algum script básico (+?).
Com file Notes
você pode adicionar notas a um diretório e também arquivos.
Seria uma simples questão de pesquisar no Tag por suas tags específicas e criar links temporários (ou permanentes) para cada diretório com uma tag correspondente no 'Notes' ... depois colocar esses links em uma pesquisa ' diretório de resultados ... que você apresentaria em uma janela do Nautilus! ...
Se eu tivesse tempo livre, eu mesmo o faria, mas, em vez disso, aqui está um script que escrevi para acessar, escrever e excluir o Nautilus Notes. Ele não faz o que descrevi acima, mas mostra como acessar o cache de dados do Notes . O script é destinado ao uso pornautilus-actions
O script está em pastbin.ubuntu.com
ATUALIZAÇÃO : Agora eu escrevi um script de trabalho que usa links como descrito acima. No entanto, agora troquei a idéia do "nautilus Notes" e enxertamos nos arquivos .tag do usuário desconhecido . (Então, se você gosta do script , lembre-se de que a idéia .tag é 'usuário desconhecido') .
Gosto de arquivos de texto simples (são simples, versáteis e muito fáceis de trabalhar)
que usei locate
como ferramenta de pesquisa, pois é ultrarrápida, mas é apenas tão atualizado quanto a última execução de updatedb
(que normalmente é diária, mas você pode executá-la a qualquer momento).
Tentei explicar o uso do script nos comentários, mas devo ressaltar que ele não foi totalmente testado, portanto pode se comportar mal em alguns pontos menores.
As únicas coisas que ele exclui / remove são o diretório temporário e os links de software contém ... Observe que a remoção de links flexíveis não remove os diretórios de destino / dados.
Aqui está o script
UPDATE2 : (corrigido um bug. Ele estava processando apenas os primeiros 100 arquivos .tag localizados)
#!/bin/bash
# Script: dirtags ...(by fred.bear)
#
# Summary: Open the file browser in a temporary directory
# which contains soft-links to directories whose
# '.tag' file contains the search string in $1
#
# .tag files are files you create in any directory which
# you wish to *tag*.
#
# .tag files are simple free form text, so you can
# put anything you like in them...
#
# The script uses `locate` to create a list of .tag file
# 'locate' is very fast, but because it depends on 'updatedb'
# for its list of current files, it can be a bit out of sync
# with a newly added .tag file... Modifying an existing
# .tag file does not effect `locate`
# To refresh the `locate` database, just run 'sudo updatedb'
# .. (updatedb typically auto-runs once a day, but you should check)
#
# Note: The search result soft links are put into a temporary directory
# This directory is removed each time you run the script
# TODO: allow saved searches (?) maybe
#
# Note: With nautilus, running the script a second time while
# the previoulsy opened wiondow is still open, cause the
# second window to open in its parent directory: /tmp/$USER
# ... but you can then just enter the 'dirtags' dir
# you see listed /tmp/$USER/$bname
# TODO: this probably happens because currently the
# directory is being removed each time the script
# is run... (related to "allow saved searches")
#
# A sample usage of this script:
#
# 1. Make a '.tag' file in each of several test directories.
# 2, For this first-time test, run 'sudo updatedb' so that the
# newly added .tag files are added to the 'locate's database
# 3. In each .tag file, put some tags (words or phrases to serch for)
# eg; action comedy drama good bad sci-fi documentary
# 4. Run this script with a single argument.. (a grep regex)
# eg "action|comedy"
#
function args_grep_links {
# $1 -- the grep regex
##echo grep -l '"'$1'"' ${tagged[@]}
< <(eval grep -l '$1' ${tagged[@]}) \
sed "s/^\(.*\)\/\.tag/ln -s \"\1\" $tagdbs/" \
>>"$tagdir"/.tag.slinks
##(gedit "$tagdir"/.tag.slinks &)
# make the soft links
source "$tagdir"/.tag.slinks
rm "$tagdir"/.tag.slinks
unset tagged
aix=
}
# Identity the script
bname="$(basename "$0")"
# Syntax
if [[ "$1" == "" ]] ; then
echo "ERROR: $bname requires one arg; a 'grep' regular expression string"
echo " eg: $bname \"music\" ......... Any instance of \"music\" .....(eg: \"musical\")"
echo " eg: $bname \"\<music\>\" ..... Only the word \"music\" ...(but not \"musical\")"
echo " eg: $bname \"muscic\|action\". Any instance of \"music\" or \"action\")"
exit 1
fi
# 'locate' the .tag files
# =======================
tagdir="/tmp/$USER/$bname"
tagdbs="${tagdir//\//\/}"
[[ -d "$tagdir" ]] && rm -rf "$tagdir" # remove all
[[ ! -d "$tagdir" ]] && mkdir -p "$tagdir" # fresh start
cp /dev/null "$tagdir"/.tag.slinks
unset tagged # array of .tag files
aix=0 # arg index
amax=10 # arg max per call to grep
fct=0 # file count
while IFS= read -r file ; do
tagged[$aix]="$file"
####echo ${tagged[aix]}
((aix++));((fct++))
(( aix == amax )) && args_grep_links "$1"
done < <(locate -ber ^\.tag$ |sed "s/.*/\"&\"/")
(( aix < amax )) && args_grep_links "$1"
sleep 1 # to allow time for rm to settle down after rm and adding links
xdg-open "$tagdir"
exit
#