mirror of
https://github.com/arsenetar/dupeguru.git
synced 2026-01-25 16:11:39 +00:00
Compare commits
240 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
a7eb90894a | ||
|
|
64baf2a10c | ||
|
|
392a802ef1 | ||
|
|
8efeab7b40 | ||
|
|
8a86ecee38 | ||
|
|
3e79b57409 | ||
|
|
362e020585 | ||
|
|
df5c8ddf22 | ||
|
|
70cc48d51f | ||
|
|
dccffd9516 | ||
|
|
04056c1597 | ||
|
|
69b2e37368 | ||
|
|
05478591a4 | ||
|
|
ead3b1e651 | ||
|
|
27f4c290c4 | ||
|
|
4f248ee981 | ||
|
|
d7397c0125 | ||
|
|
e4430168f7 | ||
|
|
78c2ae150d | ||
|
|
806e3917e3 | ||
|
|
6c62c2d563 | ||
|
|
7a768bd0e6 | ||
|
|
a6c01f6868 | ||
|
|
721591d3e3 | ||
|
|
1171705921 | ||
|
|
65d2581f74 | ||
|
|
2128d1787a | ||
|
|
cbf2ab82ce | ||
|
|
adef5a9dfa | ||
|
|
0c9e5c90a3 | ||
|
|
787f546c17 | ||
|
|
2d4ecf1122 | ||
|
|
1836003506 | ||
|
|
44d34f56f7 | ||
|
|
24c3d7ed00 | ||
|
|
8f7657573d | ||
|
|
c03c7f2be1 | ||
|
|
91a157cb2b | ||
|
|
7ced1e7b9d | ||
|
|
f4b8efff50 | ||
|
|
4c0545189e | ||
|
|
21af7b2fcd | ||
|
|
df9af9a796 | ||
|
|
933474400c | ||
|
|
b2c8e779bd | ||
|
|
e570a308bb | ||
|
|
69c01a658b | ||
|
|
0741cbe17b | ||
|
|
ad4ccfe347 | ||
|
|
57375f83f6 | ||
|
|
2d75ffefa7 | ||
|
|
87aa181e4b | ||
|
|
1f359e0391 | ||
|
|
c8af8ccc61 | ||
|
|
2daaaee893 | ||
|
|
03712860b1 | ||
|
|
9e1f79c152 | ||
|
|
edc385cfbc | ||
|
|
0f62917b55 | ||
|
|
515c195780 | ||
|
|
c63df97dd6 | ||
|
|
1f312d8532 | ||
|
|
fa547bb95e | ||
|
|
b500b34ef1 | ||
|
|
23cb71b522 | ||
|
|
720d2fce83 | ||
|
|
97f447fc27 | ||
|
|
6ee56dc55c | ||
|
|
771f22f208 | ||
|
|
80ff5f64f7 | ||
|
|
d0bfa2a6ca | ||
|
|
04a547656e | ||
|
|
657f6743c2 | ||
|
|
42b57431e0 | ||
|
|
3fc83d6245 | ||
|
|
ae16845477 | ||
|
|
49a7043b4d | ||
|
|
878c744c21 | ||
|
|
b4b9393e14 | ||
|
|
bf17eb715a | ||
|
|
cd9f54163b | ||
|
|
ef0a66f794 | ||
|
|
5fb7742cf4 | ||
|
|
22de2d803a | ||
|
|
188aa4bf2e | ||
|
|
05552c160c | ||
|
|
dd70bd6d41 | ||
|
|
70f88ba39c | ||
|
|
496f29b5c3 | ||
|
|
b0818f2bdf | ||
|
|
e0efd660f6 | ||
|
|
4592000464 | ||
|
|
93781a0f35 | ||
|
|
7dfb42fb41 | ||
|
|
a1fc64cd36 | ||
|
|
b12b70b0a1 | ||
|
|
9457a43993 | ||
|
|
ab201bfae0 | ||
|
|
66204ff0b5 | ||
|
|
95f77aef3f | ||
|
|
1e96b6f9c4 | ||
|
|
f813673d6c | ||
|
|
1da325a56b | ||
|
|
d885bf0b18 | ||
|
|
5f7e7fbb13 | ||
|
|
757f8569e6 | ||
|
|
bf86f56371 | ||
|
|
7d0948cd23 | ||
|
|
c4824b0f16 | ||
|
|
ea32af04fb | ||
|
|
e519e41e42 | ||
|
|
c937f2b20f | ||
|
|
fc477ab3b5 | ||
|
|
c53ddcdee1 | ||
|
|
9e668b11b8 | ||
|
|
f53a4c261c | ||
|
|
9a2554d24e | ||
|
|
b9ac135b89 | ||
|
|
235d3ae521 | ||
|
|
a487e83f3c | ||
|
|
4aaff8ffb1 | ||
|
|
302050b2d6 | ||
|
|
1b571f6fd2 | ||
|
|
baa2177439 | ||
|
|
29796e87b7 | ||
|
|
017e483b5a | ||
|
|
7a167208d0 | ||
|
|
475f2c7238 | ||
|
|
9392f818cc | ||
|
|
58347bc36f | ||
|
|
55db21f3e0 | ||
|
|
950cd0c341 | ||
|
|
937ea73c87 | ||
|
|
7bce70c128 | ||
|
|
f9ced08e6d | ||
|
|
4c8ce4b52d | ||
|
|
0d78201548 | ||
|
|
45d4915d88 | ||
|
|
a699a2ef45 | ||
|
|
f6dd1a6a42 | ||
|
|
e6819781f6 | ||
|
|
12467c9493 | ||
|
|
0c7d73854d | ||
|
|
a7eeb7db89 | ||
|
|
989026051c | ||
|
|
56fd94e205 | ||
|
|
c8e00cf0f7 | ||
|
|
0cca745d0d | ||
|
|
80043ccbea | ||
|
|
d62bfac95e | ||
|
|
f636333938 | ||
|
|
01f1e5e46e | ||
|
|
7ce72b1998 | ||
|
|
c4f95a4901 | ||
|
|
5b0d9f311c | ||
|
|
11d8f824e9 | ||
|
|
ceaf2ee4ba | ||
|
|
3b80de869a | ||
|
|
08813ce39c | ||
|
|
478f462ecc | ||
|
|
be53b6de76 | ||
|
|
ca602480d9 | ||
|
|
185cdbb6fa | ||
|
|
2d4903da26 | ||
|
|
98954bd582 | ||
|
|
f862f32fb4 | ||
|
|
804a5a1bbf | ||
|
|
f004535820 | ||
|
|
2abd932709 | ||
|
|
2a78b8ce41 | ||
|
|
2301082307 | ||
|
|
168546608d | ||
|
|
27c1a03496 | ||
|
|
d382cec0fe | ||
|
|
c5b7f6b3d5 | ||
|
|
725f9d51db | ||
|
|
b4815d91c7 | ||
|
|
28e5924633 | ||
|
|
66303a2076 | ||
|
|
d3918724c0 | ||
|
|
fa294ea142 | ||
|
|
565c58b3a9 | ||
|
|
d8970ca6b4 | ||
|
|
1b7068bfe9 | ||
|
|
756190cb8e | ||
|
|
3342b32882 | ||
|
|
561b469e41 | ||
|
|
69fbda5d2c | ||
|
|
63180eaa5b | ||
|
|
25faa458b9 | ||
|
|
760e4085fa | ||
|
|
fbe66d27c9 | ||
|
|
08fd17f208 | ||
|
|
f8af6dbd18 | ||
|
|
54d6fb080c | ||
|
|
8409a01bcc | ||
|
|
1e136d2703 | ||
|
|
25afe54be3 | ||
|
|
d9ae967439 | ||
|
|
9226a4fb7c | ||
|
|
fc5a0d914b | ||
|
|
fca66d5108 | ||
|
|
0571151c5f | ||
|
|
7e95404903 | ||
|
|
eb83b830df | ||
|
|
0b1bf79796 | ||
|
|
6ab074decb | ||
|
|
b7462f1d17 | ||
|
|
a2a8397e78 | ||
|
|
5c0d9411e5 | ||
|
|
cd2afeb32b | ||
|
|
b2fd022d07 | ||
|
|
878046b579 | ||
|
|
428a400848 | ||
|
|
8aa5826080 | ||
|
|
6b5d1e9894 | ||
|
|
07a6a37502 | ||
|
|
dd0af2fe15 | ||
|
|
df6d7141f1 | ||
|
|
81d4cdde33 | ||
|
|
88a613268d | ||
|
|
b7aa4a1ad8 | ||
|
|
6c75d3afdf | ||
|
|
771f26ba0f | ||
|
|
30676fd20b | ||
|
|
607433d918 | ||
|
|
29db39f144 | ||
|
|
49e49d5e1a | ||
|
|
b9b84c9b7d | ||
|
|
d80a56db78 | ||
|
|
036026d64a | ||
|
|
13ef2fae90 | ||
|
|
54731e4ba0 | ||
|
|
aa341bc5ed | ||
|
|
4426f924e2 | ||
|
|
a6deb04049 | ||
|
|
806d6be36c | ||
|
|
152a8772da | ||
|
|
5885ead5ab | ||
|
|
6fc5ce4bad |
18
.hgignore
18
.hgignore
@@ -4,7 +4,9 @@ syntax: glob
|
|||||||
run.py
|
run.py
|
||||||
*.pyc
|
*.pyc
|
||||||
*.so
|
*.so
|
||||||
|
*.mo
|
||||||
*.pyd
|
*.pyd
|
||||||
|
.tm_*
|
||||||
*.xcodeproj/xcuserdata
|
*.xcodeproj/xcuserdata
|
||||||
*.xcodeproj/project.xcworkspace/xcuserdata
|
*.xcodeproj/project.xcworkspace/xcuserdata
|
||||||
conf.json
|
conf.json
|
||||||
@@ -12,16 +14,24 @@ build
|
|||||||
dist
|
dist
|
||||||
install
|
install
|
||||||
installer_tmp-cache
|
installer_tmp-cache
|
||||||
|
cocoa/autogen
|
||||||
cocoa/*/Info.plist
|
cocoa/*/Info.plist
|
||||||
cocoa/*/build
|
cocoa/*/build
|
||||||
|
cocoa/*/*.app
|
||||||
cocoa/*/dg_cocoa.plugin
|
cocoa/*/dg_cocoa.plugin
|
||||||
cocoa/*/fr.lproj/*.xib
|
cocoa/*/fr.lproj/*.xib
|
||||||
cocoa/*/de.lproj/*.xib
|
cocoa/*/de.lproj/*.xib
|
||||||
cocoa/*/zh_CN.lproj/*.xib
|
cocoa/*/zh_CN.lproj/*.xib
|
||||||
|
cocoa/*/cs.lproj/*.xib
|
||||||
|
cocoa/*/it.lproj/*.xib
|
||||||
|
cs.lproj
|
||||||
|
de.lproj
|
||||||
|
fr.lproj
|
||||||
|
it.lproj
|
||||||
|
hy.lproj
|
||||||
|
ru.lproj
|
||||||
|
uk.lproj
|
||||||
|
zh_CN.lproj
|
||||||
qt/base/*_rc.py
|
qt/base/*_rc.py
|
||||||
qt/lang/fr.qm
|
|
||||||
qt/lang/en.qm
|
|
||||||
qt/lang/de.qm
|
|
||||||
qt/lang/zh.qm
|
|
||||||
help/*/conf.py
|
help/*/conf.py
|
||||||
help/*/changelog.rst
|
help/*/changelog.rst
|
||||||
19
.hgtags
19
.hgtags
@@ -57,3 +57,22 @@ e62183e907d6177cf0bac354e31afa9546c199e6 se3.1.2
|
|||||||
383b14d6e8555ed2c8d5552259bc7ce600dfb1d0 before-leopard-drop
|
383b14d6e8555ed2c8d5552259bc7ce600dfb1d0 before-leopard-drop
|
||||||
a2f7b7302e178f08725a6404ddc28464409510b1 se3.2.0
|
a2f7b7302e178f08725a6404ddc28464409510b1 se3.2.0
|
||||||
5a5134a4fa9bb7ca80ae3e32010030f5bd7ba434 me6.1.0
|
5a5134a4fa9bb7ca80ae3e32010030f5bd7ba434 me6.1.0
|
||||||
|
0fd77be57ff716d5c93232e829dc02acec036d7c se3.2.1
|
||||||
|
3dd08060135b0b9cef70b6f5a81f191ea339c8d5 me6.1.1
|
||||||
|
4e6cbef6bcdfcc0e56ff9690fbfe1cac1f4b1b09 pe2.3.0
|
||||||
|
9ea9af1b886cd1adc4f42fd2276cc2b38376eab0 se3.3.0
|
||||||
|
6e3379be6821bb36d7f0877a17dd6c07aa037b0a se3.3.1
|
||||||
|
015ba7e2c10d09afb944f387c2a9c97f7eff7571 me6.2.0
|
||||||
|
8178bda48324461a17118c98634241952c074f29 pe2.4.0
|
||||||
|
2a96f2fb3ddb6f1e0ae87951586733fc3e4a28a0 se3.3.2
|
||||||
|
6a08c1205dfe5e537e5c2dc99d05e05d1d3928f6 me6.2.1
|
||||||
|
a619f313712e2923160b8f90d8250ee0e184c7b9 pe2.4.1
|
||||||
|
fad463ae749b7189dce92f1e42a57ac4ee03987d se3.3.3
|
||||||
|
236cf9b690a144392e7e86e7c9749fc834a8b271 me6.3.0
|
||||||
|
90318f1303858d9d01065d92d78d98b888b38ea0 se3.4.0
|
||||||
|
93ed33410df2d2f21229a77ae49c83ece2c50a55 pe2.5.0
|
||||||
|
c153aef25e5c9911f2197d13899591c50cf38ffc se3.4.1
|
||||||
|
71b7e18613f3790cea18cb0dd8c9c986ce237267 me6.3.1
|
||||||
|
c3d9f91dc9c9d60f370c72bc211f09be3e4fc18d se3.5.0
|
||||||
|
254bce83ad6e56c102d69fd603f6845e2324b470 me6.4.0
|
||||||
|
e772f1de86744999ffbbe5845554417965b1dfba me6.4.1
|
||||||
|
|||||||
2
LICENSE
2
LICENSE
@@ -1,4 +1,4 @@
|
|||||||
Copyright 2011 Hardcoded Software Inc. (http://www.hardcoded.net)
|
Copyright 2012 Hardcoded Software Inc. (http://www.hardcoded.net)
|
||||||
All rights reserved.
|
All rights reserved.
|
||||||
|
|
||||||
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
|
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
|
||||||
|
|||||||
40
README
40
README
@@ -29,21 +29,18 @@ General dependencies
|
|||||||
- Python 3.2 (http://www.python.org)
|
- Python 3.2 (http://www.python.org)
|
||||||
- Send2Trash3k (http://hg.hardcoded.net/send2trash)
|
- Send2Trash3k (http://hg.hardcoded.net/send2trash)
|
||||||
- hsaudiotag3k 1.1.0 (for ME) (http://hg.hardcoded.net/hsaudiotag)
|
- hsaudiotag3k 1.1.0 (for ME) (http://hg.hardcoded.net/hsaudiotag)
|
||||||
- jobprogress 1.0.2 (http://hg.hardcoded.net/jobprogress)
|
- jobprogress 1.0.3 (http://hg.hardcoded.net/jobprogress)
|
||||||
- Sphinx 1.0.7 (http://sphinx.pocoo.org/)
|
- Sphinx 1.1 (http://sphinx.pocoo.org/)
|
||||||
|
- polib 0.7.0 (http://bitbucket.org/izi/polib)
|
||||||
- pytest 2.0.0, to run unit tests. (http://pytest.org/)
|
- pytest 2.0.0, to run unit tests. (http://pytest.org/)
|
||||||
|
|
||||||
Note: Sphinx doesn't officially support Python 3.x yet, but it doesn't matter because it is invoked
|
|
||||||
by the build system through command line, so you can build dupeGuru even if Sphinx is installed in
|
|
||||||
your Python 2.x install.
|
|
||||||
|
|
||||||
OS X prerequisites
|
OS X prerequisites
|
||||||
------------------
|
------------------
|
||||||
|
|
||||||
- XCode 4.1
|
- XCode 4.1
|
||||||
- Sparkle (http://sparkle.andymatuschak.org/)
|
- Sparkle (http://sparkle.andymatuschak.org/)
|
||||||
- PyObjC 2.3 (http://pyobjc.sourceforge.net/)
|
- objp 1.1.0 (http://bitbucket.org/hsoft/objp)
|
||||||
- pluginbuilder 1.0.1 (http://bitbucket.org/hsoft/pluginbuilder)
|
- pluginbuilder 1.1.0 (http://bitbucket.org/hsoft/pluginbuilder)
|
||||||
- appscript 1.0.0 for ME and PE (http://appscript.sourceforge.net/)
|
- appscript 1.0.0 for ME and PE (http://appscript.sourceforge.net/)
|
||||||
|
|
||||||
Windows prerequisites
|
Windows prerequisites
|
||||||
@@ -67,8 +64,7 @@ There's an easy way to install the majority of the prerequisites above, and it's
|
|||||||
pip install -r requirements-[osx|win].txt
|
pip install -r requirements-[osx|win].txt
|
||||||
|
|
||||||
([osx|win] depends, of course, on your platform. On other platforms, just use requirements.txt).
|
([osx|win] depends, of course, on your platform. On other platforms, just use requirements.txt).
|
||||||
Because Sphinx doesn't support Python 3 yet, it's not in the requirements file and you'll have to
|
You might have to compile PyObjC manually (see gotchas below). Sparkle and
|
||||||
install it manually. You might have to compile PyObjC manually too (see gotchas below). Sparkle and
|
|
||||||
Advanced Installer, having nothing to do with Python, are also manual installs.
|
Advanced Installer, having nothing to do with Python, are also manual installs.
|
||||||
|
|
||||||
PyQt isn't in the requirements file either (there's no package uploaded on PyPI) and you also have
|
PyQt isn't in the requirements file either (there's no package uploaded on PyPI) and you also have
|
||||||
@@ -84,32 +80,16 @@ If you didn't use mercurial to download this source, you probably have an incomp
|
|||||||
External projects (hscommon, qtlib, cocoalib) need to be at the root of the dupeGuru project folder.
|
External projects (hscommon, qtlib, cocoalib) need to be at the root of the dupeGuru project folder.
|
||||||
You'll have to download those separately. Or use mercurial, it's much easier.
|
You'll have to download those separately. Or use mercurial, it's much easier.
|
||||||
|
|
||||||
As far as I can tell, you don't *have* to compile/install everything manually and you can normally
|
|
||||||
use `easy_install` to install python dependencies. However, be aware that compiling/installing
|
|
||||||
manually from the repositories of each project is what I personally do, so if you hit a snag
|
|
||||||
somewhere, you might want to try the manual way.
|
|
||||||
|
|
||||||
PyObjC's website is badly outdated. Also, as far as I can tell, the package installable with
|
|
||||||
`easy_install` has good chances of not working. Your best bet is to download the latest tagged
|
|
||||||
version from the repository and compile it from source.
|
|
||||||
|
|
||||||
Also, on OS X, don't try to use the built-in python 2.x to install Sphinx on (the only pre-requisite
|
|
||||||
that doesn't run on python 3 yet). There's some weird error popping up when dupeGuru tries to build
|
|
||||||
its help file. Install your own framework version of python 2.7, and then install Sphinx on that.
|
|
||||||
When Sphinx supports Python 3, things will be easier because you'll be able to install sphinx on the
|
|
||||||
same Python version you build dupeGuru with.
|
|
||||||
|
|
||||||
Another one on OS X: I wouldn't use macports/fink/whatever. Whenever I tried using those, I always
|
Another one on OS X: I wouldn't use macports/fink/whatever. Whenever I tried using those, I always
|
||||||
ended up with problems.
|
ended up with problems.
|
||||||
|
|
||||||
On OSX Lion, for dupeGuru PE, make sure that you installed the latest version of macholib because there was a
|
|
||||||
10.7 related bug that was fixed recently. Right now, the fix hasn't even been released yet so you
|
|
||||||
have to install directly from the repo ( http://bitbucket.org/ronaldoussoren/macholib ). The fix
|
|
||||||
in question is at http://bitbucket.org/ronaldoussoren/macholib/changeset/4ab0de0f5b60
|
|
||||||
|
|
||||||
Whenever you have a problem, always double-check that you're running the correct python version.
|
Whenever you have a problem, always double-check that you're running the correct python version.
|
||||||
You'll probably have to tweak your $PATH.
|
You'll probably have to tweak your $PATH.
|
||||||
|
|
||||||
|
To setup a build machine under Ubuntu 12.04 and up, install those packages: python3-dev, python3-pyqt4,
|
||||||
|
pyqt4-dev-tools, mercurial and then python3-setuptools. Once you've done that, install pip with
|
||||||
|
`easy_install`. Once you've done that, you can then perform "The easy way!" installation.
|
||||||
|
|
||||||
Building dupeGuru
|
Building dupeGuru
|
||||||
=================
|
=================
|
||||||
|
|
||||||
|
|||||||
208
build.py
208
build.py
@@ -1,23 +1,26 @@
|
|||||||
# Created By: Virgil Dupras
|
# Created By: Virgil Dupras
|
||||||
# Created On: 2009-12-30
|
# Created On: 2009-12-30
|
||||||
# Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
# Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
#
|
#
|
||||||
# This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
# This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
# which should be included with this package. The terms are also available at
|
# which should be included with this package. The terms are also available at
|
||||||
# http://www.hardcoded.net/licenses/bsd_license
|
# http://www.hardcoded.net/licenses/bsd_license
|
||||||
|
|
||||||
|
import sys
|
||||||
import os
|
import os
|
||||||
import os.path as op
|
import os.path as op
|
||||||
from optparse import OptionParser
|
from optparse import OptionParser
|
||||||
import shutil
|
import shutil
|
||||||
import json
|
import json
|
||||||
|
import importlib
|
||||||
|
|
||||||
from setuptools import setup
|
from setuptools import setup, Extension
|
||||||
from distutils.extension import Extension
|
|
||||||
|
|
||||||
from hscommon import sphinxgen
|
from hscommon import sphinxgen
|
||||||
from hscommon.build import (add_to_pythonpath, print_and_do, copy_packages, filereplace,
|
from hscommon.build import (add_to_pythonpath, print_and_do, copy_packages, filereplace,
|
||||||
get_module_version, build_all_cocoa_locs, build_all_qt_locs)
|
get_module_version, build_all_cocoa_locs, move_all, copy_sysconfig_files_for_embed, copy_all,
|
||||||
|
move)
|
||||||
|
from hscommon import loc
|
||||||
|
|
||||||
def parse_args():
|
def parse_args():
|
||||||
usage = "usage: %prog [options]"
|
usage = "usage: %prog [options]"
|
||||||
@@ -28,37 +31,42 @@ def parse_args():
|
|||||||
help="Build only the help file")
|
help="Build only the help file")
|
||||||
parser.add_option('--loc', action='store_true', dest='loc',
|
parser.add_option('--loc', action='store_true', dest='loc',
|
||||||
help="Build only localization")
|
help="Build only localization")
|
||||||
|
parser.add_option('--cocoamod', action='store_true', dest='cocoamod',
|
||||||
|
help="Build only Cocoa modules")
|
||||||
|
parser.add_option('--updatepot', action='store_true', dest='updatepot',
|
||||||
|
help="Generate .pot files from source code.")
|
||||||
|
parser.add_option('--mergepot', action='store_true', dest='mergepot',
|
||||||
|
help="Update all .po files based on .pot files.")
|
||||||
(options, args) = parser.parse_args()
|
(options, args) = parser.parse_args()
|
||||||
return options
|
return options
|
||||||
|
|
||||||
def build_cocoa(edition, dev):
|
def build_cocoa(edition, dev):
|
||||||
from pluginbuilder import build_plugin
|
build_cocoa_proxy_module()
|
||||||
print("Building dg_cocoa.plugin")
|
build_cocoa_bridging_interfaces(edition)
|
||||||
if dev:
|
print("Building the cocoa layer")
|
||||||
tocopy = ['cocoa/inter']
|
from pluginbuilder import copy_embeddable_python_dylib, get_python_header_folder, collect_dependencies
|
||||||
else:
|
copy_embeddable_python_dylib('build')
|
||||||
specific_packages = {
|
if not op.exists('build/PythonHeaders'):
|
||||||
'se': ['core_se'],
|
os.symlink(get_python_header_folder(), 'build/PythonHeaders')
|
||||||
'me': ['core_me'],
|
if not op.exists('build/py'):
|
||||||
'pe': ['core_pe'],
|
os.mkdir('build/py')
|
||||||
}[edition]
|
|
||||||
tocopy = ['core', 'hscommon', 'cocoa/inter'] + specific_packages
|
|
||||||
copy_packages(tocopy, 'build')
|
|
||||||
cocoa_project_path = 'cocoa/{0}'.format(edition)
|
cocoa_project_path = 'cocoa/{0}'.format(edition)
|
||||||
shutil.copy(op.join(cocoa_project_path, 'dg_cocoa.py'), 'build')
|
shutil.copy(op.join(cocoa_project_path, 'dg_cocoa.py'), 'build')
|
||||||
os.chdir('build')
|
specific_packages = {
|
||||||
# We have to exclude PyQt4 specifically because it's conditionally imported in hscommon.trans
|
'se': ['core_se'],
|
||||||
build_plugin('dg_cocoa.py', excludes=['PyQt4'], alias=dev)
|
'me': ['core_me'],
|
||||||
os.chdir('..')
|
'pe': ['core_pe'],
|
||||||
pluginpath = op.join(cocoa_project_path, 'dg_cocoa.plugin')
|
}[edition]
|
||||||
if op.exists(pluginpath):
|
tocopy = ['core', 'hscommon', 'cocoa/inter', 'cocoalib/cocoa'] + specific_packages
|
||||||
shutil.rmtree(pluginpath)
|
copy_packages(tocopy, 'build')
|
||||||
shutil.move('build/dist/dg_cocoa.plugin', pluginpath)
|
sys.path.insert(0, 'build')
|
||||||
|
collect_dependencies('build/dg_cocoa.py', 'build/py', excludes=['PyQt4'])
|
||||||
|
del sys.path[0]
|
||||||
if dev:
|
if dev:
|
||||||
# In alias mode, the tweakings we do to the pythonpath aren't counted in. We have to
|
copy_packages(tocopy, 'build/py', create_links=True)
|
||||||
# manually put a .pth in the plugin
|
# Views are not referenced by python code, so they're not found by the collector.
|
||||||
pthpath = op.join(pluginpath, 'Contents/Resources/dev.pth')
|
copy_all('build/inter/*.so', 'build/py/inter')
|
||||||
open(pthpath, 'w').write(op.abspath('.'))
|
copy_sysconfig_files_for_embed('build/py')
|
||||||
os.chdir(cocoa_project_path)
|
os.chdir(cocoa_project_path)
|
||||||
print('Generating Info.plist')
|
print('Generating Info.plist')
|
||||||
app_version = get_module_version('core_{}'.format(edition))
|
app_version = get_module_version('core_{}'.format(edition))
|
||||||
@@ -73,12 +81,11 @@ def build_cocoa(edition, dev):
|
|||||||
os.system('xcodebuild {0}'.format(args))
|
os.system('xcodebuild {0}'.format(args))
|
||||||
os.chdir('../..')
|
os.chdir('../..')
|
||||||
print("Creating the run.py file")
|
print("Creating the run.py file")
|
||||||
subfolder = 'dev' if dev else 'release'
|
|
||||||
app_path = {
|
app_path = {
|
||||||
'se': 'cocoa/se/build/{0}/dupeGuru.app',
|
'se': 'cocoa/se/dupeGuru.app',
|
||||||
'me': 'cocoa/me/build/{0}/dupeGuru\\ ME.app',
|
'me': 'cocoa/me/dupeGuru\\ ME.app',
|
||||||
'pe': 'cocoa/pe/build/{0}/dupeGuru\\ PE.app',
|
'pe': 'cocoa/pe/dupeGuru\\ PE.app',
|
||||||
}[edition].format(subfolder)
|
}[edition]
|
||||||
tmpl = open('run_template_cocoa.py', 'rt').read()
|
tmpl = open('run_template_cocoa.py', 'rt').read()
|
||||||
run_contents = tmpl.replace('{{app_path}}', app_path)
|
run_contents = tmpl.replace('{{app_path}}', app_path)
|
||||||
open('run.py', 'wt').write(run_contents)
|
open('run.py', 'wt').write(run_contents)
|
||||||
@@ -100,28 +107,122 @@ def build_help(edition):
|
|||||||
tixurl = "https://hardcoded.lighthouseapp.com/projects/31699-dupeguru/tickets/{0}"
|
tixurl = "https://hardcoded.lighthouseapp.com/projects/31699-dupeguru/tickets/{0}"
|
||||||
appname = {'se': 'dupeGuru', 'me': 'dupeGuru Music Edition', 'pe': 'dupeGuru Picture Edition'}[edition]
|
appname = {'se': 'dupeGuru', 'me': 'dupeGuru Music Edition', 'pe': 'dupeGuru Picture Edition'}[edition]
|
||||||
homepage = 'http://www.hardcoded.net/dupeguru{}/'.format('_' + edition if edition != 'se' else '')
|
homepage = 'http://www.hardcoded.net/dupeguru{}/'.format('_' + edition if edition != 'se' else '')
|
||||||
confrepl = {'edition': edition, 'appname': appname, 'homepage': homepage}
|
confrepl = {'edition': edition, 'appname': appname, 'homepage': homepage, 'language': 'en'}
|
||||||
sphinxgen.gen(help_basepath, help_destpath, changelog_path, tixurl, confrepl)
|
changelogtmpl = op.join(current_path, 'help', 'changelog.tmpl')
|
||||||
|
conftmpl = op.join(current_path, 'help', 'conf.tmpl')
|
||||||
|
sphinxgen.gen(help_basepath, help_destpath, changelog_path, tixurl, confrepl, conftmpl, changelogtmpl)
|
||||||
|
|
||||||
def build_localizations(ui, edition):
|
def build_localizations(ui, edition):
|
||||||
print("Building localizations")
|
print("Building localizations")
|
||||||
|
loc.compile_all_po('locale')
|
||||||
|
loc.compile_all_po(op.join('hscommon', 'locale'))
|
||||||
|
loc.merge_locale_dir(op.join('hscommon', 'locale'), 'locale')
|
||||||
if ui == 'cocoa':
|
if ui == 'cocoa':
|
||||||
|
print("Creating lproj folders based on .po files")
|
||||||
|
for lang in loc.get_langs('locale'):
|
||||||
|
if lang == 'en':
|
||||||
|
continue
|
||||||
|
pofile = op.join('locale', lang, 'LC_MESSAGES', 'ui.po')
|
||||||
|
for edition_folder in ['base', 'se', 'me', 'pe']:
|
||||||
|
enlproj = op.join('cocoa', edition_folder, 'en.lproj')
|
||||||
|
dest_lproj = op.join('cocoa', edition_folder, lang + '.lproj')
|
||||||
|
loc.po2allxibstrings(pofile, enlproj, dest_lproj)
|
||||||
|
if edition_folder == 'base':
|
||||||
|
loc.po2strings(pofile, op.join(enlproj, 'Localizable.strings'), op.join(dest_lproj, 'Localizable.strings'))
|
||||||
|
pofile = op.join('cocoalib', 'locale', lang, 'LC_MESSAGES', 'cocoalib.po')
|
||||||
|
loc.po2allxibstrings(pofile, op.join('cocoalib', 'en.lproj'), op.join('cocoalib', lang + '.lproj'))
|
||||||
build_all_cocoa_locs('cocoalib')
|
build_all_cocoa_locs('cocoalib')
|
||||||
build_all_cocoa_locs(op.join('cocoa', 'base'))
|
build_all_cocoa_locs(op.join('cocoa', 'base'))
|
||||||
build_all_cocoa_locs(op.join('cocoa', edition))
|
build_all_cocoa_locs(op.join('cocoa', edition))
|
||||||
elif ui == 'qt':
|
elif ui == 'qt':
|
||||||
print("Building .ts files")
|
loc.compile_all_po(op.join('qtlib', 'locale'))
|
||||||
build_all_qt_locs(op.join('qt', 'lang'), extradirs=[op.join('qtlib', 'lang')])
|
loc.merge_locale_dir(op.join('qtlib', 'locale'), 'locale')
|
||||||
|
if op.exists(op.join('build', 'locale')):
|
||||||
|
shutil.rmtree(op.join('build', 'locale'))
|
||||||
|
shutil.copytree('locale', op.join('build', 'locale'), ignore=shutil.ignore_patterns('*.po', '*.pot'))
|
||||||
|
|
||||||
|
def build_updatepot():
|
||||||
|
print("Building .pot files from source files")
|
||||||
|
print("Building core.pot")
|
||||||
|
all_cores = ['core', 'core_se', 'core_me', 'core_pe']
|
||||||
|
loc.generate_pot(all_cores, op.join('locale', 'core.pot'), ['tr'])
|
||||||
|
print("Building columns.pot")
|
||||||
|
loc.generate_pot(all_cores, op.join('locale', 'columns.pot'), ['coltr'])
|
||||||
|
print("Building ui.pot")
|
||||||
|
ui_packages = ['qt', op.join('cocoa', 'inter')]
|
||||||
|
loc.generate_pot(ui_packages, op.join('locale', 'ui.pot'), ['tr'])
|
||||||
|
print("Building hscommon.pot")
|
||||||
|
loc.generate_pot(['hscommon'], op.join('hscommon', 'locale', 'hscommon.pot'), ['tr'])
|
||||||
|
print("Building qtlib.pot")
|
||||||
|
loc.generate_pot(['qtlib'], op.join('qtlib', 'locale', 'qtlib.pot'), ['tr'])
|
||||||
|
print("Building cocoalib.pot")
|
||||||
|
loc.allstrings2pot(op.join('cocoalib', 'en.lproj'), op.join('cocoalib', 'locale', 'cocoalib.pot'))
|
||||||
|
print("Enhancing ui.pot with Cocoa's strings files")
|
||||||
|
loc.allstrings2pot(op.join('cocoa', 'base', 'en.lproj'), op.join('locale', 'ui.pot'),
|
||||||
|
excludes={'core', 'message', 'columns'})
|
||||||
|
loc.allstrings2pot(op.join('cocoa', 'se', 'en.lproj'), op.join('locale', 'ui.pot'))
|
||||||
|
loc.allstrings2pot(op.join('cocoa', 'me', 'en.lproj'), op.join('locale', 'ui.pot'))
|
||||||
|
loc.allstrings2pot(op.join('cocoa', 'pe', 'en.lproj'), op.join('locale', 'ui.pot'))
|
||||||
|
|
||||||
|
def build_mergepot():
|
||||||
|
print("Updating .po files using .pot files")
|
||||||
|
loc.merge_pots_into_pos('locale')
|
||||||
|
loc.merge_pots_into_pos(op.join('hscommon', 'locale'))
|
||||||
|
loc.merge_pots_into_pos(op.join('qtlib', 'locale'))
|
||||||
|
loc.merge_pots_into_pos(op.join('cocoalib', 'locale'))
|
||||||
|
|
||||||
|
def build_cocoa_ext(extname, dest, source_files, extra_frameworks=(), extra_includes=()):
|
||||||
|
extra_link_args = ["-framework", "CoreFoundation", "-framework", "Foundation"]
|
||||||
|
for extra in extra_frameworks:
|
||||||
|
extra_link_args += ['-framework', extra]
|
||||||
|
ext = Extension(extname, source_files, extra_link_args=extra_link_args, include_dirs=extra_includes)
|
||||||
|
setup(script_args=['build_ext', '--inplace'], ext_modules=[ext])
|
||||||
|
fn = extname + '.so'
|
||||||
|
assert op.exists(fn)
|
||||||
|
move(fn, op.join(dest, fn))
|
||||||
|
|
||||||
|
def build_cocoa_proxy_module():
|
||||||
|
print("Building Cocoa Proxy")
|
||||||
|
import objp.p2o
|
||||||
|
objp.p2o.generate_python_proxy_code('cocoalib/cocoa/CocoaProxy.h', 'build/CocoaProxy.m')
|
||||||
|
build_cocoa_ext("CocoaProxy", 'cocoalib/cocoa',
|
||||||
|
['cocoalib/cocoa/CocoaProxy.m', 'build/CocoaProxy.m', 'build/ObjP.m', 'cocoalib/HSErrorReportWindow.m'],
|
||||||
|
['AppKit', 'CoreServices'],
|
||||||
|
['cocoalib'])
|
||||||
|
|
||||||
|
def build_cocoa_bridging_interfaces(edition):
|
||||||
|
print("Building Cocoa Bridging Interfaces")
|
||||||
|
import objp.o2p
|
||||||
|
import objp.p2o
|
||||||
|
add_to_pythonpath('cocoa')
|
||||||
|
add_to_pythonpath('cocoalib')
|
||||||
|
from cocoa.inter import (PyGUIObject, GUIObjectView, PyColumns, ColumnsView, PyOutline,
|
||||||
|
OutlineView, PySelectableList, SelectableListView, PyTable, TableView, PyFairware)
|
||||||
|
from inter.deletion_options import PyDeletionOptions, DeletionOptionsView
|
||||||
|
from inter.details_panel import PyDetailsPanel, DetailsPanelView
|
||||||
|
from inter.directory_outline import PyDirectoryOutline, DirectoryOutlineView
|
||||||
|
from inter.prioritize_dialog import PyPrioritizeDialog, PrioritizeDialogView
|
||||||
|
from inter.prioritize_list import PyPrioritizeList, PrioritizeListView
|
||||||
|
from inter.problem_dialog import PyProblemDialog
|
||||||
|
from inter.ignore_list_dialog import PyIgnoreListDialog, IgnoreListDialogView
|
||||||
|
from inter.result_table import PyResultTable, ResultTableView
|
||||||
|
from inter.stats_label import PyStatsLabel, StatsLabelView
|
||||||
|
from inter.app import PyDupeGuruBase, DupeGuruView
|
||||||
|
appmod = importlib.import_module('inter.app_{}'.format(edition))
|
||||||
|
allclasses = [PyGUIObject, PyColumns, PyOutline, PySelectableList, PyTable, PyFairware,
|
||||||
|
PyDetailsPanel, PyDirectoryOutline, PyPrioritizeDialog, PyPrioritizeList, PyProblemDialog,
|
||||||
|
PyIgnoreListDialog, PyDeletionOptions, PyResultTable, PyStatsLabel, PyDupeGuruBase,
|
||||||
|
appmod.PyDupeGuru]
|
||||||
|
for class_ in allclasses:
|
||||||
|
objp.o2p.generate_objc_code(class_, 'cocoa/autogen', inherit=True)
|
||||||
|
allclasses = [GUIObjectView, ColumnsView, OutlineView, SelectableListView, TableView,
|
||||||
|
DetailsPanelView, DirectoryOutlineView, PrioritizeDialogView, PrioritizeListView,
|
||||||
|
IgnoreListDialogView, DeletionOptionsView, ResultTableView, StatsLabelView, DupeGuruView]
|
||||||
|
clsspecs = [objp.o2p.spec_from_python_class(class_) for class_ in allclasses]
|
||||||
|
objp.p2o.generate_python_proxy_code_from_clsspec(clsspecs, 'build/CocoaViews.m')
|
||||||
|
build_cocoa_ext('CocoaViews', 'cocoa/inter', ['build/CocoaViews.m', 'build/ObjP.m'])
|
||||||
|
|
||||||
def build_pe_modules(ui):
|
def build_pe_modules(ui):
|
||||||
def move(src, dst):
|
|
||||||
if not op.exists(src):
|
|
||||||
return
|
|
||||||
if op.exists(dst):
|
|
||||||
os.remove(dst)
|
|
||||||
print('Moving %s --> %s' % (src, dst))
|
|
||||||
os.rename(src, dst)
|
|
||||||
|
|
||||||
print("Building PE Modules")
|
print("Building PE Modules")
|
||||||
exts = [
|
exts = [
|
||||||
Extension("_block", [op.join('core_pe', 'modules', 'block.c'), op.join('core_pe', 'modules', 'common.c')]),
|
Extension("_block", [op.join('core_pe', 'modules', 'block.c'), op.join('core_pe', 'modules', 'common.c')]),
|
||||||
@@ -141,13 +242,9 @@ def build_pe_modules(ui):
|
|||||||
script_args = ['build_ext', '--inplace'],
|
script_args = ['build_ext', '--inplace'],
|
||||||
ext_modules = exts,
|
ext_modules = exts,
|
||||||
)
|
)
|
||||||
move('_block.so', op.join('core_pe', '_block.so'))
|
move_all('_block_qt*', op.join('qt', 'pe'))
|
||||||
move('_block.pyd', op.join('core_pe', '_block.pyd'))
|
move_all('_block*', 'core_pe')
|
||||||
move('_block_osx.so', op.join('core_pe', '_block_osx.so'))
|
move_all('_cache*', 'core_pe')
|
||||||
move('_cache.so', op.join('core_pe', '_cache.so'))
|
|
||||||
move('_cache.pyd', op.join('core_pe', '_cache.pyd'))
|
|
||||||
move('_block_qt.so', op.join('qt', 'pe', '_block_qt.so'))
|
|
||||||
move('_block_qt.pyd', op.join('qt', 'pe', '_block_qt.pyd'))
|
|
||||||
|
|
||||||
def build_normal(edition, ui, dev):
|
def build_normal(edition, ui, dev):
|
||||||
print("Building dupeGuru {0} with UI {1}".format(edition.upper(), ui))
|
print("Building dupeGuru {0} with UI {1}".format(edition.upper(), ui))
|
||||||
@@ -179,6 +276,13 @@ def main():
|
|||||||
build_help(edition)
|
build_help(edition)
|
||||||
elif options.loc:
|
elif options.loc:
|
||||||
build_localizations(ui, edition)
|
build_localizations(ui, edition)
|
||||||
|
elif options.updatepot:
|
||||||
|
build_updatepot()
|
||||||
|
elif options.mergepot:
|
||||||
|
build_mergepot()
|
||||||
|
elif options.cocoamod:
|
||||||
|
build_cocoa_proxy_module()
|
||||||
|
build_cocoa_bridging_interfaces(edition)
|
||||||
else:
|
else:
|
||||||
build_normal(edition, ui, dev)
|
build_normal(edition, ui, dev)
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
which should be included with this package. The terms are also available at
|
which should be included with this package. The terms are also available at
|
||||||
@@ -11,26 +11,28 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
#import "ResultWindow.h"
|
#import "ResultWindow.h"
|
||||||
#import "DetailsPanel.h"
|
#import "DetailsPanel.h"
|
||||||
#import "DirectoryPanel.h"
|
#import "DirectoryPanel.h"
|
||||||
|
#import "IgnoreListDialog.h"
|
||||||
#import "HSAboutBox.h"
|
#import "HSAboutBox.h"
|
||||||
#import "HSRecentFiles.h"
|
#import "HSRecentFiles.h"
|
||||||
|
|
||||||
@interface AppDelegateBase : NSObject
|
@interface AppDelegateBase : NSObject
|
||||||
{
|
{
|
||||||
IBOutlet PyDupeGuruBase *py;
|
|
||||||
IBOutlet NSMenu *recentResultsMenu;
|
IBOutlet NSMenu *recentResultsMenu;
|
||||||
IBOutlet NSMenu *actionsMenu;
|
IBOutlet NSMenu *actionsMenu;
|
||||||
IBOutlet NSMenu *columnsMenu;
|
IBOutlet NSMenu *columnsMenu;
|
||||||
|
|
||||||
|
PyDupeGuru *model;
|
||||||
ResultWindowBase *_resultWindow;
|
ResultWindowBase *_resultWindow;
|
||||||
DirectoryPanel *_directoryPanel;
|
DirectoryPanel *_directoryPanel;
|
||||||
DetailsPanel *_detailsPanel;
|
DetailsPanel *_detailsPanel;
|
||||||
|
IgnoreListDialog *_ignoreListDialog;
|
||||||
NSWindowController *_preferencesPanel;
|
NSWindowController *_preferencesPanel;
|
||||||
HSAboutBox *_aboutBox;
|
HSAboutBox *_aboutBox;
|
||||||
HSRecentFiles *_recentResults;
|
HSRecentFiles *_recentResults;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Virtual */
|
/* Virtual */
|
||||||
- (PyDupeGuruBase *)py;
|
- (PyDupeGuru *)model;
|
||||||
- (ResultWindowBase *)createResultWindow;
|
- (ResultWindowBase *)createResultWindow;
|
||||||
- (DirectoryPanel *)createDirectoryPanel;
|
- (DirectoryPanel *)createDirectoryPanel;
|
||||||
- (DetailsPanel *)createDetailsPanel;
|
- (DetailsPanel *)createDetailsPanel;
|
||||||
@@ -58,10 +60,10 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
- (IBAction)showDirectoryWindow:(id)sender;
|
- (IBAction)showDirectoryWindow:(id)sender;
|
||||||
- (IBAction)showPreferencesPanel:(id)sender;
|
- (IBAction)showPreferencesPanel:(id)sender;
|
||||||
- (IBAction)showResultWindow:(id)sender;
|
- (IBAction)showResultWindow:(id)sender;
|
||||||
|
- (IBAction)showIgnoreList:(id)sender;
|
||||||
- (IBAction)startScanning:(id)sender;
|
- (IBAction)startScanning:(id)sender;
|
||||||
|
|
||||||
/* model --> view */
|
/* model --> view */
|
||||||
- (void)showExtraFairwareReminder;
|
|
||||||
- (void)showMessage:(NSString *)msg;
|
- (void)showMessage:(NSString *)msg;
|
||||||
- (void)setupAsRegistered;
|
- (void)setupAsRegistered;
|
||||||
- (void)showFairwareNagWithPrompt:(NSString *)prompt;
|
- (void)showFairwareNagWithPrompt:(NSString *)prompt;
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
which should be included with this package. The terms are also available at
|
which should be included with this package. The terms are also available at
|
||||||
@@ -9,8 +9,7 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
#import "AppDelegate.h"
|
#import "AppDelegate.h"
|
||||||
#import "ProgressController.h"
|
#import "ProgressController.h"
|
||||||
#import "HSFairwareReminder.h"
|
#import "HSFairwareReminder.h"
|
||||||
#import "ExtraFairwareReminder.h"
|
#import "HSPyUtil.h"
|
||||||
#import "Utils.h"
|
|
||||||
#import "Consts.h"
|
#import "Consts.h"
|
||||||
#import "Dialogs.h"
|
#import "Dialogs.h"
|
||||||
#import "ValueTransformers.h"
|
#import "ValueTransformers.h"
|
||||||
@@ -25,7 +24,8 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
|
|
||||||
- (void)awakeFromNib
|
- (void)awakeFromNib
|
||||||
{
|
{
|
||||||
[py bindCocoa:self];
|
model = [[PyDupeGuru alloc] init];
|
||||||
|
[model bindCallback:createCallback(@"DupeGuruView", self)];
|
||||||
NSUserDefaults *ud = [NSUserDefaults standardUserDefaults];
|
NSUserDefaults *ud = [NSUserDefaults standardUserDefaults];
|
||||||
/* Because the pref pane is lazily loaded, we have to manually do the update check if the
|
/* Because the pref pane is lazily loaded, we have to manually do the update check if the
|
||||||
preference is set.
|
preference is set.
|
||||||
@@ -37,7 +37,8 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
[_recentResults setDelegate:self];
|
[_recentResults setDelegate:self];
|
||||||
_resultWindow = [self createResultWindow];
|
_resultWindow = [self createResultWindow];
|
||||||
_directoryPanel = [self createDirectoryPanel];
|
_directoryPanel = [self createDirectoryPanel];
|
||||||
_detailsPanel = nil; // Lazily loaded
|
_detailsPanel = [self createDetailsPanel];
|
||||||
|
_ignoreListDialog = [[IgnoreListDialog alloc] initWithPyRef:[model ignoreListDialog]];
|
||||||
_aboutBox = nil; // Lazily loaded
|
_aboutBox = nil; // Lazily loaded
|
||||||
_preferencesPanel = nil; // Lazily loaded
|
_preferencesPanel = nil; // Lazily loaded
|
||||||
[[[self directoryPanel] window] makeKeyAndOrderFront:self];
|
[[[self directoryPanel] window] makeKeyAndOrderFront:self];
|
||||||
@@ -45,7 +46,10 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
|
|
||||||
/* Virtual */
|
/* Virtual */
|
||||||
|
|
||||||
- (PyDupeGuruBase *)py { return py; }
|
- (PyDupeGuru *)model
|
||||||
|
{
|
||||||
|
return model;
|
||||||
|
}
|
||||||
|
|
||||||
- (ResultWindowBase *)createResultWindow
|
- (ResultWindowBase *)createResultWindow
|
||||||
{
|
{
|
||||||
@@ -59,7 +63,7 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
|
|
||||||
- (DetailsPanel *)createDetailsPanel
|
- (DetailsPanel *)createDetailsPanel
|
||||||
{
|
{
|
||||||
return [[DetailsPanel alloc] initWithPy:py];
|
return [[DetailsPanel alloc] initWithPyRef:[model detailsPanel]];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (NSString *)homepageURL
|
- (NSString *)homepageURL
|
||||||
@@ -80,8 +84,6 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
|
|
||||||
- (DetailsPanel *)detailsPanel
|
- (DetailsPanel *)detailsPanel
|
||||||
{
|
{
|
||||||
if (!_detailsPanel)
|
|
||||||
_detailsPanel = [self createDetailsPanel];
|
|
||||||
return _detailsPanel;
|
return _detailsPanel;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -101,10 +103,10 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
[op setCanCreateDirectories:NO];
|
[op setCanCreateDirectories:NO];
|
||||||
[op setAllowsMultipleSelection:NO];
|
[op setAllowsMultipleSelection:NO];
|
||||||
[op setAllowedFileTypes:[NSArray arrayWithObject:@"dupeguru"]];
|
[op setAllowedFileTypes:[NSArray arrayWithObject:@"dupeguru"]];
|
||||||
[op setTitle:TRMSG(@"SelectResultToLoadMsg")];
|
[op setTitle:TR(@"Select a results file to load")];
|
||||||
if ([op runModal] == NSOKButton) {
|
if ([op runModal] == NSOKButton) {
|
||||||
NSString *filename = [[op filenames] objectAtIndex:0];
|
NSString *filename = [[op filenames] objectAtIndex:0];
|
||||||
[py loadResultsFrom:filename];
|
[model loadResultsFrom:filename];
|
||||||
[[self recentResults] addFile:filename];
|
[[self recentResults] addFile:filename];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -125,7 +127,7 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
- (IBAction)showAboutBox:(id)sender
|
- (IBAction)showAboutBox:(id)sender
|
||||||
{
|
{
|
||||||
if (_aboutBox == nil) {
|
if (_aboutBox == nil) {
|
||||||
_aboutBox = [[HSAboutBox alloc] initWithApp:py];
|
_aboutBox = [[HSAboutBox alloc] initWithApp:model];
|
||||||
}
|
}
|
||||||
[[_aboutBox window] makeKeyAndOrderFront:sender];
|
[[_aboutBox window] makeKeyAndOrderFront:sender];
|
||||||
}
|
}
|
||||||
@@ -148,6 +150,11 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
[[[self resultWindow] window] makeKeyAndOrderFront:nil];
|
[[[self resultWindow] window] makeKeyAndOrderFront:nil];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
- (IBAction)showIgnoreList:(id)sender
|
||||||
|
{
|
||||||
|
[model showIgnoreList];
|
||||||
|
}
|
||||||
|
|
||||||
- (IBAction)startScanning:(id)sender
|
- (IBAction)startScanning:(id)sender
|
||||||
{
|
{
|
||||||
[[self resultWindow] startDuplicateScan:sender];
|
[[self resultWindow] startDuplicateScan:sender];
|
||||||
@@ -157,17 +164,9 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
/* Delegate */
|
/* Delegate */
|
||||||
- (void)applicationDidFinishLaunching:(NSNotification *)aNotification
|
- (void)applicationDidFinishLaunching:(NSNotification *)aNotification
|
||||||
{
|
{
|
||||||
[[ProgressController mainProgressController] setWorker:py];
|
[[ProgressController mainProgressController] setWorker:model];
|
||||||
NSUserDefaults *ud = [NSUserDefaults standardUserDefaults];
|
[model initialRegistrationSetup];
|
||||||
//Restore Columns
|
[model loadSession];
|
||||||
NSArray *columnsOrder = [ud arrayForKey:@"columnsOrder"];
|
|
||||||
NSDictionary *columnsWidth = [ud dictionaryForKey:@"columnsWidth"];
|
|
||||||
if ([columnsOrder count])
|
|
||||||
[[self resultWindow] restoreColumnsPosition:columnsOrder widths:columnsWidth];
|
|
||||||
else
|
|
||||||
[[self resultWindow] resetColumnsToDefault:nil];
|
|
||||||
[py initialRegistrationSetup];
|
|
||||||
[py loadSession];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)applicationWillBecomeActive:(NSNotification *)aNotification
|
- (void)applicationWillBecomeActive:(NSNotification *)aNotification
|
||||||
@@ -179,8 +178,8 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
|
|
||||||
- (NSApplicationTerminateReply)applicationShouldTerminate:(NSApplication *)sender
|
- (NSApplicationTerminateReply)applicationShouldTerminate:(NSApplication *)sender
|
||||||
{
|
{
|
||||||
if ([py resultsAreModified]) {
|
if ([model resultsAreModified]) {
|
||||||
NSString *msg = TRMSG(@"ReallyWantToQuitMsg");
|
NSString *msg = TR(@"You have unsaved results, do you really want to quit?");
|
||||||
if ([Dialogs askYesNo:msg] == NSAlertSecondButtonReturn) { // NO
|
if ([Dialogs askYesNo:msg] == NSAlertSecondButtonReturn) { // NO
|
||||||
return NSTerminateCancel;
|
return NSTerminateCancel;
|
||||||
}
|
}
|
||||||
@@ -191,15 +190,13 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
- (void)applicationWillTerminate:(NSNotification *)aNotification
|
- (void)applicationWillTerminate:(NSNotification *)aNotification
|
||||||
{
|
{
|
||||||
NSUserDefaults *ud = [NSUserDefaults standardUserDefaults];
|
NSUserDefaults *ud = [NSUserDefaults standardUserDefaults];
|
||||||
[ud setObject: [[self resultWindow] getColumnsOrder] forKey:@"columnsOrder"];
|
|
||||||
[ud setObject: [[self resultWindow] getColumnsWidth] forKey:@"columnsWidth"];
|
|
||||||
NSInteger sc = [ud integerForKey:@"sessionCountSinceLastIgnorePurge"];
|
NSInteger sc = [ud integerForKey:@"sessionCountSinceLastIgnorePurge"];
|
||||||
if (sc >= 10) {
|
if (sc >= 10) {
|
||||||
sc = -1;
|
sc = -1;
|
||||||
[py purgeIgnoreList];
|
[model purgeIgnoreList];
|
||||||
}
|
}
|
||||||
sc++;
|
sc++;
|
||||||
[py saveSession];
|
[model saveSession];
|
||||||
[ud setInteger:sc forKey:@"sessionCountSinceLastIgnorePurge"];
|
[ud setInteger:sc forKey:@"sessionCountSinceLastIgnorePurge"];
|
||||||
// NSApplication does not release nib instances objects, we must do it manually
|
// NSApplication does not release nib instances objects, we must do it manually
|
||||||
// Well, it isn't needed because the memory is freed anyway (we are quitting the application
|
// Well, it isn't needed because the memory is freed anyway (we are quitting the application
|
||||||
@@ -210,24 +207,26 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
|
|
||||||
- (void)recentFileClicked:(NSString *)path
|
- (void)recentFileClicked:(NSString *)path
|
||||||
{
|
{
|
||||||
[py loadResultsFrom:path];
|
[model loadResultsFrom:path];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* model --> view */
|
/* model --> view */
|
||||||
- (void)showExtraFairwareReminder
|
|
||||||
{
|
|
||||||
ExtraFairwareReminder *dialog = [[ExtraFairwareReminder alloc] initWithPy:py];
|
|
||||||
[dialog start];
|
|
||||||
[NSApp runModalForWindow:[dialog window]];
|
|
||||||
[dialog release];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)showMessage:(NSString *)msg
|
- (void)showMessage:(NSString *)msg
|
||||||
{
|
{
|
||||||
[Dialogs showMessage:msg];
|
[Dialogs showMessage:msg];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
- (BOOL)askYesNoWithPrompt:(NSString *)prompt
|
||||||
|
{
|
||||||
|
return [Dialogs askYesNo:prompt] == NSAlertFirstButtonReturn;
|
||||||
|
}
|
||||||
|
|
||||||
|
- (void)showProblemDialog
|
||||||
|
{
|
||||||
|
[[self resultWindow] showProblemDialog];
|
||||||
|
}
|
||||||
|
|
||||||
- (void)setupAsRegistered
|
- (void)setupAsRegistered
|
||||||
{
|
{
|
||||||
// Nothing to do.
|
// Nothing to do.
|
||||||
@@ -235,11 +234,28 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
|
|
||||||
- (void)showFairwareNagWithPrompt:(NSString *)prompt
|
- (void)showFairwareNagWithPrompt:(NSString *)prompt
|
||||||
{
|
{
|
||||||
[HSFairwareReminder showFairwareNagWithApp:[self py] prompt:prompt];
|
[HSFairwareReminder showFairwareNagWithApp:[self model] prompt:prompt];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)showDemoNagWithPrompt:(NSString *)prompt
|
- (void)showDemoNagWithPrompt:(NSString *)prompt
|
||||||
{
|
{
|
||||||
[HSFairwareReminder showDemoNagWithApp:[self py] prompt:prompt];
|
[HSFairwareReminder showDemoNagWithApp:[self model] prompt:prompt];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
- (NSString *)selectDestFolderWithPrompt:(NSString *)prompt
|
||||||
|
{
|
||||||
|
NSOpenPanel *op = [NSOpenPanel openPanel];
|
||||||
|
[op setCanChooseFiles:NO];
|
||||||
|
[op setCanChooseDirectories:YES];
|
||||||
|
[op setCanCreateDirectories:YES];
|
||||||
|
[op setAllowsMultipleSelection:NO];
|
||||||
|
[op setTitle:prompt];
|
||||||
|
if ([op runModal] == NSOKButton) {
|
||||||
|
return [[op filenames] objectAtIndex:0];
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
return nil;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@end
|
@end
|
||||||
|
|||||||
@@ -1,12 +1,12 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
which should be included with this package. The terms are also available at
|
which should be included with this package. The terms are also available at
|
||||||
http://www.hardcoded.net/licenses/bsd_license
|
http://www.hardcoded.net/licenses/bsd_license
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#import <Cocoa/Cocoa.h>
|
#import "HSConsts.h"
|
||||||
|
|
||||||
#define JobStarted @"JobStarted"
|
#define JobStarted @"JobStarted"
|
||||||
#define JobInProgress @"JobInProgress"
|
#define JobInProgress @"JobInProgress"
|
||||||
@@ -19,7 +19,3 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
#define jobDelete @"job_delete"
|
#define jobDelete @"job_delete"
|
||||||
|
|
||||||
#define DGPrioritizeIndexPasteboardType @"DGPrioritizeIndexPasteboardType"
|
#define DGPrioritizeIndexPasteboardType @"DGPrioritizeIndexPasteboardType"
|
||||||
|
|
||||||
#define TR(s) NSLocalizedString(s, @"")
|
|
||||||
#define TRCOL(s) NSLocalizedStringFromTable(s, @"columns", @"")
|
|
||||||
#define TRMSG(s) NSLocalizedStringFromTable(s, @"message", @"")
|
|
||||||
25
cocoa/base/DeletionOptions.h
Normal file
25
cocoa/base/DeletionOptions.h
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
/*
|
||||||
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
|
which should be included with this package. The terms are also available at
|
||||||
|
http://www.hardcoded.net/licenses/bsd_license
|
||||||
|
*/
|
||||||
|
|
||||||
|
#import <Cocoa/Cocoa.h>
|
||||||
|
#import "PyDeletionOptions.h"
|
||||||
|
|
||||||
|
@interface DeletionOptions : NSWindowController
|
||||||
|
{
|
||||||
|
IBOutlet NSTextField *messageTextField;
|
||||||
|
IBOutlet NSButton *hardlinkButton;
|
||||||
|
IBOutlet NSButton *directButton;
|
||||||
|
|
||||||
|
PyDeletionOptions *model;
|
||||||
|
}
|
||||||
|
- (id)initWithPyRef:(PyObject *)aPyRef;
|
||||||
|
|
||||||
|
- (IBAction)updateOptions:(id)sender;
|
||||||
|
- (IBAction)proceed:(id)sender;
|
||||||
|
- (IBAction)cancel:(id)sender;
|
||||||
|
@end
|
||||||
58
cocoa/base/DeletionOptions.m
Normal file
58
cocoa/base/DeletionOptions.m
Normal file
@@ -0,0 +1,58 @@
|
|||||||
|
/*
|
||||||
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
|
which should be included with this package. The terms are also available at
|
||||||
|
http://www.hardcoded.net/licenses/bsd_license
|
||||||
|
*/
|
||||||
|
|
||||||
|
#import "DeletionOptions.h"
|
||||||
|
#import "HSPyUtil.h"
|
||||||
|
|
||||||
|
@implementation DeletionOptions
|
||||||
|
- (id)initWithPyRef:(PyObject *)aPyRef
|
||||||
|
{
|
||||||
|
self = [super initWithWindowNibName:@"DeletionOptions"];
|
||||||
|
[self window];
|
||||||
|
model = [[PyDeletionOptions alloc] initWithModel:aPyRef];
|
||||||
|
[model bindCallback:createCallback(@"DeletionOptionsView", self)];
|
||||||
|
return self;
|
||||||
|
}
|
||||||
|
|
||||||
|
- (void)dealloc
|
||||||
|
{
|
||||||
|
[model release];
|
||||||
|
[super dealloc];
|
||||||
|
}
|
||||||
|
|
||||||
|
- (IBAction)updateOptions:(id)sender
|
||||||
|
{
|
||||||
|
[model setHardlink:[hardlinkButton state] == NSOnState];
|
||||||
|
[model setDirect:[directButton state] == NSOnState];
|
||||||
|
}
|
||||||
|
|
||||||
|
- (IBAction)proceed:(id)sender
|
||||||
|
{
|
||||||
|
[NSApp stopModalWithCode:NSOKButton];
|
||||||
|
}
|
||||||
|
|
||||||
|
- (IBAction)cancel:(id)sender
|
||||||
|
{
|
||||||
|
[NSApp stopModalWithCode:NSCancelButton];
|
||||||
|
}
|
||||||
|
|
||||||
|
/* model --> view */
|
||||||
|
- (void)updateMsg:(NSString *)msg
|
||||||
|
{
|
||||||
|
[messageTextField setStringValue:msg];
|
||||||
|
}
|
||||||
|
|
||||||
|
- (BOOL)show
|
||||||
|
{
|
||||||
|
[hardlinkButton setState:NSOffState];
|
||||||
|
[directButton setState:NSOffState];
|
||||||
|
NSInteger r = [NSApp runModalForWindow:[self window]];
|
||||||
|
[[self window] close];
|
||||||
|
return r == NSOKButton;
|
||||||
|
}
|
||||||
|
@end
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
which should be included with this package. The terms are also available at
|
which should be included with this package. The terms are also available at
|
||||||
@@ -7,16 +7,17 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#import <Cocoa/Cocoa.h>
|
#import <Cocoa/Cocoa.h>
|
||||||
#import "HSWindowController.h"
|
#import <Python.h>
|
||||||
#import "PyApp.h"
|
|
||||||
#import "PyDetailsPanel.h"
|
#import "PyDetailsPanel.h"
|
||||||
|
|
||||||
@interface DetailsPanel : HSWindowController
|
@interface DetailsPanel : NSWindowController
|
||||||
{
|
{
|
||||||
IBOutlet NSTableView *detailsTable;
|
IBOutlet NSTableView *detailsTable;
|
||||||
|
|
||||||
|
PyDetailsPanel *model;
|
||||||
}
|
}
|
||||||
- (id)initWithPy:(PyApp *)aPy;
|
- (id)initWithPyRef:(PyObject *)aPyRef;
|
||||||
- (PyDetailsPanel *)py;
|
- (PyDetailsPanel *)model;
|
||||||
|
|
||||||
- (BOOL)isVisible;
|
- (BOOL)isVisible;
|
||||||
- (void)toggleVisibility;
|
- (void)toggleVisibility;
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
which should be included with this package. The terms are also available at
|
which should be included with this package. The terms are also available at
|
||||||
@@ -7,26 +7,27 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#import "DetailsPanel.h"
|
#import "DetailsPanel.h"
|
||||||
#import "Utils.h"
|
#import "HSPyUtil.h"
|
||||||
|
|
||||||
@implementation DetailsPanel
|
@implementation DetailsPanel
|
||||||
- (id)initWithPy:(PyApp *)aPy
|
- (id)initWithPyRef:(PyObject *)aPyRef
|
||||||
{
|
{
|
||||||
self = [super initWithNibName:@"DetailsPanel" pyClassName:@"PyDetailsPanel" pyParent:aPy];
|
self = [super initWithWindowNibName:@"DetailsPanel"];
|
||||||
[self window]; //So the detailsTable is initialized.
|
[self window]; //So the detailsTable is initialized.
|
||||||
[self connect];
|
model = [[PyDetailsPanel alloc] initWithModel:aPyRef];
|
||||||
|
[model bindCallback:createCallback(@"DetailsPanelView", self)];
|
||||||
return self;
|
return self;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)dealloc
|
- (void)dealloc
|
||||||
{
|
{
|
||||||
[self disconnect];
|
[model release];
|
||||||
[super dealloc];
|
[super dealloc];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (PyDetailsPanel *)py
|
- (PyDetailsPanel *)model
|
||||||
{
|
{
|
||||||
return (PyDetailsPanel *)py;
|
return (PyDetailsPanel *)model;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)refreshDetails
|
- (void)refreshDetails
|
||||||
@@ -53,12 +54,12 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
/* NSTableView Delegate */
|
/* NSTableView Delegate */
|
||||||
- (NSInteger)numberOfRowsInTableView:(NSTableView *)tableView
|
- (NSInteger)numberOfRowsInTableView:(NSTableView *)tableView
|
||||||
{
|
{
|
||||||
return [[self py] numberOfRows];
|
return [[self model] numberOfRows];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (id)tableView:(NSTableView *)tableView objectValueForTableColumn:(NSTableColumn *)column row:(NSInteger)row
|
- (id)tableView:(NSTableView *)tableView objectValueForTableColumn:(NSTableColumn *)column row:(NSInteger)row
|
||||||
{
|
{
|
||||||
return [[self py] valueForColumn:[column identifier] row:row];
|
return [[self model] valueForColumn:[column identifier] row:row];
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Python --> Cocoa */
|
/* Python --> Cocoa */
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
which should be included with this package. The terms are also available at
|
which should be included with this package. The terms are also available at
|
||||||
@@ -7,12 +7,13 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#import <Cocoa/Cocoa.h>
|
#import <Cocoa/Cocoa.h>
|
||||||
|
#import <Python.h>
|
||||||
#import "HSOutline.h"
|
#import "HSOutline.h"
|
||||||
#import "PyDirectoryOutline.h"
|
#import "PyDirectoryOutline.h"
|
||||||
|
|
||||||
#define DGAddedFoldersNotification @"DGAddedFoldersNotification"
|
#define DGAddedFoldersNotification @"DGAddedFoldersNotification"
|
||||||
|
|
||||||
@interface DirectoryOutline : HSOutline {}
|
@interface DirectoryOutline : HSOutline {}
|
||||||
- (id)initWithPyParent:(id)aPyParent view:(HSOutlineView *)aOutlineView;
|
- (id)initWithPyRef:(PyObject *)aPyRef outlineView:(HSOutlineView *)aOutlineView;
|
||||||
- (PyDirectoryOutline *)py;
|
- (PyDirectoryOutline *)model;
|
||||||
@end;
|
@end;
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
which should be included with this package. The terms are also available at
|
which should be included with this package. The terms are also available at
|
||||||
@@ -9,23 +9,17 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
#import "DirectoryOutline.h"
|
#import "DirectoryOutline.h"
|
||||||
|
|
||||||
@implementation DirectoryOutline
|
@implementation DirectoryOutline
|
||||||
- (id)initWithPyParent:(id)aPyParent view:(HSOutlineView *)aOutlineView
|
- (id)initWithPyRef:(PyObject *)aPyRef outlineView:(HSOutlineView *)aOutlineView
|
||||||
{
|
{
|
||||||
self = [super initWithPyClassName:@"PyDirectoryOutline" pyParent:aPyParent view:aOutlineView];
|
self = [super initWithPyRef:aPyRef wrapperClass:[PyDirectoryOutline class]
|
||||||
[outlineView registerForDraggedTypes:[NSArray arrayWithObject:NSFilenamesPboardType]];
|
callbackClassName:@"DirectoryOutlineView" view:aOutlineView];
|
||||||
[self connect];
|
[[self view] registerForDraggedTypes:[NSArray arrayWithObject:NSFilenamesPboardType]];
|
||||||
return self;
|
return self;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)dealloc
|
- (PyDirectoryOutline *)model
|
||||||
{
|
{
|
||||||
[self disconnect];
|
return (PyDirectoryOutline *)model;
|
||||||
[super dealloc];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (PyDirectoryOutline *)py
|
|
||||||
{
|
|
||||||
return (PyDirectoryOutline *)py;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Delegate */
|
/* Delegate */
|
||||||
@@ -53,7 +47,7 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
if (!(sourceDragMask & NSDragOperationLink))
|
if (!(sourceDragMask & NSDragOperationLink))
|
||||||
return NO;
|
return NO;
|
||||||
for (NSString *foldername in foldernames) {
|
for (NSString *foldername in foldernames) {
|
||||||
[[self py] addDirectory:foldername];
|
[[self model] addDirectory:foldername];
|
||||||
}
|
}
|
||||||
NSDictionary *userInfo = [NSDictionary dictionaryWithObject:foldernames forKey:@"foldernames"];
|
NSDictionary *userInfo = [NSDictionary dictionaryWithObject:foldernames forKey:@"foldernames"];
|
||||||
[[NSNotificationCenter defaultCenter] postNotificationName:DGAddedFoldersNotification
|
[[NSNotificationCenter defaultCenter] postNotificationName:DGAddedFoldersNotification
|
||||||
@@ -67,7 +61,7 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
if ([cell isKindOfClass:[NSTextFieldCell class]]) {
|
if ([cell isKindOfClass:[NSTextFieldCell class]]) {
|
||||||
NSTextFieldCell *textCell = cell;
|
NSTextFieldCell *textCell = cell;
|
||||||
NSIndexPath *path = item;
|
NSIndexPath *path = item;
|
||||||
BOOL selected = [path isEqualTo:[outlineView selectedPath]];
|
BOOL selected = [path isEqualTo:[[self view] selectedPath]];
|
||||||
if (selected) {
|
if (selected) {
|
||||||
[textCell setTextColor:[NSColor blackColor]];
|
[textCell setTextColor:[NSColor blackColor]];
|
||||||
return;
|
return;
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
which should be included with this package. The terms are also available at
|
which should be included with this package. The terms are also available at
|
||||||
@@ -20,9 +20,10 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
IBOutlet NSPopUpButton *loadRecentButtonPopUp;
|
IBOutlet NSPopUpButton *loadRecentButtonPopUp;
|
||||||
IBOutlet HSOutlineView *outlineView;
|
IBOutlet HSOutlineView *outlineView;
|
||||||
IBOutlet NSButton *removeButton;
|
IBOutlet NSButton *removeButton;
|
||||||
|
IBOutlet NSButton *loadResultsButton;
|
||||||
|
|
||||||
AppDelegateBase *_app;
|
AppDelegateBase *_app;
|
||||||
PyDupeGuruBase *_py;
|
PyDupeGuru *model;
|
||||||
HSRecentFiles *_recentDirectories;
|
HSRecentFiles *_recentDirectories;
|
||||||
DirectoryOutline *outline;
|
DirectoryOutline *outline;
|
||||||
BOOL _alwaysShowPopUp;
|
BOOL _alwaysShowPopUp;
|
||||||
@@ -30,6 +31,7 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
- (id)initWithParentApp:(AppDelegateBase *)aParentApp;
|
- (id)initWithParentApp:(AppDelegateBase *)aParentApp;
|
||||||
|
|
||||||
- (void)fillPopUpMenu; // Virtual
|
- (void)fillPopUpMenu; // Virtual
|
||||||
|
- (void)adjustUIToLocalization;
|
||||||
|
|
||||||
- (IBAction)askForDirectory:(id)sender;
|
- (IBAction)askForDirectory:(id)sender;
|
||||||
- (IBAction)popupAddDirectoryMenu:(id)sender;
|
- (IBAction)popupAddDirectoryMenu:(id)sender;
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
which should be included with this package. The terms are also available at
|
which should be included with this package. The terms are also available at
|
||||||
@@ -18,14 +18,16 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
self = [super initWithWindowNibName:@"DirectoryPanel"];
|
self = [super initWithWindowNibName:@"DirectoryPanel"];
|
||||||
[self window];
|
[self window];
|
||||||
_app = aParentApp;
|
_app = aParentApp;
|
||||||
_py = [_app py];
|
model = [_app model];
|
||||||
[[self window] setTitle:[_py appName]];
|
[[self window] setTitle:[model appName]];
|
||||||
_alwaysShowPopUp = NO;
|
_alwaysShowPopUp = NO;
|
||||||
[self fillPopUpMenu];
|
[self fillPopUpMenu];
|
||||||
_recentDirectories = [[HSRecentFiles alloc] initWithName:@"recentDirectories" menu:[addButtonPopUp menu]];
|
_recentDirectories = [[HSRecentFiles alloc] initWithName:@"recentDirectories" menu:[addButtonPopUp menu]];
|
||||||
[_recentDirectories setDelegate:self];
|
[_recentDirectories setDelegate:self];
|
||||||
outline = [[DirectoryOutline alloc] initWithPyParent:_py view:outlineView];
|
outline = [[DirectoryOutline alloc] initWithPyRef:[model directoryTree] outlineView:outlineView];
|
||||||
[self refreshRemoveButtonText];
|
[self refreshRemoveButtonText];
|
||||||
|
[self adjustUIToLocalization];
|
||||||
|
|
||||||
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(directorySelectionChanged:)
|
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(directorySelectionChanged:)
|
||||||
name:NSOutlineViewSelectionDidChangeNotification object:outlineView];
|
name:NSOutlineViewSelectionDidChangeNotification object:outlineView];
|
||||||
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(outlineAddedFolders:)
|
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(outlineAddedFolders:)
|
||||||
@@ -40,7 +42,7 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
[super dealloc];
|
[super dealloc];
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Virtual */
|
/* Private */
|
||||||
|
|
||||||
- (void)fillPopUpMenu
|
- (void)fillPopUpMenu
|
||||||
{
|
{
|
||||||
@@ -50,6 +52,27 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
[m addItem:[NSMenuItem separatorItem]];
|
[m addItem:[NSMenuItem separatorItem]];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
- (void)adjustUIToLocalization
|
||||||
|
{
|
||||||
|
NSString *lang = [[NSBundle preferredLocalizationsFromArray:[[NSBundle mainBundle] localizations]] objectAtIndex:0];
|
||||||
|
NSInteger loadResultsWidthDelta = 0;
|
||||||
|
if ([lang isEqual:@"ru"]) {
|
||||||
|
loadResultsWidthDelta = 50;
|
||||||
|
}
|
||||||
|
else if ([lang isEqual:@"uk"]) {
|
||||||
|
loadResultsWidthDelta = 70;
|
||||||
|
}
|
||||||
|
else if ([lang isEqual:@"hy"]) {
|
||||||
|
loadResultsWidthDelta = 30;
|
||||||
|
}
|
||||||
|
if (loadResultsWidthDelta) {
|
||||||
|
NSRect r = [loadResultsButton frame];
|
||||||
|
r.size.width += loadResultsWidthDelta;
|
||||||
|
r.origin.x -= loadResultsWidthDelta;
|
||||||
|
[loadResultsButton setFrame:r];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* Actions */
|
/* Actions */
|
||||||
|
|
||||||
- (IBAction)askForDirectory:(id)sender
|
- (IBAction)askForDirectory:(id)sender
|
||||||
@@ -58,7 +81,7 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
[op setCanChooseFiles:YES];
|
[op setCanChooseFiles:YES];
|
||||||
[op setCanChooseDirectories:YES];
|
[op setCanChooseDirectories:YES];
|
||||||
[op setAllowsMultipleSelection:YES];
|
[op setAllowsMultipleSelection:YES];
|
||||||
[op setTitle:TRMSG(@"SelectFolderToAddMsg")];
|
[op setTitle:TR(@"Select a folder to add to the scanning list")];
|
||||||
[op setDelegate:self];
|
[op setDelegate:self];
|
||||||
if ([op runModal] == NSOKButton) {
|
if ([op runModal] == NSOKButton) {
|
||||||
for (NSString *directory in [op filenames]) {
|
for (NSString *directory in [op filenames]) {
|
||||||
@@ -100,32 +123,21 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
- (IBAction)removeSelectedDirectory:(id)sender
|
- (IBAction)removeSelectedDirectory:(id)sender
|
||||||
{
|
{
|
||||||
[[self window] makeKeyAndOrderFront:nil];
|
[[self window] makeKeyAndOrderFront:nil];
|
||||||
if ([outlineView selectedRow] < 0)
|
[[outline model] removeSelectedDirectory];
|
||||||
return;
|
|
||||||
NSIndexPath *path = [outline selectedIndexPath];
|
|
||||||
NSInteger state = [outline intProperty:@"state" valueAtPath:path];
|
|
||||||
if (([path length] == 1) && (state != 2)) {
|
|
||||||
[_py removeDirectory:i2n([path indexAtPosition:0])];
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
NSInteger newState = state == 2 ? 0 : 2; // If excluded, put it back
|
|
||||||
[outline setIntProperty:@"state" value:newState atPath:path];
|
|
||||||
[outlineView display];
|
|
||||||
}
|
|
||||||
[self refreshRemoveButtonText];
|
[self refreshRemoveButtonText];
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Public */
|
/* Public */
|
||||||
- (void)addDirectory:(NSString *)directory
|
- (void)addDirectory:(NSString *)directory
|
||||||
{
|
{
|
||||||
NSInteger r = [[_py addDirectory:directory] intValue];
|
NSInteger r = [model addDirectory:directory];
|
||||||
if (r) {
|
if (r) {
|
||||||
NSString *m = @"";
|
NSString *m = @"";
|
||||||
if (r == 1) {
|
if (r == 1) {
|
||||||
m = TRMSG(@"FolderAlreadyInListMsg");
|
m = TR(@"'%@' already is in the list.");
|
||||||
}
|
}
|
||||||
else if (r == 2) {
|
else if (r == 2) {
|
||||||
m = TRMSG(@"FolderDoesNotExistMsg");
|
m = TR(@"'%@' does not exist.");
|
||||||
}
|
}
|
||||||
[Dialogs showMessage:[NSString stringWithFormat:m,directory]];
|
[Dialogs showMessage:[NSString stringWithFormat:m,directory]];
|
||||||
}
|
}
|
||||||
@@ -140,9 +152,13 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
[removeButton setEnabled:YES];
|
[removeButton setEnabled:YES];
|
||||||
NSInteger state = [outline intProperty:@"state" valueAtPath:[outline selectedIndexPath]];
|
NSIndexPath *path = [outline selectedIndexPath];
|
||||||
NSString *imgName = state == 2 ? @"NSGoLeftTemplate" : @"NSRemoveTemplate";
|
if (path != nil) {
|
||||||
[removeButton setImage:[NSImage imageNamed:imgName]];
|
NSInteger state = [outline intProperty:@"state" valueAtPath:path];
|
||||||
|
BOOL shouldDisplayArrow = ([path length] > 1) && (state == 2);
|
||||||
|
NSString *imgName = shouldDisplayArrow ? @"NSGoLeftTemplate" : @"NSRemoveTemplate";
|
||||||
|
[removeButton setImage:[NSImage imageNamed:imgName]];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Delegate */
|
/* Delegate */
|
||||||
|
|||||||
@@ -1,27 +0,0 @@
|
|||||||
/*
|
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
|
||||||
which should be included with this package. The terms are also available at
|
|
||||||
http://www.hardcoded.net/licenses/bsd_license
|
|
||||||
*/
|
|
||||||
|
|
||||||
#import <Cocoa/Cocoa.h>
|
|
||||||
#import "PyExtraFairwareReminder.h"
|
|
||||||
#import "HSWindowController.h"
|
|
||||||
#import "PyApp.h"
|
|
||||||
|
|
||||||
@interface ExtraFairwareReminder : HSWindowController
|
|
||||||
{
|
|
||||||
IBOutlet NSButton *continueButton;
|
|
||||||
|
|
||||||
NSTimer *timer;
|
|
||||||
}
|
|
||||||
- (id)initWithPy:(PyApp *)aPy;
|
|
||||||
- (PyExtraFairwareReminder *)py;
|
|
||||||
|
|
||||||
- (void)start;
|
|
||||||
- (void)updateButton;
|
|
||||||
- (IBAction)continue:(id)sender;
|
|
||||||
- (IBAction)contribute:(id)sender;
|
|
||||||
@end
|
|
||||||
@@ -1,74 +0,0 @@
|
|||||||
/*
|
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
|
||||||
which should be included with this package. The terms are also available at
|
|
||||||
http://www.hardcoded.net/licenses/bsd_license
|
|
||||||
*/
|
|
||||||
|
|
||||||
#import "ExtraFairwareReminder.h"
|
|
||||||
|
|
||||||
@implementation ExtraFairwareReminder
|
|
||||||
- (id)initWithPy:(PyApp *)aPy
|
|
||||||
{
|
|
||||||
self = [super initWithNibName:@"ExtraFairwareReminder" pyClassName:@"PyExtraFairwareReminder" pyParent:aPy];
|
|
||||||
[self window];
|
|
||||||
[continueButton setEnabled:NO];
|
|
||||||
return self;
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)dealloc
|
|
||||||
{
|
|
||||||
[timer release];
|
|
||||||
[super dealloc];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (PyExtraFairwareReminder *)py
|
|
||||||
{
|
|
||||||
return (PyExtraFairwareReminder *)py;
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)start
|
|
||||||
{
|
|
||||||
[[self py] start];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)updateButton
|
|
||||||
{
|
|
||||||
[[self py] updateButton];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (IBAction)continue:(id)sender
|
|
||||||
{
|
|
||||||
[NSApp stopModal];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (IBAction)contribute:(id)sender
|
|
||||||
{
|
|
||||||
[[NSWorkspace sharedWorkspace] openURL:[NSURL URLWithString:@"http://open.hardcoded.net/contribute/"]];
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Model --> View */
|
|
||||||
- (void)startTimer
|
|
||||||
{
|
|
||||||
timer = [[NSTimer timerWithTimeInterval:0.2 target:self selector:@selector(updateButton)
|
|
||||||
userInfo:nil repeats:YES] retain];
|
|
||||||
// Needed for the timer to work in modal mode.
|
|
||||||
[[NSRunLoop currentRunLoop] addTimer:timer forMode:NSModalPanelRunLoopMode];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)stopTimer
|
|
||||||
{
|
|
||||||
[timer invalidate];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)setButtonText:(NSString *)text
|
|
||||||
{
|
|
||||||
[continueButton setTitle:text];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)enableButton
|
|
||||||
{
|
|
||||||
[continueButton setEnabled:YES];
|
|
||||||
}
|
|
||||||
@end
|
|
||||||
25
cocoa/base/IgnoreListDialog.h
Normal file
25
cocoa/base/IgnoreListDialog.h
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
/*
|
||||||
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
|
which should be included with this package. The terms are also available at
|
||||||
|
http://www.hardcoded.net/licenses/bsd_license
|
||||||
|
*/
|
||||||
|
|
||||||
|
#import <Cocoa/Cocoa.h>
|
||||||
|
#import "PyIgnoreListDialog.h"
|
||||||
|
#import "HSTable.h"
|
||||||
|
|
||||||
|
@interface IgnoreListDialog : NSWindowController
|
||||||
|
{
|
||||||
|
IBOutlet NSTableView *ignoreListTableView;
|
||||||
|
|
||||||
|
PyIgnoreListDialog *model;
|
||||||
|
HSTable *ignoreListTable;
|
||||||
|
}
|
||||||
|
- (id)initWithPyRef:(PyObject *)aPyRef;
|
||||||
|
|
||||||
|
- (void)initializeColumns;
|
||||||
|
- (IBAction)removeSelected:(id)sender;
|
||||||
|
- (IBAction)clear:(id)sender;
|
||||||
|
@end
|
||||||
57
cocoa/base/IgnoreListDialog.m
Normal file
57
cocoa/base/IgnoreListDialog.m
Normal file
@@ -0,0 +1,57 @@
|
|||||||
|
/*
|
||||||
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
|
which should be included with this package. The terms are also available at
|
||||||
|
http://www.hardcoded.net/licenses/bsd_license
|
||||||
|
*/
|
||||||
|
|
||||||
|
#import "IgnoreListDialog.h"
|
||||||
|
#import "HSPyUtil.h"
|
||||||
|
|
||||||
|
@implementation IgnoreListDialog
|
||||||
|
- (id)initWithPyRef:(PyObject *)aPyRef
|
||||||
|
{
|
||||||
|
self = [super initWithWindowNibName:@"IgnoreListDialog"];
|
||||||
|
[self window]; //So the detailsTable is initialized.
|
||||||
|
model = [[PyIgnoreListDialog alloc] initWithModel:aPyRef];
|
||||||
|
[model bindCallback:createCallback(@"IgnoreListDialogView", self)];
|
||||||
|
ignoreListTable = [[HSTable alloc] initWithPyRef:[model ignoreListTable] tableView:ignoreListTableView];
|
||||||
|
[self initializeColumns];
|
||||||
|
return self;
|
||||||
|
}
|
||||||
|
|
||||||
|
- (void)dealloc
|
||||||
|
{
|
||||||
|
[ignoreListTable release];
|
||||||
|
[model release];
|
||||||
|
[super dealloc];
|
||||||
|
}
|
||||||
|
|
||||||
|
- (void)initializeColumns
|
||||||
|
{
|
||||||
|
HSColumnDef defs[] = {
|
||||||
|
{@"path1", 240, 40, 0, NO, nil},
|
||||||
|
{@"path2", 240, 40, 0, NO, nil},
|
||||||
|
nil
|
||||||
|
};
|
||||||
|
[[ignoreListTable columns] initializeColumns:defs];
|
||||||
|
[[ignoreListTable columns] setColumnsAsReadOnly];
|
||||||
|
}
|
||||||
|
|
||||||
|
- (IBAction)removeSelected:(id)sender
|
||||||
|
{
|
||||||
|
[model removeSelected];
|
||||||
|
}
|
||||||
|
|
||||||
|
- (IBAction)clear:(id)sender
|
||||||
|
{
|
||||||
|
[model clear];
|
||||||
|
}
|
||||||
|
|
||||||
|
/* model --> view */
|
||||||
|
- (void)show
|
||||||
|
{
|
||||||
|
[self showWindow:self];
|
||||||
|
}
|
||||||
|
@end
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
which should be included with this package. The terms are also available at
|
which should be included with this package. The terms are also available at
|
||||||
@@ -7,25 +7,25 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#import <Cocoa/Cocoa.h>
|
#import <Cocoa/Cocoa.h>
|
||||||
#import "HSWindowController.h"
|
|
||||||
#import "PyApp.h"
|
|
||||||
#import "PyPrioritizeDialog.h"
|
#import "PyPrioritizeDialog.h"
|
||||||
#import "HSPopUpList.h"
|
#import "HSPopUpList.h"
|
||||||
#import "HSSelectableList.h"
|
#import "HSSelectableList.h"
|
||||||
#import "PrioritizeList.h"
|
#import "PrioritizeList.h"
|
||||||
|
#import "PyDupeGuru.h"
|
||||||
|
|
||||||
@interface PrioritizeDialog : HSWindowController
|
@interface PrioritizeDialog : NSWindowController
|
||||||
{
|
{
|
||||||
IBOutlet NSPopUpButton *categoryPopUpView;
|
IBOutlet NSPopUpButton *categoryPopUpView;
|
||||||
IBOutlet NSTableView *criteriaTableView;
|
IBOutlet NSTableView *criteriaTableView;
|
||||||
IBOutlet NSTableView *prioritizationTableView;
|
IBOutlet NSTableView *prioritizationTableView;
|
||||||
|
|
||||||
|
PyPrioritizeDialog *model;
|
||||||
HSPopUpList *categoryPopUp;
|
HSPopUpList *categoryPopUp;
|
||||||
HSSelectableList *criteriaList;
|
HSSelectableList *criteriaList;
|
||||||
PrioritizeList *prioritizationList;
|
PrioritizeList *prioritizationList;
|
||||||
}
|
}
|
||||||
- (id)initWithPy:(PyApp *)aPy;
|
- (id)initWithApp:(PyDupeGuru *)aApp;
|
||||||
- (PyPrioritizeDialog *)py;
|
- (PyPrioritizeDialog *)model;
|
||||||
|
|
||||||
- (IBAction)addSelected:(id)sender;
|
- (IBAction)addSelected:(id)sender;
|
||||||
- (IBAction)removeSelected:(id)sender;
|
- (IBAction)removeSelected:(id)sender;
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
which should be included with this package. The terms are also available at
|
which should be included with this package. The terms are also available at
|
||||||
@@ -7,50 +7,54 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#import "PrioritizeDialog.h"
|
#import "PrioritizeDialog.h"
|
||||||
|
#import "HSPyUtil.h"
|
||||||
|
|
||||||
@implementation PrioritizeDialog
|
@implementation PrioritizeDialog
|
||||||
- (id)initWithPy:(PyApp *)aPy
|
- (id)initWithApp:(PyDupeGuru *)aApp
|
||||||
{
|
{
|
||||||
self = [super initWithNibName:@"PrioritizeDialog" pyClassName:@"PyPrioritizeDialog" pyParent:aPy];
|
self = [super initWithWindowNibName:@"PrioritizeDialog"];
|
||||||
[self window];
|
[self window];
|
||||||
categoryPopUp = [[HSPopUpList alloc] initWithPy:[[self py] categoryList] view:categoryPopUpView];
|
model = [[PyPrioritizeDialog alloc] initWithApp:[aApp pyRef]];
|
||||||
criteriaList = [[HSSelectableList alloc] initWithPy:[[self py] criteriaList] view:criteriaTableView];
|
categoryPopUp = [[HSPopUpList alloc] initWithPyRef:[[self model] categoryList] popupView:categoryPopUpView];
|
||||||
prioritizationList = [[PrioritizeList alloc] initWithPy:[[self py] prioritizationList] view:prioritizationTableView];
|
criteriaList = [[HSSelectableList alloc] initWithPyRef:[[self model] criteriaList] tableView:criteriaTableView];
|
||||||
[self connect];
|
prioritizationList = [[PrioritizeList alloc] initWithPyRef:[[self model] prioritizationList] tableView:prioritizationTableView];
|
||||||
|
[model bindCallback:createCallback(@"PrioritizeDialogView", self)];
|
||||||
return self;
|
return self;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)dealloc
|
- (void)dealloc
|
||||||
{
|
{
|
||||||
[self disconnect];
|
|
||||||
[categoryPopUp release];
|
[categoryPopUp release];
|
||||||
[criteriaList release];
|
[criteriaList release];
|
||||||
[prioritizationList release];
|
[prioritizationList release];
|
||||||
|
[model release];
|
||||||
[super dealloc];
|
[super dealloc];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (PyPrioritizeDialog *)py
|
- (PyPrioritizeDialog *)model
|
||||||
{
|
{
|
||||||
return (PyPrioritizeDialog *)py;
|
return (PyPrioritizeDialog *)model;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)addSelected:(id)sender
|
- (IBAction)addSelected:(id)sender
|
||||||
{
|
{
|
||||||
[[self py] addSelected];
|
[[self model] addSelected];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)removeSelected:(id)sender
|
- (IBAction)removeSelected:(id)sender
|
||||||
{
|
{
|
||||||
[[self py] removeSelected];
|
[[self model] removeSelected];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)ok:(id)sender
|
- (IBAction)ok:(id)sender
|
||||||
{
|
{
|
||||||
[NSApp stopModal];
|
[NSApp stopModal];
|
||||||
|
[self close];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)cancel:(id)sender
|
- (IBAction)cancel:(id)sender
|
||||||
{
|
{
|
||||||
[NSApp abortModal];
|
[NSApp abortModal];
|
||||||
|
[self close];
|
||||||
}
|
}
|
||||||
@end
|
@end
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
which should be included with this package. The terms are also available at
|
which should be included with this package. The terms are also available at
|
||||||
@@ -11,5 +11,6 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
#import "PyPrioritizeList.h"
|
#import "PyPrioritizeList.h"
|
||||||
|
|
||||||
@interface PrioritizeList : HSSelectableList {}
|
@interface PrioritizeList : HSSelectableList {}
|
||||||
- (PyPrioritizeList *)py;
|
- (id)initWithPyRef:(PyObject *)aPyRef tableView:(NSTableView *)aTableView;
|
||||||
|
- (PyPrioritizeList *)model;
|
||||||
@end
|
@end
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
which should be included with this package. The terms are also available at
|
which should be included with this package. The terms are also available at
|
||||||
@@ -11,9 +11,16 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
#import "Consts.h"
|
#import "Consts.h"
|
||||||
|
|
||||||
@implementation PrioritizeList
|
@implementation PrioritizeList
|
||||||
- (PyPrioritizeList *)py
|
- (id)initWithPyRef:(PyObject *)aPyRef tableView:(NSTableView *)aTableView
|
||||||
{
|
{
|
||||||
return (PyPrioritizeList *)py;
|
self = [super initWithPyRef:aPyRef wrapperClass:[PyPrioritizeList class]
|
||||||
|
callbackClassName:@"PrioritizeListView" view:aTableView];
|
||||||
|
return self;
|
||||||
|
}
|
||||||
|
|
||||||
|
- (PyPrioritizeList *)model
|
||||||
|
{
|
||||||
|
return (PyPrioritizeList *)model;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)setView:(NSTableView *)aTableView
|
- (void)setView:(NSTableView *)aTableView
|
||||||
@@ -45,7 +52,7 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
NSPasteboard* pboard = [info draggingPasteboard];
|
NSPasteboard* pboard = [info draggingPasteboard];
|
||||||
NSData* rowData = [pboard dataForType:DGPrioritizeIndexPasteboardType];
|
NSData* rowData = [pboard dataForType:DGPrioritizeIndexPasteboardType];
|
||||||
NSIndexSet* rowIndexes = [NSKeyedUnarchiver unarchiveObjectWithData:rowData];
|
NSIndexSet* rowIndexes = [NSKeyedUnarchiver unarchiveObjectWithData:rowData];
|
||||||
[[self py] moveIndexes:[Utils indexSet2Array:rowIndexes] toIndex:row];
|
[[self model] moveIndexes:[Utils indexSet2Array:rowIndexes] toIndex:row];
|
||||||
return YES;
|
return YES;
|
||||||
}
|
}
|
||||||
@end
|
@end
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
which should be included with this package. The terms are also available at
|
which should be included with this package. The terms are also available at
|
||||||
@@ -7,19 +7,18 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#import <Cocoa/Cocoa.h>
|
#import <Cocoa/Cocoa.h>
|
||||||
#import "HSWindowController.h"
|
|
||||||
#import "PyApp.h"
|
|
||||||
#import "PyProblemDialog.h"
|
#import "PyProblemDialog.h"
|
||||||
#import "HSTable.h"
|
#import "HSTable.h"
|
||||||
|
|
||||||
@interface ProblemDialog : HSWindowController
|
@interface ProblemDialog : NSWindowController
|
||||||
{
|
{
|
||||||
IBOutlet NSTableView *problemTableView;
|
IBOutlet NSTableView *problemTableView;
|
||||||
|
|
||||||
|
PyProblemDialog *model;
|
||||||
HSTable *problemTable;
|
HSTable *problemTable;
|
||||||
}
|
}
|
||||||
- (id)initWithPy:(PyApp *)aPy;
|
- (id)initWithPyRef:(PyObject *)aPyRef;
|
||||||
- (PyProblemDialog *)py;
|
|
||||||
|
|
||||||
|
- (void)initializeColumns;
|
||||||
- (IBAction)revealSelected:(id)sender;
|
- (IBAction)revealSelected:(id)sender;
|
||||||
@end
|
@end
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
which should be included with this package. The terms are also available at
|
which should be included with this package. The terms are also available at
|
||||||
@@ -10,31 +10,35 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
#import "Utils.h"
|
#import "Utils.h"
|
||||||
|
|
||||||
@implementation ProblemDialog
|
@implementation ProblemDialog
|
||||||
- (id)initWithPy:(PyApp *)aPy
|
- (id)initWithPyRef:(PyObject *)aPyRef
|
||||||
{
|
{
|
||||||
self = [super initWithNibName:@"ProblemDialog" pyClassName:@"PyProblemDialog" pyParent:aPy];
|
self = [super initWithWindowNibName:@"ProblemDialog"];
|
||||||
[self window]; //So the detailsTable is initialized.
|
[self window]; //So the detailsTable is initialized.
|
||||||
problemTable = [[HSTable alloc] initWithPyClassName:@"PyProblemTable" pyParent:[self py] view:problemTableView];
|
model = [[PyProblemDialog alloc] initWithModel:aPyRef];
|
||||||
[self connect];
|
problemTable = [[HSTable alloc] initWithPyRef:[model problemTable] tableView:problemTableView];
|
||||||
[problemTable connect];
|
[self initializeColumns];
|
||||||
return self;
|
return self;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)dealloc
|
- (void)dealloc
|
||||||
{
|
{
|
||||||
[problemTable disconnect];
|
|
||||||
[self disconnect];
|
|
||||||
[problemTable release];
|
[problemTable release];
|
||||||
|
[model release];
|
||||||
[super dealloc];
|
[super dealloc];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (PyProblemDialog *)py
|
- (void)initializeColumns
|
||||||
{
|
{
|
||||||
return (PyProblemDialog *)py;
|
HSColumnDef defs[] = {
|
||||||
|
{@"path", 202, 40, 0, NO, nil},
|
||||||
|
{@"msg", 228, 40, 0, NO, nil},
|
||||||
|
nil
|
||||||
|
};
|
||||||
|
[[problemTable columns] initializeColumns:defs];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)revealSelected:(id)sender
|
- (IBAction)revealSelected:(id)sender
|
||||||
{
|
{
|
||||||
[[self py] revealSelected];
|
[model revealSelected];
|
||||||
}
|
}
|
||||||
@end
|
@end
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
/*
|
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
|
||||||
which should be included with this package. The terms are also available at
|
|
||||||
http://www.hardcoded.net/licenses/bsd_license
|
|
||||||
*/
|
|
||||||
|
|
||||||
#import <Cocoa/Cocoa.h>
|
|
||||||
#import "PyGUI.h"
|
|
||||||
|
|
||||||
@interface PyDetailsPanel : PyGUI
|
|
||||||
- (NSInteger)numberOfRows;
|
|
||||||
- (id)valueForColumn:(NSString *)column row:(NSInteger)row;
|
|
||||||
@end
|
|
||||||
@@ -1,14 +0,0 @@
|
|||||||
/*
|
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
|
||||||
which should be included with this package. The terms are also available at
|
|
||||||
http://www.hardcoded.net/licenses/bsd_license
|
|
||||||
*/
|
|
||||||
|
|
||||||
#import <Cocoa/Cocoa.h>
|
|
||||||
#import "PyOutline.h"
|
|
||||||
|
|
||||||
@interface PyDirectoryOutline : PyOutline
|
|
||||||
- (void)addDirectory:(NSString *)directoryPath;
|
|
||||||
@end
|
|
||||||
@@ -1,59 +0,0 @@
|
|||||||
/*
|
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
|
||||||
which should be included with this package. The terms are also available at
|
|
||||||
http://www.hardcoded.net/licenses/bsd_license
|
|
||||||
*/
|
|
||||||
|
|
||||||
#import <Cocoa/Cocoa.h>
|
|
||||||
#import "PyApp.h"
|
|
||||||
|
|
||||||
@interface PyDupeGuruBase : PyApp
|
|
||||||
- (void)bindCocoa:(id)cocoa;
|
|
||||||
//Actions
|
|
||||||
- (NSNumber *)addDirectory:(NSString *)name;
|
|
||||||
- (void)removeDirectory:(NSNumber *)index;
|
|
||||||
- (void)loadResultsFrom:(NSString *)filename;
|
|
||||||
- (void)saveResultsAs:(NSString *)filename;
|
|
||||||
- (void)loadSession;
|
|
||||||
- (void)saveSession;
|
|
||||||
- (void)clearIgnoreList;
|
|
||||||
- (void)purgeIgnoreList;
|
|
||||||
- (NSString *)exportToXHTMLwithColumns:(NSArray *)aColIds;
|
|
||||||
- (void)invokeCommand:(NSString *)cmd;
|
|
||||||
|
|
||||||
- (void)doScan;
|
|
||||||
|
|
||||||
- (void)toggleSelectedMark;
|
|
||||||
- (void)markAll;
|
|
||||||
- (void)markInvert;
|
|
||||||
- (void)markNone;
|
|
||||||
|
|
||||||
- (void)addSelectedToIgnoreList;
|
|
||||||
- (void)openSelected;
|
|
||||||
- (void)revealSelected;
|
|
||||||
- (void)makeSelectedReference;
|
|
||||||
- (void)applyFilter:(NSString *)filter;
|
|
||||||
|
|
||||||
- (void)copyOrMove:(NSNumber *)aCopy markedTo:(NSString *)destination recreatePath:(NSNumber *)aRecreateType;
|
|
||||||
- (void)deleteMarked;
|
|
||||||
- (void)hardlinkMarked;
|
|
||||||
- (void)removeMarked;
|
|
||||||
|
|
||||||
//Data
|
|
||||||
- (NSNumber *)getIgnoreListCount;
|
|
||||||
- (NSNumber *)getMarkCount;
|
|
||||||
- (BOOL)scanWasProblematic;
|
|
||||||
- (BOOL)resultsAreModified;
|
|
||||||
- (NSArray *)deltaColumns;
|
|
||||||
|
|
||||||
//Scanning options
|
|
||||||
- (void)setScanType:(NSNumber *)scan_type;
|
|
||||||
- (void)setMinMatchPercentage:(NSNumber *)percentage;
|
|
||||||
- (void)setMixFileKind:(BOOL)mix_file_kind;
|
|
||||||
- (void)setEscapeFilterRegexp:(BOOL)escape_filter_regexp;
|
|
||||||
- (void)setRemoveEmptyFolders:(BOOL)remove_empty_folders;
|
|
||||||
- (void)setIgnoreHardlinkMatches:(BOOL)ignore_hardlink_matches;
|
|
||||||
- (void)setSizeThreshold:(NSInteger)size_threshold;
|
|
||||||
@end
|
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
/*
|
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
|
||||||
which should be included with this package. The terms are also available at
|
|
||||||
http://www.hardcoded.net/licenses/bsd_license
|
|
||||||
*/
|
|
||||||
|
|
||||||
#import <Cocoa/Cocoa.h>
|
|
||||||
#import "PyGUI.h"
|
|
||||||
|
|
||||||
@interface PyExtraFairwareReminder : PyGUI
|
|
||||||
- (void)start;
|
|
||||||
- (void)updateButton;
|
|
||||||
@end
|
|
||||||
@@ -1,20 +0,0 @@
|
|||||||
/*
|
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
|
||||||
which should be included with this package. The terms are also available at
|
|
||||||
http://www.hardcoded.net/licenses/bsd_license
|
|
||||||
*/
|
|
||||||
|
|
||||||
#import <Cocoa/Cocoa.h>
|
|
||||||
#import "PyGUI.h"
|
|
||||||
#import "PySelectableList.h"
|
|
||||||
|
|
||||||
@interface PyPrioritizeDialog : PyGUI
|
|
||||||
- (PySelectableList *)categoryList;
|
|
||||||
- (PySelectableList *)criteriaList;
|
|
||||||
- (PySelectableList *)prioritizationList;
|
|
||||||
- (void)addSelected;
|
|
||||||
- (void)removeSelected;
|
|
||||||
- (void)performReprioritization;
|
|
||||||
@end
|
|
||||||
@@ -1,14 +0,0 @@
|
|||||||
/*
|
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
|
||||||
which should be included with this package. The terms are also available at
|
|
||||||
http://www.hardcoded.net/licenses/bsd_license
|
|
||||||
*/
|
|
||||||
|
|
||||||
#import <Cocoa/Cocoa.h>
|
|
||||||
#import "PySelectableList.h"
|
|
||||||
|
|
||||||
@interface PyPrioritizeList : PySelectableList
|
|
||||||
- (void)moveIndexes:(NSArray *)indexes toIndex:(NSInteger)destIndex;
|
|
||||||
@end
|
|
||||||
@@ -1,14 +0,0 @@
|
|||||||
/*
|
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
|
||||||
which should be included with this package. The terms are also available at
|
|
||||||
http://www.hardcoded.net/licenses/bsd_license
|
|
||||||
*/
|
|
||||||
|
|
||||||
#import <Cocoa/Cocoa.h>
|
|
||||||
#import "PyGUI.h"
|
|
||||||
|
|
||||||
@interface PyProblemDialog : PyGUI
|
|
||||||
- (void)revealSelected;
|
|
||||||
@end
|
|
||||||
@@ -1,25 +0,0 @@
|
|||||||
/*
|
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
|
||||||
which should be included with this package. The terms are also available at
|
|
||||||
http://www.hardcoded.net/licenses/bsd_license
|
|
||||||
*/
|
|
||||||
|
|
||||||
#import <Cocoa/Cocoa.h>
|
|
||||||
#import "PyTable.h"
|
|
||||||
|
|
||||||
@interface PyResultTable : PyTable
|
|
||||||
- (BOOL)powerMarkerMode;
|
|
||||||
- (void)setPowerMarkerMode:(BOOL)aPowerMarkerMode;
|
|
||||||
- (BOOL)deltaValuesMode;
|
|
||||||
- (void)setDeltaValuesMode:(BOOL)aDeltaValuesMode;
|
|
||||||
|
|
||||||
- (NSString *)valueForRow:(NSInteger)rowIndex column:(NSInteger)aColumn;
|
|
||||||
- (BOOL)renameSelected:(NSString *)aNewName;
|
|
||||||
- (void)sortBy:(NSInteger)aIdentifier ascending:(BOOL)aAscending;
|
|
||||||
- (void)markSelected;
|
|
||||||
- (void)removeSelected;
|
|
||||||
- (NSInteger)selectedDupeCount;
|
|
||||||
- (NSString *)pathAtIndex:(NSInteger)index;
|
|
||||||
@end
|
|
||||||
@@ -1,14 +0,0 @@
|
|||||||
/*
|
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
|
||||||
which should be included with this package. The terms are also available at
|
|
||||||
http://www.hardcoded.net/licenses/bsd_license
|
|
||||||
*/
|
|
||||||
|
|
||||||
#import <Cocoa/Cocoa.h>
|
|
||||||
#import "PyGUI.h"
|
|
||||||
|
|
||||||
@interface PyStatsLabel : PyGUI
|
|
||||||
- (NSString *)display;
|
|
||||||
@end
|
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
which should be included with this package. The terms are also available at
|
which should be included with this package. The terms are also available at
|
||||||
@@ -13,15 +13,12 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
|
|
||||||
@interface ResultTable : HSTable <QLPreviewPanelDataSource, QLPreviewPanelDelegate>
|
@interface ResultTable : HSTable <QLPreviewPanelDataSource, QLPreviewPanelDelegate>
|
||||||
{
|
{
|
||||||
NSIndexSet *_deltaColumns;
|
NSSet *_deltaColumns;
|
||||||
}
|
}
|
||||||
- (id)initWithPyParent:(id)aPyParent view:(NSTableView *)aTableView;
|
- (id)initWithPyRef:(PyObject *)aPyRef view:(NSTableView *)aTableView;
|
||||||
- (PyResultTable *)py;
|
- (PyResultTable *)model;
|
||||||
- (BOOL)powerMarkerMode;
|
- (BOOL)powerMarkerMode;
|
||||||
- (void)setPowerMarkerMode:(BOOL)aPowerMarkerMode;
|
- (void)setPowerMarkerMode:(BOOL)aPowerMarkerMode;
|
||||||
- (BOOL)deltaValuesMode;
|
- (BOOL)deltaValuesMode;
|
||||||
- (void)setDeltaValuesMode:(BOOL)aDeltaValuesMode;
|
- (void)setDeltaValuesMode:(BOOL)aDeltaValuesMode;
|
||||||
- (void)setDeltaColumns:(NSIndexSet *)aDeltaColumns;
|
|
||||||
- (NSInteger)selectedDupeCount;
|
|
||||||
- (void)removeSelected;
|
|
||||||
@end;
|
@end;
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
which should be included with this package. The terms are also available at
|
which should be included with this package. The terms are also available at
|
||||||
@@ -18,23 +18,22 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
@end
|
@end
|
||||||
|
|
||||||
@implementation ResultTable
|
@implementation ResultTable
|
||||||
- (id)initWithPyParent:(id)aPyParent view:(NSTableView *)aTableView
|
- (id)initWithPyRef:(PyObject *)aPyRef view:(NSTableView *)aTableView
|
||||||
{
|
{
|
||||||
self = [super initWithPyClassName:@"PyResultTable" pyParent:aPyParent view:aTableView];
|
self = [super initWithPyRef:aPyRef wrapperClass:[PyResultTable class] callbackClassName:@"ResultTableView" view:aTableView];
|
||||||
[self connect];
|
_deltaColumns = [[NSSet setWithArray:[[self model] deltaColumns]] retain];
|
||||||
return self;
|
return self;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)dealloc
|
- (void)dealloc
|
||||||
{
|
{
|
||||||
[self disconnect];
|
|
||||||
[_deltaColumns release];
|
[_deltaColumns release];
|
||||||
[super dealloc];
|
[super dealloc];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (PyResultTable *)py
|
- (PyResultTable *)model
|
||||||
{
|
{
|
||||||
return (PyResultTable *)py;
|
return (PyResultTable *)model;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Private */
|
/* Private */
|
||||||
@@ -60,45 +59,22 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
/* Public */
|
/* Public */
|
||||||
- (BOOL)powerMarkerMode
|
- (BOOL)powerMarkerMode
|
||||||
{
|
{
|
||||||
return [[self py] powerMarkerMode];
|
return [[self model] powerMarkerMode];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)setPowerMarkerMode:(BOOL)aPowerMarkerMode
|
- (void)setPowerMarkerMode:(BOOL)aPowerMarkerMode
|
||||||
{
|
{
|
||||||
[[self py] setPowerMarkerMode:aPowerMarkerMode];
|
[[self model] setPowerMarkerMode:aPowerMarkerMode];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (BOOL)deltaValuesMode
|
- (BOOL)deltaValuesMode
|
||||||
{
|
{
|
||||||
return [[self py] deltaValuesMode];
|
return [[self model] deltaValuesMode];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)setDeltaValuesMode:(BOOL)aDeltaValuesMode
|
- (void)setDeltaValuesMode:(BOOL)aDeltaValuesMode
|
||||||
{
|
{
|
||||||
[[self py] setDeltaValuesMode:aDeltaValuesMode];
|
[[self model] setDeltaValuesMode:aDeltaValuesMode];
|
||||||
}
|
|
||||||
|
|
||||||
- (void)setDeltaColumns:(NSIndexSet *)aDeltaColumns
|
|
||||||
{
|
|
||||||
[_deltaColumns release];
|
|
||||||
_deltaColumns = [aDeltaColumns retain];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (NSInteger)selectedDupeCount
|
|
||||||
{
|
|
||||||
return [[self py] selectedDupeCount];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)removeSelected
|
|
||||||
{
|
|
||||||
NSInteger selectedDupeCount = [self selectedDupeCount];
|
|
||||||
if (!selectedDupeCount)
|
|
||||||
return;
|
|
||||||
NSString *msgFmt = TRMSG(@"FileRemovalConfirmMsg");
|
|
||||||
NSString *msg = [NSString stringWithFormat:msgFmt,selectedDupeCount];
|
|
||||||
if ([Dialogs askYesNo:msg] == NSAlertSecondButtonReturn) // NO
|
|
||||||
return;
|
|
||||||
[[self py] removeSelected];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Datasource */
|
/* Datasource */
|
||||||
@@ -106,28 +82,27 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
{
|
{
|
||||||
NSString *identifier = [column identifier];
|
NSString *identifier = [column identifier];
|
||||||
if ([identifier isEqual:@"marked"]) {
|
if ([identifier isEqual:@"marked"]) {
|
||||||
return [[self py] valueForColumn:@"marked" row:row];
|
return [[self model] valueForColumn:@"marked" row:row];
|
||||||
}
|
}
|
||||||
NSInteger columnId = [identifier integerValue];
|
return [[self model] valueForRow:row column:identifier];
|
||||||
return [[self py] valueForRow:row column:columnId];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)tableView:(NSTableView *)aTableView setObjectValue:(id)object forTableColumn:(NSTableColumn *)column row:(NSInteger)row
|
- (void)tableView:(NSTableView *)aTableView setObjectValue:(id)object forTableColumn:(NSTableColumn *)column row:(NSInteger)row
|
||||||
{
|
{
|
||||||
NSString *identifier = [column identifier];
|
NSString *identifier = [column identifier];
|
||||||
if ([identifier isEqual:@"marked"]) {
|
if ([identifier isEqual:@"marked"]) {
|
||||||
[[self py] setValue:object forColumn:identifier row:row];
|
[[self model] setValue:object forColumn:identifier row:row];
|
||||||
}
|
}
|
||||||
else if ([identifier isEqual:@"0"]) {
|
else if ([identifier isEqual:@"name"]) {
|
||||||
NSString *oldName = [[self py] valueForRow:row column:0];
|
NSString *oldName = [[self model] valueForRow:row column:identifier];
|
||||||
NSString *newName = object;
|
NSString *newName = object;
|
||||||
if (![newName isEqual:oldName]) {
|
if (![newName isEqual:oldName]) {
|
||||||
BOOL renamed = [[self py] renameSelected:newName];
|
BOOL renamed = [[self model] renameSelected:newName];
|
||||||
if (!renamed) {
|
if (!renamed) {
|
||||||
[Dialogs showMessage:[NSString stringWithFormat:TRMSG(@"FilenameAlreadyExistsMsg"), newName]];
|
[Dialogs showMessage:[NSString stringWithFormat:TR(@"The name '%@' already exists."), newName]];
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
[tableView setNeedsDisplay:YES];
|
[[self view] setNeedsDisplay:YES];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -136,16 +111,16 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
/* Delegate */
|
/* Delegate */
|
||||||
- (void)tableView:(NSTableView *)aTableView didClickTableColumn:(NSTableColumn *)tableColumn
|
- (void)tableView:(NSTableView *)aTableView didClickTableColumn:(NSTableColumn *)tableColumn
|
||||||
{
|
{
|
||||||
if ([[tableView sortDescriptors] count] < 1)
|
if ([[[self view] sortDescriptors] count] < 1)
|
||||||
return;
|
return;
|
||||||
NSSortDescriptor *sd = [[tableView sortDescriptors] objectAtIndex:0];
|
NSSortDescriptor *sd = [[[self view] sortDescriptors] objectAtIndex:0];
|
||||||
[[self py] sortBy:[[sd key] integerValue] ascending:[sd ascending]];
|
[[self model] sortBy:[sd key] ascending:[sd ascending]];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)tableView:(NSTableView *)aTableView willDisplayCell:(id)cell forTableColumn:(NSTableColumn *)column row:(NSInteger)row
|
- (void)tableView:(NSTableView *)aTableView willDisplayCell:(id)cell forTableColumn:(NSTableColumn *)column row:(NSInteger)row
|
||||||
{
|
{
|
||||||
BOOL isSelected = [tableView isRowSelected:row];
|
BOOL isSelected = [[self view] isRowSelected:row];
|
||||||
BOOL isMarkable = n2b([[self py] valueForColumn:@"markable" row:row]);
|
BOOL isMarkable = n2b([[self model] valueForColumn:@"markable" row:row]);
|
||||||
if ([[column identifier] isEqual:@"marked"]) {
|
if ([[column identifier] isEqual:@"marked"]) {
|
||||||
[cell setEnabled:isMarkable];
|
[cell setEnabled:isMarkable];
|
||||||
// Low-tech solution, for indentation, but it works...
|
// Low-tech solution, for indentation, but it works...
|
||||||
@@ -159,8 +134,7 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
}
|
}
|
||||||
else if (isMarkable) {
|
else if (isMarkable) {
|
||||||
if ([self deltaValuesMode]) {
|
if ([self deltaValuesMode]) {
|
||||||
NSInteger i = [[column identifier] integerValue];
|
if ([_deltaColumns containsObject:[column identifier]]) {
|
||||||
if ([_deltaColumns containsIndex:i]) {
|
|
||||||
color = [NSColor orangeColor];
|
color = [NSColor orangeColor];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -174,27 +148,27 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
|
|
||||||
- (BOOL)tableViewHadDeletePressed:(NSTableView *)tableView
|
- (BOOL)tableViewHadDeletePressed:(NSTableView *)tableView
|
||||||
{
|
{
|
||||||
[self removeSelected];
|
[[self model] removeSelected];
|
||||||
return YES;
|
return YES;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (BOOL)tableViewHadSpacePressed:(NSTableView *)tableView
|
- (BOOL)tableViewHadSpacePressed:(NSTableView *)tableView
|
||||||
{
|
{
|
||||||
[[self py] markSelected];
|
[[self model] markSelected];
|
||||||
return YES;
|
return YES;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Quicklook */
|
/* Quicklook */
|
||||||
- (NSInteger)numberOfPreviewItemsInPreviewPanel:(QLPreviewPanel *)panel
|
- (NSInteger)numberOfPreviewItemsInPreviewPanel:(QLPreviewPanel *)panel
|
||||||
{
|
{
|
||||||
return [[[self py] selectedRows] count];
|
return [[[self model] selectedRows] count];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (id <QLPreviewItem>)previewPanel:(QLPreviewPanel *)panel previewItemAtIndex:(NSInteger)index
|
- (id <QLPreviewItem>)previewPanel:(QLPreviewPanel *)panel previewItemAtIndex:(NSInteger)index
|
||||||
{
|
{
|
||||||
NSArray *selectedRows = [[self py] selectedRows];
|
NSArray *selectedRows = [[self model] selectedRows];
|
||||||
NSInteger absIndex = n2i([selectedRows objectAtIndex:index]);
|
NSInteger absIndex = n2i([selectedRows objectAtIndex:index]);
|
||||||
NSString *path = [[self py] pathAtIndex:absIndex];
|
NSString *path = [[self model] pathAtIndex:absIndex];
|
||||||
return [[HSQLPreviewItem alloc] initWithUrl:[NSURL fileURLWithPath:path] title:path];
|
return [[HSQLPreviewItem alloc] initWithUrl:[NSURL fileURLWithPath:path] title:path];
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -211,6 +185,6 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
/* Python --> Cocoa */
|
/* Python --> Cocoa */
|
||||||
- (void)invalidateMarkings
|
- (void)invalidateMarkings
|
||||||
{
|
{
|
||||||
[tableView setNeedsDisplay:YES];
|
[[self view] setNeedsDisplay:YES];
|
||||||
}
|
}
|
||||||
@end
|
@end
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
which should be included with this package. The terms are also available at
|
which should be included with this package. The terms are also available at
|
||||||
@@ -11,6 +11,7 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
#import "StatsLabel.h"
|
#import "StatsLabel.h"
|
||||||
#import "ResultTable.h"
|
#import "ResultTable.h"
|
||||||
#import "ProblemDialog.h"
|
#import "ProblemDialog.h"
|
||||||
|
#import "DeletionOptions.h"
|
||||||
#import "HSTableView.h"
|
#import "HSTableView.h"
|
||||||
#import "PyDupeGuru.h"
|
#import "PyDupeGuru.h"
|
||||||
|
|
||||||
@@ -20,17 +21,18 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
{
|
{
|
||||||
@protected
|
@protected
|
||||||
IBOutlet NSSegmentedControl *optionsSwitch;
|
IBOutlet NSSegmentedControl *optionsSwitch;
|
||||||
|
IBOutlet NSToolbarItem *optionsToolbarItem;
|
||||||
IBOutlet HSTableView *matches;
|
IBOutlet HSTableView *matches;
|
||||||
IBOutlet NSTextField *stats;
|
IBOutlet NSTextField *stats;
|
||||||
IBOutlet NSSearchField *filterField;
|
IBOutlet NSSearchField *filterField;
|
||||||
|
|
||||||
AppDelegateBase *app;
|
AppDelegateBase *app;
|
||||||
PyDupeGuruBase *py;
|
PyDupeGuru *model;
|
||||||
NSMenu *columnsMenu;
|
NSMenu *columnsMenu;
|
||||||
NSMutableArray *_resultColumns;
|
|
||||||
ResultTable *table;
|
ResultTable *table;
|
||||||
StatsLabel *statsLabel;
|
StatsLabel *statsLabel;
|
||||||
ProblemDialog *problemDialog;
|
ProblemDialog *problemDialog;
|
||||||
|
DeletionOptions *deletionOptions;
|
||||||
QLPreviewPanel* previewPanel;
|
QLPreviewPanel* previewPanel;
|
||||||
}
|
}
|
||||||
- (id)initWithParentApp:(AppDelegateBase *)app;
|
- (id)initWithParentApp:(AppDelegateBase *)app;
|
||||||
@@ -41,21 +43,17 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
|
|
||||||
/* Helpers */
|
/* Helpers */
|
||||||
- (void)fillColumnsMenu;
|
- (void)fillColumnsMenu;
|
||||||
- (NSTableColumn *)getColumnForIdentifier:(NSInteger)aIdentifier title:(NSString *)aTitle width:(NSInteger)aWidth refCol:(NSTableColumn *)aColumn;
|
|
||||||
- (NSArray *)getColumnsOrder;
|
|
||||||
- (NSDictionary *)getColumnsWidth;
|
|
||||||
- (void)restoreColumnsPosition:(NSArray *)aColumnsOrder widths:(NSDictionary *)aColumnsWidth;
|
|
||||||
- (void)sendMarkedToTrash:(BOOL)hardlinkDeleted;
|
|
||||||
- (void)updateOptionSegments;
|
- (void)updateOptionSegments;
|
||||||
|
- (void)showProblemDialog;
|
||||||
|
- (void)adjustUIToLocalization;
|
||||||
|
|
||||||
/* Actions */
|
/* Actions */
|
||||||
- (IBAction)clearIgnoreList:(id)sender;
|
|
||||||
- (IBAction)changeOptions:(id)sender;
|
- (IBAction)changeOptions:(id)sender;
|
||||||
- (IBAction)copyMarked:(id)sender;
|
- (IBAction)copyMarked:(id)sender;
|
||||||
- (IBAction)deleteMarked:(id)sender;
|
- (IBAction)trashMarked:(id)sender;
|
||||||
- (IBAction)hardlinkMarked:(id)sender;
|
|
||||||
- (IBAction)exportToXHTML:(id)sender;
|
- (IBAction)exportToXHTML:(id)sender;
|
||||||
- (IBAction)filter:(id)sender;
|
- (IBAction)filter:(id)sender;
|
||||||
|
- (IBAction)focusOnFilterField:(id)sender;
|
||||||
- (IBAction)ignoreSelected:(id)sender;
|
- (IBAction)ignoreSelected:(id)sender;
|
||||||
- (IBAction)invokeCustomCommand:(id)sender;
|
- (IBAction)invokeCustomCommand:(id)sender;
|
||||||
- (IBAction)markAll:(id)sender;
|
- (IBAction)markAll:(id)sender;
|
||||||
@@ -79,7 +77,4 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
- (IBAction)toggleDetailsPanel:(id)sender;
|
- (IBAction)toggleDetailsPanel:(id)sender;
|
||||||
- (IBAction)togglePowerMarker:(id)sender;
|
- (IBAction)togglePowerMarker:(id)sender;
|
||||||
- (IBAction)toggleQuicklookPanel:(id)sender;
|
- (IBAction)toggleQuicklookPanel:(id)sender;
|
||||||
|
|
||||||
/* Notifications */
|
|
||||||
- (void)jobCompleted:(NSNotification *)aNotification;
|
|
||||||
@end
|
@end
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
which should be included with this package. The terms are also available at
|
which should be included with this package. The terms are also available at
|
||||||
@@ -19,21 +19,21 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
{
|
{
|
||||||
self = [super initWithWindowNibName:@"ResultWindow"];
|
self = [super initWithWindowNibName:@"ResultWindow"];
|
||||||
app = aApp;
|
app = aApp;
|
||||||
py = [app py];
|
model = [app model];
|
||||||
[[self window] setTitle:fmt(@"%@ Results", [py appName])];
|
[[self window] setTitle:fmt(@"%@ Results", [model appName])];
|
||||||
columnsMenu = [app columnsMenu];
|
columnsMenu = [app columnsMenu];
|
||||||
/* Put a cute iTunes-like bottom bar */
|
/* Put a cute iTunes-like bottom bar */
|
||||||
[[self window] setContentBorderThickness:28 forEdge:NSMinYEdge];
|
[[self window] setContentBorderThickness:28 forEdge:NSMinYEdge];
|
||||||
table = [[ResultTable alloc] initWithPyParent:py view:matches];
|
table = [[ResultTable alloc] initWithPyRef:[model resultTable] view:matches];
|
||||||
statsLabel = [[StatsLabel alloc] initWithPyParent:py labelView:stats];
|
statsLabel = [[StatsLabel alloc] initWithPyRef:[model statsLabel] view:stats];
|
||||||
problemDialog = [[ProblemDialog alloc] initWithPy:py];
|
problemDialog = [[ProblemDialog alloc] initWithPyRef:[model problemDialog]];
|
||||||
|
deletionOptions = [[DeletionOptions alloc] initWithPyRef:[model deletionOptions]];
|
||||||
[self initResultColumns];
|
[self initResultColumns];
|
||||||
[self fillColumnsMenu];
|
[self fillColumnsMenu];
|
||||||
[matches setTarget:self];
|
[matches setTarget:self];
|
||||||
[matches setDoubleAction:@selector(openClicked:)];
|
[matches setDoubleAction:@selector(openClicked:)];
|
||||||
[table setDeltaColumns:[Utils array2IndexSet:[py deltaColumns]]];
|
[self adjustUIToLocalization];
|
||||||
|
|
||||||
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(jobCompleted:) name:JobCompletedNotification object:nil];
|
|
||||||
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(jobStarted:) name:JobStarted object:nil];
|
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(jobStarted:) name:JobStarted object:nil];
|
||||||
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(jobInProgress:) name:JobInProgress object:nil];
|
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(jobInProgress:) name:JobInProgress object:nil];
|
||||||
return self;
|
return self;
|
||||||
@@ -50,9 +50,6 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
/* Virtual */
|
/* Virtual */
|
||||||
- (void)initResultColumns
|
- (void)initResultColumns
|
||||||
{
|
{
|
||||||
NSUserDefaults *udc = [NSUserDefaultsController sharedUserDefaultsController];
|
|
||||||
NSTableColumn *refCol = [matches tableColumnWithIdentifier:@"0"];
|
|
||||||
[refCol bind:@"fontSize" toObject:udc withKeyPath:@"values.TableFontSize" options:nil];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)setScanOptions
|
- (void)setScanOptions
|
||||||
@@ -62,14 +59,15 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
/* Helpers */
|
/* Helpers */
|
||||||
- (void)fillColumnsMenu
|
- (void)fillColumnsMenu
|
||||||
{
|
{
|
||||||
// The columns menu is supposed to be empty and initResultColumns must have been called
|
NSArray *menuItems = [[[table columns] model] menuItems];
|
||||||
for (NSTableColumn *col in _resultColumns)
|
for (NSInteger i=0; i < [menuItems count]; i++) {
|
||||||
{
|
NSArray *pair = [menuItems objectAtIndex:i];
|
||||||
NSMenuItem *mi = [columnsMenu addItemWithTitle:[[col headerCell] stringValue] action:@selector(toggleColumn:) keyEquivalent:@""];
|
NSString *display = [pair objectAtIndex:0];
|
||||||
[mi setTag:[[col identifier] integerValue]];
|
BOOL marked = n2b([pair objectAtIndex:1]);
|
||||||
|
NSMenuItem *mi = [columnsMenu addItemWithTitle:display action:@selector(toggleColumn:) keyEquivalent:@""];
|
||||||
[mi setTarget:self];
|
[mi setTarget:self];
|
||||||
if ([[matches tableColumns] containsObject:col])
|
[mi setState:marked ? NSOnState : NSOffState];
|
||||||
[mi setState:NSOnState];
|
[mi setTag:i];
|
||||||
}
|
}
|
||||||
[columnsMenu addItem:[NSMenuItem separatorItem]];
|
[columnsMenu addItem:[NSMenuItem separatorItem]];
|
||||||
NSMenuItem *mi = [columnsMenu addItemWithTitle:TR(@"Reset to Default")
|
NSMenuItem *mi = [columnsMenu addItemWithTitle:TR(@"Reset to Default")
|
||||||
@@ -77,89 +75,6 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
[mi setTarget:self];
|
[mi setTarget:self];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (NSTableColumn *)getColumnForIdentifier:(NSInteger)aIdentifier title:(NSString *)aTitle width:(NSInteger)aWidth refCol:(NSTableColumn *)aColumn
|
|
||||||
{
|
|
||||||
NSNumber *n = [NSNumber numberWithInteger:aIdentifier];
|
|
||||||
NSTableColumn *col = [[NSTableColumn alloc] initWithIdentifier:[n stringValue]];
|
|
||||||
[col setWidth:aWidth];
|
|
||||||
[col setEditable:NO];
|
|
||||||
[[col dataCell] setFont:[[aColumn dataCell] font]];
|
|
||||||
[[col headerCell] setStringValue:aTitle];
|
|
||||||
[col setResizingMask:NSTableColumnUserResizingMask];
|
|
||||||
[col setSortDescriptorPrototype:[[NSSortDescriptor alloc] initWithKey:[n stringValue] ascending:YES]];
|
|
||||||
NSUserDefaults *udc = [NSUserDefaultsController sharedUserDefaultsController];
|
|
||||||
[col bind:@"fontSize" toObject:udc withKeyPath:@"values.TableFontSize" options:nil];
|
|
||||||
return col;
|
|
||||||
}
|
|
||||||
|
|
||||||
//Returns an array of identifiers, in order.
|
|
||||||
- (NSArray *)getColumnsOrder
|
|
||||||
{
|
|
||||||
NSMutableArray *result = [NSMutableArray array];
|
|
||||||
for (NSTableColumn *col in [matches tableColumns]) {
|
|
||||||
NSString *colId = [col identifier];
|
|
||||||
[result addObject:colId];
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
- (NSDictionary *)getColumnsWidth
|
|
||||||
{
|
|
||||||
NSMutableDictionary *result = [NSMutableDictionary dictionary];
|
|
||||||
for (NSTableColumn *col in [matches tableColumns]) {
|
|
||||||
NSString *colId = [col identifier];
|
|
||||||
NSNumber *width = [NSNumber numberWithDouble:[col width]];
|
|
||||||
[result setObject:width forKey:colId];
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)restoreColumnsPosition:(NSArray *)aColumnsOrder widths:(NSDictionary *)aColumnsWidth
|
|
||||||
{
|
|
||||||
for (NSMenuItem *mi in [columnsMenu itemArray]) {
|
|
||||||
if ([mi state] == NSOnState) {
|
|
||||||
[self toggleColumn:mi];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
//Add columns and set widths
|
|
||||||
for (NSString *colId in aColumnsOrder) {
|
|
||||||
NSInteger colIndex = [colId integerValue];
|
|
||||||
if ((colIndex == 0) && (![colId isEqual:@"0"])) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
NSTableColumn *col = [_resultColumns objectAtIndex:colIndex];
|
|
||||||
NSNumber *width = [aColumnsWidth objectForKey:[col identifier]];
|
|
||||||
NSMenuItem *mi = [columnsMenu itemWithTag:colIndex];
|
|
||||||
if (width) {
|
|
||||||
[col setWidth:[width floatValue]];
|
|
||||||
}
|
|
||||||
[self toggleColumn:mi];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)sendMarkedToTrash:(BOOL)hardlinkDeleted
|
|
||||||
{
|
|
||||||
NSInteger mark_count = [[py getMarkCount] intValue];
|
|
||||||
if (!mark_count) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
NSString *msg = TRMSG(@"SendToTrashConfirmMsg");
|
|
||||||
if (hardlinkDeleted) {
|
|
||||||
msg = TRMSG(@"HardlinkConfirmMsg");
|
|
||||||
}
|
|
||||||
if ([Dialogs askYesNo:[NSString stringWithFormat:msg,mark_count]] == NSAlertSecondButtonReturn) { // NO
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
NSUserDefaults *ud = [NSUserDefaults standardUserDefaults];
|
|
||||||
[py setRemoveEmptyFolders:n2b([ud objectForKey:@"removeEmptyFolders"])];
|
|
||||||
if (hardlinkDeleted) {
|
|
||||||
[py hardlinkMarked];
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
[py deleteMarked];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)updateOptionSegments
|
- (void)updateOptionSegments
|
||||||
{
|
{
|
||||||
[optionsSwitch setSelected:[[app detailsPanel] isVisible] forSegment:0];
|
[optionsSwitch setSelected:[[app detailsPanel] isVisible] forSegment:0];
|
||||||
@@ -167,18 +82,36 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
[optionsSwitch setSelected:[table deltaValuesMode] forSegment:2];
|
[optionsSwitch setSelected:[table deltaValuesMode] forSegment:2];
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Actions */
|
- (void)showProblemDialog
|
||||||
- (IBAction)clearIgnoreList:(id)sender
|
|
||||||
{
|
{
|
||||||
NSInteger i = n2i([py getIgnoreListCount]);
|
[problemDialog showWindow:self];
|
||||||
if (!i)
|
|
||||||
return;
|
|
||||||
NSString *msg = [NSString stringWithFormat:TRMSG(@"ClearIgnoreListConfirmMsg"),i];
|
|
||||||
if ([Dialogs askYesNo:msg] == NSAlertSecondButtonReturn) // NO
|
|
||||||
return;
|
|
||||||
[py clearIgnoreList];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
- (void)adjustUIToLocalization
|
||||||
|
{
|
||||||
|
NSString *lang = [[NSBundle preferredLocalizationsFromArray:[[NSBundle mainBundle] localizations]] objectAtIndex:0];
|
||||||
|
NSInteger seg1delta = 0;
|
||||||
|
NSInteger seg2delta = 0;
|
||||||
|
if ([lang isEqual:@"ru"]) {
|
||||||
|
seg2delta = 20;
|
||||||
|
}
|
||||||
|
else if ([lang isEqual:@"uk"]) {
|
||||||
|
seg2delta = 20;
|
||||||
|
}
|
||||||
|
else if ([lang isEqual:@"hy"]) {
|
||||||
|
seg1delta = 20;
|
||||||
|
}
|
||||||
|
if (seg1delta || seg2delta) {
|
||||||
|
[optionsSwitch setWidth:[optionsSwitch widthForSegment:0]+seg1delta forSegment:0];
|
||||||
|
[optionsSwitch setWidth:[optionsSwitch widthForSegment:1]+seg2delta forSegment:1];
|
||||||
|
NSSize s = [optionsToolbarItem maxSize];
|
||||||
|
s.width += seg1delta + seg2delta;
|
||||||
|
[optionsToolbarItem setMaxSize:s];
|
||||||
|
[optionsToolbarItem setMinSize:s];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Actions */
|
||||||
- (IBAction)changeOptions:(id)sender
|
- (IBAction)changeOptions:(id)sender
|
||||||
{
|
{
|
||||||
NSInteger seg = [optionsSwitch selectedSegment];
|
NSInteger seg = [optionsSwitch selectedSegment];
|
||||||
@@ -195,105 +128,73 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
|
|
||||||
- (IBAction)copyMarked:(id)sender
|
- (IBAction)copyMarked:(id)sender
|
||||||
{
|
{
|
||||||
NSInteger mark_count = [[py getMarkCount] intValue];
|
NSUserDefaults *ud = [NSUserDefaults standardUserDefaults];
|
||||||
if (!mark_count)
|
[model setRemoveEmptyFolders:n2b([ud objectForKey:@"removeEmptyFolders"])];
|
||||||
return;
|
[model setCopyMoveDestType:n2i([ud objectForKey:@"recreatePathType"])];
|
||||||
NSOpenPanel *op = [NSOpenPanel openPanel];
|
[model copyMarked];
|
||||||
[op setCanChooseFiles:NO];
|
|
||||||
[op setCanChooseDirectories:YES];
|
|
||||||
[op setCanCreateDirectories:YES];
|
|
||||||
[op setAllowsMultipleSelection:NO];
|
|
||||||
[op setTitle:TRMSG(@"SelectCopyDestinationMsg")];
|
|
||||||
if ([op runModal] == NSOKButton) {
|
|
||||||
NSString *directory = [[op filenames] objectAtIndex:0];
|
|
||||||
NSUserDefaults *ud = [NSUserDefaults standardUserDefaults];
|
|
||||||
[py copyOrMove:b2n(YES) markedTo:directory recreatePath:[ud objectForKey:@"recreatePathType"]];
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)deleteMarked:(id)sender
|
- (IBAction)trashMarked:(id)sender
|
||||||
{
|
{
|
||||||
[self sendMarkedToTrash:NO];
|
NSUserDefaults *ud = [NSUserDefaults standardUserDefaults];
|
||||||
}
|
[model setRemoveEmptyFolders:n2b([ud objectForKey:@"removeEmptyFolders"])];
|
||||||
|
[model deleteMarked];
|
||||||
- (IBAction)hardlinkMarked:(id)sender
|
|
||||||
{
|
|
||||||
[self sendMarkedToTrash:YES];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)exportToXHTML:(id)sender
|
- (IBAction)exportToXHTML:(id)sender
|
||||||
{
|
{
|
||||||
NSString *exported = [py exportToXHTMLwithColumns:[self getColumnsOrder]];
|
NSString *exported = [model exportToXHTML];
|
||||||
[[NSWorkspace sharedWorkspace] openFile:exported];
|
[[NSWorkspace sharedWorkspace] openFile:exported];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)filter:(id)sender
|
- (IBAction)filter:(id)sender
|
||||||
{
|
{
|
||||||
NSUserDefaults *ud = [NSUserDefaults standardUserDefaults];
|
NSUserDefaults *ud = [NSUserDefaults standardUserDefaults];
|
||||||
[py setEscapeFilterRegexp:!n2b([ud objectForKey:@"useRegexpFilter"])];
|
[model setEscapeFilterRegexp:!n2b([ud objectForKey:@"useRegexpFilter"])];
|
||||||
[py applyFilter:[filterField stringValue]];
|
[model applyFilter:[filterField stringValue]];
|
||||||
|
}
|
||||||
|
|
||||||
|
- (IBAction)focusOnFilterField:(id)sender
|
||||||
|
{
|
||||||
|
[[self window] makeFirstResponder:filterField];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)ignoreSelected:(id)sender
|
- (IBAction)ignoreSelected:(id)sender
|
||||||
{
|
{
|
||||||
NSInteger selectedDupeCount = [table selectedDupeCount];
|
[model addSelectedToIgnoreList];
|
||||||
if (!selectedDupeCount)
|
|
||||||
return;
|
|
||||||
NSString *msg = [NSString stringWithFormat:TRMSG(@"IgnoreConfirmMsg"),selectedDupeCount];
|
|
||||||
if ([Dialogs askYesNo:msg] == NSAlertSecondButtonReturn) // NO
|
|
||||||
return;
|
|
||||||
[py addSelectedToIgnoreList];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)invokeCustomCommand:(id)sender
|
- (IBAction)invokeCustomCommand:(id)sender
|
||||||
{
|
{
|
||||||
NSUserDefaults *ud = [NSUserDefaults standardUserDefaults];
|
[model invokeCustomCommand];
|
||||||
NSString *cmd = [ud stringForKey:@"CustomCommand"];
|
|
||||||
if ((cmd != nil) && ([cmd length] > 0)) {
|
|
||||||
[py invokeCommand:cmd];
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
[Dialogs showMessage:TRMSG(@"NoCustomCommandMsg")];
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)markAll:(id)sender
|
- (IBAction)markAll:(id)sender
|
||||||
{
|
{
|
||||||
[py markAll];
|
[model markAll];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)markInvert:(id)sender
|
- (IBAction)markInvert:(id)sender
|
||||||
{
|
{
|
||||||
[py markInvert];
|
[model markInvert];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)markNone:(id)sender
|
- (IBAction)markNone:(id)sender
|
||||||
{
|
{
|
||||||
[py markNone];
|
[model markNone];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)markSelected:(id)sender
|
- (IBAction)markSelected:(id)sender
|
||||||
{
|
{
|
||||||
[py toggleSelectedMark];
|
[model toggleSelectedMark];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)moveMarked:(id)sender
|
- (IBAction)moveMarked:(id)sender
|
||||||
{
|
{
|
||||||
NSInteger mark_count = [[py getMarkCount] intValue];
|
NSUserDefaults *ud = [NSUserDefaults standardUserDefaults];
|
||||||
if (!mark_count)
|
[model setRemoveEmptyFolders:n2b([ud objectForKey:@"removeEmptyFolders"])];
|
||||||
return;
|
[model setCopyMoveDestType:n2i([ud objectForKey:@"recreatePathType"])];
|
||||||
NSOpenPanel *op = [NSOpenPanel openPanel];
|
[model moveMarked];
|
||||||
[op setCanChooseFiles:NO];
|
|
||||||
[op setCanChooseDirectories:YES];
|
|
||||||
[op setCanCreateDirectories:YES];
|
|
||||||
[op setAllowsMultipleSelection:NO];
|
|
||||||
[op setTitle:TRMSG(@"SelectMoveDestinationMsg")];
|
|
||||||
if ([op runModal] == NSOKButton) {
|
|
||||||
NSString *directory = [[op filenames] objectAtIndex:0];
|
|
||||||
NSUserDefaults *ud = [NSUserDefaults standardUserDefaults];
|
|
||||||
[py setRemoveEmptyFolders:n2b([ud objectForKey:@"removeEmptyFolders"])];
|
|
||||||
[py copyOrMove:b2n(NO) markedTo:directory recreatePath:[ud objectForKey:@"recreatePathType"]];
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)openClicked:(id)sender
|
- (IBAction)openClicked:(id)sender
|
||||||
@@ -302,28 +203,22 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
[matches selectRowIndexes:[NSIndexSet indexSetWithIndex:[matches clickedRow]] byExtendingSelection:NO];
|
[matches selectRowIndexes:[NSIndexSet indexSetWithIndex:[matches clickedRow]] byExtendingSelection:NO];
|
||||||
[py openSelected];
|
[model openSelected];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)openSelected:(id)sender
|
- (IBAction)openSelected:(id)sender
|
||||||
{
|
{
|
||||||
[py openSelected];
|
[model openSelected];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)removeMarked:(id)sender
|
- (IBAction)removeMarked:(id)sender
|
||||||
{
|
{
|
||||||
int mark_count = [[py getMarkCount] intValue];
|
[model removeMarked];
|
||||||
if (!mark_count)
|
|
||||||
return;
|
|
||||||
NSString *msg = [NSString stringWithFormat:@"You are about to remove %d files from results. Continue?",mark_count];
|
|
||||||
if ([Dialogs askYesNo:msg] == NSAlertSecondButtonReturn) // NO
|
|
||||||
return;
|
|
||||||
[py removeMarked];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)removeSelected:(id)sender
|
- (IBAction)removeSelected:(id)sender
|
||||||
{
|
{
|
||||||
[table removeSelected];
|
[model removeSelected];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)renameSelected:(id)sender
|
- (IBAction)renameSelected:(id)sender
|
||||||
@@ -335,10 +230,10 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
|
|
||||||
- (IBAction)reprioritizeResults:(id)sender
|
- (IBAction)reprioritizeResults:(id)sender
|
||||||
{
|
{
|
||||||
PrioritizeDialog *dlg = [[PrioritizeDialog alloc] initWithPy:py];
|
PrioritizeDialog *dlg = [[PrioritizeDialog alloc] initWithApp:model];
|
||||||
NSInteger result = [NSApp runModalForWindow:[dlg window]];
|
NSInteger result = [NSApp runModalForWindow:[dlg window]];
|
||||||
if (result == NSRunStoppedResponse) {
|
if (result == NSRunStoppedResponse) {
|
||||||
[[dlg py] performReprioritization];
|
[[dlg model] performReprioritization];
|
||||||
}
|
}
|
||||||
[dlg release];
|
[dlg release];
|
||||||
[[self window] makeKeyAndOrderFront:nil];
|
[[self window] makeKeyAndOrderFront:nil];
|
||||||
@@ -346,12 +241,12 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
|
|
||||||
- (IBAction)resetColumnsToDefault:(id)sender
|
- (IBAction)resetColumnsToDefault:(id)sender
|
||||||
{
|
{
|
||||||
// Virtual
|
[[[table columns] model] resetToDefaults];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)revealSelected:(id)sender
|
- (IBAction)revealSelected:(id)sender
|
||||||
{
|
{
|
||||||
[py revealSelected];
|
[model revealSelected];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)saveResults:(id)sender
|
- (IBAction)saveResults:(id)sender
|
||||||
@@ -359,44 +254,33 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
NSSavePanel *sp = [NSSavePanel savePanel];
|
NSSavePanel *sp = [NSSavePanel savePanel];
|
||||||
[sp setCanCreateDirectories:YES];
|
[sp setCanCreateDirectories:YES];
|
||||||
[sp setAllowedFileTypes:[NSArray arrayWithObject:@"dupeguru"]];
|
[sp setAllowedFileTypes:[NSArray arrayWithObject:@"dupeguru"]];
|
||||||
[sp setTitle:TRMSG(@"SelectResultToSaveMsg")];
|
[sp setTitle:TR(@"Select a file to save your results to")];
|
||||||
if ([sp runModal] == NSOKButton) {
|
if ([sp runModal] == NSOKButton) {
|
||||||
[py saveResultsAs:[sp filename]];
|
[model saveResultsAs:[sp filename]];
|
||||||
[[app recentResults] addFile:[sp filename]];
|
[[app recentResults] addFile:[sp filename]];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)startDuplicateScan:(id)sender
|
- (IBAction)startDuplicateScan:(id)sender
|
||||||
{
|
{
|
||||||
if ([py resultsAreModified]) {
|
if ([model resultsAreModified]) {
|
||||||
if ([Dialogs askYesNo:TRMSG(@"ReallyWantToContinueMsg")] == NSAlertSecondButtonReturn) // NO
|
if ([Dialogs askYesNo:TR(@"You have unsaved results, do you really want to continue?")] == NSAlertSecondButtonReturn) // NO
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
[self setScanOptions];
|
[self setScanOptions];
|
||||||
[py doScan];
|
[model doScan];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)switchSelected:(id)sender
|
- (IBAction)switchSelected:(id)sender
|
||||||
{
|
{
|
||||||
[py makeSelectedReference];
|
[model makeSelectedReference];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)toggleColumn:(id)sender
|
- (IBAction)toggleColumn:(id)sender
|
||||||
{
|
{
|
||||||
NSMenuItem *mi = sender;
|
NSMenuItem *mi = sender;
|
||||||
NSString *colId = [NSString stringWithFormat:@"%d",[mi tag]];
|
BOOL checked = [[[table columns] model] toggleMenuItem:[mi tag]];
|
||||||
NSTableColumn *col = [matches tableColumnWithIdentifier:colId];
|
[mi setState:checked ? NSOnState : NSOffState];
|
||||||
if (col == nil) {
|
|
||||||
//Add Column
|
|
||||||
col = [_resultColumns objectAtIndex:[mi tag]];
|
|
||||||
[matches addTableColumn:col];
|
|
||||||
[mi setState:NSOnState];
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
//Remove column
|
|
||||||
[matches removeTableColumn:col];
|
|
||||||
[mi setState:NSOffState];
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
- (IBAction)toggleDetailsPanel:(id)sender
|
- (IBAction)toggleDetailsPanel:(id)sender
|
||||||
@@ -451,45 +335,9 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
previewPanel = nil;
|
previewPanel = nil;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Notifications */
|
|
||||||
- (void)jobCompleted:(NSNotification *)aNotification
|
|
||||||
{
|
|
||||||
id lastAction = [[ProgressController mainProgressController] jobId];
|
|
||||||
if ([lastAction isEqualTo:jobCopy]) {
|
|
||||||
if ([py scanWasProblematic]) {
|
|
||||||
[problemDialog showWindow:self];
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
[Dialogs showMessage:TRMSG(@"CopySuccessMsg")];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if ([lastAction isEqualTo:jobMove]) {
|
|
||||||
if ([py scanWasProblematic]) {
|
|
||||||
[problemDialog showWindow:self];
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
[Dialogs showMessage:TRMSG(@"MoveSuccessMsg")];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if ([lastAction isEqualTo:jobDelete]) {
|
|
||||||
if ([py scanWasProblematic]) {
|
|
||||||
[problemDialog showWindow:self];
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
[Dialogs showMessage:TRMSG(@"SendToTrashSuccessMsg")];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if ([lastAction isEqualTo:jobScan]) {
|
|
||||||
NSInteger rowCount = [[table py] numberOfRows];
|
|
||||||
if (rowCount == 0) {
|
|
||||||
[Dialogs showMessage:TRMSG(@"NoDuplicateFoundMsg")];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)jobInProgress:(NSNotification *)aNotification
|
- (void)jobInProgress:(NSNotification *)aNotification
|
||||||
{
|
{
|
||||||
[Dialogs showMessage:TRMSG(@"TaskHangingMsg")];
|
[Dialogs showMessage:TR(@"A previous action is still hanging in there. You can't start a new one yet. Wait a few seconds, then try again.")];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)jobStarted:(NSNotification *)aNotification
|
- (void)jobStarted:(NSNotification *)aNotification
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
which should be included with this package. The terms are also available at
|
which should be included with this package. The terms are also available at
|
||||||
@@ -10,10 +10,8 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
#import "HSGUIController.h"
|
#import "HSGUIController.h"
|
||||||
#import "PyStatsLabel.h"
|
#import "PyStatsLabel.h"
|
||||||
|
|
||||||
@interface StatsLabel : HSGUIController
|
@interface StatsLabel : HSGUIController {}
|
||||||
{
|
- (id)initWithPyRef:(PyObject *)aPyRef view:(NSTextField *)aLabelView;
|
||||||
NSTextField *labelView;
|
- (PyStatsLabel *)model;
|
||||||
}
|
- (NSTextField *)labelView;
|
||||||
- (id)initWithPyParent:(id)aPyParent labelView:(NSTextField *)aLabelView;
|
|
||||||
- (PyStatsLabel *)py;
|
|
||||||
@end
|
@end
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
which should be included with this package. The terms are also available at
|
which should be included with this package. The terms are also available at
|
||||||
@@ -10,29 +10,25 @@ http://www.hardcoded.net/licenses/bsd_license
|
|||||||
#import "Utils.h"
|
#import "Utils.h"
|
||||||
|
|
||||||
@implementation StatsLabel
|
@implementation StatsLabel
|
||||||
- (id)initWithPyParent:(id)aPyParent labelView:(NSTextField *)aLabelView
|
- (id)initWithPyRef:(PyObject *)aPyRef view:(NSTextField *)aLabelView
|
||||||
{
|
{
|
||||||
self = [super initWithPyClassName:@"PyStatsLabel" pyParent:aPyParent];
|
return [super initWithPyRef:aPyRef wrapperClass:[PyStatsLabel class]
|
||||||
labelView = [aLabelView retain];
|
callbackClassName:@"StatsLabelView" view:aLabelView];
|
||||||
[self connect];
|
|
||||||
return self;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)dealloc
|
- (PyStatsLabel *)model
|
||||||
{
|
{
|
||||||
[self disconnect];
|
return (PyStatsLabel *)model;
|
||||||
[labelView release];
|
|
||||||
[super dealloc];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
- (PyStatsLabel *)py
|
- (NSTextField *)labelView
|
||||||
{
|
{
|
||||||
return (PyStatsLabel *)py;
|
return (NSTextField *)view;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Python --> Cocoa */
|
/* Python --> Cocoa */
|
||||||
- (void)refresh
|
- (void)refresh
|
||||||
{
|
{
|
||||||
[labelView setStringValue:[[self py] display]];
|
[[self labelView] setStringValue:[[self model] display]];
|
||||||
}
|
}
|
||||||
@end
|
@end
|
||||||
|
|||||||
@@ -1,12 +0,0 @@
|
|||||||
|
|
||||||
/* Class = "NSPanel"; title = "Details of Selected File"; ObjectID = "5"; */
|
|
||||||
"5.title" = "Details of Selected File";
|
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "Selected"; ObjectID = "9"; */
|
|
||||||
"9.headerCell.title" = "Ausgewählt";
|
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "Reference"; ObjectID = "10"; */
|
|
||||||
"10.headerCell.title" = "Referenz";
|
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "Attribute"; ObjectID = "11"; */
|
|
||||||
"11.headerCell.title" = "Attribut";
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
/* Class = "NSTableColumn"; headerCell.title = "State"; ObjectID = "13"; */
|
|
||||||
"13.headerCell.title" = "Zustand";
|
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "Name"; ObjectID = "15"; */
|
|
||||||
"15.headerCell.title" = "Name";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Scan"; ObjectID = "48"; */
|
|
||||||
"48.title" = "Scan";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Normal"; ObjectID = "55"; */
|
|
||||||
"55.title" = "Normal";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Reference"; ObjectID = "56"; */
|
|
||||||
"56.title" = "Referenz";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Excluded"; ObjectID = "57"; */
|
|
||||||
"57.title" = "Ausgeschlossen";
|
|
||||||
|
|
||||||
/* Class = "NSTextFieldCell"; title = "Select folders to scan and press \"Scan\"."; ObjectID = "71"; */
|
|
||||||
"71.title" = "Zu scannende Ordner auswählen und \"Scan\" drücken.";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Load Results"; ObjectID = "73"; */
|
|
||||||
"73.title" = "Lade Ergebnisse";
|
|
||||||
@@ -1,11 +0,0 @@
|
|||||||
/* Class = "NSWindow"; title = "Sorry, I must insist"; ObjectID = "1"; */
|
|
||||||
"1.title" = "Entschuldigung, ich muss darauf beharren";
|
|
||||||
|
|
||||||
/* Class = "NSTextFieldCell"; title = "This reminder showed up because:
1. You are processing more than 100 duplicates
2. You have not yet contributed to dupeGuru
3. There are unpaid hours in the project"; ObjectID = "4"; */
|
|
||||||
"4.title" = "Diese Erinnerung erschien, weil:\n\n1. Mehr als 100 Duplikate verarbeitet wurden\n2. Sie noch nicht an dupeGuru gespendet haben\n3. Es unbezahlte Arbeitstunden im Projekt gibt";
|
|
||||||
|
|
||||||
/* Class = "NSTextFieldCell"; title = "It seems that you found a lot of duplicates. Nice! I must insist, however, that contributions are expected when there are unpaid hours on the project.
You might think \"but I'm only going to use this once, I don't have to contribute\". The problem is that most people use dupeGuru only once in a while. If everyone thinks like that, dupeGuru development cannot be funded.
If you can't afford to contribute, you can ignore this reminder or send me an e-mail at hsoft@hardcoded.net so I can give you a key to remove this popup."; ObjectID = "6"; */
|
|
||||||
"6.title" = "Scheinbar haben Sie eine Menge Duplikate gefunden. Schön! Ich muss Sie jedoch daran erinnern das Spenden gewünscht werden, wenn noch nicht alle Arbeitsstunden bezahlt wurden.\n\nSie denken vielleicht \"aber ich nutze dieses Programm doch nur einmal, da brauche ich nicht zu spenden\". Das Problem ist, das die meisten Menschen dupeGuru nur sehr selten nutzen. Wenn jeder so denkt kann die Entwicklung von dupeGuru nicht finanziert werden. Aufgrund dieser, dem Wesen von dupeGuru innenliegenden Eigenschaft, muss ich hier auf Ihre Unterstützung bestehen.\n\nWenn Sie es sich nicht leisten können zu spenden, können Sie diese Erinnerung entweder ignorieren oder mir eine Nachricht an hsoft@hardcoded.net schicken, damit ich ihnen einen Schlüssel gebe um diesen Hinweis zu entfernen.";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Contribute"; ObjectID = "10"; */
|
|
||||||
"10.title" = "Spenden";
|
|
||||||
@@ -1,9 +0,0 @@
|
|||||||
"Add New Folder..." = "Add New Folder...";
|
|
||||||
"Load from file..." = "Load from file...";
|
|
||||||
"Reset to Default" = "Reset to Default";
|
|
||||||
|
|
||||||
"Add iTunes Directory" = "Add iTunes Directory";
|
|
||||||
"Remove Dead Tracks in iTunes" = "Remove Dead Tracks in iTunes";
|
|
||||||
|
|
||||||
"Add iPhoto Library" = "Add iPhoto Library";
|
|
||||||
"Clear Picture Cache" = "Bildzwischenspeicher leeren";
|
|
||||||
@@ -1,177 +0,0 @@
|
|||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Bring All to Front"; ObjectID = "5"; */
|
|
||||||
"5.title" = "Alle nach vorne bringen";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Window"; ObjectID = "19"; */
|
|
||||||
"19.title" = "Fenster";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Minimize"; ObjectID = "23"; */
|
|
||||||
"23.title" = "Im Dock ablegen";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Window"; ObjectID = "24"; */
|
|
||||||
"24.title" = "Fenster";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "About dupeGuru"; ObjectID = "58"; */
|
|
||||||
"58.title" = "Über dupeGuru";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Help"; ObjectID = "103"; */
|
|
||||||
"103.title" = "Hilfe";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Help"; ObjectID = "106"; */
|
|
||||||
"106.title" = "Hilfe";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "dupeGuru Help"; ObjectID = "111"; */
|
|
||||||
"111.title" = "dupeGuru Hilfe";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Hide dupeGuru"; ObjectID = "134"; */
|
|
||||||
"134.title" = "dupeGuru ausblenden";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Quit dupeGuru"; ObjectID = "136"; */
|
|
||||||
"136.title" = "dupeGuru beenden";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Hide Others"; ObjectID = "145"; */
|
|
||||||
"145.title" = "Andere ausblenden";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Show All"; ObjectID = "150"; */
|
|
||||||
"150.title" = "Alle einblenden";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Zoom"; ObjectID = "197"; */
|
|
||||||
"197.title" = "Zoomen";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Details Panel"; ObjectID = "398"; */
|
|
||||||
"398.title" = "Details Panel";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Preferences..."; ObjectID = "541"; */
|
|
||||||
"541.title" = "Preferences...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Folder Selection Window"; ObjectID = "579"; */
|
|
||||||
"579.title" = "Folder Selection Window";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Actions"; ObjectID = "597"; */
|
|
||||||
"597.title" = "Aktionen";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Actions"; ObjectID = "598"; */
|
|
||||||
"598.title" = "Aktionen";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Send Marked to Trash"; ObjectID = "599"; */
|
|
||||||
"599.title" = "Send Marked to Trash";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Move Marked to..."; ObjectID = "600"; */
|
|
||||||
"600.title" = "Verschiebe Markierte nach...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Copy Marked to..."; ObjectID = "601"; */
|
|
||||||
"601.title" = "Kopiere Markierte nach...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Make Selected Reference"; ObjectID = "602"; */
|
|
||||||
"602.title" = "Mache Ausgewählte zur Referenz";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Remove Marked from Results"; ObjectID = "603"; */
|
|
||||||
"603.title" = "Entferne Markierte aus den Ergebnissen";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Remove Selected from Results"; ObjectID = "605"; */
|
|
||||||
"605.title" = "Entferne Ausgewählte aus den Ergebnissen";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Columns"; ObjectID = "618"; */
|
|
||||||
"618.title" = "Spalten";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Columns"; ObjectID = "619"; */
|
|
||||||
"619.title" = "Spalten";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Open Selected with Default Application"; ObjectID = "708"; */
|
|
||||||
"708.title" = "Öffne Ausgewählte mit Standardanwendung";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Reveal Selected in Finder"; ObjectID = "710"; */
|
|
||||||
"710.title" = "Reveal Selected in Finder";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Add Selected to Ignore List"; ObjectID = "922"; */
|
|
||||||
"922.title" = "Füge Ausgewählte der Ignorier-Liste hinzu";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Close Window"; ObjectID = "924"; */
|
|
||||||
"924.title" = "Fenster Schließen";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Start Duplicate Scan"; ObjectID = "926"; */
|
|
||||||
"926.title" = "Start Duplicate Scan";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Clear Ignore List"; ObjectID = "927"; */
|
|
||||||
"927.title" = "Ignorier-Liste leeren";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Rename Selected"; ObjectID = "933"; */
|
|
||||||
"933.title" = "Ausgewählte umbenennen";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Export Results to XHTML"; ObjectID = "947"; */
|
|
||||||
"947.title" = "Export Results to XHTML";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Check for update..."; ObjectID = "950"; */
|
|
||||||
"950.title" = "Check for update...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Mode"; ObjectID = "959"; */
|
|
||||||
"959.title" = "Mode";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Mode"; ObjectID = "960"; */
|
|
||||||
"960.title" = "Mode";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Show Dupes Only"; ObjectID = "961"; */
|
|
||||||
"961.title" = "Nur Duplikate anzeigen";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Show Delta Values"; ObjectID = "962"; */
|
|
||||||
"962.title" = "Zeige Deltawerte";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Edit"; ObjectID = "965"; */
|
|
||||||
"965.title" = "Bearbeiten";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Edit"; ObjectID = "966"; */
|
|
||||||
"966.title" = "Bearbeiten";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Cut"; ObjectID = "985"; */
|
|
||||||
"985.title" = "Ausschneiden";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Copy"; ObjectID = "986"; */
|
|
||||||
"986.title" = "Kopieren";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Paste"; ObjectID = "991"; */
|
|
||||||
"991.title" = "Einsetzen";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Mark All"; ObjectID = "1011"; */
|
|
||||||
"1011.title" = "Alles markieren";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Mark None"; ObjectID = "1012"; */
|
|
||||||
"1012.title" = "Nichts markieren";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Invert Marking"; ObjectID = "1013"; */
|
|
||||||
"1013.title" = "Markierung invertieren";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Mark Selected"; ObjectID = "1014"; */
|
|
||||||
"1014.title" = "Ausgewählte markieren";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "dupeGuru Website"; ObjectID = "1023"; */
|
|
||||||
"1023.title" = "dupeGuru Website";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Invoke Custom Command"; ObjectID = "1177"; */
|
|
||||||
"1177.title" = "Eigenen Befehl ausführen";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "File"; ObjectID = "1203"; */
|
|
||||||
"1203.title" = "Ablage";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "File"; ObjectID = "1204"; */
|
|
||||||
"1204.title" = "Ablage";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Load Results..."; ObjectID = "1205"; */
|
|
||||||
"1205.title" = "Lade Ergebnisse...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Save Results..."; ObjectID = "1206"; */
|
|
||||||
"1206.title" = "Speichere Ergebnisse...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Delete Marked and Replace with Hardlinks"; ObjectID = "1227"; */
|
|
||||||
"1227.title" = "Lösche Markierte und ersetze mit Hardlinks";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Load Recent Results"; ObjectID = "1239"; */
|
|
||||||
"1239.title" = "Lade letzte Ergebnisse";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Load Recent Results"; ObjectID = "1240"; */
|
|
||||||
"1240.title" = "Lade letzte Ergebnisse";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Results Window"; ObjectID = "1272"; */
|
|
||||||
"1272.title" = "Ergebnisfenster";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Re-Prioritize Results"; ObjectID = "1276"; */
|
|
||||||
"1276.title" = "Re-Prioritize Results";
|
|
||||||
@@ -1,12 +0,0 @@
|
|||||||
|
|
||||||
/* Class = "NSWindow"; title = "Re-Prioritize duplicates"; ObjectID = "1"; */
|
|
||||||
"1.title" = "Re-Prioritize duplicates";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Ok"; ObjectID = "37"; */
|
|
||||||
"37.title" = "Ok";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Cancel"; ObjectID = "39"; */
|
|
||||||
"39.title" = "Cancel";
|
|
||||||
|
|
||||||
/* Class = "NSTextFieldCell"; title = "Add criteria to the right box and click OK to send the dupes that correspond the best to these criteria to their respective group's reference position. Read the help file for more information."; ObjectID = "41"; */
|
|
||||||
"41.title" = "Add criteria to the right box and click OK to send the dupes that correspond the best to these criteria to their respective group's reference position. Read the help file for more information.";
|
|
||||||
@@ -1,18 +0,0 @@
|
|||||||
|
|
||||||
/* Class = "NSWindow"; title = "Problems!"; ObjectID = "1"; */
|
|
||||||
"1.title" = "Probleme!";
|
|
||||||
|
|
||||||
/* Class = "NSTextFieldCell"; title = "There were problems processing some (or all) of the files. The cause of these problems are described in the table below. Those files were not removed from your results."; ObjectID = "4"; */
|
|
||||||
"4.title" = "Es gab Probleme bei der Verarbeitung einiger (aller) Dateien. Der Grund der Probleme ist unten in der Tabelle beschrieben.";
|
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "File Path"; ObjectID = "10"; */
|
|
||||||
"10.headerCell.title" = "Dateipfad";
|
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "Error Message"; ObjectID = "11"; */
|
|
||||||
"11.headerCell.title" = "Fehlermeldung";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Close"; ObjectID = "19"; */
|
|
||||||
"19.title" = "Schließen";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Reveal Selected"; ObjectID = "21"; */
|
|
||||||
"21.title" = "Zeige Markierte";
|
|
||||||
@@ -1,99 +0,0 @@
|
|||||||
|
|
||||||
/* Class = "NSWindow"; title = "dupeGuru Results"; ObjectID = "1"; */
|
|
||||||
"1.title" = "dupeGuru Results";
|
|
||||||
|
|
||||||
/* Class = "NSTextFieldCell"; title = "Marked: 0 files, 0 B. Total: 0 files, 0 B."; ObjectID = "6"; */
|
|
||||||
"6.title" = "Marked: 0 files, 0 B. Total: 0 files, 0 B.";
|
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "Name"; ObjectID = "11"; */
|
|
||||||
"11.headerCell.title" = "Name";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; label = "Options"; ObjectID = "15"; */
|
|
||||||
"15.label" = "Options";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; paletteLabel = "Options"; ObjectID = "15"; */
|
|
||||||
"15.paletteLabel" = "Options";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; label = "Filter"; ObjectID = "16"; */
|
|
||||||
"16.label" = "Filter";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; paletteLabel = "Filter"; ObjectID = "16"; */
|
|
||||||
"16.paletteLabel" = "Filter";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; label = "Action"; ObjectID = "17"; */
|
|
||||||
"17.label" = "Action";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; paletteLabel = "Action"; ObjectID = "17"; */
|
|
||||||
"17.paletteLabel" = "Action";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; label = "Directories"; ObjectID = "19"; */
|
|
||||||
"19.label" = "Directories";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; paletteLabel = "Directories"; ObjectID = "19"; */
|
|
||||||
"19.paletteLabel" = "Directories";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Delete Marked and Replace with Hardlinks"; ObjectID = "27"; */
|
|
||||||
"27.title" = "Lösche Markierte und ersetze mit Hardlinks";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Send Marked to Trash"; ObjectID = "29"; */
|
|
||||||
"29.title" = "Send Marked to Trash";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Move Marked to..."; ObjectID = "30"; */
|
|
||||||
"30.title" = "Verschiebe Markierte nach...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Copy Marked to..."; ObjectID = "31"; */
|
|
||||||
"31.title" = "Kopiere Markierte nach...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Remove Marked from Results"; ObjectID = "32"; */
|
|
||||||
"32.title" = "Entferne Markierte aus den Ergebnissen";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Remove Selected from Results"; ObjectID = "34"; */
|
|
||||||
"34.title" = "Entferne Ausgewählte aus den Ergebnissen";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Add Selected to Ignore List"; ObjectID = "35"; */
|
|
||||||
"35.title" = "Füge Ausgewählte der Ignorier-Liste hinzu";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Make Selected Reference"; ObjectID = "36"; */
|
|
||||||
"36.title" = "Mache Ausgewählte zur Referenz";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Open Selected with Default Application"; ObjectID = "38"; */
|
|
||||||
"38.title" = "Öffne Ausgewählte mit Standardanwendung";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Reveal Selected in Finder"; ObjectID = "39"; */
|
|
||||||
"39.title" = "Reveal Selected in Finder";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Rename Selected"; ObjectID = "40"; */
|
|
||||||
"40.title" = "Ausgewählte umbenennen";
|
|
||||||
|
|
||||||
/* Class = "NSSearchFieldCell"; placeholderString = "Filter"; ObjectID = "42"; */
|
|
||||||
"42.placeholderString" = "Filter";
|
|
||||||
|
|
||||||
/* Class = "NSSegmentedCell"; 44.ibShadowedLabels[0] = "Details"; ObjectID = "44"; */
|
|
||||||
"44.ibShadowedLabels[0]" = "Details";
|
|
||||||
|
|
||||||
/* Class = "NSSegmentedCell"; 44.ibShadowedLabels[1] = "Dupes Only"; ObjectID = "44"; */
|
|
||||||
"44.ibShadowedLabels[1]" = "Dupes Only";
|
|
||||||
|
|
||||||
/* Class = "NSSegmentedCell"; 44.ibShadowedLabels[2] = "Delta"; ObjectID = "44"; */
|
|
||||||
"44.ibShadowedLabels[2]" = "Delta";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Menu"; ObjectID = "67"; */
|
|
||||||
"67.title" = "Menu";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Add Selected to Ignore List"; ObjectID = "68"; */
|
|
||||||
"68.title" = "Füge Ausgewählte der Ignorier-Liste hinzu";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Rename Selected"; ObjectID = "70"; */
|
|
||||||
"70.title" = "Ausgewählte umbenennen";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Remove Selected from Results"; ObjectID = "71"; */
|
|
||||||
"71.title" = "Entferne Ausgewählte aus den Ergebnissen";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Make Selected Reference"; ObjectID = "72"; */
|
|
||||||
"72.title" = "Mache Ausgewählte zur Referenz";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Reveal Selected in Finder"; ObjectID = "73"; */
|
|
||||||
"73.title" = "Reveal Selected in Finder";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Open Selected with Default Application"; ObjectID = "74"; */
|
|
||||||
"74.title" = "Öffne Ausgewählte mit Standardanwendung";
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
"Filename" = "Filename";
|
|
||||||
"Folder" = "Ordner";
|
|
||||||
"Size" = "Größe";
|
|
||||||
"Size (KB)" = "Größe (KB)";
|
|
||||||
"Size (MB)" = "Größe (MB)";
|
|
||||||
"Kind" = "Typ";
|
|
||||||
"Modification" = "Modifikation";
|
|
||||||
"Match %" = "Übereinstimmung %";
|
|
||||||
"Words Used" = "Wörter genutzt";
|
|
||||||
"Dupe Count" = "Anzahl Duplikate";
|
|
||||||
|
|
||||||
"Time" = "Zeit";
|
|
||||||
"Bitrate" = "Bitrate";
|
|
||||||
"Sample Rate" = "Abtastrate";
|
|
||||||
"Title" = "Titel";
|
|
||||||
"Artist" = "Künstler";
|
|
||||||
"Album" = "Album";
|
|
||||||
"Genre" = "Genre";
|
|
||||||
"Year" = "Jahr";
|
|
||||||
"Track Number" = "Stück Nummer";
|
|
||||||
"Comment" = "Kommentar";
|
|
||||||
|
|
||||||
"Dimensions" = "Dimensionen";
|
|
||||||
@@ -1,39 +0,0 @@
|
|||||||
"Collecting files to scan" = "Sammle Dateien zum Scannen";
|
|
||||||
"%s (%d discarded)" = "%s (%d verworfen)";
|
|
||||||
"Scanning for duplicates" = "Suche nach Duplikaten";
|
|
||||||
"Loading" = "Laden";
|
|
||||||
"Moving" = "Verschieben";
|
|
||||||
"Copying" = "Kopieren";
|
|
||||||
"Sending to Trash" = "Verschiebe in den Mülleimer";
|
|
||||||
"0 matches found" = "0 Paare gefunden";
|
|
||||||
"%d matches found" = "%d Paare gefunden";
|
|
||||||
"Read size of %d/%d files" = "Lese Größe von %d/%d Dateien";
|
|
||||||
"Grouped %d/%d matches" = "%d/%d Paare gruppiert";
|
|
||||||
"%d / %d (%s / %s) duplicates marked." = "%d / %d (%s / %s) Duplikate markiert.";
|
|
||||||
" filter: %s" = " Filter: %s";
|
|
||||||
"Read metadata of %d/%d files" = "Lese Metadaten von %d/%d Dateien";
|
|
||||||
"Removing false matches" = "Entferne Falschpositive.";
|
|
||||||
"Processed %d/%d matches against the ignore list" = "Verarbeitung von %d/%d Paaren gegen die Ignorier-Liste";
|
|
||||||
"Doing group prioritization" = "Gruppenpriorisierung";
|
|
||||||
|
|
||||||
"Continue" = "Fortfahren";
|
|
||||||
"Continue ({})" = "Fortfahren ({})";
|
|
||||||
|
|
||||||
"Analyzed %d/%d pictures" = "Analysiere %d/%d Bilder";
|
|
||||||
"Preparing for matching" = "Vorbereitung auf den Vergleich";
|
|
||||||
"Performed %d/%d chunk matches" = "Performed %d/%d chunk matches";
|
|
||||||
"Verified %d/%d matches" = "%d/%d verifizierte Paare";
|
|
||||||
|
|
||||||
"Removing dead tracks from your iTunes Library" = "Entferne tote Stücke aus Ihrer iTunes Bibliothek.";
|
|
||||||
"Scanning the iTunes Library" = "Scanne die iTunes Bibiliothek";
|
|
||||||
|
|
||||||
"Probing iPhoto. Don't touch it during the operation!" = "Untersuche iPhoto. Während der Operation nicht anfassen!";
|
|
||||||
"Sending dupes to the Trash" = "Verschiebe Duplikate in den Mülleimer";
|
|
||||||
|
|
||||||
/* Prioritization */
|
|
||||||
"Ends with number" = "Ends with number";
|
|
||||||
"Doesn't end with number" = "Doesn't end with number";
|
|
||||||
"Highest" = "Highest";
|
|
||||||
"Lowest" = "Lowest";
|
|
||||||
"Newest" = "Newest";
|
|
||||||
"Oldest" = "Oldest";
|
|
||||||
@@ -1,33 +0,0 @@
|
|||||||
"SelectResultToLoadMsg" = "Wählen Sie eine Ergebnisliste zum Laden aus.";
|
|
||||||
"SelectCopyDestinationMsg" = "Select a directory to copy marked files to";
|
|
||||||
"SelectMoveDestinationMsg" = "Select a directory to move marked files to";
|
|
||||||
"SelectResultToSaveMsg" = "Datei zum Speichern der Ergebnisliste auswählen.";
|
|
||||||
"SelectFolderToAddMsg" = "Wählen Sie einen Ordner aus, um ihn der Scanliste hinzuzufügen.";
|
|
||||||
"ReallyWantToQuitMsg" = "Sie haben ungespeicherte Ergebnisse. Wollen Sie wirklich beenden?";
|
|
||||||
"ReallyWantToContinueMsg" = "Sie haben ungespeicherte Ergebnisse. Möchten Sie wirklich fortfahren?";
|
|
||||||
"FolderAlreadyInListMsg" = "'%@' already is in the list.";
|
|
||||||
"FolderDoesNotExistMsg" = "'%@' does not exist.";
|
|
||||||
"FileRemovalConfirmMsg" = "{} Dateien werden aus der Ergebnisliste entfernt. Fortfahren?";
|
|
||||||
"FilenameAlreadyExistsMsg" = "The name '%@' already exists.";
|
|
||||||
"NoScannableFileMsg" = "Der ausgewählte Ordner enthält keine scannbare Dateien.";
|
|
||||||
"UnknownErrorMsg" = "Unknown Error.";
|
|
||||||
"SendToTrashConfirmMsg" = "{} Dateien werden in den Mülleimer zu verschoben. Fortfahren?";
|
|
||||||
"HardlinkConfirmMsg" = "{} Dateien werden gelöscht und mit physikalischen Verknüpfungen ersetzt. Fortfahren?";
|
|
||||||
"ClearIgnoreListConfirmMsg" = "Möchten Sie wirklich alle {} Einträge aus der Ignorier-Liste löschen?";
|
|
||||||
"IgnoreConfirmMsg" = "%d Dateien werden in zukünftigen Scans ignoriert werden. Fortfahren?";
|
|
||||||
"NoCustomCommandMsg" = "Sie haben keinen eigenen Befehl erstellt. Bitte in den Einstellungen konfigurieren.";
|
|
||||||
"CopySuccessMsg" = "All marked files were copied sucessfully.";
|
|
||||||
"MoveSuccessMsg" = "All marked files were moved sucessfully.";
|
|
||||||
"SendToTrashSuccessMsg" = "All marked files were sucessfully sent to Trash.";
|
|
||||||
"NoDuplicateFoundMsg" = "Keine Duplikate gefunden.";
|
|
||||||
"TaskHangingMsg" = "Eine vorherige Aktion ist noch in der Bearbeitung. Sie können noch keine Neue starten. Warten Sie einige Sekunden und versuchen es erneut.";
|
|
||||||
|
|
||||||
"RemoveDeadTracksConfirmMsg" = "Your iTunes Library contains %d dead tracks ready to be removed. Continue?";
|
|
||||||
"NoDeadTrackMsg" = "You have no dead tracks in your iTunes Library";
|
|
||||||
|
|
||||||
"IPhotoAppNotFoundMsg" = "The iPhoto application couldn't be found.";
|
|
||||||
"ClearPictureCacheConfirmMsg" = "Möchten Sie wirklich alle zwischengespeicherten Bildanalysen entfernen?";
|
|
||||||
|
|
||||||
/* hscommon */
|
|
||||||
"FairwarePromptMsg" = "{name} ist Fairware, das bedeutet \"Open Source Software, entwickelt in der Hoffnung auf einen fairen Beitrag von den Benutzern\". Viel Zeit wurde in die Software investiert, mit der Erwartung der Nutzer möge fair genug sein die Entwickler für ihren Einsatz zu kompensieren. Die \"Unbezahlte Stunden\" Abbildung zeigt die Anzahl der Stunden die noch nicht bezahlt wurden.\nWenn Sie diese Anwendung mögen, so spenden Sie bitte einen Ihrer Ansicht nach angemessenen Betrag. Danke!\n\nWenn Sie es sich nicht leisten können zu spenden, können Sie diese Erinnerung entweder ignorieren oder mir eine Anfrage an hsoft@hardcoded.net schicken, mit der Bitte für einen Registrierungsschlüssel.\n\nDieser Dialog erscheint nicht, wenn es keine unbezahlten Stunden gibt oder Sie einen gültigen Registrierungsschlüssel besitzen.";
|
|
||||||
"DemoPromptMsg" = "{name} is fairware, which means \"open source software developed with expectation of fair contributions from users\". It's a very interesting concept, but one year of fairware has shown that most people just want to know how much it costs and not be bothered with theories about intellectual property.\n\nSo I won't bother you and will be very straightforward: You can try {name} for free but you have to buy it in order to use it without limitations. In demo mode, {name} {limitation}.\n\nSo it's as simple as this. If you're curious about fairware, however, I encourage you to read more about it by clicking on the \"Fairware?\" button.";
|
|
||||||
21
cocoa/base/en.lproj/DeletionOptions.strings
Normal file
21
cocoa/base/en.lproj/DeletionOptions.strings
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
|
||||||
|
/* Class = "NSWindow"; title = "Deletion Options"; ObjectID = "1"; */
|
||||||
|
"1.title" = "Deletion Options";
|
||||||
|
|
||||||
|
/* Class = "NSButtonCell"; title = "Hardlink deleted files"; ObjectID = "4"; */
|
||||||
|
"4.title" = "Hardlink deleted files";
|
||||||
|
|
||||||
|
/* Class = "NSTextFieldCell"; title = "After having deleted a duplicate, place a hardlink targeting the reference file to replace the deleted file."; ObjectID = "8"; */
|
||||||
|
"8.title" = "After having deleted a duplicate, place a hardlink targeting the reference file to replace the deleted file.";
|
||||||
|
|
||||||
|
/* Class = "NSButtonCell"; title = "Directly delete files"; ObjectID = "36"; */
|
||||||
|
"36.title" = "Directly delete files";
|
||||||
|
|
||||||
|
/* Class = "NSTextFieldCell"; title = "Instead of sending files to trash, delete them directly. This option is usually used as a workaround when the normal deletion method doesn't work."; ObjectID = "38"; */
|
||||||
|
"38.title" = "Instead of sending files to trash, delete them directly. This option is usually used as a workaround when the normal deletion method doesn't work.";
|
||||||
|
|
||||||
|
/* Class = "NSButtonCell"; title = "Proceed"; ObjectID = "40"; */
|
||||||
|
"40.title" = "Proceed";
|
||||||
|
|
||||||
|
/* Class = "NSButtonCell"; title = "Cancel"; ObjectID = "42"; */
|
||||||
|
"42.title" = "Cancel";
|
||||||
556
cocoa/base/en.lproj/DeletionOptions.xib
Normal file
556
cocoa/base/en.lproj/DeletionOptions.xib
Normal file
@@ -0,0 +1,556 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<archive type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="8.00">
|
||||||
|
<data>
|
||||||
|
<int key="IBDocument.SystemTarget">1060</int>
|
||||||
|
<string key="IBDocument.SystemVersion">11E53</string>
|
||||||
|
<string key="IBDocument.InterfaceBuilderVersion">2182</string>
|
||||||
|
<string key="IBDocument.AppKitVersion">1138.47</string>
|
||||||
|
<string key="IBDocument.HIToolboxVersion">569.00</string>
|
||||||
|
<object class="NSMutableDictionary" key="IBDocument.PluginVersions">
|
||||||
|
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="NS.object.0">2182</string>
|
||||||
|
</object>
|
||||||
|
<array key="IBDocument.IntegratedClassDependencies">
|
||||||
|
<string>NSTextField</string>
|
||||||
|
<string>NSView</string>
|
||||||
|
<string>NSWindowTemplate</string>
|
||||||
|
<string>NSTextFieldCell</string>
|
||||||
|
<string>NSButtonCell</string>
|
||||||
|
<string>NSButton</string>
|
||||||
|
<string>NSCustomObject</string>
|
||||||
|
</array>
|
||||||
|
<array key="IBDocument.PluginDependencies">
|
||||||
|
<string>com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
</array>
|
||||||
|
<object class="NSMutableDictionary" key="IBDocument.Metadata">
|
||||||
|
<string key="NS.key.0">PluginDependencyRecalculationVersion</string>
|
||||||
|
<integer value="1" key="NS.object.0"/>
|
||||||
|
</object>
|
||||||
|
<array class="NSMutableArray" key="IBDocument.RootObjects" id="1000">
|
||||||
|
<object class="NSCustomObject" id="1001">
|
||||||
|
<string key="NSClassName">DeletionOptions</string>
|
||||||
|
</object>
|
||||||
|
<object class="NSCustomObject" id="1003">
|
||||||
|
<string key="NSClassName">FirstResponder</string>
|
||||||
|
</object>
|
||||||
|
<object class="NSCustomObject" id="1004">
|
||||||
|
<string key="NSClassName">NSApplication</string>
|
||||||
|
</object>
|
||||||
|
<object class="NSWindowTemplate" id="1005">
|
||||||
|
<int key="NSWindowStyleMask">3</int>
|
||||||
|
<int key="NSWindowBacking">2</int>
|
||||||
|
<string key="NSWindowRect">{{196, 240}, {449, 215}}</string>
|
||||||
|
<int key="NSWTFlags">1618477056</int>
|
||||||
|
<string key="NSWindowTitle">Deletion Options</string>
|
||||||
|
<string key="NSWindowClass">NSWindow</string>
|
||||||
|
<nil key="NSViewClass"/>
|
||||||
|
<nil key="NSUserInterfaceItemIdentifier"/>
|
||||||
|
<object class="NSView" key="NSWindowView" id="1006">
|
||||||
|
<reference key="NSNextResponder"/>
|
||||||
|
<int key="NSvFlags">256</int>
|
||||||
|
<array class="NSMutableArray" key="NSSubviews">
|
||||||
|
<object class="NSButton" id="22939991">
|
||||||
|
<reference key="NSNextResponder" ref="1006"/>
|
||||||
|
<int key="NSvFlags">268</int>
|
||||||
|
<string key="NSFrame">{{18, 154}, {413, 18}}</string>
|
||||||
|
<reference key="NSSuperview" ref="1006"/>
|
||||||
|
<reference key="NSWindow"/>
|
||||||
|
<reference key="NSNextKeyView" ref="258896148"/>
|
||||||
|
<string key="NSReuseIdentifierKey">_NS:9</string>
|
||||||
|
<bool key="NSEnabled">YES</bool>
|
||||||
|
<object class="NSButtonCell" key="NSCell" id="199073808">
|
||||||
|
<int key="NSCellFlags">67239424</int>
|
||||||
|
<int key="NSCellFlags2">0</int>
|
||||||
|
<string key="NSContents">Hardlink deleted files</string>
|
||||||
|
<object class="NSFont" key="NSSupport" id="672375986">
|
||||||
|
<string key="NSName">LucidaGrande</string>
|
||||||
|
<double key="NSSize">13</double>
|
||||||
|
<int key="NSfFlags">1044</int>
|
||||||
|
</object>
|
||||||
|
<string key="NSCellIdentifier">_NS:9</string>
|
||||||
|
<reference key="NSControlView" ref="22939991"/>
|
||||||
|
<int key="NSButtonFlags">1211912703</int>
|
||||||
|
<int key="NSButtonFlags2">2</int>
|
||||||
|
<object class="NSCustomResource" key="NSNormalImage" id="28662763">
|
||||||
|
<string key="NSClassName">NSImage</string>
|
||||||
|
<string key="NSResourceName">NSSwitch</string>
|
||||||
|
</object>
|
||||||
|
<object class="NSButtonImageSource" key="NSAlternateImage" id="1065109393">
|
||||||
|
<string key="NSImageName">NSSwitch</string>
|
||||||
|
</object>
|
||||||
|
<string key="NSAlternateContents"/>
|
||||||
|
<string key="NSKeyEquivalent"/>
|
||||||
|
<int key="NSPeriodicDelay">200</int>
|
||||||
|
<int key="NSPeriodicInterval">25</int>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
|
<object class="NSButton" id="1003638083">
|
||||||
|
<reference key="NSNextResponder" ref="1006"/>
|
||||||
|
<int key="NSvFlags">268</int>
|
||||||
|
<string key="NSFrame">{{18, 96}, {413, 18}}</string>
|
||||||
|
<reference key="NSSuperview" ref="1006"/>
|
||||||
|
<reference key="NSWindow"/>
|
||||||
|
<reference key="NSNextKeyView" ref="316971589"/>
|
||||||
|
<string key="NSReuseIdentifierKey">_NS:9</string>
|
||||||
|
<bool key="NSEnabled">YES</bool>
|
||||||
|
<object class="NSButtonCell" key="NSCell" id="791836143">
|
||||||
|
<int key="NSCellFlags">67239424</int>
|
||||||
|
<int key="NSCellFlags2">0</int>
|
||||||
|
<string key="NSContents">Directly delete files</string>
|
||||||
|
<reference key="NSSupport" ref="672375986"/>
|
||||||
|
<string key="NSCellIdentifier">_NS:9</string>
|
||||||
|
<reference key="NSControlView" ref="1003638083"/>
|
||||||
|
<int key="NSButtonFlags">1211912703</int>
|
||||||
|
<int key="NSButtonFlags2">2</int>
|
||||||
|
<reference key="NSNormalImage" ref="28662763"/>
|
||||||
|
<reference key="NSAlternateImage" ref="1065109393"/>
|
||||||
|
<string key="NSAlternateContents"/>
|
||||||
|
<string key="NSKeyEquivalent"/>
|
||||||
|
<int key="NSPeriodicDelay">200</int>
|
||||||
|
<int key="NSPeriodicInterval">25</int>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
|
<object class="NSTextField" id="258896148">
|
||||||
|
<reference key="NSNextResponder" ref="1006"/>
|
||||||
|
<int key="NSvFlags">268</int>
|
||||||
|
<string key="NSFrame">{{38, 120}, {394, 28}}</string>
|
||||||
|
<reference key="NSSuperview" ref="1006"/>
|
||||||
|
<reference key="NSWindow"/>
|
||||||
|
<reference key="NSNextKeyView" ref="1003638083"/>
|
||||||
|
<string key="NSReuseIdentifierKey">_NS:9</string>
|
||||||
|
<string key="NSAntiCompressionPriority">{250, 750}</string>
|
||||||
|
<bool key="NSEnabled">YES</bool>
|
||||||
|
<object class="NSTextFieldCell" key="NSCell" id="939395720">
|
||||||
|
<int key="NSCellFlags">67239424</int>
|
||||||
|
<int key="NSCellFlags2">272629760</int>
|
||||||
|
<string key="NSContents">After having deleted a duplicate, place a hardlink targeting the reference file to replace the deleted file.</string>
|
||||||
|
<object class="NSFont" key="NSSupport" id="1067329392">
|
||||||
|
<string key="NSName">LucidaGrande</string>
|
||||||
|
<double key="NSSize">11</double>
|
||||||
|
<int key="NSfFlags">16</int>
|
||||||
|
</object>
|
||||||
|
<string key="NSCellIdentifier">_NS:9</string>
|
||||||
|
<reference key="NSControlView" ref="258896148"/>
|
||||||
|
<object class="NSColor" key="NSBackgroundColor" id="360163505">
|
||||||
|
<int key="NSColorSpace">6</int>
|
||||||
|
<string key="NSCatalogName">System</string>
|
||||||
|
<string key="NSColorName">controlColor</string>
|
||||||
|
<object class="NSColor" key="NSColor">
|
||||||
|
<int key="NSColorSpace">3</int>
|
||||||
|
<bytes key="NSWhite">MC42NjY2NjY2NjY3AA</bytes>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
|
<object class="NSColor" key="NSTextColor" id="819030839">
|
||||||
|
<int key="NSColorSpace">6</int>
|
||||||
|
<string key="NSCatalogName">System</string>
|
||||||
|
<string key="NSColorName">controlTextColor</string>
|
||||||
|
<object class="NSColor" key="NSColor">
|
||||||
|
<int key="NSColorSpace">3</int>
|
||||||
|
<bytes key="NSWhite">MAA</bytes>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
|
<object class="NSTextField" id="316971589">
|
||||||
|
<reference key="NSNextResponder" ref="1006"/>
|
||||||
|
<int key="NSvFlags">268</int>
|
||||||
|
<string key="NSFrame">{{38, 48}, {394, 42}}</string>
|
||||||
|
<reference key="NSSuperview" ref="1006"/>
|
||||||
|
<reference key="NSWindow"/>
|
||||||
|
<reference key="NSNextKeyView" ref="375232713"/>
|
||||||
|
<string key="NSReuseIdentifierKey">_NS:9</string>
|
||||||
|
<string key="NSAntiCompressionPriority">{250, 750}</string>
|
||||||
|
<bool key="NSEnabled">YES</bool>
|
||||||
|
<object class="NSTextFieldCell" key="NSCell" id="404549205">
|
||||||
|
<int key="NSCellFlags">67239424</int>
|
||||||
|
<int key="NSCellFlags2">272629760</int>
|
||||||
|
<string key="NSContents">Instead of sending files to trash, delete them directly. This option is usually used as a workaround when the normal deletion method doesn't work.</string>
|
||||||
|
<reference key="NSSupport" ref="1067329392"/>
|
||||||
|
<string key="NSCellIdentifier">_NS:9</string>
|
||||||
|
<reference key="NSControlView" ref="316971589"/>
|
||||||
|
<reference key="NSBackgroundColor" ref="360163505"/>
|
||||||
|
<reference key="NSTextColor" ref="819030839"/>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
|
<object class="NSButton" id="630940386">
|
||||||
|
<reference key="NSNextResponder" ref="1006"/>
|
||||||
|
<int key="NSvFlags">268</int>
|
||||||
|
<string key="NSFrame">{{331, 12}, {104, 32}}</string>
|
||||||
|
<reference key="NSSuperview" ref="1006"/>
|
||||||
|
<reference key="NSWindow"/>
|
||||||
|
<reference key="NSNextKeyView"/>
|
||||||
|
<string key="NSReuseIdentifierKey">_NS:9</string>
|
||||||
|
<bool key="NSEnabled">YES</bool>
|
||||||
|
<object class="NSButtonCell" key="NSCell" id="551779024">
|
||||||
|
<int key="NSCellFlags">67239424</int>
|
||||||
|
<int key="NSCellFlags2">134217728</int>
|
||||||
|
<string key="NSContents">Proceed</string>
|
||||||
|
<reference key="NSSupport" ref="672375986"/>
|
||||||
|
<string key="NSCellIdentifier">_NS:9</string>
|
||||||
|
<reference key="NSControlView" ref="630940386"/>
|
||||||
|
<int key="NSButtonFlags">-2038284033</int>
|
||||||
|
<int key="NSButtonFlags2">129</int>
|
||||||
|
<string key="NSAlternateContents"/>
|
||||||
|
<string type="base64-UTF8" key="NSKeyEquivalent">DQ</string>
|
||||||
|
<int key="NSPeriodicDelay">200</int>
|
||||||
|
<int key="NSPeriodicInterval">25</int>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
|
<object class="NSButton" id="375232713">
|
||||||
|
<reference key="NSNextResponder" ref="1006"/>
|
||||||
|
<int key="NSvFlags">268</int>
|
||||||
|
<string key="NSFrame">{{227, 12}, {104, 32}}</string>
|
||||||
|
<reference key="NSSuperview" ref="1006"/>
|
||||||
|
<reference key="NSWindow"/>
|
||||||
|
<reference key="NSNextKeyView" ref="630940386"/>
|
||||||
|
<string key="NSReuseIdentifierKey">_NS:9</string>
|
||||||
|
<bool key="NSEnabled">YES</bool>
|
||||||
|
<object class="NSButtonCell" key="NSCell" id="311692270">
|
||||||
|
<int key="NSCellFlags">67239424</int>
|
||||||
|
<int key="NSCellFlags2">134217728</int>
|
||||||
|
<string key="NSContents">Cancel</string>
|
||||||
|
<reference key="NSSupport" ref="672375986"/>
|
||||||
|
<string key="NSCellIdentifier">_NS:9</string>
|
||||||
|
<reference key="NSControlView" ref="375232713"/>
|
||||||
|
<int key="NSButtonFlags">-2038284033</int>
|
||||||
|
<int key="NSButtonFlags2">129</int>
|
||||||
|
<string key="NSAlternateContents"/>
|
||||||
|
<string type="base64-UTF8" key="NSKeyEquivalent">Gw</string>
|
||||||
|
<int key="NSPeriodicDelay">200</int>
|
||||||
|
<int key="NSPeriodicInterval">25</int>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
|
<object class="NSTextField" id="275527426">
|
||||||
|
<reference key="NSNextResponder" ref="1006"/>
|
||||||
|
<int key="NSvFlags">268</int>
|
||||||
|
<string key="NSFrame">{{17, 178}, {415, 17}}</string>
|
||||||
|
<reference key="NSSuperview" ref="1006"/>
|
||||||
|
<reference key="NSWindow"/>
|
||||||
|
<reference key="NSNextKeyView" ref="22939991"/>
|
||||||
|
<string key="NSReuseIdentifierKey">_NS:1505</string>
|
||||||
|
<bool key="NSEnabled">YES</bool>
|
||||||
|
<object class="NSTextFieldCell" key="NSCell" id="184485433">
|
||||||
|
<int key="NSCellFlags">68288064</int>
|
||||||
|
<int key="NSCellFlags2">272630784</int>
|
||||||
|
<string key="NSContents"/>
|
||||||
|
<reference key="NSSupport" ref="672375986"/>
|
||||||
|
<string key="NSCellIdentifier">_NS:1505</string>
|
||||||
|
<reference key="NSControlView" ref="275527426"/>
|
||||||
|
<reference key="NSBackgroundColor" ref="360163505"/>
|
||||||
|
<reference key="NSTextColor" ref="819030839"/>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
|
</array>
|
||||||
|
<string key="NSFrameSize">{449, 215}</string>
|
||||||
|
<reference key="NSSuperview"/>
|
||||||
|
<reference key="NSWindow"/>
|
||||||
|
<reference key="NSNextKeyView" ref="275527426"/>
|
||||||
|
</object>
|
||||||
|
<string key="NSScreenRect">{{0, 0}, {1920, 1058}}</string>
|
||||||
|
<string key="NSMaxSize">{10000000000000, 10000000000000}</string>
|
||||||
|
<bool key="NSWindowIsRestorable">NO</bool>
|
||||||
|
</object>
|
||||||
|
</array>
|
||||||
|
<object class="IBObjectContainer" key="IBDocument.Objects">
|
||||||
|
<array class="NSMutableArray" key="connectionRecords">
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBOutletConnection" key="connection">
|
||||||
|
<string key="label">messageTextField</string>
|
||||||
|
<reference key="source" ref="1001"/>
|
||||||
|
<reference key="destination" ref="275527426"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">45</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBOutletConnection" key="connection">
|
||||||
|
<string key="label">hardlinkButton</string>
|
||||||
|
<reference key="source" ref="1001"/>
|
||||||
|
<reference key="destination" ref="22939991"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">46</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBOutletConnection" key="connection">
|
||||||
|
<string key="label">directButton</string>
|
||||||
|
<reference key="source" ref="1001"/>
|
||||||
|
<reference key="destination" ref="1003638083"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">47</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBActionConnection" key="connection">
|
||||||
|
<string key="label">updateOptions:</string>
|
||||||
|
<reference key="source" ref="1001"/>
|
||||||
|
<reference key="destination" ref="22939991"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">48</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBActionConnection" key="connection">
|
||||||
|
<string key="label">updateOptions:</string>
|
||||||
|
<reference key="source" ref="1001"/>
|
||||||
|
<reference key="destination" ref="1003638083"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">49</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBActionConnection" key="connection">
|
||||||
|
<string key="label">cancel:</string>
|
||||||
|
<reference key="source" ref="1001"/>
|
||||||
|
<reference key="destination" ref="375232713"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">50</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBActionConnection" key="connection">
|
||||||
|
<string key="label">proceed:</string>
|
||||||
|
<reference key="source" ref="1001"/>
|
||||||
|
<reference key="destination" ref="630940386"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">51</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBOutletConnection" key="connection">
|
||||||
|
<string key="label">window</string>
|
||||||
|
<reference key="source" ref="1001"/>
|
||||||
|
<reference key="destination" ref="1005"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">52</int>
|
||||||
|
</object>
|
||||||
|
</array>
|
||||||
|
<object class="IBMutableOrderedSet" key="objectRecords">
|
||||||
|
<array key="orderedObjects">
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">0</int>
|
||||||
|
<array key="object" id="0"/>
|
||||||
|
<reference key="children" ref="1000"/>
|
||||||
|
<nil key="parent"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">-2</int>
|
||||||
|
<reference key="object" ref="1001"/>
|
||||||
|
<reference key="parent" ref="0"/>
|
||||||
|
<string key="objectName">File's Owner</string>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">-1</int>
|
||||||
|
<reference key="object" ref="1003"/>
|
||||||
|
<reference key="parent" ref="0"/>
|
||||||
|
<string key="objectName">First Responder</string>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">-3</int>
|
||||||
|
<reference key="object" ref="1004"/>
|
||||||
|
<reference key="parent" ref="0"/>
|
||||||
|
<string key="objectName">Application</string>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">1</int>
|
||||||
|
<reference key="object" ref="1005"/>
|
||||||
|
<array class="NSMutableArray" key="children">
|
||||||
|
<reference ref="1006"/>
|
||||||
|
</array>
|
||||||
|
<reference key="parent" ref="0"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">2</int>
|
||||||
|
<reference key="object" ref="1006"/>
|
||||||
|
<array class="NSMutableArray" key="children">
|
||||||
|
<reference ref="275527426"/>
|
||||||
|
<reference ref="22939991"/>
|
||||||
|
<reference ref="1003638083"/>
|
||||||
|
<reference ref="258896148"/>
|
||||||
|
<reference ref="316971589"/>
|
||||||
|
<reference ref="630940386"/>
|
||||||
|
<reference ref="375232713"/>
|
||||||
|
</array>
|
||||||
|
<reference key="parent" ref="1005"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">3</int>
|
||||||
|
<reference key="object" ref="22939991"/>
|
||||||
|
<array class="NSMutableArray" key="children">
|
||||||
|
<reference ref="199073808"/>
|
||||||
|
</array>
|
||||||
|
<reference key="parent" ref="1006"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">4</int>
|
||||||
|
<reference key="object" ref="199073808"/>
|
||||||
|
<reference key="parent" ref="22939991"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">7</int>
|
||||||
|
<reference key="object" ref="258896148"/>
|
||||||
|
<array class="NSMutableArray" key="children">
|
||||||
|
<reference ref="939395720"/>
|
||||||
|
</array>
|
||||||
|
<reference key="parent" ref="1006"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">8</int>
|
||||||
|
<reference key="object" ref="939395720"/>
|
||||||
|
<reference key="parent" ref="258896148"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">35</int>
|
||||||
|
<reference key="object" ref="1003638083"/>
|
||||||
|
<array class="NSMutableArray" key="children">
|
||||||
|
<reference ref="791836143"/>
|
||||||
|
</array>
|
||||||
|
<reference key="parent" ref="1006"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">36</int>
|
||||||
|
<reference key="object" ref="791836143"/>
|
||||||
|
<reference key="parent" ref="1003638083"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">37</int>
|
||||||
|
<reference key="object" ref="316971589"/>
|
||||||
|
<array class="NSMutableArray" key="children">
|
||||||
|
<reference ref="404549205"/>
|
||||||
|
</array>
|
||||||
|
<reference key="parent" ref="1006"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">38</int>
|
||||||
|
<reference key="object" ref="404549205"/>
|
||||||
|
<reference key="parent" ref="316971589"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">39</int>
|
||||||
|
<reference key="object" ref="630940386"/>
|
||||||
|
<array class="NSMutableArray" key="children">
|
||||||
|
<reference ref="551779024"/>
|
||||||
|
</array>
|
||||||
|
<reference key="parent" ref="1006"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">40</int>
|
||||||
|
<reference key="object" ref="551779024"/>
|
||||||
|
<reference key="parent" ref="630940386"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">41</int>
|
||||||
|
<reference key="object" ref="375232713"/>
|
||||||
|
<array class="NSMutableArray" key="children">
|
||||||
|
<reference ref="311692270"/>
|
||||||
|
</array>
|
||||||
|
<reference key="parent" ref="1006"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">42</int>
|
||||||
|
<reference key="object" ref="311692270"/>
|
||||||
|
<reference key="parent" ref="375232713"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">43</int>
|
||||||
|
<reference key="object" ref="275527426"/>
|
||||||
|
<array class="NSMutableArray" key="children">
|
||||||
|
<reference ref="184485433"/>
|
||||||
|
</array>
|
||||||
|
<reference key="parent" ref="1006"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">44</int>
|
||||||
|
<reference key="object" ref="184485433"/>
|
||||||
|
<reference key="parent" ref="275527426"/>
|
||||||
|
</object>
|
||||||
|
</array>
|
||||||
|
</object>
|
||||||
|
<dictionary class="NSMutableDictionary" key="flattenedProperties">
|
||||||
|
<string key="-1.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="-2.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="-3.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<boolean value="YES" key="1.IBNSWindowAutoPositionCentersHorizontal"/>
|
||||||
|
<boolean value="YES" key="1.IBNSWindowAutoPositionCentersVertical"/>
|
||||||
|
<string key="1.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="1.IBWindowTemplateEditedContentRect">{{357, 418}, {480, 270}}</string>
|
||||||
|
<boolean value="NO" key="1.NSWindowTemplate.visibleAtLaunch"/>
|
||||||
|
<string key="2.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="3.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="35.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="36.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="37.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="38.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="39.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="4.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="40.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="41.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="42.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="43.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="44.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="7.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="8.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
</dictionary>
|
||||||
|
<dictionary class="NSMutableDictionary" key="unlocalizedProperties"/>
|
||||||
|
<nil key="activeLocalization"/>
|
||||||
|
<dictionary class="NSMutableDictionary" key="localizations"/>
|
||||||
|
<nil key="sourceID"/>
|
||||||
|
<int key="maxID">52</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBClassDescriber" key="IBDocument.Classes">
|
||||||
|
<array class="NSMutableArray" key="referencedPartialClassDescriptions">
|
||||||
|
<object class="IBPartialClassDescription">
|
||||||
|
<string key="className">DeletionOptions</string>
|
||||||
|
<string key="superclassName">NSWindowController</string>
|
||||||
|
<dictionary class="NSMutableDictionary" key="actions">
|
||||||
|
<string key="cancel:">id</string>
|
||||||
|
<string key="proceed:">id</string>
|
||||||
|
<string key="updateOptions:">id</string>
|
||||||
|
</dictionary>
|
||||||
|
<dictionary class="NSMutableDictionary" key="actionInfosByName">
|
||||||
|
<object class="IBActionInfo" key="cancel:">
|
||||||
|
<string key="name">cancel:</string>
|
||||||
|
<string key="candidateClassName">id</string>
|
||||||
|
</object>
|
||||||
|
<object class="IBActionInfo" key="proceed:">
|
||||||
|
<string key="name">proceed:</string>
|
||||||
|
<string key="candidateClassName">id</string>
|
||||||
|
</object>
|
||||||
|
<object class="IBActionInfo" key="updateOptions:">
|
||||||
|
<string key="name">updateOptions:</string>
|
||||||
|
<string key="candidateClassName">id</string>
|
||||||
|
</object>
|
||||||
|
</dictionary>
|
||||||
|
<dictionary class="NSMutableDictionary" key="outlets">
|
||||||
|
<string key="directButton">NSButton</string>
|
||||||
|
<string key="hardlinkButton">NSButton</string>
|
||||||
|
<string key="messageTextField">NSTextField</string>
|
||||||
|
</dictionary>
|
||||||
|
<dictionary class="NSMutableDictionary" key="toOneOutletInfosByName">
|
||||||
|
<object class="IBToOneOutletInfo" key="directButton">
|
||||||
|
<string key="name">directButton</string>
|
||||||
|
<string key="candidateClassName">NSButton</string>
|
||||||
|
</object>
|
||||||
|
<object class="IBToOneOutletInfo" key="hardlinkButton">
|
||||||
|
<string key="name">hardlinkButton</string>
|
||||||
|
<string key="candidateClassName">NSButton</string>
|
||||||
|
</object>
|
||||||
|
<object class="IBToOneOutletInfo" key="messageTextField">
|
||||||
|
<string key="name">messageTextField</string>
|
||||||
|
<string key="candidateClassName">NSTextField</string>
|
||||||
|
</object>
|
||||||
|
</dictionary>
|
||||||
|
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
||||||
|
<string key="majorKey">IBProjectSource</string>
|
||||||
|
<string key="minorKey">./Classes/DeletionOptions.h</string>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
|
</array>
|
||||||
|
</object>
|
||||||
|
<int key="IBDocument.localizationMode">0</int>
|
||||||
|
<string key="IBDocument.TargetRuntimeIdentifier">IBCocoaFramework</string>
|
||||||
|
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDependencyDefaults">
|
||||||
|
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.macosx</string>
|
||||||
|
<real value="1060" key="NS.object.0"/>
|
||||||
|
</object>
|
||||||
|
<bool key="IBDocument.PluginDeclaredDependenciesTrackSystemTargetVersion">YES</bool>
|
||||||
|
<int key="IBDocument.defaultPropertyAccessControl">3</int>
|
||||||
|
<object class="NSMutableDictionary" key="IBDocument.LastKnownImageSizes">
|
||||||
|
<string key="NS.key.0">NSSwitch</string>
|
||||||
|
<string key="NS.object.0">{15, 15}</string>
|
||||||
|
</object>
|
||||||
|
</data>
|
||||||
|
</archive>
|
||||||
@@ -2,13 +2,13 @@
|
|||||||
<archive type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="8.00">
|
<archive type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="8.00">
|
||||||
<data>
|
<data>
|
||||||
<int key="IBDocument.SystemTarget">1060</int>
|
<int key="IBDocument.SystemTarget">1060</int>
|
||||||
<string key="IBDocument.SystemVersion">11B26</string>
|
<string key="IBDocument.SystemVersion">11D50</string>
|
||||||
<string key="IBDocument.InterfaceBuilderVersion">1617</string>
|
<string key="IBDocument.InterfaceBuilderVersion">2182</string>
|
||||||
<string key="IBDocument.AppKitVersion">1138</string>
|
<string key="IBDocument.AppKitVersion">1138.32</string>
|
||||||
<string key="IBDocument.HIToolboxVersion">566.00</string>
|
<string key="IBDocument.HIToolboxVersion">568.00</string>
|
||||||
<object class="NSMutableDictionary" key="IBDocument.PluginVersions">
|
<object class="NSMutableDictionary" key="IBDocument.PluginVersions">
|
||||||
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="NS.object.0">1617</string>
|
<string key="NS.object.0">2182</string>
|
||||||
</object>
|
</object>
|
||||||
<array key="IBDocument.IntegratedClassDependencies">
|
<array key="IBDocument.IntegratedClassDependencies">
|
||||||
<string>NSTextField</string>
|
<string>NSTextField</string>
|
||||||
@@ -31,7 +31,10 @@
|
|||||||
<array key="IBDocument.PluginDependencies">
|
<array key="IBDocument.PluginDependencies">
|
||||||
<string>com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string>com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
</array>
|
</array>
|
||||||
<dictionary class="NSMutableDictionary" key="IBDocument.Metadata"/>
|
<object class="NSMutableDictionary" key="IBDocument.Metadata">
|
||||||
|
<string key="NS.key.0">PluginDependencyRecalculationVersion</string>
|
||||||
|
<integer value="1" key="NS.object.0"/>
|
||||||
|
</object>
|
||||||
<array class="NSMutableArray" key="IBDocument.RootObjects" id="238648523">
|
<array class="NSMutableArray" key="IBDocument.RootObjects" id="238648523">
|
||||||
<object class="NSCustomObject" id="566600593">
|
<object class="NSCustomObject" id="566600593">
|
||||||
<string key="NSClassName">DirectoryPanel</string>
|
<string key="NSClassName">DirectoryPanel</string>
|
||||||
@@ -45,7 +48,7 @@
|
|||||||
<object class="NSWindowTemplate" id="970147395">
|
<object class="NSWindowTemplate" id="970147395">
|
||||||
<int key="NSWindowStyleMask">11</int>
|
<int key="NSWindowStyleMask">11</int>
|
||||||
<int key="NSWindowBacking">2</int>
|
<int key="NSWindowBacking">2</int>
|
||||||
<string key="NSWindowRect">{{387, 265}, {395, 294}}</string>
|
<string key="NSWindowRect">{{387, 265}, {422, 294}}</string>
|
||||||
<int key="NSWTFlags">1886913536</int>
|
<int key="NSWTFlags">1886913536</int>
|
||||||
<string key="NSWindowTitle">dupeGuru</string>
|
<string key="NSWindowTitle">dupeGuru</string>
|
||||||
<string key="NSWindowClass">NSWindow</string>
|
<string key="NSWindowClass">NSWindow</string>
|
||||||
@@ -69,14 +72,14 @@
|
|||||||
<object class="NSOutlineView" id="10140319">
|
<object class="NSOutlineView" id="10140319">
|
||||||
<reference key="NSNextResponder" ref="514281221"/>
|
<reference key="NSNextResponder" ref="514281221"/>
|
||||||
<int key="NSvFlags">256</int>
|
<int key="NSvFlags">256</int>
|
||||||
<string key="NSFrameSize">{353, 183}</string>
|
<string key="NSFrameSize">{380, 183}</string>
|
||||||
<reference key="NSSuperview" ref="514281221"/>
|
<reference key="NSSuperview" ref="514281221"/>
|
||||||
<reference key="NSWindow"/>
|
<reference key="NSWindow"/>
|
||||||
<bool key="NSEnabled">YES</bool>
|
<bool key="NSEnabled">YES</bool>
|
||||||
<object class="NSTableHeaderView" key="NSHeaderView" id="885660940">
|
<object class="NSTableHeaderView" key="NSHeaderView" id="885660940">
|
||||||
<reference key="NSNextResponder" ref="395832192"/>
|
<reference key="NSNextResponder" ref="395832192"/>
|
||||||
<int key="NSvFlags">256</int>
|
<int key="NSvFlags">256</int>
|
||||||
<string key="NSFrameSize">{353, 17}</string>
|
<string key="NSFrameSize">{380, 17}</string>
|
||||||
<reference key="NSSuperview" ref="395832192"/>
|
<reference key="NSSuperview" ref="395832192"/>
|
||||||
<reference key="NSWindow"/>
|
<reference key="NSWindow"/>
|
||||||
<reference key="NSTableView" ref="10140319"/>
|
<reference key="NSTableView" ref="10140319"/>
|
||||||
@@ -91,7 +94,7 @@
|
|||||||
<array class="NSMutableArray" key="NSTableColumns">
|
<array class="NSMutableArray" key="NSTableColumns">
|
||||||
<object class="NSTableColumn" id="547470852">
|
<object class="NSTableColumn" id="547470852">
|
||||||
<string key="NSIdentifier">name</string>
|
<string key="NSIdentifier">name</string>
|
||||||
<double key="NSWidth">262</double>
|
<double key="NSWidth">289</double>
|
||||||
<double key="NSMinWidth">16</double>
|
<double key="NSMinWidth">16</double>
|
||||||
<double key="NSMaxWidth">1000</double>
|
<double key="NSMaxWidth">1000</double>
|
||||||
<object class="NSTableHeaderCell" key="NSHeaderCell">
|
<object class="NSTableHeaderCell" key="NSHeaderCell">
|
||||||
@@ -233,7 +236,7 @@
|
|||||||
</object>
|
</object>
|
||||||
</object>
|
</object>
|
||||||
<double key="NSRowHeight">14</double>
|
<double key="NSRowHeight">14</double>
|
||||||
<int key="NSTvFlags">1379958784</int>
|
<int key="NSTvFlags">1514176512</int>
|
||||||
<reference key="NSDelegate"/>
|
<reference key="NSDelegate"/>
|
||||||
<reference key="NSDataSource"/>
|
<reference key="NSDataSource"/>
|
||||||
<int key="NSColumnAutoresizingStyle">1</int>
|
<int key="NSColumnAutoresizingStyle">1</int>
|
||||||
@@ -244,7 +247,7 @@
|
|||||||
<int key="NSTableViewGroupRowStyle">1</int>
|
<int key="NSTableViewGroupRowStyle">1</int>
|
||||||
</object>
|
</object>
|
||||||
</array>
|
</array>
|
||||||
<string key="NSFrame">{{1, 17}, {353, 183}}</string>
|
<string key="NSFrame">{{1, 17}, {380, 183}}</string>
|
||||||
<reference key="NSSuperview" ref="242279311"/>
|
<reference key="NSSuperview" ref="242279311"/>
|
||||||
<reference key="NSWindow"/>
|
<reference key="NSWindow"/>
|
||||||
<reference key="NSNextKeyView" ref="10140319"/>
|
<reference key="NSNextKeyView" ref="10140319"/>
|
||||||
@@ -279,7 +282,7 @@
|
|||||||
<array class="NSMutableArray" key="NSSubviews">
|
<array class="NSMutableArray" key="NSSubviews">
|
||||||
<reference ref="885660940"/>
|
<reference ref="885660940"/>
|
||||||
</array>
|
</array>
|
||||||
<string key="NSFrame">{{1, 0}, {353, 17}}</string>
|
<string key="NSFrame">{{1, 0}, {380, 17}}</string>
|
||||||
<reference key="NSSuperview" ref="242279311"/>
|
<reference key="NSSuperview" ref="242279311"/>
|
||||||
<reference key="NSWindow"/>
|
<reference key="NSWindow"/>
|
||||||
<reference key="NSNextKeyView" ref="885660940"/>
|
<reference key="NSNextKeyView" ref="885660940"/>
|
||||||
@@ -289,7 +292,7 @@
|
|||||||
</object>
|
</object>
|
||||||
<reference ref="950325122"/>
|
<reference ref="950325122"/>
|
||||||
</array>
|
</array>
|
||||||
<string key="NSFrame">{{20, 48}, {355, 201}}</string>
|
<string key="NSFrame">{{20, 48}, {382, 201}}</string>
|
||||||
<reference key="NSSuperview" ref="53314480"/>
|
<reference key="NSSuperview" ref="53314480"/>
|
||||||
<reference key="NSWindow"/>
|
<reference key="NSWindow"/>
|
||||||
<reference key="NSNextKeyView" ref="514281221"/>
|
<reference key="NSNextKeyView" ref="514281221"/>
|
||||||
@@ -384,7 +387,7 @@
|
|||||||
<object class="NSButton" id="580397230">
|
<object class="NSButton" id="580397230">
|
||||||
<reference key="NSNextResponder" ref="53314480"/>
|
<reference key="NSNextResponder" ref="53314480"/>
|
||||||
<int key="NSvFlags">289</int>
|
<int key="NSvFlags">289</int>
|
||||||
<string key="NSFrame">{{251, 12}, {130, 32}}</string>
|
<string key="NSFrame">{{278, 13}, {130, 32}}</string>
|
||||||
<reference key="NSSuperview" ref="53314480"/>
|
<reference key="NSSuperview" ref="53314480"/>
|
||||||
<reference key="NSWindow"/>
|
<reference key="NSWindow"/>
|
||||||
<bool key="NSEnabled">YES</bool>
|
<bool key="NSEnabled">YES</bool>
|
||||||
@@ -456,7 +459,7 @@
|
|||||||
<object class="NSTextField" id="186572573">
|
<object class="NSTextField" id="186572573">
|
||||||
<reference key="NSNextResponder" ref="53314480"/>
|
<reference key="NSNextResponder" ref="53314480"/>
|
||||||
<int key="NSvFlags">266</int>
|
<int key="NSvFlags">266</int>
|
||||||
<string key="NSFrame">{{17, 257}, {361, 17}}</string>
|
<string key="NSFrame">{{17, 257}, {388, 17}}</string>
|
||||||
<reference key="NSSuperview" ref="53314480"/>
|
<reference key="NSSuperview" ref="53314480"/>
|
||||||
<reference key="NSWindow"/>
|
<reference key="NSWindow"/>
|
||||||
<bool key="NSEnabled">YES</bool>
|
<bool key="NSEnabled">YES</bool>
|
||||||
@@ -478,7 +481,7 @@
|
|||||||
<object class="NSButton" id="84918337">
|
<object class="NSButton" id="84918337">
|
||||||
<reference key="NSNextResponder" ref="53314480"/>
|
<reference key="NSNextResponder" ref="53314480"/>
|
||||||
<int key="NSvFlags">289</int>
|
<int key="NSvFlags">289</int>
|
||||||
<string key="NSFrame">{{121, 12}, {130, 32}}</string>
|
<string key="NSFrame">{{148, 13}, {130, 32}}</string>
|
||||||
<reference key="NSSuperview" ref="53314480"/>
|
<reference key="NSSuperview" ref="53314480"/>
|
||||||
<reference key="NSWindow"/>
|
<reference key="NSWindow"/>
|
||||||
<bool key="NSEnabled">YES</bool>
|
<bool key="NSEnabled">YES</bool>
|
||||||
@@ -497,7 +500,7 @@
|
|||||||
</object>
|
</object>
|
||||||
</object>
|
</object>
|
||||||
</array>
|
</array>
|
||||||
<string key="NSFrameSize">{395, 294}</string>
|
<string key="NSFrameSize">{422, 294}</string>
|
||||||
<reference key="NSSuperview"/>
|
<reference key="NSSuperview"/>
|
||||||
<reference key="NSWindow"/>
|
<reference key="NSWindow"/>
|
||||||
</object>
|
</object>
|
||||||
@@ -510,14 +513,6 @@
|
|||||||
</array>
|
</array>
|
||||||
<object class="IBObjectContainer" key="IBDocument.Objects">
|
<object class="IBObjectContainer" key="IBDocument.Objects">
|
||||||
<array class="NSMutableArray" key="connectionRecords">
|
<array class="NSMutableArray" key="connectionRecords">
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBOutletConnection" key="connection">
|
|
||||||
<string key="label">initialFirstResponder</string>
|
|
||||||
<reference key="source" ref="970147395"/>
|
|
||||||
<reference key="destination" ref="10140319"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">19</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBConnectionRecord">
|
<object class="IBConnectionRecord">
|
||||||
<object class="IBOutletConnection" key="connection">
|
<object class="IBOutletConnection" key="connection">
|
||||||
<string key="label">window</string>
|
<string key="label">window</string>
|
||||||
@@ -542,14 +537,6 @@
|
|||||||
</object>
|
</object>
|
||||||
<int key="connectionID">54</int>
|
<int key="connectionID">54</int>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBActionConnection" key="connection">
|
|
||||||
<string key="label">startScanning:</string>
|
|
||||||
<reference key="source" ref="244639324"/>
|
|
||||||
<reference key="destination" ref="580397230"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">60</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBConnectionRecord">
|
<object class="IBConnectionRecord">
|
||||||
<object class="IBActionConnection" key="connection">
|
<object class="IBActionConnection" key="connection">
|
||||||
<string key="label">removeSelectedDirectory:</string>
|
<string key="label">removeSelectedDirectory:</string>
|
||||||
@@ -590,6 +577,30 @@
|
|||||||
</object>
|
</object>
|
||||||
<int key="connectionID">78</int>
|
<int key="connectionID">78</int>
|
||||||
</object>
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBOutletConnection" key="connection">
|
||||||
|
<string key="label">loadResultsButton</string>
|
||||||
|
<reference key="source" ref="566600593"/>
|
||||||
|
<reference key="destination" ref="84918337"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">79</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBActionConnection" key="connection">
|
||||||
|
<string key="label">startScanning:</string>
|
||||||
|
<reference key="source" ref="244639324"/>
|
||||||
|
<reference key="destination" ref="580397230"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">60</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBOutletConnection" key="connection">
|
||||||
|
<string key="label">initialFirstResponder</string>
|
||||||
|
<reference key="source" ref="970147395"/>
|
||||||
|
<reference key="destination" ref="10140319"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">19</int>
|
||||||
|
</object>
|
||||||
</array>
|
</array>
|
||||||
<object class="IBMutableOrderedSet" key="objectRecords">
|
<object class="IBMutableOrderedSet" key="objectRecords">
|
||||||
<array key="orderedObjects">
|
<array key="orderedObjects">
|
||||||
@@ -886,7 +897,7 @@
|
|||||||
<nil key="activeLocalization"/>
|
<nil key="activeLocalization"/>
|
||||||
<dictionary class="NSMutableDictionary" key="localizations"/>
|
<dictionary class="NSMutableDictionary" key="localizations"/>
|
||||||
<nil key="sourceID"/>
|
<nil key="sourceID"/>
|
||||||
<int key="maxID">78</int>
|
<int key="maxID">79</int>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBClassDescriber" key="IBDocument.Classes">
|
<object class="IBClassDescriber" key="IBDocument.Classes">
|
||||||
<array class="NSMutableArray" key="referencedPartialClassDescriptions">
|
<array class="NSMutableArray" key="referencedPartialClassDescriptions">
|
||||||
@@ -899,6 +910,7 @@
|
|||||||
<string key="openWebsite:">id</string>
|
<string key="openWebsite:">id</string>
|
||||||
<string key="showAboutBox:">id</string>
|
<string key="showAboutBox:">id</string>
|
||||||
<string key="showDirectoryWindow:">id</string>
|
<string key="showDirectoryWindow:">id</string>
|
||||||
|
<string key="showIgnoreList:">id</string>
|
||||||
<string key="showPreferencesPanel:">id</string>
|
<string key="showPreferencesPanel:">id</string>
|
||||||
<string key="showResultWindow:">id</string>
|
<string key="showResultWindow:">id</string>
|
||||||
<string key="startScanning:">id</string>
|
<string key="startScanning:">id</string>
|
||||||
@@ -924,6 +936,10 @@
|
|||||||
<string key="name">showDirectoryWindow:</string>
|
<string key="name">showDirectoryWindow:</string>
|
||||||
<string key="candidateClassName">id</string>
|
<string key="candidateClassName">id</string>
|
||||||
</object>
|
</object>
|
||||||
|
<object class="IBActionInfo" key="showIgnoreList:">
|
||||||
|
<string key="name">showIgnoreList:</string>
|
||||||
|
<string key="candidateClassName">id</string>
|
||||||
|
</object>
|
||||||
<object class="IBActionInfo" key="showPreferencesPanel:">
|
<object class="IBActionInfo" key="showPreferencesPanel:">
|
||||||
<string key="name">showPreferencesPanel:</string>
|
<string key="name">showPreferencesPanel:</string>
|
||||||
<string key="candidateClassName">id</string>
|
<string key="candidateClassName">id</string>
|
||||||
@@ -940,7 +956,6 @@
|
|||||||
<dictionary class="NSMutableDictionary" key="outlets">
|
<dictionary class="NSMutableDictionary" key="outlets">
|
||||||
<string key="actionsMenu">NSMenu</string>
|
<string key="actionsMenu">NSMenu</string>
|
||||||
<string key="columnsMenu">NSMenu</string>
|
<string key="columnsMenu">NSMenu</string>
|
||||||
<string key="py">PyDupeGuruBase</string>
|
|
||||||
<string key="recentResultsMenu">NSMenu</string>
|
<string key="recentResultsMenu">NSMenu</string>
|
||||||
</dictionary>
|
</dictionary>
|
||||||
<dictionary class="NSMutableDictionary" key="toOneOutletInfosByName">
|
<dictionary class="NSMutableDictionary" key="toOneOutletInfosByName">
|
||||||
@@ -952,10 +967,6 @@
|
|||||||
<string key="name">columnsMenu</string>
|
<string key="name">columnsMenu</string>
|
||||||
<string key="candidateClassName">NSMenu</string>
|
<string key="candidateClassName">NSMenu</string>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBToOneOutletInfo" key="py">
|
|
||||||
<string key="name">py</string>
|
|
||||||
<string key="candidateClassName">PyDupeGuruBase</string>
|
|
||||||
</object>
|
|
||||||
<object class="IBToOneOutletInfo" key="recentResultsMenu">
|
<object class="IBToOneOutletInfo" key="recentResultsMenu">
|
||||||
<string key="name">recentResultsMenu</string>
|
<string key="name">recentResultsMenu</string>
|
||||||
<string key="candidateClassName">NSMenu</string>
|
<string key="candidateClassName">NSMenu</string>
|
||||||
@@ -996,6 +1007,7 @@
|
|||||||
<dictionary class="NSMutableDictionary" key="outlets">
|
<dictionary class="NSMutableDictionary" key="outlets">
|
||||||
<string key="addButtonPopUp">NSPopUpButton</string>
|
<string key="addButtonPopUp">NSPopUpButton</string>
|
||||||
<string key="loadRecentButtonPopUp">NSPopUpButton</string>
|
<string key="loadRecentButtonPopUp">NSPopUpButton</string>
|
||||||
|
<string key="loadResultsButton">NSButton</string>
|
||||||
<string key="outlineView">HSOutlineView</string>
|
<string key="outlineView">HSOutlineView</string>
|
||||||
<string key="removeButton">NSButton</string>
|
<string key="removeButton">NSButton</string>
|
||||||
</dictionary>
|
</dictionary>
|
||||||
@@ -1008,6 +1020,10 @@
|
|||||||
<string key="name">loadRecentButtonPopUp</string>
|
<string key="name">loadRecentButtonPopUp</string>
|
||||||
<string key="candidateClassName">NSPopUpButton</string>
|
<string key="candidateClassName">NSPopUpButton</string>
|
||||||
</object>
|
</object>
|
||||||
|
<object class="IBToOneOutletInfo" key="loadResultsButton">
|
||||||
|
<string key="name">loadResultsButton</string>
|
||||||
|
<string key="candidateClassName">NSButton</string>
|
||||||
|
</object>
|
||||||
<object class="IBToOneOutletInfo" key="outlineView">
|
<object class="IBToOneOutletInfo" key="outlineView">
|
||||||
<string key="name">outlineView</string>
|
<string key="name">outlineView</string>
|
||||||
<string key="candidateClassName">HSOutlineView</string>
|
<string key="candidateClassName">HSOutlineView</string>
|
||||||
@@ -1025,35 +1041,22 @@
|
|||||||
<object class="IBPartialClassDescription">
|
<object class="IBPartialClassDescription">
|
||||||
<string key="className">HSOutlineView</string>
|
<string key="className">HSOutlineView</string>
|
||||||
<string key="superclassName">NSOutlineView</string>
|
<string key="superclassName">NSOutlineView</string>
|
||||||
|
<object class="NSMutableDictionary" key="actions">
|
||||||
|
<string key="NS.key.0">copy:</string>
|
||||||
|
<string key="NS.object.0">id</string>
|
||||||
|
</object>
|
||||||
|
<object class="NSMutableDictionary" key="actionInfosByName">
|
||||||
|
<string key="NS.key.0">copy:</string>
|
||||||
|
<object class="IBActionInfo" key="NS.object.0">
|
||||||
|
<string key="name">copy:</string>
|
||||||
|
<string key="candidateClassName">id</string>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
||||||
<string key="majorKey">IBProjectSource</string>
|
<string key="majorKey">IBProjectSource</string>
|
||||||
<string key="minorKey">./Classes/HSOutlineView.h</string>
|
<string key="minorKey">./Classes/HSOutlineView.h</string>
|
||||||
</object>
|
</object>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBPartialClassDescription">
|
|
||||||
<string key="className">PyApp</string>
|
|
||||||
<string key="superclassName">PyFairware</string>
|
|
||||||
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
|
||||||
<string key="majorKey">IBProjectSource</string>
|
|
||||||
<string key="minorKey">./Classes/PyApp.h</string>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
<object class="IBPartialClassDescription">
|
|
||||||
<string key="className">PyDupeGuruBase</string>
|
|
||||||
<string key="superclassName">PyApp</string>
|
|
||||||
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
|
||||||
<string key="majorKey">IBProjectSource</string>
|
|
||||||
<string key="minorKey">./Classes/PyDupeGuruBase.h</string>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
<object class="IBPartialClassDescription">
|
|
||||||
<string key="className">PyFairware</string>
|
|
||||||
<string key="superclassName">NSObject</string>
|
|
||||||
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
|
||||||
<string key="majorKey">IBProjectSource</string>
|
|
||||||
<string key="minorKey">./Classes/PyFairware.h</string>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
</array>
|
</array>
|
||||||
</object>
|
</object>
|
||||||
<int key="IBDocument.localizationMode">0</int>
|
<int key="IBDocument.localizationMode">0</int>
|
||||||
@@ -1064,7 +1067,7 @@
|
|||||||
</object>
|
</object>
|
||||||
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDependencyDefaults">
|
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDependencyDefaults">
|
||||||
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.macosx</string>
|
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.macosx</string>
|
||||||
<integer value="1050" key="NS.object.0"/>
|
<real value="1060" key="NS.object.0"/>
|
||||||
</object>
|
</object>
|
||||||
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDevelopmentDependencies">
|
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDevelopmentDependencies">
|
||||||
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.InterfaceBuilder3</string>
|
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.InterfaceBuilder3</string>
|
||||||
|
|||||||
@@ -1,11 +0,0 @@
|
|||||||
/* Class = "NSWindow"; title = "Sorry, I must insist"; ObjectID = "1"; */
|
|
||||||
"1.title" = "Sorry, I must insist";
|
|
||||||
|
|
||||||
/* Class = "NSTextFieldCell"; title = "This reminder showed up because:
1. You are processing more than 100 duplicates
2. You have not yet contributed to dupeGuru
3. There are unpaid hours in the project"; ObjectID = "4"; */
|
|
||||||
"4.title" = "This reminder showed up because:\n\n1. You are processing more than 100 duplicates\n2. You have not yet contributed to dupeGuru\n3. There are unpaid hours in the project";
|
|
||||||
|
|
||||||
/* Class = "NSTextFieldCell"; title = "It seems that you found a lot of duplicates. Nice! I must insist, however, that contributions are expected when there are unpaid hours on the project.
You might think \"but I'm only going to use this once, I don't have to contribute\". The problem is that most people use dupeGuru only once in a while. If everyone thinks like that, dupeGuru development cannot be funded.
If you can't afford to contribute, you can ignore this reminder or send me an e-mail at hsoft@hardcoded.net so I can give you a key to remove this popup."; ObjectID = "6"; */
|
|
||||||
"6.title" = "It seems that you found a lot of duplicates. Nice! I must insist, however, that contributions are expected when there are unpaid hours on the project.\n\nYou might think \"but I'm only going to use this once, I don't have to contribute\". The problem is that most people use dupeGuru only once in a while. If everyone thinks like that, dupeGuru development cannot be funded. It's because of this tendency inherent to dupeGuru's nature that I have to insist here.\n\nIf you can't afford to contribute, you can ignore this reminder or send me an e-mail at hsoft@hardcoded.net so I can give you a key to remove this popup.";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Contribute"; ObjectID = "10"; */
|
|
||||||
"10.title" = "Contribute";
|
|
||||||
@@ -1,382 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<archive type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="8.00">
|
|
||||||
<data>
|
|
||||||
<int key="IBDocument.SystemTarget">1060</int>
|
|
||||||
<string key="IBDocument.SystemVersion">11B26</string>
|
|
||||||
<string key="IBDocument.InterfaceBuilderVersion">1617</string>
|
|
||||||
<string key="IBDocument.AppKitVersion">1138</string>
|
|
||||||
<string key="IBDocument.HIToolboxVersion">566.00</string>
|
|
||||||
<object class="NSMutableDictionary" key="IBDocument.PluginVersions">
|
|
||||||
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="NS.object.0">1617</string>
|
|
||||||
</object>
|
|
||||||
<array key="IBDocument.IntegratedClassDependencies">
|
|
||||||
<string>NSTextField</string>
|
|
||||||
<string>NSView</string>
|
|
||||||
<string>NSWindowTemplate</string>
|
|
||||||
<string>NSCustomObject</string>
|
|
||||||
<string>NSButtonCell</string>
|
|
||||||
<string>NSButton</string>
|
|
||||||
<string>NSTextFieldCell</string>
|
|
||||||
</array>
|
|
||||||
<array key="IBDocument.PluginDependencies">
|
|
||||||
<string>com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
</array>
|
|
||||||
<dictionary class="NSMutableDictionary" key="IBDocument.Metadata"/>
|
|
||||||
<array class="NSMutableArray" key="IBDocument.RootObjects" id="1000">
|
|
||||||
<object class="NSCustomObject" id="1001">
|
|
||||||
<string key="NSClassName">ExtraFairwareReminder</string>
|
|
||||||
</object>
|
|
||||||
<object class="NSCustomObject" id="1003">
|
|
||||||
<string key="NSClassName">FirstResponder</string>
|
|
||||||
</object>
|
|
||||||
<object class="NSCustomObject" id="1004">
|
|
||||||
<string key="NSClassName">NSApplication</string>
|
|
||||||
</object>
|
|
||||||
<object class="NSWindowTemplate" id="1005">
|
|
||||||
<int key="NSWindowStyleMask">1</int>
|
|
||||||
<int key="NSWindowBacking">2</int>
|
|
||||||
<string key="NSWindowRect">{{418, 295}, {480, 390}}</string>
|
|
||||||
<int key="NSWTFlags">1081606144</int>
|
|
||||||
<string key="NSWindowTitle">Sorry, I must insist</string>
|
|
||||||
<string key="NSWindowClass">NSWindow</string>
|
|
||||||
<nil key="NSViewClass"/>
|
|
||||||
<nil key="NSUserInterfaceItemIdentifier"/>
|
|
||||||
<object class="NSView" key="NSWindowView" id="1006">
|
|
||||||
<reference key="NSNextResponder"/>
|
|
||||||
<int key="NSvFlags">256</int>
|
|
||||||
<array class="NSMutableArray" key="NSSubviews">
|
|
||||||
<object class="NSTextField" id="359672030">
|
|
||||||
<reference key="NSNextResponder" ref="1006"/>
|
|
||||||
<int key="NSvFlags">268</int>
|
|
||||||
<string key="NSFrame">{{17, 48}, {446, 85}}</string>
|
|
||||||
<reference key="NSSuperview" ref="1006"/>
|
|
||||||
<reference key="NSWindow"/>
|
|
||||||
<bool key="NSEnabled">YES</bool>
|
|
||||||
<object class="NSTextFieldCell" key="NSCell" id="855705720">
|
|
||||||
<int key="NSCellFlags">67239424</int>
|
|
||||||
<int key="NSCellFlags2">272629760</int>
|
|
||||||
<string key="NSContents">This reminder showed up because:
1. You are processing more than 100 duplicates
2. You have not yet contributed to dupeGuru
3. There are unpaid hours in the project</string>
|
|
||||||
<object class="NSFont" key="NSSupport">
|
|
||||||
<string key="NSName">LucidaGrande-Bold</string>
|
|
||||||
<double key="NSSize">12</double>
|
|
||||||
<int key="NSfFlags">16</int>
|
|
||||||
</object>
|
|
||||||
<reference key="NSControlView" ref="359672030"/>
|
|
||||||
<object class="NSColor" key="NSBackgroundColor" id="732565682">
|
|
||||||
<int key="NSColorSpace">6</int>
|
|
||||||
<string key="NSCatalogName">System</string>
|
|
||||||
<string key="NSColorName">controlColor</string>
|
|
||||||
<object class="NSColor" key="NSColor">
|
|
||||||
<int key="NSColorSpace">3</int>
|
|
||||||
<bytes key="NSWhite">MC42NjY2NjY2NjY3AA</bytes>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
<object class="NSColor" key="NSTextColor" id="873511993">
|
|
||||||
<int key="NSColorSpace">6</int>
|
|
||||||
<string key="NSCatalogName">System</string>
|
|
||||||
<string key="NSColorName">controlTextColor</string>
|
|
||||||
<object class="NSColor" key="NSColor">
|
|
||||||
<int key="NSColorSpace">3</int>
|
|
||||||
<bytes key="NSWhite">MAA</bytes>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
<object class="NSTextField" id="450147645">
|
|
||||||
<reference key="NSNextResponder" ref="1006"/>
|
|
||||||
<int key="NSvFlags">268</int>
|
|
||||||
<string key="NSFrame">{{17, 141}, {446, 229}}</string>
|
|
||||||
<reference key="NSSuperview" ref="1006"/>
|
|
||||||
<reference key="NSWindow"/>
|
|
||||||
<bool key="NSEnabled">YES</bool>
|
|
||||||
<object class="NSTextFieldCell" key="NSCell" id="307619415">
|
|
||||||
<int key="NSCellFlags">67239424</int>
|
|
||||||
<int key="NSCellFlags2">205520896</int>
|
|
||||||
<string key="NSContents">It seems that you found a lot of duplicates. Nice! I must insist, however, that contributions are expected when there are unpaid hours on the project.
You might think "but I'm only going to use this once, I don't have to contribute". The problem is that most people use dupeGuru only once in a while. If everyone thinks like that, dupeGuru development cannot be funded. It's because of this tendency inherent to dupeGuru's nature that I have to insist here.
If you can't afford to contribute, you can ignore this reminder or send me an e-mail at hsoft@hardcoded.net so I can give you a key to remove this popup.</string>
|
|
||||||
<object class="NSFont" key="NSSupport">
|
|
||||||
<string key="NSName">LucidaGrande</string>
|
|
||||||
<double key="NSSize">12</double>
|
|
||||||
<int key="NSfFlags">16</int>
|
|
||||||
</object>
|
|
||||||
<reference key="NSControlView" ref="450147645"/>
|
|
||||||
<reference key="NSBackgroundColor" ref="732565682"/>
|
|
||||||
<reference key="NSTextColor" ref="873511993"/>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
<object class="NSButton" id="858267836">
|
|
||||||
<reference key="NSNextResponder" ref="1006"/>
|
|
||||||
<int key="NSvFlags">268</int>
|
|
||||||
<string key="NSFrame">{{338, 12}, {128, 32}}</string>
|
|
||||||
<reference key="NSSuperview" ref="1006"/>
|
|
||||||
<reference key="NSWindow"/>
|
|
||||||
<bool key="NSEnabled">YES</bool>
|
|
||||||
<object class="NSButtonCell" key="NSCell" id="444055328">
|
|
||||||
<int key="NSCellFlags">67239424</int>
|
|
||||||
<int key="NSCellFlags2">134217728</int>
|
|
||||||
<string key="NSContents">Continue</string>
|
|
||||||
<object class="NSFont" key="NSSupport" id="534597488">
|
|
||||||
<string key="NSName">LucidaGrande</string>
|
|
||||||
<double key="NSSize">13</double>
|
|
||||||
<int key="NSfFlags">1044</int>
|
|
||||||
</object>
|
|
||||||
<reference key="NSControlView" ref="858267836"/>
|
|
||||||
<int key="NSButtonFlags">-2038284033</int>
|
|
||||||
<int key="NSButtonFlags2">129</int>
|
|
||||||
<string key="NSAlternateContents"/>
|
|
||||||
<string key="NSKeyEquivalent"/>
|
|
||||||
<int key="NSPeriodicDelay">200</int>
|
|
||||||
<int key="NSPeriodicInterval">25</int>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
<object class="NSButton" id="789504727">
|
|
||||||
<reference key="NSNextResponder" ref="1006"/>
|
|
||||||
<int key="NSvFlags">268</int>
|
|
||||||
<string key="NSFrame">{{210, 12}, {128, 32}}</string>
|
|
||||||
<reference key="NSSuperview" ref="1006"/>
|
|
||||||
<reference key="NSWindow"/>
|
|
||||||
<bool key="NSEnabled">YES</bool>
|
|
||||||
<object class="NSButtonCell" key="NSCell" id="639557916">
|
|
||||||
<int key="NSCellFlags">67239424</int>
|
|
||||||
<int key="NSCellFlags2">134217728</int>
|
|
||||||
<string key="NSContents">Contribute</string>
|
|
||||||
<reference key="NSSupport" ref="534597488"/>
|
|
||||||
<reference key="NSControlView" ref="789504727"/>
|
|
||||||
<int key="NSButtonFlags">-2038284033</int>
|
|
||||||
<int key="NSButtonFlags2">129</int>
|
|
||||||
<string key="NSAlternateContents"/>
|
|
||||||
<string type="base64-UTF8" key="NSKeyEquivalent">DQ</string>
|
|
||||||
<int key="NSPeriodicDelay">200</int>
|
|
||||||
<int key="NSPeriodicInterval">25</int>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
</array>
|
|
||||||
<string key="NSFrameSize">{480, 390}</string>
|
|
||||||
<reference key="NSSuperview"/>
|
|
||||||
<reference key="NSWindow"/>
|
|
||||||
</object>
|
|
||||||
<string key="NSScreenRect">{{0, 0}, {1440, 878}}</string>
|
|
||||||
<string key="NSMaxSize">{10000000000000, 10000000000000}</string>
|
|
||||||
<bool key="NSWindowIsRestorable">YES</bool>
|
|
||||||
</object>
|
|
||||||
</array>
|
|
||||||
<object class="IBObjectContainer" key="IBDocument.Objects">
|
|
||||||
<array class="NSMutableArray" key="connectionRecords">
|
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBActionConnection" key="connection">
|
|
||||||
<string key="label">contribute:</string>
|
|
||||||
<reference key="source" ref="1001"/>
|
|
||||||
<reference key="destination" ref="789504727"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">11</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBActionConnection" key="connection">
|
|
||||||
<string key="label">continue:</string>
|
|
||||||
<reference key="source" ref="1001"/>
|
|
||||||
<reference key="destination" ref="858267836"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">12</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBOutletConnection" key="connection">
|
|
||||||
<string key="label">window</string>
|
|
||||||
<reference key="source" ref="1001"/>
|
|
||||||
<reference key="destination" ref="1005"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">13</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBOutletConnection" key="connection">
|
|
||||||
<string key="label">continueButton</string>
|
|
||||||
<reference key="source" ref="1001"/>
|
|
||||||
<reference key="destination" ref="858267836"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">14</int>
|
|
||||||
</object>
|
|
||||||
</array>
|
|
||||||
<object class="IBMutableOrderedSet" key="objectRecords">
|
|
||||||
<array key="orderedObjects">
|
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">0</int>
|
|
||||||
<array key="object" id="0"/>
|
|
||||||
<reference key="children" ref="1000"/>
|
|
||||||
<nil key="parent"/>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">-2</int>
|
|
||||||
<reference key="object" ref="1001"/>
|
|
||||||
<reference key="parent" ref="0"/>
|
|
||||||
<string key="objectName">File's Owner</string>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">-1</int>
|
|
||||||
<reference key="object" ref="1003"/>
|
|
||||||
<reference key="parent" ref="0"/>
|
|
||||||
<string key="objectName">First Responder</string>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">-3</int>
|
|
||||||
<reference key="object" ref="1004"/>
|
|
||||||
<reference key="parent" ref="0"/>
|
|
||||||
<string key="objectName">Application</string>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">1</int>
|
|
||||||
<reference key="object" ref="1005"/>
|
|
||||||
<array class="NSMutableArray" key="children">
|
|
||||||
<reference ref="1006"/>
|
|
||||||
</array>
|
|
||||||
<reference key="parent" ref="0"/>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">2</int>
|
|
||||||
<reference key="object" ref="1006"/>
|
|
||||||
<array class="NSMutableArray" key="children">
|
|
||||||
<reference ref="450147645"/>
|
|
||||||
<reference ref="359672030"/>
|
|
||||||
<reference ref="858267836"/>
|
|
||||||
<reference ref="789504727"/>
|
|
||||||
</array>
|
|
||||||
<reference key="parent" ref="1005"/>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">3</int>
|
|
||||||
<reference key="object" ref="359672030"/>
|
|
||||||
<array class="NSMutableArray" key="children">
|
|
||||||
<reference ref="855705720"/>
|
|
||||||
</array>
|
|
||||||
<reference key="parent" ref="1006"/>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">4</int>
|
|
||||||
<reference key="object" ref="855705720"/>
|
|
||||||
<reference key="parent" ref="359672030"/>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">5</int>
|
|
||||||
<reference key="object" ref="450147645"/>
|
|
||||||
<array class="NSMutableArray" key="children">
|
|
||||||
<reference ref="307619415"/>
|
|
||||||
</array>
|
|
||||||
<reference key="parent" ref="1006"/>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">6</int>
|
|
||||||
<reference key="object" ref="307619415"/>
|
|
||||||
<reference key="parent" ref="450147645"/>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">7</int>
|
|
||||||
<reference key="object" ref="858267836"/>
|
|
||||||
<array class="NSMutableArray" key="children">
|
|
||||||
<reference ref="444055328"/>
|
|
||||||
</array>
|
|
||||||
<reference key="parent" ref="1006"/>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">8</int>
|
|
||||||
<reference key="object" ref="444055328"/>
|
|
||||||
<reference key="parent" ref="858267836"/>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">9</int>
|
|
||||||
<reference key="object" ref="789504727"/>
|
|
||||||
<array class="NSMutableArray" key="children">
|
|
||||||
<reference ref="639557916"/>
|
|
||||||
</array>
|
|
||||||
<reference key="parent" ref="1006"/>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">10</int>
|
|
||||||
<reference key="object" ref="639557916"/>
|
|
||||||
<reference key="parent" ref="789504727"/>
|
|
||||||
</object>
|
|
||||||
</array>
|
|
||||||
</object>
|
|
||||||
<dictionary class="NSMutableDictionary" key="flattenedProperties">
|
|
||||||
<string key="-1.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="-2.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="-3.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="1.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="1.IBWindowTemplateEditedContentRect">{{418, 295}, {480, 390}}</string>
|
|
||||||
<boolean value="NO" key="1.NSWindowTemplate.visibleAtLaunch"/>
|
|
||||||
<string key="10.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="2.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="3.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="4.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="5.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="6.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="7.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="8.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="9.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
</dictionary>
|
|
||||||
<dictionary class="NSMutableDictionary" key="unlocalizedProperties"/>
|
|
||||||
<nil key="activeLocalization"/>
|
|
||||||
<dictionary class="NSMutableDictionary" key="localizations"/>
|
|
||||||
<nil key="sourceID"/>
|
|
||||||
<int key="maxID">14</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBClassDescriber" key="IBDocument.Classes">
|
|
||||||
<array class="NSMutableArray" key="referencedPartialClassDescriptions">
|
|
||||||
<object class="IBPartialClassDescription">
|
|
||||||
<string key="className">ExtraFairwareReminder</string>
|
|
||||||
<string key="superclassName">HSWindowController</string>
|
|
||||||
<dictionary class="NSMutableDictionary" key="actions">
|
|
||||||
<string key="continue:">id</string>
|
|
||||||
<string key="contribute:">id</string>
|
|
||||||
</dictionary>
|
|
||||||
<dictionary class="NSMutableDictionary" key="actionInfosByName">
|
|
||||||
<object class="IBActionInfo" key="continue:">
|
|
||||||
<string key="name">continue:</string>
|
|
||||||
<string key="candidateClassName">id</string>
|
|
||||||
</object>
|
|
||||||
<object class="IBActionInfo" key="contribute:">
|
|
||||||
<string key="name">contribute:</string>
|
|
||||||
<string key="candidateClassName">id</string>
|
|
||||||
</object>
|
|
||||||
</dictionary>
|
|
||||||
<object class="NSMutableDictionary" key="outlets">
|
|
||||||
<string key="NS.key.0">continueButton</string>
|
|
||||||
<string key="NS.object.0">NSButton</string>
|
|
||||||
</object>
|
|
||||||
<object class="NSMutableDictionary" key="toOneOutletInfosByName">
|
|
||||||
<string key="NS.key.0">continueButton</string>
|
|
||||||
<object class="IBToOneOutletInfo" key="NS.object.0">
|
|
||||||
<string key="name">continueButton</string>
|
|
||||||
<string key="candidateClassName">NSButton</string>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
|
||||||
<string key="majorKey">IBProjectSource</string>
|
|
||||||
<string key="minorKey">./Classes/ExtraFairwareReminder.h</string>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
<object class="IBPartialClassDescription">
|
|
||||||
<string key="className">HSWindowController</string>
|
|
||||||
<string key="superclassName">NSWindowController</string>
|
|
||||||
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
|
||||||
<string key="majorKey">IBProjectSource</string>
|
|
||||||
<string key="minorKey">./Classes/HSWindowController.h</string>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
</array>
|
|
||||||
</object>
|
|
||||||
<int key="IBDocument.localizationMode">0</int>
|
|
||||||
<string key="IBDocument.TargetRuntimeIdentifier">IBCocoaFramework</string>
|
|
||||||
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDependencies">
|
|
||||||
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.macosx</string>
|
|
||||||
<real value="1060" key="NS.object.0"/>
|
|
||||||
</object>
|
|
||||||
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDependencyDefaults">
|
|
||||||
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.macosx</string>
|
|
||||||
<integer value="1050" key="NS.object.0"/>
|
|
||||||
</object>
|
|
||||||
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDevelopmentDependencies">
|
|
||||||
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.InterfaceBuilder3</string>
|
|
||||||
<real value="4100" key="NS.object.0"/>
|
|
||||||
</object>
|
|
||||||
<bool key="IBDocument.PluginDeclaredDependenciesTrackSystemTargetVersion">YES</bool>
|
|
||||||
<int key="IBDocument.defaultPropertyAccessControl">3</int>
|
|
||||||
</data>
|
|
||||||
</archive>
|
|
||||||
12
cocoa/base/en.lproj/IgnoreListDialog.strings
Normal file
12
cocoa/base/en.lproj/IgnoreListDialog.strings
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
|
||||||
|
/* Class = "NSWindow"; title = "Ignore List"; ObjectID = "1"; */
|
||||||
|
"1.title" = "Ignore List";
|
||||||
|
|
||||||
|
/* Class = "NSButtonCell"; title = "Close"; ObjectID = "19"; */
|
||||||
|
"19.title" = "Close";
|
||||||
|
|
||||||
|
/* Class = "NSButtonCell"; title = "Remove Selected"; ObjectID = "21"; */
|
||||||
|
"21.title" = "Remove Selected";
|
||||||
|
|
||||||
|
/* Class = "NSButtonCell"; title = "Clear"; ObjectID = "28"; */
|
||||||
|
"28.title" = "Clear";
|
||||||
504
cocoa/base/en.lproj/IgnoreListDialog.xib
Normal file
504
cocoa/base/en.lproj/IgnoreListDialog.xib
Normal file
@@ -0,0 +1,504 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<archive type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="8.00">
|
||||||
|
<data>
|
||||||
|
<int key="IBDocument.SystemTarget">1060</int>
|
||||||
|
<string key="IBDocument.SystemVersion">11D50</string>
|
||||||
|
<string key="IBDocument.InterfaceBuilderVersion">2177</string>
|
||||||
|
<string key="IBDocument.AppKitVersion">1138.32</string>
|
||||||
|
<string key="IBDocument.HIToolboxVersion">568.00</string>
|
||||||
|
<object class="NSMutableDictionary" key="IBDocument.PluginVersions">
|
||||||
|
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="NS.object.0">2177</string>
|
||||||
|
</object>
|
||||||
|
<array key="IBDocument.IntegratedClassDependencies">
|
||||||
|
<string>NSView</string>
|
||||||
|
<string>NSTableView</string>
|
||||||
|
<string>NSScrollView</string>
|
||||||
|
<string>NSWindowTemplate</string>
|
||||||
|
<string>NSTableHeaderView</string>
|
||||||
|
<string>NSButtonCell</string>
|
||||||
|
<string>NSButton</string>
|
||||||
|
<string>NSScroller</string>
|
||||||
|
<string>NSCustomObject</string>
|
||||||
|
</array>
|
||||||
|
<array key="IBDocument.PluginDependencies">
|
||||||
|
<string>com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
</array>
|
||||||
|
<object class="NSMutableDictionary" key="IBDocument.Metadata">
|
||||||
|
<string key="NS.key.0">PluginDependencyRecalculationVersion</string>
|
||||||
|
<integer value="1" key="NS.object.0"/>
|
||||||
|
</object>
|
||||||
|
<array class="NSMutableArray" key="IBDocument.RootObjects" id="1000">
|
||||||
|
<object class="NSCustomObject" id="1001">
|
||||||
|
<string key="NSClassName">IgnoreListDialog</string>
|
||||||
|
</object>
|
||||||
|
<object class="NSCustomObject" id="1003">
|
||||||
|
<string key="NSClassName">FirstResponder</string>
|
||||||
|
</object>
|
||||||
|
<object class="NSCustomObject" id="1004">
|
||||||
|
<string key="NSClassName">NSApplication</string>
|
||||||
|
</object>
|
||||||
|
<object class="NSWindowTemplate" id="359561441">
|
||||||
|
<int key="NSWindowStyleMask">11</int>
|
||||||
|
<int key="NSWindowBacking">2</int>
|
||||||
|
<string key="NSWindowRect">{{477, 306}, {574, 347}}</string>
|
||||||
|
<int key="NSWTFlags">1685585920</int>
|
||||||
|
<string key="NSWindowTitle">Ignore List</string>
|
||||||
|
<string key="NSWindowClass">NSWindow</string>
|
||||||
|
<nil key="NSViewClass"/>
|
||||||
|
<nil key="NSUserInterfaceItemIdentifier"/>
|
||||||
|
<object class="NSView" key="NSWindowView" id="976198330">
|
||||||
|
<reference key="NSNextResponder"/>
|
||||||
|
<int key="NSvFlags">256</int>
|
||||||
|
<array class="NSMutableArray" key="NSSubviews">
|
||||||
|
<object class="NSScrollView" id="458371270">
|
||||||
|
<reference key="NSNextResponder" ref="976198330"/>
|
||||||
|
<int key="NSvFlags">274</int>
|
||||||
|
<array class="NSMutableArray" key="NSSubviews">
|
||||||
|
<object class="NSClipView" id="831830981">
|
||||||
|
<reference key="NSNextResponder" ref="458371270"/>
|
||||||
|
<int key="NSvFlags">2304</int>
|
||||||
|
<array class="NSMutableArray" key="NSSubviews">
|
||||||
|
<object class="NSTableView" id="252791348">
|
||||||
|
<reference key="NSNextResponder" ref="831830981"/>
|
||||||
|
<int key="NSvFlags">256</int>
|
||||||
|
<string key="NSFrameSize">{532, 211}</string>
|
||||||
|
<reference key="NSSuperview" ref="831830981"/>
|
||||||
|
<reference key="NSWindow"/>
|
||||||
|
<reference key="NSNextKeyView" ref="777677330"/>
|
||||||
|
<bool key="NSEnabled">YES</bool>
|
||||||
|
<object class="NSTableHeaderView" key="NSHeaderView" id="903452051">
|
||||||
|
<reference key="NSNextResponder" ref="777677330"/>
|
||||||
|
<int key="NSvFlags">256</int>
|
||||||
|
<string key="NSFrameSize">{532, 17}</string>
|
||||||
|
<reference key="NSSuperview" ref="777677330"/>
|
||||||
|
<reference key="NSWindow"/>
|
||||||
|
<reference key="NSNextKeyView" ref="564034022"/>
|
||||||
|
<reference key="NSTableView" ref="252791348"/>
|
||||||
|
</object>
|
||||||
|
<object class="_NSCornerView" key="NSCornerView" id="564034022">
|
||||||
|
<reference key="NSNextResponder" ref="458371270"/>
|
||||||
|
<int key="NSvFlags">-2147483392</int>
|
||||||
|
<string key="NSFrame">{{224, 0}, {16, 17}}</string>
|
||||||
|
<reference key="NSSuperview" ref="458371270"/>
|
||||||
|
<reference key="NSWindow"/>
|
||||||
|
<reference key="NSNextKeyView" ref="831830981"/>
|
||||||
|
</object>
|
||||||
|
<array class="NSMutableArray" key="NSTableColumns"/>
|
||||||
|
<double key="NSIntercellSpacingWidth">3</double>
|
||||||
|
<double key="NSIntercellSpacingHeight">2</double>
|
||||||
|
<object class="NSColor" key="NSBackgroundColor">
|
||||||
|
<int key="NSColorSpace">3</int>
|
||||||
|
<bytes key="NSWhite">MQA</bytes>
|
||||||
|
</object>
|
||||||
|
<object class="NSColor" key="NSGridColor">
|
||||||
|
<int key="NSColorSpace">6</int>
|
||||||
|
<string key="NSCatalogName">System</string>
|
||||||
|
<string key="NSColorName">gridColor</string>
|
||||||
|
<object class="NSColor" key="NSColor">
|
||||||
|
<int key="NSColorSpace">3</int>
|
||||||
|
<bytes key="NSWhite">MC41AA</bytes>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
|
<double key="NSRowHeight">17</double>
|
||||||
|
<int key="NSTvFlags">1512046592</int>
|
||||||
|
<reference key="NSDelegate"/>
|
||||||
|
<reference key="NSDataSource"/>
|
||||||
|
<int key="NSColumnAutoresizingStyle">4</int>
|
||||||
|
<int key="NSDraggingSourceMaskForLocal">15</int>
|
||||||
|
<int key="NSDraggingSourceMaskForNonLocal">0</int>
|
||||||
|
<bool key="NSAllowsTypeSelect">NO</bool>
|
||||||
|
<int key="NSTableViewDraggingDestinationStyle">0</int>
|
||||||
|
<int key="NSTableViewGroupRowStyle">1</int>
|
||||||
|
</object>
|
||||||
|
</array>
|
||||||
|
<string key="NSFrame">{{1, 17}, {532, 249}}</string>
|
||||||
|
<reference key="NSSuperview" ref="458371270"/>
|
||||||
|
<reference key="NSWindow"/>
|
||||||
|
<reference key="NSNextKeyView" ref="252791348"/>
|
||||||
|
<reference key="NSDocView" ref="252791348"/>
|
||||||
|
<object class="NSColor" key="NSBGColor" id="765209443">
|
||||||
|
<int key="NSColorSpace">6</int>
|
||||||
|
<string key="NSCatalogName">System</string>
|
||||||
|
<string key="NSColorName">controlBackgroundColor</string>
|
||||||
|
<object class="NSColor" key="NSColor">
|
||||||
|
<int key="NSColorSpace">3</int>
|
||||||
|
<bytes key="NSWhite">MC42NjY2NjY2NjY3AA</bytes>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
|
<int key="NScvFlags">4</int>
|
||||||
|
</object>
|
||||||
|
<object class="NSScroller" id="99096694">
|
||||||
|
<reference key="NSNextResponder" ref="458371270"/>
|
||||||
|
<int key="NSvFlags">-2147483392</int>
|
||||||
|
<string key="NSFrame">{{224, 17}, {15, 102}}</string>
|
||||||
|
<reference key="NSSuperview" ref="458371270"/>
|
||||||
|
<reference key="NSWindow"/>
|
||||||
|
<reference key="NSNextKeyView" ref="47224920"/>
|
||||||
|
<reference key="NSTarget" ref="458371270"/>
|
||||||
|
<string key="NSAction">_doScroller:</string>
|
||||||
|
<double key="NSPercent">0.99052132701421802</double>
|
||||||
|
</object>
|
||||||
|
<object class="NSScroller" id="47224920">
|
||||||
|
<reference key="NSNextResponder" ref="458371270"/>
|
||||||
|
<int key="NSvFlags">-2147483392</int>
|
||||||
|
<string key="NSFrame">{{1, 154}, {438, 15}}</string>
|
||||||
|
<reference key="NSSuperview" ref="458371270"/>
|
||||||
|
<reference key="NSWindow"/>
|
||||||
|
<reference key="NSNextKeyView" ref="253286088"/>
|
||||||
|
<int key="NSsFlags">1</int>
|
||||||
|
<reference key="NSTarget" ref="458371270"/>
|
||||||
|
<string key="NSAction">_doScroller:</string>
|
||||||
|
<double key="NSCurValue">1</double>
|
||||||
|
<double key="NSPercent">0.98871331828442433</double>
|
||||||
|
</object>
|
||||||
|
<object class="NSClipView" id="777677330">
|
||||||
|
<reference key="NSNextResponder" ref="458371270"/>
|
||||||
|
<int key="NSvFlags">2304</int>
|
||||||
|
<array class="NSMutableArray" key="NSSubviews">
|
||||||
|
<reference ref="903452051"/>
|
||||||
|
</array>
|
||||||
|
<string key="NSFrame">{{1, 0}, {532, 17}}</string>
|
||||||
|
<reference key="NSSuperview" ref="458371270"/>
|
||||||
|
<reference key="NSWindow"/>
|
||||||
|
<reference key="NSNextKeyView" ref="903452051"/>
|
||||||
|
<reference key="NSDocView" ref="903452051"/>
|
||||||
|
<reference key="NSBGColor" ref="765209443"/>
|
||||||
|
<int key="NScvFlags">4</int>
|
||||||
|
</object>
|
||||||
|
<reference ref="564034022"/>
|
||||||
|
</array>
|
||||||
|
<string key="NSFrame">{{20, 60}, {534, 267}}</string>
|
||||||
|
<reference key="NSSuperview" ref="976198330"/>
|
||||||
|
<reference key="NSWindow"/>
|
||||||
|
<reference key="NSNextKeyView" ref="831830981"/>
|
||||||
|
<int key="NSsFlags">133682</int>
|
||||||
|
<reference key="NSVScroller" ref="99096694"/>
|
||||||
|
<reference key="NSHScroller" ref="47224920"/>
|
||||||
|
<reference key="NSContentView" ref="831830981"/>
|
||||||
|
<reference key="NSHeaderClipView" ref="777677330"/>
|
||||||
|
<reference key="NSCornerView" ref="564034022"/>
|
||||||
|
<bytes key="NSScrollAmts">QSAAAEEgAABBmAAAQZgAAA</bytes>
|
||||||
|
</object>
|
||||||
|
<object class="NSButton" id="4380169">
|
||||||
|
<reference key="NSNextResponder" ref="976198330"/>
|
||||||
|
<int key="NSvFlags">289</int>
|
||||||
|
<string key="NSFrame">{{464, 12}, {96, 32}}</string>
|
||||||
|
<reference key="NSSuperview" ref="976198330"/>
|
||||||
|
<reference key="NSWindow"/>
|
||||||
|
<bool key="NSEnabled">YES</bool>
|
||||||
|
<object class="NSButtonCell" key="NSCell" id="373771329">
|
||||||
|
<int key="NSCellFlags">67239424</int>
|
||||||
|
<int key="NSCellFlags2">134217728</int>
|
||||||
|
<string key="NSContents">Close</string>
|
||||||
|
<object class="NSFont" key="NSSupport" id="680801460">
|
||||||
|
<string key="NSName">LucidaGrande</string>
|
||||||
|
<double key="NSSize">13</double>
|
||||||
|
<int key="NSfFlags">1044</int>
|
||||||
|
</object>
|
||||||
|
<reference key="NSControlView" ref="4380169"/>
|
||||||
|
<int key="NSButtonFlags">-2038284033</int>
|
||||||
|
<int key="NSButtonFlags2">129</int>
|
||||||
|
<string key="NSAlternateContents"/>
|
||||||
|
<string type="base64-UTF8" key="NSKeyEquivalent">DQ</string>
|
||||||
|
<int key="NSPeriodicDelay">200</int>
|
||||||
|
<int key="NSPeriodicInterval">25</int>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
|
<object class="NSButton" id="253286088">
|
||||||
|
<reference key="NSNextResponder" ref="976198330"/>
|
||||||
|
<int key="NSvFlags">292</int>
|
||||||
|
<string key="NSFrame">{{14, 12}, {154, 32}}</string>
|
||||||
|
<reference key="NSSuperview" ref="976198330"/>
|
||||||
|
<reference key="NSWindow"/>
|
||||||
|
<reference key="NSNextKeyView" ref="983148229"/>
|
||||||
|
<bool key="NSEnabled">YES</bool>
|
||||||
|
<object class="NSButtonCell" key="NSCell" id="671547957">
|
||||||
|
<int key="NSCellFlags">67239424</int>
|
||||||
|
<int key="NSCellFlags2">134217728</int>
|
||||||
|
<string key="NSContents">Remove Selected</string>
|
||||||
|
<reference key="NSSupport" ref="680801460"/>
|
||||||
|
<reference key="NSControlView" ref="253286088"/>
|
||||||
|
<int key="NSButtonFlags">-2038284033</int>
|
||||||
|
<int key="NSButtonFlags2">129</int>
|
||||||
|
<string key="NSAlternateContents"/>
|
||||||
|
<string key="NSKeyEquivalent"/>
|
||||||
|
<int key="NSPeriodicDelay">200</int>
|
||||||
|
<int key="NSPeriodicInterval">25</int>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
|
<object class="NSButton" id="983148229">
|
||||||
|
<reference key="NSNextResponder" ref="976198330"/>
|
||||||
|
<int key="NSvFlags">292</int>
|
||||||
|
<string key="NSFrame">{{162, 12}, {154, 32}}</string>
|
||||||
|
<reference key="NSSuperview" ref="976198330"/>
|
||||||
|
<reference key="NSWindow"/>
|
||||||
|
<reference key="NSNextKeyView" ref="4380169"/>
|
||||||
|
<bool key="NSEnabled">YES</bool>
|
||||||
|
<object class="NSButtonCell" key="NSCell" id="409951495">
|
||||||
|
<int key="NSCellFlags">67239424</int>
|
||||||
|
<int key="NSCellFlags2">134217728</int>
|
||||||
|
<string key="NSContents">Clear</string>
|
||||||
|
<reference key="NSSupport" ref="680801460"/>
|
||||||
|
<reference key="NSControlView" ref="983148229"/>
|
||||||
|
<int key="NSButtonFlags">-2038284033</int>
|
||||||
|
<int key="NSButtonFlags2">129</int>
|
||||||
|
<string key="NSAlternateContents"/>
|
||||||
|
<string key="NSKeyEquivalent"/>
|
||||||
|
<int key="NSPeriodicDelay">200</int>
|
||||||
|
<int key="NSPeriodicInterval">25</int>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
|
</array>
|
||||||
|
<string key="NSFrameSize">{574, 347}</string>
|
||||||
|
<reference key="NSSuperview"/>
|
||||||
|
<reference key="NSWindow"/>
|
||||||
|
<reference key="NSNextKeyView" ref="458371270"/>
|
||||||
|
</object>
|
||||||
|
<string key="NSScreenRect">{{0, 0}, {1920, 1058}}</string>
|
||||||
|
<string key="NSMaxSize">{10000000000000, 10000000000000}</string>
|
||||||
|
<bool key="NSWindowIsRestorable">YES</bool>
|
||||||
|
</object>
|
||||||
|
</array>
|
||||||
|
<object class="IBObjectContainer" key="IBDocument.Objects">
|
||||||
|
<array class="NSMutableArray" key="connectionRecords">
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBOutletConnection" key="connection">
|
||||||
|
<string key="label">window</string>
|
||||||
|
<reference key="source" ref="1001"/>
|
||||||
|
<reference key="destination" ref="359561441"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">22</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBOutletConnection" key="connection">
|
||||||
|
<string key="label">ignoreListTableView</string>
|
||||||
|
<reference key="source" ref="1001"/>
|
||||||
|
<reference key="destination" ref="252791348"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">30</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBActionConnection" key="connection">
|
||||||
|
<string key="label">removeSelected:</string>
|
||||||
|
<reference key="source" ref="1001"/>
|
||||||
|
<reference key="destination" ref="253286088"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">31</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBActionConnection" key="connection">
|
||||||
|
<string key="label">clear:</string>
|
||||||
|
<reference key="source" ref="1001"/>
|
||||||
|
<reference key="destination" ref="983148229"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">32</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBActionConnection" key="connection">
|
||||||
|
<string key="label">performClose:</string>
|
||||||
|
<reference key="source" ref="359561441"/>
|
||||||
|
<reference key="destination" ref="4380169"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">25</int>
|
||||||
|
</object>
|
||||||
|
</array>
|
||||||
|
<object class="IBMutableOrderedSet" key="objectRecords">
|
||||||
|
<array key="orderedObjects">
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">0</int>
|
||||||
|
<array key="object" id="0"/>
|
||||||
|
<reference key="children" ref="1000"/>
|
||||||
|
<nil key="parent"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">-2</int>
|
||||||
|
<reference key="object" ref="1001"/>
|
||||||
|
<reference key="parent" ref="0"/>
|
||||||
|
<string key="objectName">File's Owner</string>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">-1</int>
|
||||||
|
<reference key="object" ref="1003"/>
|
||||||
|
<reference key="parent" ref="0"/>
|
||||||
|
<string key="objectName">First Responder</string>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">-3</int>
|
||||||
|
<reference key="object" ref="1004"/>
|
||||||
|
<reference key="parent" ref="0"/>
|
||||||
|
<string key="objectName">Application</string>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">1</int>
|
||||||
|
<reference key="object" ref="359561441"/>
|
||||||
|
<array class="NSMutableArray" key="children">
|
||||||
|
<reference ref="976198330"/>
|
||||||
|
</array>
|
||||||
|
<reference key="parent" ref="0"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">2</int>
|
||||||
|
<reference key="object" ref="976198330"/>
|
||||||
|
<array class="NSMutableArray" key="children">
|
||||||
|
<reference ref="458371270"/>
|
||||||
|
<reference ref="4380169"/>
|
||||||
|
<reference ref="253286088"/>
|
||||||
|
<reference ref="983148229"/>
|
||||||
|
</array>
|
||||||
|
<reference key="parent" ref="359561441"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">5</int>
|
||||||
|
<reference key="object" ref="458371270"/>
|
||||||
|
<array class="NSMutableArray" key="children">
|
||||||
|
<reference ref="99096694"/>
|
||||||
|
<reference ref="47224920"/>
|
||||||
|
<reference ref="252791348"/>
|
||||||
|
<reference ref="903452051"/>
|
||||||
|
</array>
|
||||||
|
<reference key="parent" ref="976198330"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">6</int>
|
||||||
|
<reference key="object" ref="99096694"/>
|
||||||
|
<reference key="parent" ref="458371270"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">7</int>
|
||||||
|
<reference key="object" ref="47224920"/>
|
||||||
|
<reference key="parent" ref="458371270"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">8</int>
|
||||||
|
<reference key="object" ref="252791348"/>
|
||||||
|
<array class="NSMutableArray" key="children"/>
|
||||||
|
<reference key="parent" ref="458371270"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">9</int>
|
||||||
|
<reference key="object" ref="903452051"/>
|
||||||
|
<reference key="parent" ref="458371270"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">18</int>
|
||||||
|
<reference key="object" ref="4380169"/>
|
||||||
|
<array class="NSMutableArray" key="children">
|
||||||
|
<reference ref="373771329"/>
|
||||||
|
</array>
|
||||||
|
<reference key="parent" ref="976198330"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">19</int>
|
||||||
|
<reference key="object" ref="373771329"/>
|
||||||
|
<reference key="parent" ref="4380169"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">20</int>
|
||||||
|
<reference key="object" ref="253286088"/>
|
||||||
|
<array class="NSMutableArray" key="children">
|
||||||
|
<reference ref="671547957"/>
|
||||||
|
</array>
|
||||||
|
<reference key="parent" ref="976198330"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">21</int>
|
||||||
|
<reference key="object" ref="671547957"/>
|
||||||
|
<reference key="parent" ref="253286088"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">27</int>
|
||||||
|
<reference key="object" ref="983148229"/>
|
||||||
|
<array class="NSMutableArray" key="children">
|
||||||
|
<reference ref="409951495"/>
|
||||||
|
</array>
|
||||||
|
<reference key="parent" ref="976198330"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">28</int>
|
||||||
|
<reference key="object" ref="409951495"/>
|
||||||
|
<reference key="parent" ref="983148229"/>
|
||||||
|
</object>
|
||||||
|
</array>
|
||||||
|
</object>
|
||||||
|
<dictionary class="NSMutableDictionary" key="flattenedProperties">
|
||||||
|
<string key="-1.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="-2.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="-3.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="1.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="1.IBWindowTemplateEditedContentRect">{{477, 306}, {480, 309}}</string>
|
||||||
|
<boolean value="NO" key="1.NSWindowTemplate.visibleAtLaunch"/>
|
||||||
|
<string key="18.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="19.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="2.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="20.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="21.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="27.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="28.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="5.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="6.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="7.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="8.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="9.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
</dictionary>
|
||||||
|
<dictionary class="NSMutableDictionary" key="unlocalizedProperties"/>
|
||||||
|
<nil key="activeLocalization"/>
|
||||||
|
<dictionary class="NSMutableDictionary" key="localizations"/>
|
||||||
|
<nil key="sourceID"/>
|
||||||
|
<int key="maxID">32</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBClassDescriber" key="IBDocument.Classes">
|
||||||
|
<array class="NSMutableArray" key="referencedPartialClassDescriptions">
|
||||||
|
<object class="IBPartialClassDescription">
|
||||||
|
<string key="className">IgnoreListDialog</string>
|
||||||
|
<string key="superclassName">NSWindowController</string>
|
||||||
|
<dictionary class="NSMutableDictionary" key="actions">
|
||||||
|
<string key="clear:">id</string>
|
||||||
|
<string key="removeSelected:">id</string>
|
||||||
|
</dictionary>
|
||||||
|
<dictionary class="NSMutableDictionary" key="actionInfosByName">
|
||||||
|
<object class="IBActionInfo" key="clear:">
|
||||||
|
<string key="name">clear:</string>
|
||||||
|
<string key="candidateClassName">id</string>
|
||||||
|
</object>
|
||||||
|
<object class="IBActionInfo" key="removeSelected:">
|
||||||
|
<string key="name">removeSelected:</string>
|
||||||
|
<string key="candidateClassName">id</string>
|
||||||
|
</object>
|
||||||
|
</dictionary>
|
||||||
|
<object class="NSMutableDictionary" key="outlets">
|
||||||
|
<string key="NS.key.0">ignoreListTableView</string>
|
||||||
|
<string key="NS.object.0">NSTableView</string>
|
||||||
|
</object>
|
||||||
|
<object class="NSMutableDictionary" key="toOneOutletInfosByName">
|
||||||
|
<string key="NS.key.0">ignoreListTableView</string>
|
||||||
|
<object class="IBToOneOutletInfo" key="NS.object.0">
|
||||||
|
<string key="name">ignoreListTableView</string>
|
||||||
|
<string key="candidateClassName">NSTableView</string>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
|
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
||||||
|
<string key="majorKey">IBProjectSource</string>
|
||||||
|
<string key="minorKey">./Classes/IgnoreListDialog.h</string>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
|
</array>
|
||||||
|
</object>
|
||||||
|
<int key="IBDocument.localizationMode">0</int>
|
||||||
|
<string key="IBDocument.TargetRuntimeIdentifier">IBCocoaFramework</string>
|
||||||
|
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDependencies">
|
||||||
|
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.macosx</string>
|
||||||
|
<real value="1060" key="NS.object.0"/>
|
||||||
|
</object>
|
||||||
|
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDependencyDefaults">
|
||||||
|
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.macosx</string>
|
||||||
|
<real value="1060" key="NS.object.0"/>
|
||||||
|
</object>
|
||||||
|
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDevelopmentDependencies">
|
||||||
|
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.InterfaceBuilder3</string>
|
||||||
|
<real value="4100" key="NS.object.0"/>
|
||||||
|
</object>
|
||||||
|
<bool key="IBDocument.PluginDeclaredDependenciesTrackSystemTargetVersion">YES</bool>
|
||||||
|
<int key="IBDocument.defaultPropertyAccessControl">3</int>
|
||||||
|
</data>
|
||||||
|
</archive>
|
||||||
@@ -2,8 +2,27 @@
|
|||||||
"Load from file..." = "Load from file...";
|
"Load from file..." = "Load from file...";
|
||||||
"Reset to Default" = "Reset to Default";
|
"Reset to Default" = "Reset to Default";
|
||||||
|
|
||||||
"Add iTunes Directory" = "Add iTunes Directory";
|
"Select a results file to load" = "Select a results file to load";
|
||||||
|
"You have unsaved results, do you really want to quit?" = "You have unsaved results, do you really want to quit?";
|
||||||
|
"Select a file to save your results to" = "Select a file to save your results to";
|
||||||
|
"Select a folder to add to the scanning list" = "Select a folder to add to the scanning list";
|
||||||
|
"You have unsaved results, do you really want to continue?" = "You have unsaved results, do you really want to continue?";
|
||||||
|
"'%@' already is in the list." = "'%@' already is in the list.";
|
||||||
|
"'%@' does not exist." = "'%@' does not exist.";
|
||||||
|
"The name '%@' already exists." = "The name '%@' already exists.";
|
||||||
|
"A previous action is still hanging in there. You can't start a new one yet. Wait a few seconds, then try again." = "A previous action is still hanging in there. You can't start a new one yet. Wait a few seconds, then try again.";
|
||||||
|
"Your iTunes Library contains %d dead tracks ready to be removed. Continue?" = "Your iTunes Library contains %d dead tracks ready to be removed. Continue?";
|
||||||
|
"You have no dead tracks in your iTunes Library" = "You have no dead tracks in your iTunes Library";
|
||||||
|
"Do you really want to remove all your cached picture analysis?" = "Do you really want to remove all your cached picture analysis?";
|
||||||
|
|
||||||
|
|
||||||
|
"Add iTunes Library" = "Add iTunes Library";
|
||||||
"Remove Dead Tracks in iTunes" = "Remove Dead Tracks in iTunes";
|
"Remove Dead Tracks in iTunes" = "Remove Dead Tracks in iTunes";
|
||||||
|
|
||||||
"Add iPhoto Library" = "Add iPhoto Library";
|
"Add iPhoto Library" = "Add iPhoto Library";
|
||||||
|
"Add Aperture Library" = "Add Aperture Library";
|
||||||
"Clear Picture Cache" = "Clear Picture Cache";
|
"Clear Picture Cache" = "Clear Picture Cache";
|
||||||
|
|
||||||
|
"Yes" = "Yes";
|
||||||
|
"No" = "No";
|
||||||
|
"OK" = "OK";
|
||||||
@@ -53,8 +53,8 @@
|
|||||||
/* Class = "NSMenu"; title = "Actions"; ObjectID = "598"; */
|
/* Class = "NSMenu"; title = "Actions"; ObjectID = "598"; */
|
||||||
"598.title" = "Actions";
|
"598.title" = "Actions";
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Send Marked to Trash"; ObjectID = "599"; */
|
/* Class = "NSMenuItem"; title = "Send Marked to Trash..."; ObjectID = "599"; */
|
||||||
"599.title" = "Send Marked to Trash";
|
"599.title" = "Send Marked to Trash...";
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Move Marked to..."; ObjectID = "600"; */
|
/* Class = "NSMenuItem"; title = "Move Marked to..."; ObjectID = "600"; */
|
||||||
"600.title" = "Move Marked to...";
|
"600.title" = "Move Marked to...";
|
||||||
@@ -92,9 +92,6 @@
|
|||||||
/* Class = "NSMenuItem"; title = "Start Duplicate Scan"; ObjectID = "926"; */
|
/* Class = "NSMenuItem"; title = "Start Duplicate Scan"; ObjectID = "926"; */
|
||||||
"926.title" = "Start Duplicate Scan";
|
"926.title" = "Start Duplicate Scan";
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Clear Ignore List"; ObjectID = "927"; */
|
|
||||||
"927.title" = "Clear Ignore List";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Rename Selected"; ObjectID = "933"; */
|
/* Class = "NSMenuItem"; title = "Rename Selected"; ObjectID = "933"; */
|
||||||
"933.title" = "Rename Selected";
|
"933.title" = "Rename Selected";
|
||||||
|
|
||||||
@@ -161,9 +158,6 @@
|
|||||||
/* Class = "NSMenuItem"; title = "Save Results..."; ObjectID = "1206"; */
|
/* Class = "NSMenuItem"; title = "Save Results..."; ObjectID = "1206"; */
|
||||||
"1206.title" = "Save Results...";
|
"1206.title" = "Save Results...";
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Delete Marked and Replace with Hardlinks"; ObjectID = "1227"; */
|
|
||||||
"1227.title" = "Delete Marked and Replace with Hardlinks";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Load Recent Results"; ObjectID = "1239"; */
|
/* Class = "NSMenuItem"; title = "Load Recent Results"; ObjectID = "1239"; */
|
||||||
"1239.title" = "Load Recent Results";
|
"1239.title" = "Load Recent Results";
|
||||||
|
|
||||||
@@ -175,3 +169,12 @@
|
|||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Re-Prioritize Results"; ObjectID = "1276"; */
|
/* Class = "NSMenuItem"; title = "Re-Prioritize Results"; ObjectID = "1276"; */
|
||||||
"1276.title" = "Re-Prioritize Results";
|
"1276.title" = "Re-Prioritize Results";
|
||||||
|
|
||||||
|
/* Class = "NSMenuItem"; title = "Quicklook"; ObjectID = "1280"; */
|
||||||
|
"1280.title" = "Quick Look";
|
||||||
|
|
||||||
|
/* Class = "NSMenuItem"; title = "Ignore List"; ObjectID = "1283"; */
|
||||||
|
"1283.title" = "Ignore List";
|
||||||
|
|
||||||
|
/* Class = "NSMenuItem"; title = "Filter Results..."; ObjectID = "1288"; */
|
||||||
|
"1288.title" = "Filter Results...";
|
||||||
|
|||||||
@@ -2,13 +2,13 @@
|
|||||||
<archive type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="8.00">
|
<archive type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="8.00">
|
||||||
<data>
|
<data>
|
||||||
<int key="IBDocument.SystemTarget">1060</int>
|
<int key="IBDocument.SystemTarget">1060</int>
|
||||||
<string key="IBDocument.SystemVersion">11B26</string>
|
<string key="IBDocument.SystemVersion">11E53</string>
|
||||||
<string key="IBDocument.InterfaceBuilderVersion">1617</string>
|
<string key="IBDocument.InterfaceBuilderVersion">2182</string>
|
||||||
<string key="IBDocument.AppKitVersion">1138</string>
|
<string key="IBDocument.AppKitVersion">1138.47</string>
|
||||||
<string key="IBDocument.HIToolboxVersion">566.00</string>
|
<string key="IBDocument.HIToolboxVersion">569.00</string>
|
||||||
<object class="NSMutableDictionary" key="IBDocument.PluginVersions">
|
<object class="NSMutableDictionary" key="IBDocument.PluginVersions">
|
||||||
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="NS.object.0">1617</string>
|
<string key="NS.object.0">2182</string>
|
||||||
</object>
|
</object>
|
||||||
<array key="IBDocument.IntegratedClassDependencies">
|
<array key="IBDocument.IntegratedClassDependencies">
|
||||||
<string>NSMenu</string>
|
<string>NSMenu</string>
|
||||||
@@ -18,7 +18,10 @@
|
|||||||
<array key="IBDocument.PluginDependencies">
|
<array key="IBDocument.PluginDependencies">
|
||||||
<string>com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string>com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
</array>
|
</array>
|
||||||
<dictionary class="NSMutableDictionary" key="IBDocument.Metadata"/>
|
<object class="NSMutableDictionary" key="IBDocument.Metadata">
|
||||||
|
<string key="NS.key.0">PluginDependencyRecalculationVersion</string>
|
||||||
|
<integer value="1" key="NS.object.0"/>
|
||||||
|
</object>
|
||||||
<array class="NSMutableArray" key="IBDocument.RootObjects" id="248533267">
|
<array class="NSMutableArray" key="IBDocument.RootObjects" id="248533267">
|
||||||
<object class="NSCustomObject" id="77446904">
|
<object class="NSCustomObject" id="77446904">
|
||||||
<string key="NSClassName">NSApplication</string>
|
<string key="NSClassName">NSApplication</string>
|
||||||
@@ -291,6 +294,26 @@
|
|||||||
<reference key="NSOnImage" ref="34697260"/>
|
<reference key="NSOnImage" ref="34697260"/>
|
||||||
<reference key="NSMixedImage" ref="201180191"/>
|
<reference key="NSMixedImage" ref="201180191"/>
|
||||||
</object>
|
</object>
|
||||||
|
<object class="NSMenuItem" id="1047465480">
|
||||||
|
<reference key="NSMenu" ref="649942443"/>
|
||||||
|
<bool key="NSIsDisabled">YES</bool>
|
||||||
|
<bool key="NSIsSeparator">YES</bool>
|
||||||
|
<string key="NSTitle"/>
|
||||||
|
<string key="NSKeyEquiv"/>
|
||||||
|
<int key="NSKeyEquivModMask">1048576</int>
|
||||||
|
<int key="NSMnemonicLoc">2147483647</int>
|
||||||
|
<reference key="NSOnImage" ref="34697260"/>
|
||||||
|
<reference key="NSMixedImage" ref="201180191"/>
|
||||||
|
</object>
|
||||||
|
<object class="NSMenuItem" id="820963618">
|
||||||
|
<reference key="NSMenu" ref="649942443"/>
|
||||||
|
<string key="NSTitle">Filter Results...</string>
|
||||||
|
<string key="NSKeyEquiv">f</string>
|
||||||
|
<int key="NSKeyEquivModMask">1572864</int>
|
||||||
|
<int key="NSMnemonicLoc">2147483647</int>
|
||||||
|
<reference key="NSOnImage" ref="34697260"/>
|
||||||
|
<reference key="NSMixedImage" ref="201180191"/>
|
||||||
|
</object>
|
||||||
</array>
|
</array>
|
||||||
</object>
|
</object>
|
||||||
</object>
|
</object>
|
||||||
@@ -315,15 +338,6 @@
|
|||||||
<reference key="NSOnImage" ref="34697260"/>
|
<reference key="NSOnImage" ref="34697260"/>
|
||||||
<reference key="NSMixedImage" ref="201180191"/>
|
<reference key="NSMixedImage" ref="201180191"/>
|
||||||
</object>
|
</object>
|
||||||
<object class="NSMenuItem" id="578499792">
|
|
||||||
<reference key="NSMenu" ref="600111647"/>
|
|
||||||
<string key="NSTitle">Clear Ignore List</string>
|
|
||||||
<string key="NSKeyEquiv">G</string>
|
|
||||||
<int key="NSKeyEquivModMask">1048576</int>
|
|
||||||
<int key="NSMnemonicLoc">2147483647</int>
|
|
||||||
<reference key="NSOnImage" ref="34697260"/>
|
|
||||||
<reference key="NSMixedImage" ref="201180191"/>
|
|
||||||
</object>
|
|
||||||
<object class="NSMenuItem" id="189815600">
|
<object class="NSMenuItem" id="189815600">
|
||||||
<reference key="NSMenu" ref="600111647"/>
|
<reference key="NSMenu" ref="600111647"/>
|
||||||
<bool key="NSIsDisabled">YES</bool>
|
<bool key="NSIsDisabled">YES</bool>
|
||||||
@@ -337,22 +351,13 @@
|
|||||||
</object>
|
</object>
|
||||||
<object class="NSMenuItem" id="894871136">
|
<object class="NSMenuItem" id="894871136">
|
||||||
<reference key="NSMenu" ref="600111647"/>
|
<reference key="NSMenu" ref="600111647"/>
|
||||||
<string key="NSTitle">Send Marked to Trash</string>
|
<string key="NSTitle">Send Marked to Trash...</string>
|
||||||
<string key="NSKeyEquiv">t</string>
|
<string key="NSKeyEquiv">t</string>
|
||||||
<int key="NSKeyEquivModMask">1048576</int>
|
<int key="NSKeyEquivModMask">1048576</int>
|
||||||
<int key="NSMnemonicLoc">2147483647</int>
|
<int key="NSMnemonicLoc">2147483647</int>
|
||||||
<reference key="NSOnImage" ref="34697260"/>
|
<reference key="NSOnImage" ref="34697260"/>
|
||||||
<reference key="NSMixedImage" ref="201180191"/>
|
<reference key="NSMixedImage" ref="201180191"/>
|
||||||
</object>
|
</object>
|
||||||
<object class="NSMenuItem" id="514384201">
|
|
||||||
<reference key="NSMenu" ref="600111647"/>
|
|
||||||
<string key="NSTitle">Delete Marked and Replace with Hardlinks</string>
|
|
||||||
<string key="NSKeyEquiv">T</string>
|
|
||||||
<int key="NSKeyEquivModMask">1048576</int>
|
|
||||||
<int key="NSMnemonicLoc">2147483647</int>
|
|
||||||
<reference key="NSOnImage" ref="34697260"/>
|
|
||||||
<reference key="NSMixedImage" ref="201180191"/>
|
|
||||||
</object>
|
|
||||||
<object class="NSMenuItem" id="207129050">
|
<object class="NSMenuItem" id="207129050">
|
||||||
<reference key="NSMenu" ref="600111647"/>
|
<reference key="NSMenu" ref="600111647"/>
|
||||||
<string key="NSTitle">Move Marked to...</string>
|
<string key="NSTitle">Move Marked to...</string>
|
||||||
@@ -550,6 +555,14 @@
|
|||||||
<reference key="NSOnImage" ref="34697260"/>
|
<reference key="NSOnImage" ref="34697260"/>
|
||||||
<reference key="NSMixedImage" ref="201180191"/>
|
<reference key="NSMixedImage" ref="201180191"/>
|
||||||
</object>
|
</object>
|
||||||
|
<object class="NSMenuItem" id="361987512">
|
||||||
|
<reference key="NSMenu" ref="472719764"/>
|
||||||
|
<string key="NSTitle">Ignore List</string>
|
||||||
|
<string key="NSKeyEquiv"/>
|
||||||
|
<int key="NSMnemonicLoc">2147483647</int>
|
||||||
|
<reference key="NSOnImage" ref="34697260"/>
|
||||||
|
<reference key="NSMixedImage" ref="201180191"/>
|
||||||
|
</object>
|
||||||
<object class="NSMenuItem" id="961037837">
|
<object class="NSMenuItem" id="961037837">
|
||||||
<reference key="NSMenu" ref="472719764"/>
|
<reference key="NSMenu" ref="472719764"/>
|
||||||
<string key="NSTitle">Details Panel</string>
|
<string key="NSTitle">Details Panel</string>
|
||||||
@@ -561,7 +574,7 @@
|
|||||||
</object>
|
</object>
|
||||||
<object class="NSMenuItem" id="343354529">
|
<object class="NSMenuItem" id="343354529">
|
||||||
<reference key="NSMenu" ref="472719764"/>
|
<reference key="NSMenu" ref="472719764"/>
|
||||||
<string key="NSTitle">Quicklook</string>
|
<string key="NSTitle">Quick Look</string>
|
||||||
<string key="NSKeyEquiv">l</string>
|
<string key="NSKeyEquiv">l</string>
|
||||||
<int key="NSKeyEquivModMask">1048576</int>
|
<int key="NSKeyEquivModMask">1048576</int>
|
||||||
<int key="NSMnemonicLoc">2147483647</int>
|
<int key="NSMnemonicLoc">2147483647</int>
|
||||||
@@ -668,31 +681,12 @@
|
|||||||
<object class="NSCustomObject" id="91622651">
|
<object class="NSCustomObject" id="91622651">
|
||||||
<string key="NSClassName">AppDelegate</string>
|
<string key="NSClassName">AppDelegate</string>
|
||||||
</object>
|
</object>
|
||||||
<object class="NSCustomObject" id="875360857">
|
|
||||||
<string key="NSClassName">PyDupeGuru</string>
|
|
||||||
</object>
|
|
||||||
<object class="NSCustomObject" id="23220930">
|
<object class="NSCustomObject" id="23220930">
|
||||||
<string key="NSClassName">SUUpdater</string>
|
<string key="NSClassName">SUUpdater</string>
|
||||||
</object>
|
</object>
|
||||||
</array>
|
</array>
|
||||||
<object class="IBObjectContainer" key="IBDocument.Objects">
|
<object class="IBObjectContainer" key="IBDocument.Objects">
|
||||||
<array class="NSMutableArray" key="connectionRecords">
|
<array class="NSMutableArray" key="connectionRecords">
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBActionConnection" key="connection">
|
|
||||||
<string key="label">performMiniaturize:</string>
|
|
||||||
<reference key="source" ref="83466988"/>
|
|
||||||
<reference key="destination" ref="1033736835"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">37</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBActionConnection" key="connection">
|
|
||||||
<string key="label">arrangeInFront:</string>
|
|
||||||
<reference key="source" ref="83466988"/>
|
|
||||||
<reference key="destination" ref="941358624"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">39</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBConnectionRecord">
|
<object class="IBConnectionRecord">
|
||||||
<object class="IBActionConnection" key="connection">
|
<object class="IBActionConnection" key="connection">
|
||||||
<string key="label">terminate:</string>
|
<string key="label">terminate:</string>
|
||||||
@@ -725,14 +719,6 @@
|
|||||||
</object>
|
</object>
|
||||||
<int key="connectionID">153</int>
|
<int key="connectionID">153</int>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBActionConnection" key="connection">
|
|
||||||
<string key="label">performZoom:</string>
|
|
||||||
<reference key="source" ref="83466988"/>
|
|
||||||
<reference key="destination" ref="781972485"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">198</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBConnectionRecord">
|
<object class="IBConnectionRecord">
|
||||||
<object class="IBOutletConnection" key="connection">
|
<object class="IBOutletConnection" key="connection">
|
||||||
<string key="label">delegate</string>
|
<string key="label">delegate</string>
|
||||||
@@ -742,20 +728,28 @@
|
|||||||
<int key="connectionID">207</int>
|
<int key="connectionID">207</int>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBConnectionRecord">
|
<object class="IBConnectionRecord">
|
||||||
<object class="IBOutletConnection" key="connection">
|
<object class="IBActionConnection" key="connection">
|
||||||
<string key="label">delegate</string>
|
<string key="label">performMiniaturize:</string>
|
||||||
<reference key="source" ref="133452984"/>
|
<reference key="source" ref="83466988"/>
|
||||||
<reference key="destination" ref="91622651"/>
|
<reference key="destination" ref="1033736835"/>
|
||||||
</object>
|
</object>
|
||||||
<int key="connectionID">208</int>
|
<int key="connectionID">37</int>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBConnectionRecord">
|
<object class="IBConnectionRecord">
|
||||||
<object class="IBOutletConnection" key="connection">
|
<object class="IBActionConnection" key="connection">
|
||||||
<string key="label">py</string>
|
<string key="label">arrangeInFront:</string>
|
||||||
<reference key="source" ref="91622651"/>
|
<reference key="source" ref="83466988"/>
|
||||||
<reference key="destination" ref="875360857"/>
|
<reference key="destination" ref="941358624"/>
|
||||||
</object>
|
</object>
|
||||||
<int key="connectionID">614</int>
|
<int key="connectionID">39</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBActionConnection" key="connection">
|
||||||
|
<string key="label">performZoom:</string>
|
||||||
|
<reference key="source" ref="83466988"/>
|
||||||
|
<reference key="destination" ref="781972485"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">198</int>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBConnectionRecord">
|
<object class="IBConnectionRecord">
|
||||||
<object class="IBActionConnection" key="connection">
|
<object class="IBActionConnection" key="connection">
|
||||||
@@ -765,14 +759,6 @@
|
|||||||
</object>
|
</object>
|
||||||
<int key="connectionID">925</int>
|
<int key="connectionID">925</int>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBActionConnection" key="connection">
|
|
||||||
<string key="label">checkForUpdates:</string>
|
|
||||||
<reference key="source" ref="23220930"/>
|
|
||||||
<reference key="destination" ref="688262014"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">951</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBConnectionRecord">
|
<object class="IBConnectionRecord">
|
||||||
<object class="IBActionConnection" key="connection">
|
<object class="IBActionConnection" key="connection">
|
||||||
<string key="label">cut:</string>
|
<string key="label">cut:</string>
|
||||||
@@ -797,54 +783,6 @@
|
|||||||
</object>
|
</object>
|
||||||
<int key="connectionID">1005</int>
|
<int key="connectionID">1005</int>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBActionConnection" key="connection">
|
|
||||||
<string key="label">openWebsite:</string>
|
|
||||||
<reference key="source" ref="91622651"/>
|
|
||||||
<reference key="destination" ref="440547877"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">1024</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBOutletConnection" key="connection">
|
|
||||||
<string key="label">delegate</string>
|
|
||||||
<reference key="source" ref="23220930"/>
|
|
||||||
<reference key="destination" ref="91622651"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">1175</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBActionConnection" key="connection">
|
|
||||||
<string key="label">showAboutBox:</string>
|
|
||||||
<reference key="source" ref="91622651"/>
|
|
||||||
<reference key="destination" ref="436112936"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">1232</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBActionConnection" key="connection">
|
|
||||||
<string key="label">openHelp:</string>
|
|
||||||
<reference key="source" ref="91622651"/>
|
|
||||||
<reference key="destination" ref="914881560"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">1233</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBOutletConnection" key="connection">
|
|
||||||
<string key="label">recentResultsMenu</string>
|
|
||||||
<reference key="source" ref="91622651"/>
|
|
||||||
<reference key="destination" ref="782784943"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">1242</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBActionConnection" key="connection">
|
|
||||||
<string key="label">clearIgnoreList:</string>
|
|
||||||
<reference key="source" ref="83466988"/>
|
|
||||||
<reference key="destination" ref="578499792"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">1243</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBConnectionRecord">
|
<object class="IBConnectionRecord">
|
||||||
<object class="IBActionConnection" key="connection">
|
<object class="IBActionConnection" key="connection">
|
||||||
<string key="label">copyMarked:</string>
|
<string key="label">copyMarked:</string>
|
||||||
@@ -853,14 +791,6 @@
|
|||||||
</object>
|
</object>
|
||||||
<int key="connectionID">1244</int>
|
<int key="connectionID">1244</int>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBActionConnection" key="connection">
|
|
||||||
<string key="label">deleteMarked:</string>
|
|
||||||
<reference key="source" ref="83466988"/>
|
|
||||||
<reference key="destination" ref="894871136"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">1245</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBConnectionRecord">
|
<object class="IBConnectionRecord">
|
||||||
<object class="IBActionConnection" key="connection">
|
<object class="IBActionConnection" key="connection">
|
||||||
<string key="label">exportToXHTML:</string>
|
<string key="label">exportToXHTML:</string>
|
||||||
@@ -869,14 +799,6 @@
|
|||||||
</object>
|
</object>
|
||||||
<int key="connectionID">1246</int>
|
<int key="connectionID">1246</int>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBActionConnection" key="connection">
|
|
||||||
<string key="label">hardlinkMarked:</string>
|
|
||||||
<reference key="source" ref="83466988"/>
|
|
||||||
<reference key="destination" ref="514384201"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">1247</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBConnectionRecord">
|
<object class="IBConnectionRecord">
|
||||||
<object class="IBActionConnection" key="connection">
|
<object class="IBActionConnection" key="connection">
|
||||||
<string key="label">ignoreSelected:</string>
|
<string key="label">ignoreSelected:</string>
|
||||||
@@ -1013,6 +935,86 @@
|
|||||||
</object>
|
</object>
|
||||||
<int key="connectionID">1266</int>
|
<int key="connectionID">1266</int>
|
||||||
</object>
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBActionConnection" key="connection">
|
||||||
|
<string key="label">reprioritizeResults:</string>
|
||||||
|
<reference key="source" ref="83466988"/>
|
||||||
|
<reference key="destination" ref="200019883"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">1278</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBActionConnection" key="connection">
|
||||||
|
<string key="label">removeMarked:</string>
|
||||||
|
<reference key="source" ref="83466988"/>
|
||||||
|
<reference key="destination" ref="733607971"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">1279</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBActionConnection" key="connection">
|
||||||
|
<string key="label">toggleQuicklookPanel:</string>
|
||||||
|
<reference key="source" ref="83466988"/>
|
||||||
|
<reference key="destination" ref="343354529"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">1282</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBActionConnection" key="connection">
|
||||||
|
<string key="label">trashMarked:</string>
|
||||||
|
<reference key="source" ref="83466988"/>
|
||||||
|
<reference key="destination" ref="894871136"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">1286</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBActionConnection" key="connection">
|
||||||
|
<string key="label">focusOnFilterField:</string>
|
||||||
|
<reference key="source" ref="83466988"/>
|
||||||
|
<reference key="destination" ref="820963618"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">1289</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBOutletConnection" key="connection">
|
||||||
|
<string key="label">delegate</string>
|
||||||
|
<reference key="source" ref="133452984"/>
|
||||||
|
<reference key="destination" ref="91622651"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">208</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBActionConnection" key="connection">
|
||||||
|
<string key="label">openWebsite:</string>
|
||||||
|
<reference key="source" ref="91622651"/>
|
||||||
|
<reference key="destination" ref="440547877"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">1024</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBActionConnection" key="connection">
|
||||||
|
<string key="label">showAboutBox:</string>
|
||||||
|
<reference key="source" ref="91622651"/>
|
||||||
|
<reference key="destination" ref="436112936"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">1232</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBActionConnection" key="connection">
|
||||||
|
<string key="label">openHelp:</string>
|
||||||
|
<reference key="source" ref="91622651"/>
|
||||||
|
<reference key="destination" ref="914881560"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">1233</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBOutletConnection" key="connection">
|
||||||
|
<string key="label">recentResultsMenu</string>
|
||||||
|
<reference key="source" ref="91622651"/>
|
||||||
|
<reference key="destination" ref="782784943"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">1242</int>
|
||||||
|
</object>
|
||||||
<object class="IBConnectionRecord">
|
<object class="IBConnectionRecord">
|
||||||
<object class="IBOutletConnection" key="connection">
|
<object class="IBOutletConnection" key="connection">
|
||||||
<string key="label">columnsMenu</string>
|
<string key="label">columnsMenu</string>
|
||||||
@@ -1063,27 +1065,27 @@
|
|||||||
</object>
|
</object>
|
||||||
<object class="IBConnectionRecord">
|
<object class="IBConnectionRecord">
|
||||||
<object class="IBActionConnection" key="connection">
|
<object class="IBActionConnection" key="connection">
|
||||||
<string key="label">reprioritizeResults:</string>
|
<string key="label">showIgnoreList:</string>
|
||||||
<reference key="source" ref="83466988"/>
|
<reference key="source" ref="91622651"/>
|
||||||
<reference key="destination" ref="200019883"/>
|
<reference key="destination" ref="361987512"/>
|
||||||
</object>
|
</object>
|
||||||
<int key="connectionID">1278</int>
|
<int key="connectionID">1285</int>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBConnectionRecord">
|
<object class="IBConnectionRecord">
|
||||||
<object class="IBActionConnection" key="connection">
|
<object class="IBActionConnection" key="connection">
|
||||||
<string key="label">removeMarked:</string>
|
<string key="label">checkForUpdates:</string>
|
||||||
<reference key="source" ref="83466988"/>
|
<reference key="source" ref="23220930"/>
|
||||||
<reference key="destination" ref="733607971"/>
|
<reference key="destination" ref="688262014"/>
|
||||||
</object>
|
</object>
|
||||||
<int key="connectionID">1279</int>
|
<int key="connectionID">951</int>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBConnectionRecord">
|
<object class="IBConnectionRecord">
|
||||||
<object class="IBActionConnection" key="connection">
|
<object class="IBOutletConnection" key="connection">
|
||||||
<string key="label">toggleQuicklookPanel:</string>
|
<string key="label">delegate</string>
|
||||||
<reference key="source" ref="83466988"/>
|
<reference key="source" ref="23220930"/>
|
||||||
<reference key="destination" ref="343354529"/>
|
<reference key="destination" ref="91622651"/>
|
||||||
</object>
|
</object>
|
||||||
<int key="connectionID">1282</int>
|
<int key="connectionID">1175</int>
|
||||||
</object>
|
</object>
|
||||||
</array>
|
</array>
|
||||||
<object class="IBMutableOrderedSet" key="objectRecords">
|
<object class="IBMutableOrderedSet" key="objectRecords">
|
||||||
@@ -1150,6 +1152,7 @@
|
|||||||
<reference ref="762484626"/>
|
<reference ref="762484626"/>
|
||||||
<reference ref="937862901"/>
|
<reference ref="937862901"/>
|
||||||
<reference ref="343354529"/>
|
<reference ref="343354529"/>
|
||||||
|
<reference ref="361987512"/>
|
||||||
</array>
|
</array>
|
||||||
<reference key="parent" ref="751320875"/>
|
<reference key="parent" ref="751320875"/>
|
||||||
</object>
|
</object>
|
||||||
@@ -1318,12 +1321,10 @@
|
|||||||
<reference ref="616313144"/>
|
<reference ref="616313144"/>
|
||||||
<reference ref="904423169"/>
|
<reference ref="904423169"/>
|
||||||
<reference ref="1035429435"/>
|
<reference ref="1035429435"/>
|
||||||
<reference ref="578499792"/>
|
|
||||||
<reference ref="189815600"/>
|
<reference ref="189815600"/>
|
||||||
<reference ref="564101661"/>
|
<reference ref="564101661"/>
|
||||||
<reference ref="747820446"/>
|
<reference ref="747820446"/>
|
||||||
<reference ref="517397504"/>
|
<reference ref="517397504"/>
|
||||||
<reference ref="514384201"/>
|
|
||||||
<reference ref="200019883"/>
|
<reference ref="200019883"/>
|
||||||
</array>
|
</array>
|
||||||
<reference key="parent" ref="528113253"/>
|
<reference key="parent" ref="528113253"/>
|
||||||
@@ -1383,11 +1384,6 @@
|
|||||||
<reference key="object" ref="1035429435"/>
|
<reference key="object" ref="1035429435"/>
|
||||||
<reference key="parent" ref="600111647"/>
|
<reference key="parent" ref="600111647"/>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">927</int>
|
|
||||||
<reference key="object" ref="578499792"/>
|
|
||||||
<reference key="parent" ref="600111647"/>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
<object class="IBObjectRecord">
|
||||||
<int key="objectID">928</int>
|
<int key="objectID">928</int>
|
||||||
<reference key="object" ref="189815600"/>
|
<reference key="object" ref="189815600"/>
|
||||||
@@ -1459,6 +1455,8 @@
|
|||||||
<reference ref="666519843"/>
|
<reference ref="666519843"/>
|
||||||
<reference ref="996047427"/>
|
<reference ref="996047427"/>
|
||||||
<reference ref="956279291"/>
|
<reference ref="956279291"/>
|
||||||
|
<reference ref="1047465480"/>
|
||||||
|
<reference ref="820963618"/>
|
||||||
</array>
|
</array>
|
||||||
<reference key="parent" ref="551331186"/>
|
<reference key="parent" ref="551331186"/>
|
||||||
</object>
|
</object>
|
||||||
@@ -1508,12 +1506,6 @@
|
|||||||
<reference key="parent" ref="0"/>
|
<reference key="parent" ref="0"/>
|
||||||
<string key="objectName">AppDelegate</string>
|
<string key="objectName">AppDelegate</string>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">613</int>
|
|
||||||
<reference key="object" ref="875360857"/>
|
|
||||||
<reference key="parent" ref="0"/>
|
|
||||||
<string key="objectName">PyDupeGuru</string>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
<object class="IBObjectRecord">
|
||||||
<int key="objectID">949</int>
|
<int key="objectID">949</int>
|
||||||
<reference key="object" ref="23220930"/>
|
<reference key="object" ref="23220930"/>
|
||||||
@@ -1564,11 +1556,6 @@
|
|||||||
<reference key="object" ref="630362403"/>
|
<reference key="object" ref="630362403"/>
|
||||||
<reference key="parent" ref="948321368"/>
|
<reference key="parent" ref="948321368"/>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">1227</int>
|
|
||||||
<reference key="object" ref="514384201"/>
|
|
||||||
<reference key="parent" ref="600111647"/>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
<object class="IBObjectRecord">
|
||||||
<int key="objectID">1239</int>
|
<int key="objectID">1239</int>
|
||||||
<reference key="object" ref="356425059"/>
|
<reference key="object" ref="356425059"/>
|
||||||
@@ -1598,6 +1585,21 @@
|
|||||||
<reference key="object" ref="343354529"/>
|
<reference key="object" ref="343354529"/>
|
||||||
<reference key="parent" ref="472719764"/>
|
<reference key="parent" ref="472719764"/>
|
||||||
</object>
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">1283</int>
|
||||||
|
<reference key="object" ref="361987512"/>
|
||||||
|
<reference key="parent" ref="472719764"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">1287</int>
|
||||||
|
<reference key="object" ref="1047465480"/>
|
||||||
|
<reference key="parent" ref="649942443"/>
|
||||||
|
</object>
|
||||||
|
<object class="IBObjectRecord">
|
||||||
|
<int key="objectID">1288</int>
|
||||||
|
<reference key="object" ref="820963618"/>
|
||||||
|
<reference key="parent" ref="649942443"/>
|
||||||
|
</object>
|
||||||
</array>
|
</array>
|
||||||
</object>
|
</object>
|
||||||
<dictionary class="NSMutableDictionary" key="flattenedProperties">
|
<dictionary class="NSMutableDictionary" key="flattenedProperties">
|
||||||
@@ -1618,12 +1620,14 @@
|
|||||||
<string key="1204.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="1204.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="1205.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="1205.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="1206.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="1206.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="1227.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="1239.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="1239.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="1240.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="1240.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="1272.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="1272.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="1276.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="1276.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="1280.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="1280.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="1283.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="1287.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
|
<string key="1288.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="134.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="134.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="136.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="136.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="144.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="144.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
@@ -1654,7 +1658,6 @@
|
|||||||
<string key="603.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="603.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="604.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="604.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="605.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="605.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="613.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="618.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="618.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="619.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="619.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="707.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="707.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
@@ -1664,7 +1667,6 @@
|
|||||||
<string key="922.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="922.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="924.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="924.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="926.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="926.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="927.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="928.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="928.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="933.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="933.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="947.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="947.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
@@ -1684,7 +1686,7 @@
|
|||||||
<nil key="activeLocalization"/>
|
<nil key="activeLocalization"/>
|
||||||
<dictionary class="NSMutableDictionary" key="localizations"/>
|
<dictionary class="NSMutableDictionary" key="localizations"/>
|
||||||
<nil key="sourceID"/>
|
<nil key="sourceID"/>
|
||||||
<int key="maxID">1282</int>
|
<int key="maxID">1289</int>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBClassDescriber" key="IBDocument.Classes">
|
<object class="IBClassDescriber" key="IBDocument.Classes">
|
||||||
<array class="NSMutableArray" key="referencedPartialClassDescriptions">
|
<array class="NSMutableArray" key="referencedPartialClassDescriptions">
|
||||||
@@ -1705,6 +1707,7 @@
|
|||||||
<string key="openWebsite:">id</string>
|
<string key="openWebsite:">id</string>
|
||||||
<string key="showAboutBox:">id</string>
|
<string key="showAboutBox:">id</string>
|
||||||
<string key="showDirectoryWindow:">id</string>
|
<string key="showDirectoryWindow:">id</string>
|
||||||
|
<string key="showIgnoreList:">id</string>
|
||||||
<string key="showPreferencesPanel:">id</string>
|
<string key="showPreferencesPanel:">id</string>
|
||||||
<string key="showResultWindow:">id</string>
|
<string key="showResultWindow:">id</string>
|
||||||
<string key="startScanning:">id</string>
|
<string key="startScanning:">id</string>
|
||||||
@@ -1730,6 +1733,10 @@
|
|||||||
<string key="name">showDirectoryWindow:</string>
|
<string key="name">showDirectoryWindow:</string>
|
||||||
<string key="candidateClassName">id</string>
|
<string key="candidateClassName">id</string>
|
||||||
</object>
|
</object>
|
||||||
|
<object class="IBActionInfo" key="showIgnoreList:">
|
||||||
|
<string key="name">showIgnoreList:</string>
|
||||||
|
<string key="candidateClassName">id</string>
|
||||||
|
</object>
|
||||||
<object class="IBActionInfo" key="showPreferencesPanel:">
|
<object class="IBActionInfo" key="showPreferencesPanel:">
|
||||||
<string key="name">showPreferencesPanel:</string>
|
<string key="name">showPreferencesPanel:</string>
|
||||||
<string key="candidateClassName">id</string>
|
<string key="candidateClassName">id</string>
|
||||||
@@ -1746,7 +1753,6 @@
|
|||||||
<dictionary class="NSMutableDictionary" key="outlets">
|
<dictionary class="NSMutableDictionary" key="outlets">
|
||||||
<string key="actionsMenu">NSMenu</string>
|
<string key="actionsMenu">NSMenu</string>
|
||||||
<string key="columnsMenu">NSMenu</string>
|
<string key="columnsMenu">NSMenu</string>
|
||||||
<string key="py">PyDupeGuruBase</string>
|
|
||||||
<string key="recentResultsMenu">NSMenu</string>
|
<string key="recentResultsMenu">NSMenu</string>
|
||||||
</dictionary>
|
</dictionary>
|
||||||
<dictionary class="NSMutableDictionary" key="toOneOutletInfosByName">
|
<dictionary class="NSMutableDictionary" key="toOneOutletInfosByName">
|
||||||
@@ -1758,10 +1764,6 @@
|
|||||||
<string key="name">columnsMenu</string>
|
<string key="name">columnsMenu</string>
|
||||||
<string key="candidateClassName">NSMenu</string>
|
<string key="candidateClassName">NSMenu</string>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBToOneOutletInfo" key="py">
|
|
||||||
<string key="name">py</string>
|
|
||||||
<string key="candidateClassName">PyDupeGuruBase</string>
|
|
||||||
</object>
|
|
||||||
<object class="IBToOneOutletInfo" key="recentResultsMenu">
|
<object class="IBToOneOutletInfo" key="recentResultsMenu">
|
||||||
<string key="name">recentResultsMenu</string>
|
<string key="name">recentResultsMenu</string>
|
||||||
<string key="candidateClassName">NSMenu</string>
|
<string key="candidateClassName">NSMenu</string>
|
||||||
@@ -1772,6 +1774,25 @@
|
|||||||
<string key="minorKey">./Classes/AppDelegateBase.h</string>
|
<string key="minorKey">./Classes/AppDelegateBase.h</string>
|
||||||
</object>
|
</object>
|
||||||
</object>
|
</object>
|
||||||
|
<object class="IBPartialClassDescription">
|
||||||
|
<string key="className">HSOutlineView</string>
|
||||||
|
<string key="superclassName">NSOutlineView</string>
|
||||||
|
<object class="NSMutableDictionary" key="actions">
|
||||||
|
<string key="NS.key.0">copy:</string>
|
||||||
|
<string key="NS.object.0">id</string>
|
||||||
|
</object>
|
||||||
|
<object class="NSMutableDictionary" key="actionInfosByName">
|
||||||
|
<string key="NS.key.0">copy:</string>
|
||||||
|
<object class="IBActionInfo" key="NS.object.0">
|
||||||
|
<string key="name">copy:</string>
|
||||||
|
<string key="candidateClassName">id</string>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
|
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
||||||
|
<string key="majorKey">IBProjectSource</string>
|
||||||
|
<string key="minorKey">./Classes/HSOutlineView.h</string>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
<object class="IBPartialClassDescription">
|
<object class="IBPartialClassDescription">
|
||||||
<string key="className">HSTableView</string>
|
<string key="className">HSTableView</string>
|
||||||
<string key="superclassName">NSTableView</string>
|
<string key="superclassName">NSTableView</string>
|
||||||
@@ -1781,16 +1802,41 @@
|
|||||||
</object>
|
</object>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBPartialClassDescription">
|
<object class="IBPartialClassDescription">
|
||||||
<string key="className">HSWindowController</string>
|
<string key="className">IgnoreListDialog</string>
|
||||||
<string key="superclassName">NSWindowController</string>
|
<string key="superclassName">NSWindowController</string>
|
||||||
|
<dictionary class="NSMutableDictionary" key="actions">
|
||||||
|
<string key="clear:">id</string>
|
||||||
|
<string key="removeSelected:">id</string>
|
||||||
|
</dictionary>
|
||||||
|
<dictionary class="NSMutableDictionary" key="actionInfosByName">
|
||||||
|
<object class="IBActionInfo" key="clear:">
|
||||||
|
<string key="name">clear:</string>
|
||||||
|
<string key="candidateClassName">id</string>
|
||||||
|
</object>
|
||||||
|
<object class="IBActionInfo" key="removeSelected:">
|
||||||
|
<string key="name">removeSelected:</string>
|
||||||
|
<string key="candidateClassName">id</string>
|
||||||
|
</object>
|
||||||
|
</dictionary>
|
||||||
|
<object class="NSMutableDictionary" key="outlets">
|
||||||
|
<string key="NS.key.0">ignoreListTableView</string>
|
||||||
|
<string key="NS.object.0">NSTableView</string>
|
||||||
|
</object>
|
||||||
|
<object class="NSMutableDictionary" key="toOneOutletInfosByName">
|
||||||
|
<string key="NS.key.0">ignoreListTableView</string>
|
||||||
|
<object class="IBToOneOutletInfo" key="NS.object.0">
|
||||||
|
<string key="name">ignoreListTableView</string>
|
||||||
|
<string key="candidateClassName">NSTableView</string>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
||||||
<string key="majorKey">IBProjectSource</string>
|
<string key="majorKey">IBProjectSource</string>
|
||||||
<string key="minorKey">./Classes/HSWindowController.h</string>
|
<string key="minorKey">./Classes/IgnoreListDialog.h</string>
|
||||||
</object>
|
</object>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBPartialClassDescription">
|
<object class="IBPartialClassDescription">
|
||||||
<string key="className">PrioritizeDialog</string>
|
<string key="className">PrioritizeDialog</string>
|
||||||
<string key="superclassName">HSWindowController</string>
|
<string key="superclassName">NSWindowController</string>
|
||||||
<dictionary class="NSMutableDictionary" key="actions">
|
<dictionary class="NSMutableDictionary" key="actions">
|
||||||
<string key="addSelected:">id</string>
|
<string key="addSelected:">id</string>
|
||||||
<string key="cancel:">id</string>
|
<string key="cancel:">id</string>
|
||||||
@@ -1841,7 +1887,7 @@
|
|||||||
</object>
|
</object>
|
||||||
<object class="IBPartialClassDescription">
|
<object class="IBPartialClassDescription">
|
||||||
<string key="className">ProblemDialog</string>
|
<string key="className">ProblemDialog</string>
|
||||||
<string key="superclassName">HSWindowController</string>
|
<string key="superclassName">NSWindowController</string>
|
||||||
<object class="NSMutableDictionary" key="actions">
|
<object class="NSMutableDictionary" key="actions">
|
||||||
<string key="NS.key.0">revealSelected:</string>
|
<string key="NS.key.0">revealSelected:</string>
|
||||||
<string key="NS.object.0">id</string>
|
<string key="NS.object.0">id</string>
|
||||||
@@ -1869,49 +1915,15 @@
|
|||||||
<string key="minorKey">./Classes/ProblemDialog.h</string>
|
<string key="minorKey">./Classes/ProblemDialog.h</string>
|
||||||
</object>
|
</object>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBPartialClassDescription">
|
|
||||||
<string key="className">PyApp</string>
|
|
||||||
<string key="superclassName">PyFairware</string>
|
|
||||||
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
|
||||||
<string key="majorKey">IBProjectSource</string>
|
|
||||||
<string key="minorKey">./Classes/PyApp.h</string>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
<object class="IBPartialClassDescription">
|
|
||||||
<string key="className">PyDupeGuru</string>
|
|
||||||
<string key="superclassName">PyDupeGuruBase</string>
|
|
||||||
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
|
||||||
<string key="majorKey">IBProjectSource</string>
|
|
||||||
<string key="minorKey">./Classes/PyDupeGuru.h</string>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
<object class="IBPartialClassDescription">
|
|
||||||
<string key="className">PyDupeGuruBase</string>
|
|
||||||
<string key="superclassName">PyApp</string>
|
|
||||||
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
|
||||||
<string key="majorKey">IBProjectSource</string>
|
|
||||||
<string key="minorKey">./Classes/PyDupeGuruBase.h</string>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
<object class="IBPartialClassDescription">
|
|
||||||
<string key="className">PyFairware</string>
|
|
||||||
<string key="superclassName">NSObject</string>
|
|
||||||
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
|
||||||
<string key="majorKey">IBProjectSource</string>
|
|
||||||
<string key="minorKey">./Classes/PyFairware.h</string>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
<object class="IBPartialClassDescription">
|
<object class="IBPartialClassDescription">
|
||||||
<string key="className">ResultWindowBase</string>
|
<string key="className">ResultWindowBase</string>
|
||||||
<string key="superclassName">NSWindowController</string>
|
<string key="superclassName">NSWindowController</string>
|
||||||
<dictionary class="NSMutableDictionary" key="actions">
|
<dictionary class="NSMutableDictionary" key="actions">
|
||||||
<string key="changeOptions:">id</string>
|
<string key="changeOptions:">id</string>
|
||||||
<string key="clearIgnoreList:">id</string>
|
|
||||||
<string key="copyMarked:">id</string>
|
<string key="copyMarked:">id</string>
|
||||||
<string key="deleteMarked:">id</string>
|
|
||||||
<string key="exportToXHTML:">id</string>
|
<string key="exportToXHTML:">id</string>
|
||||||
<string key="filter:">id</string>
|
<string key="filter:">id</string>
|
||||||
<string key="hardlinkMarked:">id</string>
|
<string key="focusOnFilterField:">id</string>
|
||||||
<string key="ignoreSelected:">id</string>
|
<string key="ignoreSelected:">id</string>
|
||||||
<string key="invokeCustomCommand:">id</string>
|
<string key="invokeCustomCommand:">id</string>
|
||||||
<string key="markAll:">id</string>
|
<string key="markAll:">id</string>
|
||||||
@@ -1935,24 +1947,17 @@
|
|||||||
<string key="toggleDetailsPanel:">id</string>
|
<string key="toggleDetailsPanel:">id</string>
|
||||||
<string key="togglePowerMarker:">id</string>
|
<string key="togglePowerMarker:">id</string>
|
||||||
<string key="toggleQuicklookPanel:">id</string>
|
<string key="toggleQuicklookPanel:">id</string>
|
||||||
|
<string key="trashMarked:">id</string>
|
||||||
</dictionary>
|
</dictionary>
|
||||||
<dictionary class="NSMutableDictionary" key="actionInfosByName">
|
<dictionary class="NSMutableDictionary" key="actionInfosByName">
|
||||||
<object class="IBActionInfo" key="changeOptions:">
|
<object class="IBActionInfo" key="changeOptions:">
|
||||||
<string key="name">changeOptions:</string>
|
<string key="name">changeOptions:</string>
|
||||||
<string key="candidateClassName">id</string>
|
<string key="candidateClassName">id</string>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBActionInfo" key="clearIgnoreList:">
|
|
||||||
<string key="name">clearIgnoreList:</string>
|
|
||||||
<string key="candidateClassName">id</string>
|
|
||||||
</object>
|
|
||||||
<object class="IBActionInfo" key="copyMarked:">
|
<object class="IBActionInfo" key="copyMarked:">
|
||||||
<string key="name">copyMarked:</string>
|
<string key="name">copyMarked:</string>
|
||||||
<string key="candidateClassName">id</string>
|
<string key="candidateClassName">id</string>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBActionInfo" key="deleteMarked:">
|
|
||||||
<string key="name">deleteMarked:</string>
|
|
||||||
<string key="candidateClassName">id</string>
|
|
||||||
</object>
|
|
||||||
<object class="IBActionInfo" key="exportToXHTML:">
|
<object class="IBActionInfo" key="exportToXHTML:">
|
||||||
<string key="name">exportToXHTML:</string>
|
<string key="name">exportToXHTML:</string>
|
||||||
<string key="candidateClassName">id</string>
|
<string key="candidateClassName">id</string>
|
||||||
@@ -1961,8 +1966,8 @@
|
|||||||
<string key="name">filter:</string>
|
<string key="name">filter:</string>
|
||||||
<string key="candidateClassName">id</string>
|
<string key="candidateClassName">id</string>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBActionInfo" key="hardlinkMarked:">
|
<object class="IBActionInfo" key="focusOnFilterField:">
|
||||||
<string key="name">hardlinkMarked:</string>
|
<string key="name">focusOnFilterField:</string>
|
||||||
<string key="candidateClassName">id</string>
|
<string key="candidateClassName">id</string>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBActionInfo" key="ignoreSelected:">
|
<object class="IBActionInfo" key="ignoreSelected:">
|
||||||
@@ -2057,11 +2062,16 @@
|
|||||||
<string key="name">toggleQuicklookPanel:</string>
|
<string key="name">toggleQuicklookPanel:</string>
|
||||||
<string key="candidateClassName">id</string>
|
<string key="candidateClassName">id</string>
|
||||||
</object>
|
</object>
|
||||||
|
<object class="IBActionInfo" key="trashMarked:">
|
||||||
|
<string key="name">trashMarked:</string>
|
||||||
|
<string key="candidateClassName">id</string>
|
||||||
|
</object>
|
||||||
</dictionary>
|
</dictionary>
|
||||||
<dictionary class="NSMutableDictionary" key="outlets">
|
<dictionary class="NSMutableDictionary" key="outlets">
|
||||||
<string key="filterField">NSSearchField</string>
|
<string key="filterField">NSSearchField</string>
|
||||||
<string key="matches">HSTableView</string>
|
<string key="matches">HSTableView</string>
|
||||||
<string key="optionsSwitch">NSSegmentedControl</string>
|
<string key="optionsSwitch">NSSegmentedControl</string>
|
||||||
|
<string key="optionsToolbarItem">NSToolbarItem</string>
|
||||||
<string key="stats">NSTextField</string>
|
<string key="stats">NSTextField</string>
|
||||||
</dictionary>
|
</dictionary>
|
||||||
<dictionary class="NSMutableDictionary" key="toOneOutletInfosByName">
|
<dictionary class="NSMutableDictionary" key="toOneOutletInfosByName">
|
||||||
@@ -2077,6 +2087,10 @@
|
|||||||
<string key="name">optionsSwitch</string>
|
<string key="name">optionsSwitch</string>
|
||||||
<string key="candidateClassName">NSSegmentedControl</string>
|
<string key="candidateClassName">NSSegmentedControl</string>
|
||||||
</object>
|
</object>
|
||||||
|
<object class="IBToOneOutletInfo" key="optionsToolbarItem">
|
||||||
|
<string key="name">optionsToolbarItem</string>
|
||||||
|
<string key="candidateClassName">NSToolbarItem</string>
|
||||||
|
</object>
|
||||||
<object class="IBToOneOutletInfo" key="stats">
|
<object class="IBToOneOutletInfo" key="stats">
|
||||||
<string key="name">stats</string>
|
<string key="name">stats</string>
|
||||||
<string key="candidateClassName">NSTextField</string>
|
<string key="candidateClassName">NSTextField</string>
|
||||||
@@ -2121,23 +2135,15 @@
|
|||||||
</object>
|
</object>
|
||||||
<int key="IBDocument.localizationMode">0</int>
|
<int key="IBDocument.localizationMode">0</int>
|
||||||
<string key="IBDocument.TargetRuntimeIdentifier">IBCocoaFramework</string>
|
<string key="IBDocument.TargetRuntimeIdentifier">IBCocoaFramework</string>
|
||||||
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDependencies">
|
|
||||||
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.macosx</string>
|
|
||||||
<real value="1060" key="NS.object.0"/>
|
|
||||||
</object>
|
|
||||||
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDependencyDefaults">
|
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDependencyDefaults">
|
||||||
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.macosx</string>
|
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.macosx</string>
|
||||||
<integer value="1050" key="NS.object.0"/>
|
<real value="1060" key="NS.object.0"/>
|
||||||
</object>
|
|
||||||
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDevelopmentDependencies">
|
|
||||||
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.InterfaceBuilder3</string>
|
|
||||||
<real value="4100" key="NS.object.0"/>
|
|
||||||
</object>
|
</object>
|
||||||
<bool key="IBDocument.PluginDeclaredDependenciesTrackSystemTargetVersion">YES</bool>
|
<bool key="IBDocument.PluginDeclaredDependenciesTrackSystemTargetVersion">YES</bool>
|
||||||
<int key="IBDocument.defaultPropertyAccessControl">3</int>
|
<int key="IBDocument.defaultPropertyAccessControl">3</int>
|
||||||
<dictionary class="NSMutableDictionary" key="IBDocument.LastKnownImageSizes">
|
<dictionary class="NSMutableDictionary" key="IBDocument.LastKnownImageSizes">
|
||||||
<string key="NSMenuCheckmark">{9, 8}</string>
|
<string key="NSMenuCheckmark">{11, 11}</string>
|
||||||
<string key="NSMenuMixedState">{7, 2}</string>
|
<string key="NSMenuMixedState">{10, 3}</string>
|
||||||
</dictionary>
|
</dictionary>
|
||||||
</data>
|
</data>
|
||||||
</archive>
|
</archive>
|
||||||
|
|||||||
@@ -2,13 +2,13 @@
|
|||||||
<archive type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="8.00">
|
<archive type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="8.00">
|
||||||
<data>
|
<data>
|
||||||
<int key="IBDocument.SystemTarget">1060</int>
|
<int key="IBDocument.SystemTarget">1060</int>
|
||||||
<string key="IBDocument.SystemVersion">11B26</string>
|
<string key="IBDocument.SystemVersion">11D50</string>
|
||||||
<string key="IBDocument.InterfaceBuilderVersion">1617</string>
|
<string key="IBDocument.InterfaceBuilderVersion">2182</string>
|
||||||
<string key="IBDocument.AppKitVersion">1138</string>
|
<string key="IBDocument.AppKitVersion">1138.32</string>
|
||||||
<string key="IBDocument.HIToolboxVersion">566.00</string>
|
<string key="IBDocument.HIToolboxVersion">568.00</string>
|
||||||
<object class="NSMutableDictionary" key="IBDocument.PluginVersions">
|
<object class="NSMutableDictionary" key="IBDocument.PluginVersions">
|
||||||
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="NS.object.0">1617</string>
|
<string key="NS.object.0">2182</string>
|
||||||
</object>
|
</object>
|
||||||
<array key="IBDocument.IntegratedClassDependencies">
|
<array key="IBDocument.IntegratedClassDependencies">
|
||||||
<string>NSTextField</string>
|
<string>NSTextField</string>
|
||||||
@@ -29,7 +29,10 @@
|
|||||||
<array key="IBDocument.PluginDependencies">
|
<array key="IBDocument.PluginDependencies">
|
||||||
<string>com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string>com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
</array>
|
</array>
|
||||||
<dictionary class="NSMutableDictionary" key="IBDocument.Metadata"/>
|
<object class="NSMutableDictionary" key="IBDocument.Metadata">
|
||||||
|
<string key="NS.key.0">PluginDependencyRecalculationVersion</string>
|
||||||
|
<integer value="1" key="NS.object.0"/>
|
||||||
|
</object>
|
||||||
<array class="NSMutableArray" key="IBDocument.RootObjects" id="1000">
|
<array class="NSMutableArray" key="IBDocument.RootObjects" id="1000">
|
||||||
<object class="NSCustomObject" id="1001">
|
<object class="NSCustomObject" id="1001">
|
||||||
<string key="NSClassName">PrioritizeDialog</string>
|
<string key="NSClassName">PrioritizeDialog</string>
|
||||||
@@ -411,7 +414,7 @@
|
|||||||
<object class="NSButton" id="620738811">
|
<object class="NSButton" id="620738811">
|
||||||
<reference key="NSNextResponder" ref="1006"/>
|
<reference key="NSNextResponder" ref="1006"/>
|
||||||
<int key="NSvFlags">289</int>
|
<int key="NSvFlags">289</int>
|
||||||
<string key="NSFrame">{{513, 12}, {82, 32}}</string>
|
<string key="NSFrame">{{495, 12}, {100, 32}}</string>
|
||||||
<reference key="NSSuperview" ref="1006"/>
|
<reference key="NSSuperview" ref="1006"/>
|
||||||
<reference key="NSWindow"/>
|
<reference key="NSWindow"/>
|
||||||
<reference key="NSNextKeyView"/>
|
<reference key="NSNextKeyView"/>
|
||||||
@@ -435,7 +438,7 @@
|
|||||||
<object class="NSButton" id="955319632">
|
<object class="NSButton" id="955319632">
|
||||||
<reference key="NSNextResponder" ref="1006"/>
|
<reference key="NSNextResponder" ref="1006"/>
|
||||||
<int key="NSvFlags">289</int>
|
<int key="NSvFlags">289</int>
|
||||||
<string key="NSFrame">{{431, 12}, {82, 32}}</string>
|
<string key="NSFrame">{{395, 12}, {100, 32}}</string>
|
||||||
<reference key="NSSuperview" ref="1006"/>
|
<reference key="NSSuperview" ref="1006"/>
|
||||||
<reference key="NSWindow"/>
|
<reference key="NSWindow"/>
|
||||||
<reference key="NSNextKeyView" ref="620738811"/>
|
<reference key="NSNextKeyView" ref="620738811"/>
|
||||||
@@ -602,9 +605,9 @@
|
|||||||
<reference ref="386461059"/>
|
<reference ref="386461059"/>
|
||||||
<reference ref="878293971"/>
|
<reference ref="878293971"/>
|
||||||
<reference ref="596965746"/>
|
<reference ref="596965746"/>
|
||||||
|
<reference ref="687805562"/>
|
||||||
<reference ref="620738811"/>
|
<reference ref="620738811"/>
|
||||||
<reference ref="955319632"/>
|
<reference ref="955319632"/>
|
||||||
<reference ref="687805562"/>
|
|
||||||
</array>
|
</array>
|
||||||
<reference key="parent" ref="1005"/>
|
<reference key="parent" ref="1005"/>
|
||||||
</object>
|
</object>
|
||||||
@@ -821,17 +824,9 @@
|
|||||||
</object>
|
</object>
|
||||||
<object class="IBClassDescriber" key="IBDocument.Classes">
|
<object class="IBClassDescriber" key="IBDocument.Classes">
|
||||||
<array class="NSMutableArray" key="referencedPartialClassDescriptions">
|
<array class="NSMutableArray" key="referencedPartialClassDescriptions">
|
||||||
<object class="IBPartialClassDescription">
|
|
||||||
<string key="className">HSWindowController</string>
|
|
||||||
<string key="superclassName">NSWindowController</string>
|
|
||||||
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
|
||||||
<string key="majorKey">IBProjectSource</string>
|
|
||||||
<string key="minorKey">./Classes/HSWindowController.h</string>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
<object class="IBPartialClassDescription">
|
<object class="IBPartialClassDescription">
|
||||||
<string key="className">PrioritizeDialog</string>
|
<string key="className">PrioritizeDialog</string>
|
||||||
<string key="superclassName">HSWindowController</string>
|
<string key="superclassName">NSWindowController</string>
|
||||||
<dictionary class="NSMutableDictionary" key="actions">
|
<dictionary class="NSMutableDictionary" key="actions">
|
||||||
<string key="addSelected:">id</string>
|
<string key="addSelected:">id</string>
|
||||||
<string key="cancel:">id</string>
|
<string key="cancel:">id</string>
|
||||||
@@ -888,6 +883,10 @@
|
|||||||
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.macosx</string>
|
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.macosx</string>
|
||||||
<real value="1060" key="NS.object.0"/>
|
<real value="1060" key="NS.object.0"/>
|
||||||
</object>
|
</object>
|
||||||
|
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDependencyDefaults">
|
||||||
|
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.macosx</string>
|
||||||
|
<real value="1060" key="NS.object.0"/>
|
||||||
|
</object>
|
||||||
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDevelopmentDependencies">
|
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDevelopmentDependencies">
|
||||||
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.InterfaceBuilder3</string>
|
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.InterfaceBuilder3</string>
|
||||||
<real value="4100" key="NS.object.0"/>
|
<real value="4100" key="NS.object.0"/>
|
||||||
|
|||||||
@@ -5,12 +5,6 @@
|
|||||||
/* Class = "NSTextFieldCell"; title = "There were problems processing some (or all) of the files. The cause of these problems are described in the table below. Those files were not removed from your results."; ObjectID = "4"; */
|
/* Class = "NSTextFieldCell"; title = "There were problems processing some (or all) of the files. The cause of these problems are described in the table below. Those files were not removed from your results."; ObjectID = "4"; */
|
||||||
"4.title" = "There were problems processing some (or all) of the files. The cause of these problems are described in the table below. Those files were not removed from your results.";
|
"4.title" = "There were problems processing some (or all) of the files. The cause of these problems are described in the table below. Those files were not removed from your results.";
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "File Path"; ObjectID = "10"; */
|
|
||||||
"10.headerCell.title" = "File Path";
|
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "Error Message"; ObjectID = "11"; */
|
|
||||||
"11.headerCell.title" = "Error Message";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Close"; ObjectID = "19"; */
|
/* Class = "NSButtonCell"; title = "Close"; ObjectID = "19"; */
|
||||||
"19.title" = "Close";
|
"19.title" = "Close";
|
||||||
|
|
||||||
|
|||||||
@@ -2,32 +2,34 @@
|
|||||||
<archive type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="8.00">
|
<archive type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="8.00">
|
||||||
<data>
|
<data>
|
||||||
<int key="IBDocument.SystemTarget">1060</int>
|
<int key="IBDocument.SystemTarget">1060</int>
|
||||||
<string key="IBDocument.SystemVersion">11B26</string>
|
<string key="IBDocument.SystemVersion">11D50</string>
|
||||||
<string key="IBDocument.InterfaceBuilderVersion">1617</string>
|
<string key="IBDocument.InterfaceBuilderVersion">2182</string>
|
||||||
<string key="IBDocument.AppKitVersion">1138</string>
|
<string key="IBDocument.AppKitVersion">1138.32</string>
|
||||||
<string key="IBDocument.HIToolboxVersion">566.00</string>
|
<string key="IBDocument.HIToolboxVersion">568.00</string>
|
||||||
<object class="NSMutableDictionary" key="IBDocument.PluginVersions">
|
<object class="NSMutableDictionary" key="IBDocument.PluginVersions">
|
||||||
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="NS.object.0">1617</string>
|
<string key="NS.object.0">2182</string>
|
||||||
</object>
|
</object>
|
||||||
<array key="IBDocument.IntegratedClassDependencies">
|
<array key="IBDocument.IntegratedClassDependencies">
|
||||||
<string>NSScroller</string>
|
<string>NSTextField</string>
|
||||||
<string>NSTableHeaderView</string>
|
|
||||||
<string>NSButton</string>
|
|
||||||
<string>NSScrollView</string>
|
|
||||||
<string>NSTextFieldCell</string>
|
|
||||||
<string>NSButtonCell</string>
|
|
||||||
<string>NSTableView</string>
|
|
||||||
<string>NSCustomObject</string>
|
|
||||||
<string>NSView</string>
|
<string>NSView</string>
|
||||||
<string>NSWindowTemplate</string>
|
<string>NSWindowTemplate</string>
|
||||||
<string>NSTextField</string>
|
<string>NSScrollView</string>
|
||||||
<string>NSTableColumn</string>
|
<string>NSCustomObject</string>
|
||||||
|
<string>NSTableView</string>
|
||||||
|
<string>NSTableHeaderView</string>
|
||||||
|
<string>NSButtonCell</string>
|
||||||
|
<string>NSButton</string>
|
||||||
|
<string>NSScroller</string>
|
||||||
|
<string>NSTextFieldCell</string>
|
||||||
</array>
|
</array>
|
||||||
<array key="IBDocument.PluginDependencies">
|
<array key="IBDocument.PluginDependencies">
|
||||||
<string>com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string>com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
</array>
|
</array>
|
||||||
<dictionary class="NSMutableDictionary" key="IBDocument.Metadata"/>
|
<object class="NSMutableDictionary" key="IBDocument.Metadata">
|
||||||
|
<string key="NS.key.0">PluginDependencyRecalculationVersion</string>
|
||||||
|
<integer value="1" key="NS.object.0"/>
|
||||||
|
</object>
|
||||||
<array class="NSMutableArray" key="IBDocument.RootObjects" id="1000">
|
<array class="NSMutableArray" key="IBDocument.RootObjects" id="1000">
|
||||||
<object class="NSCustomObject" id="1001">
|
<object class="NSCustomObject" id="1001">
|
||||||
<string key="NSClassName">ProblemDialog</string>
|
<string key="NSClassName">ProblemDialog</string>
|
||||||
@@ -77,11 +79,11 @@
|
|||||||
<bytes key="NSWhite">MC42NjY2NjY2NjY3AA</bytes>
|
<bytes key="NSWhite">MC42NjY2NjY2NjY3AA</bytes>
|
||||||
</object>
|
</object>
|
||||||
</object>
|
</object>
|
||||||
<object class="NSColor" key="NSTextColor" id="87662436">
|
<object class="NSColor" key="NSTextColor">
|
||||||
<int key="NSColorSpace">6</int>
|
<int key="NSColorSpace">6</int>
|
||||||
<string key="NSCatalogName">System</string>
|
<string key="NSCatalogName">System</string>
|
||||||
<string key="NSColorName">controlTextColor</string>
|
<string key="NSColorName">controlTextColor</string>
|
||||||
<object class="NSColor" key="NSColor" id="665310199">
|
<object class="NSColor" key="NSColor">
|
||||||
<int key="NSColorSpace">3</int>
|
<int key="NSColorSpace">3</int>
|
||||||
<bytes key="NSWhite">MAA</bytes>
|
<bytes key="NSWhite">MAA</bytes>
|
||||||
</object>
|
</object>
|
||||||
@@ -118,81 +120,7 @@
|
|||||||
<reference key="NSSuperview" ref="458371270"/>
|
<reference key="NSSuperview" ref="458371270"/>
|
||||||
<reference key="NSWindow"/>
|
<reference key="NSWindow"/>
|
||||||
</object>
|
</object>
|
||||||
<array class="NSMutableArray" key="NSTableColumns">
|
<array class="NSMutableArray" key="NSTableColumns"/>
|
||||||
<object class="NSTableColumn" id="152748337">
|
|
||||||
<string key="NSIdentifier">path</string>
|
|
||||||
<double key="NSWidth">202</double>
|
|
||||||
<double key="NSMinWidth">40</double>
|
|
||||||
<double key="NSMaxWidth">1000</double>
|
|
||||||
<object class="NSTableHeaderCell" key="NSHeaderCell">
|
|
||||||
<int key="NSCellFlags">75628096</int>
|
|
||||||
<int key="NSCellFlags2">2048</int>
|
|
||||||
<string key="NSContents">File Path</string>
|
|
||||||
<object class="NSFont" key="NSSupport" id="26">
|
|
||||||
<string key="NSName">LucidaGrande</string>
|
|
||||||
<double key="NSSize">11</double>
|
|
||||||
<int key="NSfFlags">3100</int>
|
|
||||||
</object>
|
|
||||||
<object class="NSColor" key="NSBackgroundColor" id="505238712">
|
|
||||||
<int key="NSColorSpace">3</int>
|
|
||||||
<bytes key="NSWhite">MC4zMzMzMzI5ODU2AA</bytes>
|
|
||||||
</object>
|
|
||||||
<object class="NSColor" key="NSTextColor" id="899094524">
|
|
||||||
<int key="NSColorSpace">6</int>
|
|
||||||
<string key="NSCatalogName">System</string>
|
|
||||||
<string key="NSColorName">headerTextColor</string>
|
|
||||||
<reference key="NSColor" ref="665310199"/>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
<object class="NSTextFieldCell" key="NSDataCell" id="182886300">
|
|
||||||
<int key="NSCellFlags">337772096</int>
|
|
||||||
<int key="NSCellFlags2">2048</int>
|
|
||||||
<string key="NSContents">Text Cell</string>
|
|
||||||
<object class="NSFont" key="NSSupport" id="578468928">
|
|
||||||
<string key="NSName">LucidaGrande</string>
|
|
||||||
<double key="NSSize">11</double>
|
|
||||||
<int key="NSfFlags">16</int>
|
|
||||||
</object>
|
|
||||||
<reference key="NSControlView" ref="252791348"/>
|
|
||||||
<object class="NSColor" key="NSBackgroundColor" id="765209443">
|
|
||||||
<int key="NSColorSpace">6</int>
|
|
||||||
<string key="NSCatalogName">System</string>
|
|
||||||
<string key="NSColorName">controlBackgroundColor</string>
|
|
||||||
<reference key="NSColor" ref="869923403"/>
|
|
||||||
</object>
|
|
||||||
<reference key="NSTextColor" ref="87662436"/>
|
|
||||||
</object>
|
|
||||||
<int key="NSResizingMask">3</int>
|
|
||||||
<bool key="NSIsResizeable">YES</bool>
|
|
||||||
<reference key="NSTableView" ref="252791348"/>
|
|
||||||
</object>
|
|
||||||
<object class="NSTableColumn" id="579292183">
|
|
||||||
<string key="NSIdentifier">msg</string>
|
|
||||||
<double key="NSWidth">228</double>
|
|
||||||
<double key="NSMinWidth">40</double>
|
|
||||||
<double key="NSMaxWidth">1000</double>
|
|
||||||
<object class="NSTableHeaderCell" key="NSHeaderCell">
|
|
||||||
<int key="NSCellFlags">75628096</int>
|
|
||||||
<int key="NSCellFlags2">2048</int>
|
|
||||||
<string key="NSContents">Error Message</string>
|
|
||||||
<reference key="NSSupport" ref="26"/>
|
|
||||||
<reference key="NSBackgroundColor" ref="505238712"/>
|
|
||||||
<reference key="NSTextColor" ref="899094524"/>
|
|
||||||
</object>
|
|
||||||
<object class="NSTextFieldCell" key="NSDataCell" id="630211358">
|
|
||||||
<int key="NSCellFlags">337772096</int>
|
|
||||||
<int key="NSCellFlags2">2048</int>
|
|
||||||
<string key="NSContents">Text Cell</string>
|
|
||||||
<reference key="NSSupport" ref="578468928"/>
|
|
||||||
<reference key="NSControlView" ref="252791348"/>
|
|
||||||
<reference key="NSBackgroundColor" ref="765209443"/>
|
|
||||||
<reference key="NSTextColor" ref="87662436"/>
|
|
||||||
</object>
|
|
||||||
<int key="NSResizingMask">3</int>
|
|
||||||
<bool key="NSIsResizeable">YES</bool>
|
|
||||||
<reference key="NSTableView" ref="252791348"/>
|
|
||||||
</object>
|
|
||||||
</array>
|
|
||||||
<double key="NSIntercellSpacingWidth">3</double>
|
<double key="NSIntercellSpacingWidth">3</double>
|
||||||
<double key="NSIntercellSpacingHeight">2</double>
|
<double key="NSIntercellSpacingHeight">2</double>
|
||||||
<object class="NSColor" key="NSBackgroundColor">
|
<object class="NSColor" key="NSBackgroundColor">
|
||||||
@@ -225,7 +153,12 @@
|
|||||||
<reference key="NSWindow"/>
|
<reference key="NSWindow"/>
|
||||||
<reference key="NSNextKeyView" ref="252791348"/>
|
<reference key="NSNextKeyView" ref="252791348"/>
|
||||||
<reference key="NSDocView" ref="252791348"/>
|
<reference key="NSDocView" ref="252791348"/>
|
||||||
<reference key="NSBGColor" ref="765209443"/>
|
<object class="NSColor" key="NSBGColor" id="765209443">
|
||||||
|
<int key="NSColorSpace">6</int>
|
||||||
|
<string key="NSCatalogName">System</string>
|
||||||
|
<string key="NSColorName">controlBackgroundColor</string>
|
||||||
|
<reference key="NSColor" ref="869923403"/>
|
||||||
|
</object>
|
||||||
<int key="NScvFlags">4</int>
|
<int key="NScvFlags">4</int>
|
||||||
</object>
|
</object>
|
||||||
<object class="NSScroller" id="99096694">
|
<object class="NSScroller" id="99096694">
|
||||||
@@ -281,7 +214,7 @@
|
|||||||
<object class="NSButton" id="4380169">
|
<object class="NSButton" id="4380169">
|
||||||
<reference key="NSNextResponder" ref="976198330"/>
|
<reference key="NSNextResponder" ref="976198330"/>
|
||||||
<int key="NSvFlags">289</int>
|
<int key="NSvFlags">289</int>
|
||||||
<string key="NSFrame">{{370, 12}, {96, 32}}</string>
|
<string key="NSFrame">{{356, 12}, {110, 32}}</string>
|
||||||
<reference key="NSSuperview" ref="976198330"/>
|
<reference key="NSSuperview" ref="976198330"/>
|
||||||
<reference key="NSWindow"/>
|
<reference key="NSWindow"/>
|
||||||
<bool key="NSEnabled">YES</bool>
|
<bool key="NSEnabled">YES</bool>
|
||||||
@@ -306,7 +239,7 @@
|
|||||||
<object class="NSButton" id="253286088">
|
<object class="NSButton" id="253286088">
|
||||||
<reference key="NSNextResponder" ref="976198330"/>
|
<reference key="NSNextResponder" ref="976198330"/>
|
||||||
<int key="NSvFlags">292</int>
|
<int key="NSvFlags">292</int>
|
||||||
<string key="NSFrame">{{14, 12}, {137, 32}}</string>
|
<string key="NSFrame">{{14, 12}, {162, 32}}</string>
|
||||||
<reference key="NSSuperview" ref="976198330"/>
|
<reference key="NSSuperview" ref="976198330"/>
|
||||||
<reference key="NSWindow"/>
|
<reference key="NSWindow"/>
|
||||||
<bool key="NSEnabled">YES</bool>
|
<bool key="NSEnabled">YES</bool>
|
||||||
@@ -329,7 +262,7 @@
|
|||||||
<reference key="NSSuperview"/>
|
<reference key="NSSuperview"/>
|
||||||
<reference key="NSWindow"/>
|
<reference key="NSWindow"/>
|
||||||
</object>
|
</object>
|
||||||
<string key="NSScreenRect">{{0, 0}, {1440, 878}}</string>
|
<string key="NSScreenRect">{{0, 0}, {1920, 1058}}</string>
|
||||||
<string key="NSMaxSize">{10000000000000, 10000000000000}</string>
|
<string key="NSMaxSize">{10000000000000, 10000000000000}</string>
|
||||||
<bool key="NSWindowIsRestorable">YES</bool>
|
<bool key="NSWindowIsRestorable">YES</bool>
|
||||||
</object>
|
</object>
|
||||||
@@ -352,14 +285,6 @@
|
|||||||
</object>
|
</object>
|
||||||
<int key="connectionID">24</int>
|
<int key="connectionID">24</int>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBActionConnection" key="connection">
|
|
||||||
<string key="label">performClose:</string>
|
|
||||||
<reference key="source" ref="359561441"/>
|
|
||||||
<reference key="destination" ref="4380169"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">25</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBConnectionRecord">
|
<object class="IBConnectionRecord">
|
||||||
<object class="IBOutletConnection" key="connection">
|
<object class="IBOutletConnection" key="connection">
|
||||||
<string key="label">problemTableView</string>
|
<string key="label">problemTableView</string>
|
||||||
@@ -368,6 +293,14 @@
|
|||||||
</object>
|
</object>
|
||||||
<int key="connectionID">26</int>
|
<int key="connectionID">26</int>
|
||||||
</object>
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBActionConnection" key="connection">
|
||||||
|
<string key="label">performClose:</string>
|
||||||
|
<reference key="source" ref="359561441"/>
|
||||||
|
<reference key="destination" ref="4380169"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">25</int>
|
||||||
|
</object>
|
||||||
</array>
|
</array>
|
||||||
<object class="IBMutableOrderedSet" key="objectRecords">
|
<object class="IBMutableOrderedSet" key="objectRecords">
|
||||||
<array key="orderedObjects">
|
<array key="orderedObjects">
|
||||||
@@ -451,10 +384,7 @@
|
|||||||
<object class="IBObjectRecord">
|
<object class="IBObjectRecord">
|
||||||
<int key="objectID">8</int>
|
<int key="objectID">8</int>
|
||||||
<reference key="object" ref="252791348"/>
|
<reference key="object" ref="252791348"/>
|
||||||
<array class="NSMutableArray" key="children">
|
<array class="NSMutableArray" key="children"/>
|
||||||
<reference ref="152748337"/>
|
|
||||||
<reference ref="579292183"/>
|
|
||||||
</array>
|
|
||||||
<reference key="parent" ref="458371270"/>
|
<reference key="parent" ref="458371270"/>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBObjectRecord">
|
<object class="IBObjectRecord">
|
||||||
@@ -462,32 +392,6 @@
|
|||||||
<reference key="object" ref="903452051"/>
|
<reference key="object" ref="903452051"/>
|
||||||
<reference key="parent" ref="458371270"/>
|
<reference key="parent" ref="458371270"/>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">10</int>
|
|
||||||
<reference key="object" ref="152748337"/>
|
|
||||||
<array class="NSMutableArray" key="children">
|
|
||||||
<reference ref="182886300"/>
|
|
||||||
</array>
|
|
||||||
<reference key="parent" ref="252791348"/>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">11</int>
|
|
||||||
<reference key="object" ref="579292183"/>
|
|
||||||
<array class="NSMutableArray" key="children">
|
|
||||||
<reference ref="630211358"/>
|
|
||||||
</array>
|
|
||||||
<reference key="parent" ref="252791348"/>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">12</int>
|
|
||||||
<reference key="object" ref="630211358"/>
|
|
||||||
<reference key="parent" ref="579292183"/>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">13</int>
|
|
||||||
<reference key="object" ref="182886300"/>
|
|
||||||
<reference key="parent" ref="152748337"/>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
<object class="IBObjectRecord">
|
||||||
<int key="objectID">18</int>
|
<int key="objectID">18</int>
|
||||||
<reference key="object" ref="4380169"/>
|
<reference key="object" ref="4380169"/>
|
||||||
@@ -523,10 +427,6 @@
|
|||||||
<string key="1.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="1.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="1.IBWindowTemplateEditedContentRect">{{477, 306}, {480, 309}}</string>
|
<string key="1.IBWindowTemplateEditedContentRect">{{477, 306}, {480, 309}}</string>
|
||||||
<boolean value="NO" key="1.NSWindowTemplate.visibleAtLaunch"/>
|
<boolean value="NO" key="1.NSWindowTemplate.visibleAtLaunch"/>
|
||||||
<string key="10.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="11.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="12.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="13.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="18.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="18.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="19.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="19.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="2.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="2.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
@@ -548,17 +448,9 @@
|
|||||||
</object>
|
</object>
|
||||||
<object class="IBClassDescriber" key="IBDocument.Classes">
|
<object class="IBClassDescriber" key="IBDocument.Classes">
|
||||||
<array class="NSMutableArray" key="referencedPartialClassDescriptions">
|
<array class="NSMutableArray" key="referencedPartialClassDescriptions">
|
||||||
<object class="IBPartialClassDescription">
|
|
||||||
<string key="className">HSWindowController</string>
|
|
||||||
<string key="superclassName">NSWindowController</string>
|
|
||||||
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
|
||||||
<string key="majorKey">IBProjectSource</string>
|
|
||||||
<string key="minorKey">./Classes/HSWindowController.h</string>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
<object class="IBPartialClassDescription">
|
<object class="IBPartialClassDescription">
|
||||||
<string key="className">ProblemDialog</string>
|
<string key="className">ProblemDialog</string>
|
||||||
<string key="superclassName">HSWindowController</string>
|
<string key="superclassName">NSWindowController</string>
|
||||||
<object class="NSMutableDictionary" key="actions">
|
<object class="NSMutableDictionary" key="actions">
|
||||||
<string key="NS.key.0">revealSelected:</string>
|
<string key="NS.key.0">revealSelected:</string>
|
||||||
<string key="NS.object.0">id</string>
|
<string key="NS.object.0">id</string>
|
||||||
@@ -596,7 +488,7 @@
|
|||||||
</object>
|
</object>
|
||||||
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDependencyDefaults">
|
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDependencyDefaults">
|
||||||
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.macosx</string>
|
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.macosx</string>
|
||||||
<integer value="1050" key="NS.object.0"/>
|
<real value="1060" key="NS.object.0"/>
|
||||||
</object>
|
</object>
|
||||||
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDevelopmentDependencies">
|
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDevelopmentDependencies">
|
||||||
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.InterfaceBuilder3</string>
|
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.InterfaceBuilder3</string>
|
||||||
|
|||||||
@@ -5,9 +5,6 @@
|
|||||||
/* Class = "NSTextFieldCell"; title = "Marked: 0 files, 0 B. Total: 0 files, 0 B."; ObjectID = "6"; */
|
/* Class = "NSTextFieldCell"; title = "Marked: 0 files, 0 B. Total: 0 files, 0 B."; ObjectID = "6"; */
|
||||||
"6.title" = "Marked: 0 files, 0 B. Total: 0 files, 0 B.";
|
"6.title" = "Marked: 0 files, 0 B. Total: 0 files, 0 B.";
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "Name"; ObjectID = "11"; */
|
|
||||||
"11.headerCell.title" = "Name";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; label = "Options"; ObjectID = "15"; */
|
/* Class = "NSToolbarItem"; label = "Options"; ObjectID = "15"; */
|
||||||
"15.label" = "Options";
|
"15.label" = "Options";
|
||||||
|
|
||||||
@@ -32,11 +29,8 @@
|
|||||||
/* Class = "NSToolbarItem"; paletteLabel = "Directories"; ObjectID = "19"; */
|
/* Class = "NSToolbarItem"; paletteLabel = "Directories"; ObjectID = "19"; */
|
||||||
"19.paletteLabel" = "Directories";
|
"19.paletteLabel" = "Directories";
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Delete Marked and Replace with Hardlinks"; ObjectID = "27"; */
|
/* Class = "NSMenuItem"; title = "Send Marked to Trash..."; ObjectID = "29"; */
|
||||||
"27.title" = "Delete Marked and Replace with Hardlinks";
|
"29.title" = "Send Marked to Trash...";
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Send Marked to Trash"; ObjectID = "29"; */
|
|
||||||
"29.title" = "Send Marked to Trash";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Move Marked to..."; ObjectID = "30"; */
|
/* Class = "NSMenuItem"; title = "Move Marked to..."; ObjectID = "30"; */
|
||||||
"30.title" = "Move Marked to...";
|
"30.title" = "Move Marked to...";
|
||||||
@@ -97,3 +91,9 @@
|
|||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Open Selected with Default Application"; ObjectID = "74"; */
|
/* Class = "NSMenuItem"; title = "Open Selected with Default Application"; ObjectID = "74"; */
|
||||||
"74.title" = "Open Selected with Default Application";
|
"74.title" = "Open Selected with Default Application";
|
||||||
|
|
||||||
|
/* Class = "NSToolbarItem"; label = "Quick Look"; ObjectID = "86"; */
|
||||||
|
"86.label" = "Quick Look";
|
||||||
|
|
||||||
|
/* Class = "NSToolbarItem"; paletteLabel = "Quick Look"; ObjectID = "86"; */
|
||||||
|
"86.paletteLabel" = "Quick Look";
|
||||||
|
|||||||
@@ -2,13 +2,13 @@
|
|||||||
<archive type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="8.00">
|
<archive type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="8.00">
|
||||||
<data>
|
<data>
|
||||||
<int key="IBDocument.SystemTarget">1060</int>
|
<int key="IBDocument.SystemTarget">1060</int>
|
||||||
<string key="IBDocument.SystemVersion">11B26</string>
|
<string key="IBDocument.SystemVersion">11E53</string>
|
||||||
<string key="IBDocument.InterfaceBuilderVersion">1617</string>
|
<string key="IBDocument.InterfaceBuilderVersion">2182</string>
|
||||||
<string key="IBDocument.AppKitVersion">1138</string>
|
<string key="IBDocument.AppKitVersion">1138.47</string>
|
||||||
<string key="IBDocument.HIToolboxVersion">566.00</string>
|
<string key="IBDocument.HIToolboxVersion">569.00</string>
|
||||||
<object class="NSMutableDictionary" key="IBDocument.PluginVersions">
|
<object class="NSMutableDictionary" key="IBDocument.PluginVersions">
|
||||||
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="NS.object.0">1617</string>
|
<string key="NS.object.0">2182</string>
|
||||||
</object>
|
</object>
|
||||||
<array key="IBDocument.IntegratedClassDependencies">
|
<array key="IBDocument.IntegratedClassDependencies">
|
||||||
<string>NSPopUpButton</string>
|
<string>NSPopUpButton</string>
|
||||||
@@ -18,13 +18,12 @@
|
|||||||
<string>NSToolbarFlexibleSpaceItem</string>
|
<string>NSToolbarFlexibleSpaceItem</string>
|
||||||
<string>NSCustomObject</string>
|
<string>NSCustomObject</string>
|
||||||
<string>NSTableView</string>
|
<string>NSTableView</string>
|
||||||
<string>NSTextField</string>
|
|
||||||
<string>NSSearchField</string>
|
<string>NSSearchField</string>
|
||||||
|
<string>NSTextField</string>
|
||||||
<string>NSSearchFieldCell</string>
|
<string>NSSearchFieldCell</string>
|
||||||
<string>NSWindowTemplate</string>
|
<string>NSWindowTemplate</string>
|
||||||
<string>NSTextFieldCell</string>
|
<string>NSTextFieldCell</string>
|
||||||
<string>NSButtonCell</string>
|
<string>NSButtonCell</string>
|
||||||
<string>NSTableColumn</string>
|
|
||||||
<string>NSSegmentedControl</string>
|
<string>NSSegmentedControl</string>
|
||||||
<string>NSToolbarSpaceItem</string>
|
<string>NSToolbarSpaceItem</string>
|
||||||
<string>NSPopUpButtonCell</string>
|
<string>NSPopUpButtonCell</string>
|
||||||
@@ -40,7 +39,10 @@
|
|||||||
<array key="IBDocument.PluginDependencies">
|
<array key="IBDocument.PluginDependencies">
|
||||||
<string>com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string>com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
</array>
|
</array>
|
||||||
<dictionary class="NSMutableDictionary" key="IBDocument.Metadata"/>
|
<object class="NSMutableDictionary" key="IBDocument.Metadata">
|
||||||
|
<string key="NS.key.0">PluginDependencyRecalculationVersion</string>
|
||||||
|
<integer value="1" key="NS.object.0"/>
|
||||||
|
</object>
|
||||||
<array class="NSMutableArray" key="IBDocument.RootObjects" id="1000">
|
<array class="NSMutableArray" key="IBDocument.RootObjects" id="1000">
|
||||||
<object class="NSCustomObject" id="1001">
|
<object class="NSCustomObject" id="1001">
|
||||||
<string key="NSClassName">ResultWindow</string>
|
<string key="NSClassName">ResultWindow</string>
|
||||||
@@ -155,14 +157,16 @@
|
|||||||
<string key="NSToolbarItemPaletteLabel">Options</string>
|
<string key="NSToolbarItemPaletteLabel">Options</string>
|
||||||
<nil key="NSToolbarItemToolTip"/>
|
<nil key="NSToolbarItemToolTip"/>
|
||||||
<object class="NSSegmentedControl" key="NSToolbarItemView" id="452019408">
|
<object class="NSSegmentedControl" key="NSToolbarItemView" id="452019408">
|
||||||
<nil key="NSNextResponder"/>
|
<reference key="NSNextResponder"/>
|
||||||
<int key="NSvFlags">268</int>
|
<int key="NSvFlags">268</int>
|
||||||
<string key="NSFrame">{{0, 14}, {195, 23}}</string>
|
<string key="NSFrame">{{0, 14}, {195, 23}}</string>
|
||||||
|
<reference key="NSSuperview"/>
|
||||||
|
<reference key="NSNextKeyView"/>
|
||||||
<bool key="NSEnabled">YES</bool>
|
<bool key="NSEnabled">YES</bool>
|
||||||
<object class="NSSegmentedCell" key="NSCell" id="993391476">
|
<object class="NSSegmentedCell" key="NSCell" id="993391476">
|
||||||
<int key="NSCellFlags">67239424</int>
|
<int key="NSCellFlags">67239424</int>
|
||||||
<int key="NSCellFlags2">0</int>
|
<int key="NSCellFlags2">0</int>
|
||||||
<object class="NSFont" key="NSSupport" id="241613967">
|
<object class="NSFont" key="NSSupport">
|
||||||
<string key="NSName">LucidaGrande</string>
|
<string key="NSName">LucidaGrande</string>
|
||||||
<double key="NSSize">11</double>
|
<double key="NSSize">11</double>
|
||||||
<int key="NSfFlags">16</int>
|
<int key="NSfFlags">16</int>
|
||||||
@@ -210,9 +214,11 @@
|
|||||||
<string key="NSToolbarItemPaletteLabel">Filter</string>
|
<string key="NSToolbarItemPaletteLabel">Filter</string>
|
||||||
<nil key="NSToolbarItemToolTip"/>
|
<nil key="NSToolbarItemToolTip"/>
|
||||||
<object class="NSSearchField" key="NSToolbarItemView" id="363479146">
|
<object class="NSSearchField" key="NSToolbarItemView" id="363479146">
|
||||||
<nil key="NSNextResponder"/>
|
<reference key="NSNextResponder"/>
|
||||||
<int key="NSvFlags">258</int>
|
<int key="NSvFlags">258</int>
|
||||||
<string key="NSFrame">{{0, 14}, {81, 22}}</string>
|
<string key="NSFrame">{{0, 14}, {81, 22}}</string>
|
||||||
|
<reference key="NSSuperview"/>
|
||||||
|
<reference key="NSNextKeyView"/>
|
||||||
<bool key="NSEnabled">YES</bool>
|
<bool key="NSEnabled">YES</bool>
|
||||||
<object class="NSSearchFieldCell" key="NSCell" id="830851754">
|
<object class="NSSearchFieldCell" key="NSCell" id="830851754">
|
||||||
<int key="NSCellFlags">343014976</int>
|
<int key="NSCellFlags">343014976</int>
|
||||||
@@ -240,7 +246,7 @@
|
|||||||
<int key="NSColorSpace">6</int>
|
<int key="NSColorSpace">6</int>
|
||||||
<string key="NSCatalogName">System</string>
|
<string key="NSCatalogName">System</string>
|
||||||
<string key="NSColorName">controlTextColor</string>
|
<string key="NSColorName">controlTextColor</string>
|
||||||
<object class="NSColor" key="NSColor" id="300787132">
|
<object class="NSColor" key="NSColor">
|
||||||
<int key="NSColorSpace">3</int>
|
<int key="NSColorSpace">3</int>
|
||||||
<bytes key="NSWhite">MAA</bytes>
|
<bytes key="NSWhite">MAA</bytes>
|
||||||
</object>
|
</object>
|
||||||
@@ -300,9 +306,11 @@
|
|||||||
<string key="NSToolbarItemPaletteLabel">Quick Look</string>
|
<string key="NSToolbarItemPaletteLabel">Quick Look</string>
|
||||||
<nil key="NSToolbarItemToolTip"/>
|
<nil key="NSToolbarItemToolTip"/>
|
||||||
<object class="NSButton" key="NSToolbarItemView" id="796071131">
|
<object class="NSButton" key="NSToolbarItemView" id="796071131">
|
||||||
<nil key="NSNextResponder"/>
|
<reference key="NSNextResponder"/>
|
||||||
<int key="NSvFlags">268</int>
|
<int key="NSvFlags">268</int>
|
||||||
<string key="NSFrame">{{12, 14}, {44, 25}}</string>
|
<string key="NSFrame">{{12, 14}, {44, 25}}</string>
|
||||||
|
<reference key="NSSuperview"/>
|
||||||
|
<reference key="NSNextKeyView"/>
|
||||||
<string key="NSReuseIdentifierKey">_NS:161</string>
|
<string key="NSReuseIdentifierKey">_NS:161</string>
|
||||||
<bool key="NSEnabled">YES</bool>
|
<bool key="NSEnabled">YES</bool>
|
||||||
<object class="NSButtonCell" key="NSCell" id="560045192">
|
<object class="NSButtonCell" key="NSCell" id="560045192">
|
||||||
@@ -365,9 +373,11 @@
|
|||||||
<string key="NSToolbarItemPaletteLabel">Action</string>
|
<string key="NSToolbarItemPaletteLabel">Action</string>
|
||||||
<nil key="NSToolbarItemToolTip"/>
|
<nil key="NSToolbarItemToolTip"/>
|
||||||
<object class="NSPopUpButton" key="NSToolbarItemView" id="1050768959">
|
<object class="NSPopUpButton" key="NSToolbarItemView" id="1050768959">
|
||||||
<nil key="NSNextResponder"/>
|
<reference key="NSNextResponder"/>
|
||||||
<int key="NSvFlags">256</int>
|
<int key="NSvFlags">256</int>
|
||||||
<string key="NSFrame">{{1, 14}, {40, 25}}</string>
|
<string key="NSFrame">{{1, 14}, {40, 25}}</string>
|
||||||
|
<reference key="NSSuperview"/>
|
||||||
|
<reference key="NSNextKeyView"/>
|
||||||
<bool key="NSEnabled">YES</bool>
|
<bool key="NSEnabled">YES</bool>
|
||||||
<object class="NSPopUpButtonCell" key="NSCell" id="302095930">
|
<object class="NSPopUpButtonCell" key="NSCell" id="302095930">
|
||||||
<int key="NSCellFlags">-2076049856</int>
|
<int key="NSCellFlags">-2076049856</int>
|
||||||
@@ -408,17 +418,7 @@
|
|||||||
<reference ref="764786770"/>
|
<reference ref="764786770"/>
|
||||||
<object class="NSMenuItem" id="799999563">
|
<object class="NSMenuItem" id="799999563">
|
||||||
<reference key="NSMenu" ref="778415311"/>
|
<reference key="NSMenu" ref="778415311"/>
|
||||||
<string key="NSTitle">Send Marked to Trash</string>
|
<string key="NSTitle">Send Marked to Trash...</string>
|
||||||
<string key="NSKeyEquiv"/>
|
|
||||||
<int key="NSMnemonicLoc">2147483647</int>
|
|
||||||
<reference key="NSOnImage" ref="1054238029"/>
|
|
||||||
<reference key="NSMixedImage" ref="1014570658"/>
|
|
||||||
<string key="NSAction">_popUpItemAction:</string>
|
|
||||||
<reference key="NSTarget" ref="302095930"/>
|
|
||||||
</object>
|
|
||||||
<object class="NSMenuItem" id="104143636">
|
|
||||||
<reference key="NSMenu" ref="778415311"/>
|
|
||||||
<string key="NSTitle">Delete Marked and Replace with Hardlinks</string>
|
|
||||||
<string key="NSKeyEquiv"/>
|
<string key="NSKeyEquiv"/>
|
||||||
<int key="NSMnemonicLoc">2147483647</int>
|
<int key="NSMnemonicLoc">2147483647</int>
|
||||||
<reference key="NSOnImage" ref="1054238029"/>
|
<reference key="NSOnImage" ref="1054238029"/>
|
||||||
@@ -546,6 +546,7 @@
|
|||||||
</object>
|
</object>
|
||||||
</array>
|
</array>
|
||||||
</object>
|
</object>
|
||||||
|
<int key="NSSelectedIndex">1</int>
|
||||||
<bool key="NSPullDown">YES</bool>
|
<bool key="NSPullDown">YES</bool>
|
||||||
<int key="NSPreferredEdge">3</int>
|
<int key="NSPreferredEdge">3</int>
|
||||||
<bool key="NSUsesItemFromMenu">YES</bool>
|
<bool key="NSUsesItemFromMenu">YES</bool>
|
||||||
@@ -703,94 +704,7 @@
|
|||||||
<reference key="NSWindow"/>
|
<reference key="NSWindow"/>
|
||||||
<reference key="NSNextKeyView" ref="607866053"/>
|
<reference key="NSNextKeyView" ref="607866053"/>
|
||||||
</object>
|
</object>
|
||||||
<array class="NSMutableArray" key="NSTableColumns">
|
<array class="NSMutableArray" key="NSTableColumns"/>
|
||||||
<object class="NSTableColumn" id="442382151">
|
|
||||||
<string key="NSIdentifier">marked</string>
|
|
||||||
<double key="NSWidth">26</double>
|
|
||||||
<double key="NSMinWidth">26</double>
|
|
||||||
<double key="NSMaxWidth">26</double>
|
|
||||||
<object class="NSTableHeaderCell" key="NSHeaderCell">
|
|
||||||
<int key="NSCellFlags">75628096</int>
|
|
||||||
<int key="NSCellFlags2">134219776</int>
|
|
||||||
<string key="NSContents"/>
|
|
||||||
<object class="NSFont" key="NSSupport" id="26">
|
|
||||||
<string key="NSName">LucidaGrande</string>
|
|
||||||
<double key="NSSize">11</double>
|
|
||||||
<int key="NSfFlags">3100</int>
|
|
||||||
</object>
|
|
||||||
<object class="NSColor" key="NSBackgroundColor" id="980928921">
|
|
||||||
<int key="NSColorSpace">6</int>
|
|
||||||
<string key="NSCatalogName">System</string>
|
|
||||||
<string key="NSColorName">headerColor</string>
|
|
||||||
<reference key="NSColor" ref="552368973"/>
|
|
||||||
</object>
|
|
||||||
<object class="NSColor" key="NSTextColor" id="532863179">
|
|
||||||
<int key="NSColorSpace">6</int>
|
|
||||||
<string key="NSCatalogName">System</string>
|
|
||||||
<string key="NSColorName">headerTextColor</string>
|
|
||||||
<reference key="NSColor" ref="300787132"/>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
<object class="NSButtonCell" key="NSDataCell" id="777504751">
|
|
||||||
<int key="NSCellFlags">67239424</int>
|
|
||||||
<int key="NSCellFlags2">131072</int>
|
|
||||||
<string key="NSContents"/>
|
|
||||||
<reference key="NSSupport" ref="26"/>
|
|
||||||
<reference key="NSControlView" ref="387493015"/>
|
|
||||||
<int key="NSButtonFlags">1211912703</int>
|
|
||||||
<int key="NSButtonFlags2">2</int>
|
|
||||||
<object class="NSCustomResource" key="NSNormalImage">
|
|
||||||
<string key="NSClassName">NSImage</string>
|
|
||||||
<string key="NSResourceName">NSSwitch</string>
|
|
||||||
</object>
|
|
||||||
<object class="NSButtonImageSource" key="NSAlternateImage">
|
|
||||||
<string key="NSImageName">NSSwitch</string>
|
|
||||||
</object>
|
|
||||||
<string key="NSAlternateContents"/>
|
|
||||||
<string key="NSKeyEquivalent"/>
|
|
||||||
<int key="NSPeriodicDelay">200</int>
|
|
||||||
<int key="NSPeriodicInterval">25</int>
|
|
||||||
</object>
|
|
||||||
<bool key="NSIsEditable">YES</bool>
|
|
||||||
<reference key="NSTableView" ref="387493015"/>
|
|
||||||
</object>
|
|
||||||
<object class="NSTableColumn" id="418301244">
|
|
||||||
<string key="NSIdentifier">0</string>
|
|
||||||
<double key="NSWidth">195</double>
|
|
||||||
<double key="NSMinWidth">16</double>
|
|
||||||
<double key="NSMaxWidth">3.4028234663852886e+38</double>
|
|
||||||
<object class="NSTableHeaderCell" key="NSHeaderCell">
|
|
||||||
<int key="NSCellFlags">75628096</int>
|
|
||||||
<int key="NSCellFlags2">2048</int>
|
|
||||||
<string key="NSContents">Name</string>
|
|
||||||
<reference key="NSSupport" ref="26"/>
|
|
||||||
<reference key="NSBackgroundColor" ref="980928921"/>
|
|
||||||
<reference key="NSTextColor" ref="532863179"/>
|
|
||||||
</object>
|
|
||||||
<object class="NSTextFieldCell" key="NSDataCell" id="270170598">
|
|
||||||
<int key="NSCellFlags">337772096</int>
|
|
||||||
<int key="NSCellFlags2">2048</int>
|
|
||||||
<string key="NSContents">Text Cell</string>
|
|
||||||
<reference key="NSSupport" ref="241613967"/>
|
|
||||||
<reference key="NSControlView" ref="387493015"/>
|
|
||||||
<object class="NSColor" key="NSBackgroundColor" id="1072464721">
|
|
||||||
<int key="NSColorSpace">6</int>
|
|
||||||
<string key="NSCatalogName">System</string>
|
|
||||||
<string key="NSColorName">controlBackgroundColor</string>
|
|
||||||
<reference key="NSColor" ref="359204506"/>
|
|
||||||
</object>
|
|
||||||
<reference key="NSTextColor" ref="453389366"/>
|
|
||||||
</object>
|
|
||||||
<int key="NSResizingMask">2</int>
|
|
||||||
<bool key="NSIsResizeable">YES</bool>
|
|
||||||
<reference key="NSTableView" ref="387493015"/>
|
|
||||||
<object class="NSSortDescriptor" key="NSSortDescriptorPrototype">
|
|
||||||
<string key="NSKey">0</string>
|
|
||||||
<bool key="NSAscending">YES</bool>
|
|
||||||
<string key="NSSelector">compare:</string>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
</array>
|
|
||||||
<double key="NSIntercellSpacingWidth">3</double>
|
<double key="NSIntercellSpacingWidth">3</double>
|
||||||
<double key="NSIntercellSpacingHeight">2</double>
|
<double key="NSIntercellSpacingHeight">2</double>
|
||||||
<reference key="NSBackgroundColor" ref="552368973"/>
|
<reference key="NSBackgroundColor" ref="552368973"/>
|
||||||
@@ -821,7 +735,12 @@
|
|||||||
<reference key="NSWindow"/>
|
<reference key="NSWindow"/>
|
||||||
<reference key="NSNextKeyView" ref="387493015"/>
|
<reference key="NSNextKeyView" ref="387493015"/>
|
||||||
<reference key="NSDocView" ref="387493015"/>
|
<reference key="NSDocView" ref="387493015"/>
|
||||||
<reference key="NSBGColor" ref="1072464721"/>
|
<object class="NSColor" key="NSBGColor" id="1072464721">
|
||||||
|
<int key="NSColorSpace">6</int>
|
||||||
|
<string key="NSCatalogName">System</string>
|
||||||
|
<string key="NSColorName">controlBackgroundColor</string>
|
||||||
|
<reference key="NSColor" ref="359204506"/>
|
||||||
|
</object>
|
||||||
<int key="NScvFlags">4</int>
|
<int key="NScvFlags">4</int>
|
||||||
</object>
|
</object>
|
||||||
<object class="NSScroller" id="777138208">
|
<object class="NSScroller" id="777138208">
|
||||||
@@ -894,14 +813,6 @@
|
|||||||
</array>
|
</array>
|
||||||
<object class="IBObjectContainer" key="IBDocument.Objects">
|
<object class="IBObjectContainer" key="IBDocument.Objects">
|
||||||
<array class="NSMutableArray" key="connectionRecords">
|
<array class="NSMutableArray" key="connectionRecords">
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBOutletConnection" key="connection">
|
|
||||||
<string key="label">delegate</string>
|
|
||||||
<reference key="source" ref="866620243"/>
|
|
||||||
<reference key="destination" ref="1001"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">45</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBConnectionRecord">
|
<object class="IBConnectionRecord">
|
||||||
<object class="IBOutletConnection" key="connection">
|
<object class="IBOutletConnection" key="connection">
|
||||||
<string key="label">window</string>
|
<string key="label">window</string>
|
||||||
@@ -910,22 +821,6 @@
|
|||||||
</object>
|
</object>
|
||||||
<int key="connectionID">46</int>
|
<int key="connectionID">46</int>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBActionConnection" key="connection">
|
|
||||||
<string key="label">deleteMarked:</string>
|
|
||||||
<reference key="source" ref="1001"/>
|
|
||||||
<reference key="destination" ref="799999563"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">50</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBActionConnection" key="connection">
|
|
||||||
<string key="label">hardlinkMarked:</string>
|
|
||||||
<reference key="source" ref="1001"/>
|
|
||||||
<reference key="destination" ref="104143636"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">51</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBConnectionRecord">
|
<object class="IBConnectionRecord">
|
||||||
<object class="IBActionConnection" key="connection">
|
<object class="IBActionConnection" key="connection">
|
||||||
<string key="label">moveMarked:</string>
|
<string key="label">moveMarked:</string>
|
||||||
@@ -1094,6 +989,22 @@
|
|||||||
</object>
|
</object>
|
||||||
<int key="connectionID">81</int>
|
<int key="connectionID">81</int>
|
||||||
</object>
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBActionConnection" key="connection">
|
||||||
|
<string key="label">toggleQuicklookPanel:</string>
|
||||||
|
<reference key="source" ref="1001"/>
|
||||||
|
<reference key="destination" ref="831294603"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">87</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBOutletConnection" key="connection">
|
||||||
|
<string key="label">optionsToolbarItem</string>
|
||||||
|
<reference key="source" ref="1001"/>
|
||||||
|
<reference key="destination" ref="234109357"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">92</int>
|
||||||
|
</object>
|
||||||
<object class="IBConnectionRecord">
|
<object class="IBConnectionRecord">
|
||||||
<object class="IBActionConnection" key="connection">
|
<object class="IBActionConnection" key="connection">
|
||||||
<string key="label">showDirectoryWindow:</string>
|
<string key="label">showDirectoryWindow:</string>
|
||||||
@@ -1102,6 +1013,22 @@
|
|||||||
</object>
|
</object>
|
||||||
<int key="connectionID">82</int>
|
<int key="connectionID">82</int>
|
||||||
</object>
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBActionConnection" key="connection">
|
||||||
|
<string key="label">trashMarked:</string>
|
||||||
|
<reference key="source" ref="1003"/>
|
||||||
|
<reference key="destination" ref="799999563"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">93</int>
|
||||||
|
</object>
|
||||||
|
<object class="IBConnectionRecord">
|
||||||
|
<object class="IBOutletConnection" key="connection">
|
||||||
|
<string key="label">delegate</string>
|
||||||
|
<reference key="source" ref="866620243"/>
|
||||||
|
<reference key="destination" ref="1001"/>
|
||||||
|
</object>
|
||||||
|
<int key="connectionID">45</int>
|
||||||
|
</object>
|
||||||
<object class="IBConnectionRecord">
|
<object class="IBConnectionRecord">
|
||||||
<object class="IBOutletConnection" key="connection">
|
<object class="IBOutletConnection" key="connection">
|
||||||
<string key="label">menu</string>
|
<string key="label">menu</string>
|
||||||
@@ -1110,14 +1037,6 @@
|
|||||||
</object>
|
</object>
|
||||||
<int key="connectionID">83</int>
|
<int key="connectionID">83</int>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBConnectionRecord">
|
|
||||||
<object class="IBActionConnection" key="connection">
|
|
||||||
<string key="label">toggleQuicklookPanel:</string>
|
|
||||||
<reference key="source" ref="1001"/>
|
|
||||||
<reference key="destination" ref="831294603"/>
|
|
||||||
</object>
|
|
||||||
<int key="connectionID">87</int>
|
|
||||||
</object>
|
|
||||||
<object class="IBConnectionRecord">
|
<object class="IBConnectionRecord">
|
||||||
<object class="IBBindingConnection" key="connection">
|
<object class="IBBindingConnection" key="connection">
|
||||||
<string key="label">rowHeight: values.TableFontSize</string>
|
<string key="label">rowHeight: values.TableFontSize</string>
|
||||||
@@ -1216,10 +1135,7 @@
|
|||||||
<object class="IBObjectRecord">
|
<object class="IBObjectRecord">
|
||||||
<int key="objectID">8</int>
|
<int key="objectID">8</int>
|
||||||
<reference key="object" ref="387493015"/>
|
<reference key="object" ref="387493015"/>
|
||||||
<array class="NSMutableArray" key="children">
|
<array class="NSMutableArray" key="children"/>
|
||||||
<reference ref="418301244"/>
|
|
||||||
<reference ref="442382151"/>
|
|
||||||
</array>
|
|
||||||
<reference key="parent" ref="489091452"/>
|
<reference key="parent" ref="489091452"/>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBObjectRecord">
|
<object class="IBObjectRecord">
|
||||||
@@ -1232,32 +1148,6 @@
|
|||||||
<reference key="object" ref="777138208"/>
|
<reference key="object" ref="777138208"/>
|
||||||
<reference key="parent" ref="489091452"/>
|
<reference key="parent" ref="489091452"/>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">11</int>
|
|
||||||
<reference key="object" ref="418301244"/>
|
|
||||||
<array class="NSMutableArray" key="children">
|
|
||||||
<reference ref="270170598"/>
|
|
||||||
</array>
|
|
||||||
<reference key="parent" ref="387493015"/>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">12</int>
|
|
||||||
<reference key="object" ref="442382151"/>
|
|
||||||
<array class="NSMutableArray" key="children">
|
|
||||||
<reference ref="777504751"/>
|
|
||||||
</array>
|
|
||||||
<reference key="parent" ref="387493015"/>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">13</int>
|
|
||||||
<reference key="object" ref="777504751"/>
|
|
||||||
<reference key="parent" ref="442382151"/>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">14</int>
|
|
||||||
<reference key="object" ref="270170598"/>
|
|
||||||
<reference key="parent" ref="418301244"/>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
<object class="IBObjectRecord">
|
||||||
<int key="objectID">67</int>
|
<int key="objectID">67</int>
|
||||||
<reference key="object" ref="593436906"/>
|
<reference key="object" ref="593436906"/>
|
||||||
@@ -1365,7 +1255,6 @@
|
|||||||
<int key="objectID">26</int>
|
<int key="objectID">26</int>
|
||||||
<reference key="object" ref="778415311"/>
|
<reference key="object" ref="778415311"/>
|
||||||
<array class="NSMutableArray" key="children">
|
<array class="NSMutableArray" key="children">
|
||||||
<reference ref="104143636"/>
|
|
||||||
<reference ref="764786770"/>
|
<reference ref="764786770"/>
|
||||||
<reference ref="799999563"/>
|
<reference ref="799999563"/>
|
||||||
<reference ref="294016844"/>
|
<reference ref="294016844"/>
|
||||||
@@ -1447,11 +1336,6 @@
|
|||||||
<reference key="object" ref="764786770"/>
|
<reference key="object" ref="764786770"/>
|
||||||
<reference key="parent" ref="778415311"/>
|
<reference key="parent" ref="778415311"/>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBObjectRecord">
|
|
||||||
<int key="objectID">27</int>
|
|
||||||
<reference key="object" ref="104143636"/>
|
|
||||||
<reference key="parent" ref="778415311"/>
|
|
||||||
</object>
|
|
||||||
<object class="IBObjectRecord">
|
<object class="IBObjectRecord">
|
||||||
<int key="objectID">16</int>
|
<int key="objectID">16</int>
|
||||||
<reference key="object" ref="695856706"/>
|
<reference key="object" ref="695856706"/>
|
||||||
@@ -1530,10 +1414,6 @@
|
|||||||
<string key="1.IBWindowTemplateEditedContentRect">{{324, 305}, {557, 400}}</string>
|
<string key="1.IBWindowTemplateEditedContentRect">{{324, 305}, {557, 400}}</string>
|
||||||
<boolean value="NO" key="1.NSWindowTemplate.visibleAtLaunch"/>
|
<boolean value="NO" key="1.NSWindowTemplate.visibleAtLaunch"/>
|
||||||
<string key="10.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="10.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="11.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="12.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="13.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="14.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="15.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="15.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="16.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="16.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="17.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="17.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
@@ -1544,7 +1424,6 @@
|
|||||||
<string key="24.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="24.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="25.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="25.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="26.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="26.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="27.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
|
||||||
<string key="28.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="28.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="29.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="29.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="3.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="3.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
@@ -1563,7 +1442,7 @@
|
|||||||
<string key="41.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="41.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="42.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="42.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<string key="43.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="43.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<integer value="0" key="44.IBNSSegmentedControlInspectorSelectedSegmentMetadataKey"/>
|
<integer value="2" key="44.IBNSSegmentedControlInspectorSelectedSegmentMetadataKey"/>
|
||||||
<string key="44.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="44.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
<integer value="2" key="44.IBSegmentedControlInspectorSelectedSegmentMetadataKey"/>
|
<integer value="2" key="44.IBSegmentedControlInspectorSelectedSegmentMetadataKey"/>
|
||||||
<string key="5.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
<string key="5.IBPluginDependency">com.apple.InterfaceBuilder.CocoaPlugin</string>
|
||||||
@@ -1589,7 +1468,7 @@
|
|||||||
<nil key="activeLocalization"/>
|
<nil key="activeLocalization"/>
|
||||||
<dictionary class="NSMutableDictionary" key="localizations"/>
|
<dictionary class="NSMutableDictionary" key="localizations"/>
|
||||||
<nil key="sourceID"/>
|
<nil key="sourceID"/>
|
||||||
<int key="maxID">90</int>
|
<int key="maxID">93</int>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBClassDescriber" key="IBDocument.Classes">
|
<object class="IBClassDescriber" key="IBDocument.Classes">
|
||||||
<array class="NSMutableArray" key="referencedPartialClassDescriptions">
|
<array class="NSMutableArray" key="referencedPartialClassDescriptions">
|
||||||
@@ -1602,6 +1481,7 @@
|
|||||||
<string key="openWebsite:">id</string>
|
<string key="openWebsite:">id</string>
|
||||||
<string key="showAboutBox:">id</string>
|
<string key="showAboutBox:">id</string>
|
||||||
<string key="showDirectoryWindow:">id</string>
|
<string key="showDirectoryWindow:">id</string>
|
||||||
|
<string key="showIgnoreList:">id</string>
|
||||||
<string key="showPreferencesPanel:">id</string>
|
<string key="showPreferencesPanel:">id</string>
|
||||||
<string key="showResultWindow:">id</string>
|
<string key="showResultWindow:">id</string>
|
||||||
<string key="startScanning:">id</string>
|
<string key="startScanning:">id</string>
|
||||||
@@ -1627,6 +1507,10 @@
|
|||||||
<string key="name">showDirectoryWindow:</string>
|
<string key="name">showDirectoryWindow:</string>
|
||||||
<string key="candidateClassName">id</string>
|
<string key="candidateClassName">id</string>
|
||||||
</object>
|
</object>
|
||||||
|
<object class="IBActionInfo" key="showIgnoreList:">
|
||||||
|
<string key="name">showIgnoreList:</string>
|
||||||
|
<string key="candidateClassName">id</string>
|
||||||
|
</object>
|
||||||
<object class="IBActionInfo" key="showPreferencesPanel:">
|
<object class="IBActionInfo" key="showPreferencesPanel:">
|
||||||
<string key="name">showPreferencesPanel:</string>
|
<string key="name">showPreferencesPanel:</string>
|
||||||
<string key="candidateClassName">id</string>
|
<string key="candidateClassName">id</string>
|
||||||
@@ -1643,7 +1527,6 @@
|
|||||||
<dictionary class="NSMutableDictionary" key="outlets">
|
<dictionary class="NSMutableDictionary" key="outlets">
|
||||||
<string key="actionsMenu">NSMenu</string>
|
<string key="actionsMenu">NSMenu</string>
|
||||||
<string key="columnsMenu">NSMenu</string>
|
<string key="columnsMenu">NSMenu</string>
|
||||||
<string key="py">PyDupeGuruBase</string>
|
|
||||||
<string key="recentResultsMenu">NSMenu</string>
|
<string key="recentResultsMenu">NSMenu</string>
|
||||||
</dictionary>
|
</dictionary>
|
||||||
<dictionary class="NSMutableDictionary" key="toOneOutletInfosByName">
|
<dictionary class="NSMutableDictionary" key="toOneOutletInfosByName">
|
||||||
@@ -1655,10 +1538,6 @@
|
|||||||
<string key="name">columnsMenu</string>
|
<string key="name">columnsMenu</string>
|
||||||
<string key="candidateClassName">NSMenu</string>
|
<string key="candidateClassName">NSMenu</string>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBToOneOutletInfo" key="py">
|
|
||||||
<string key="name">py</string>
|
|
||||||
<string key="candidateClassName">PyDupeGuruBase</string>
|
|
||||||
</object>
|
|
||||||
<object class="IBToOneOutletInfo" key="recentResultsMenu">
|
<object class="IBToOneOutletInfo" key="recentResultsMenu">
|
||||||
<string key="name">recentResultsMenu</string>
|
<string key="name">recentResultsMenu</string>
|
||||||
<string key="candidateClassName">NSMenu</string>
|
<string key="candidateClassName">NSMenu</string>
|
||||||
@@ -1677,33 +1556,20 @@
|
|||||||
<string key="minorKey">./Classes/HSTableView.h</string>
|
<string key="minorKey">./Classes/HSTableView.h</string>
|
||||||
</object>
|
</object>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBPartialClassDescription">
|
|
||||||
<string key="className">PyApp</string>
|
|
||||||
<string key="superclassName">PyFairware</string>
|
|
||||||
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
|
||||||
<string key="majorKey">IBProjectSource</string>
|
|
||||||
<string key="minorKey">./Classes/PyApp.h</string>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
<object class="IBPartialClassDescription">
|
|
||||||
<string key="className">PyDupeGuruBase</string>
|
|
||||||
<string key="superclassName">PyApp</string>
|
|
||||||
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
|
||||||
<string key="majorKey">IBProjectSource</string>
|
|
||||||
<string key="minorKey">./Classes/PyDupeGuruBase.h</string>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
<object class="IBPartialClassDescription">
|
|
||||||
<string key="className">PyFairware</string>
|
|
||||||
<string key="superclassName">NSObject</string>
|
|
||||||
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
|
||||||
<string key="majorKey">IBProjectSource</string>
|
|
||||||
<string key="minorKey">./Classes/PyFairware.h</string>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
<object class="IBPartialClassDescription">
|
<object class="IBPartialClassDescription">
|
||||||
<string key="className">ResultWindow</string>
|
<string key="className">ResultWindow</string>
|
||||||
<string key="superclassName">ResultWindowBase</string>
|
<string key="superclassName">ResultWindowBase</string>
|
||||||
|
<object class="NSMutableDictionary" key="actions">
|
||||||
|
<string key="NS.key.0">clearPictureCache:</string>
|
||||||
|
<string key="NS.object.0">id</string>
|
||||||
|
</object>
|
||||||
|
<object class="NSMutableDictionary" key="actionInfosByName">
|
||||||
|
<string key="NS.key.0">clearPictureCache:</string>
|
||||||
|
<object class="IBActionInfo" key="NS.object.0">
|
||||||
|
<string key="name">clearPictureCache:</string>
|
||||||
|
<string key="candidateClassName">id</string>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
<object class="IBClassDescriptionSource" key="sourceIdentifier">
|
||||||
<string key="majorKey">IBProjectSource</string>
|
<string key="majorKey">IBProjectSource</string>
|
||||||
<string key="minorKey">./Classes/ResultWindow.h</string>
|
<string key="minorKey">./Classes/ResultWindow.h</string>
|
||||||
@@ -1714,12 +1580,10 @@
|
|||||||
<string key="superclassName">NSWindowController</string>
|
<string key="superclassName">NSWindowController</string>
|
||||||
<dictionary class="NSMutableDictionary" key="actions">
|
<dictionary class="NSMutableDictionary" key="actions">
|
||||||
<string key="changeOptions:">id</string>
|
<string key="changeOptions:">id</string>
|
||||||
<string key="clearIgnoreList:">id</string>
|
|
||||||
<string key="copyMarked:">id</string>
|
<string key="copyMarked:">id</string>
|
||||||
<string key="deleteMarked:">id</string>
|
|
||||||
<string key="exportToXHTML:">id</string>
|
<string key="exportToXHTML:">id</string>
|
||||||
<string key="filter:">id</string>
|
<string key="filter:">id</string>
|
||||||
<string key="hardlinkMarked:">id</string>
|
<string key="focusOnFilterField:">id</string>
|
||||||
<string key="ignoreSelected:">id</string>
|
<string key="ignoreSelected:">id</string>
|
||||||
<string key="invokeCustomCommand:">id</string>
|
<string key="invokeCustomCommand:">id</string>
|
||||||
<string key="markAll:">id</string>
|
<string key="markAll:">id</string>
|
||||||
@@ -1743,24 +1607,17 @@
|
|||||||
<string key="toggleDetailsPanel:">id</string>
|
<string key="toggleDetailsPanel:">id</string>
|
||||||
<string key="togglePowerMarker:">id</string>
|
<string key="togglePowerMarker:">id</string>
|
||||||
<string key="toggleQuicklookPanel:">id</string>
|
<string key="toggleQuicklookPanel:">id</string>
|
||||||
|
<string key="trashMarked:">id</string>
|
||||||
</dictionary>
|
</dictionary>
|
||||||
<dictionary class="NSMutableDictionary" key="actionInfosByName">
|
<dictionary class="NSMutableDictionary" key="actionInfosByName">
|
||||||
<object class="IBActionInfo" key="changeOptions:">
|
<object class="IBActionInfo" key="changeOptions:">
|
||||||
<string key="name">changeOptions:</string>
|
<string key="name">changeOptions:</string>
|
||||||
<string key="candidateClassName">id</string>
|
<string key="candidateClassName">id</string>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBActionInfo" key="clearIgnoreList:">
|
|
||||||
<string key="name">clearIgnoreList:</string>
|
|
||||||
<string key="candidateClassName">id</string>
|
|
||||||
</object>
|
|
||||||
<object class="IBActionInfo" key="copyMarked:">
|
<object class="IBActionInfo" key="copyMarked:">
|
||||||
<string key="name">copyMarked:</string>
|
<string key="name">copyMarked:</string>
|
||||||
<string key="candidateClassName">id</string>
|
<string key="candidateClassName">id</string>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBActionInfo" key="deleteMarked:">
|
|
||||||
<string key="name">deleteMarked:</string>
|
|
||||||
<string key="candidateClassName">id</string>
|
|
||||||
</object>
|
|
||||||
<object class="IBActionInfo" key="exportToXHTML:">
|
<object class="IBActionInfo" key="exportToXHTML:">
|
||||||
<string key="name">exportToXHTML:</string>
|
<string key="name">exportToXHTML:</string>
|
||||||
<string key="candidateClassName">id</string>
|
<string key="candidateClassName">id</string>
|
||||||
@@ -1769,8 +1626,8 @@
|
|||||||
<string key="name">filter:</string>
|
<string key="name">filter:</string>
|
||||||
<string key="candidateClassName">id</string>
|
<string key="candidateClassName">id</string>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBActionInfo" key="hardlinkMarked:">
|
<object class="IBActionInfo" key="focusOnFilterField:">
|
||||||
<string key="name">hardlinkMarked:</string>
|
<string key="name">focusOnFilterField:</string>
|
||||||
<string key="candidateClassName">id</string>
|
<string key="candidateClassName">id</string>
|
||||||
</object>
|
</object>
|
||||||
<object class="IBActionInfo" key="ignoreSelected:">
|
<object class="IBActionInfo" key="ignoreSelected:">
|
||||||
@@ -1865,11 +1722,16 @@
|
|||||||
<string key="name">toggleQuicklookPanel:</string>
|
<string key="name">toggleQuicklookPanel:</string>
|
||||||
<string key="candidateClassName">id</string>
|
<string key="candidateClassName">id</string>
|
||||||
</object>
|
</object>
|
||||||
|
<object class="IBActionInfo" key="trashMarked:">
|
||||||
|
<string key="name">trashMarked:</string>
|
||||||
|
<string key="candidateClassName">id</string>
|
||||||
|
</object>
|
||||||
</dictionary>
|
</dictionary>
|
||||||
<dictionary class="NSMutableDictionary" key="outlets">
|
<dictionary class="NSMutableDictionary" key="outlets">
|
||||||
<string key="filterField">NSSearchField</string>
|
<string key="filterField">NSSearchField</string>
|
||||||
<string key="matches">HSTableView</string>
|
<string key="matches">HSTableView</string>
|
||||||
<string key="optionsSwitch">NSSegmentedControl</string>
|
<string key="optionsSwitch">NSSegmentedControl</string>
|
||||||
|
<string key="optionsToolbarItem">NSToolbarItem</string>
|
||||||
<string key="stats">NSTextField</string>
|
<string key="stats">NSTextField</string>
|
||||||
</dictionary>
|
</dictionary>
|
||||||
<dictionary class="NSMutableDictionary" key="toOneOutletInfosByName">
|
<dictionary class="NSMutableDictionary" key="toOneOutletInfosByName">
|
||||||
@@ -1885,6 +1747,10 @@
|
|||||||
<string key="name">optionsSwitch</string>
|
<string key="name">optionsSwitch</string>
|
||||||
<string key="candidateClassName">NSSegmentedControl</string>
|
<string key="candidateClassName">NSSegmentedControl</string>
|
||||||
</object>
|
</object>
|
||||||
|
<object class="IBToOneOutletInfo" key="optionsToolbarItem">
|
||||||
|
<string key="name">optionsToolbarItem</string>
|
||||||
|
<string key="candidateClassName">NSToolbarItem</string>
|
||||||
|
</object>
|
||||||
<object class="IBToOneOutletInfo" key="stats">
|
<object class="IBToOneOutletInfo" key="stats">
|
||||||
<string key="name">stats</string>
|
<string key="name">stats</string>
|
||||||
<string key="candidateClassName">NSTextField</string>
|
<string key="candidateClassName">NSTextField</string>
|
||||||
@@ -1899,26 +1765,17 @@
|
|||||||
</object>
|
</object>
|
||||||
<int key="IBDocument.localizationMode">0</int>
|
<int key="IBDocument.localizationMode">0</int>
|
||||||
<string key="IBDocument.TargetRuntimeIdentifier">IBCocoaFramework</string>
|
<string key="IBDocument.TargetRuntimeIdentifier">IBCocoaFramework</string>
|
||||||
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDependencies">
|
|
||||||
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.macosx</string>
|
|
||||||
<real value="1060" key="NS.object.0"/>
|
|
||||||
</object>
|
|
||||||
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDependencyDefaults">
|
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDependencyDefaults">
|
||||||
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.macosx</string>
|
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.macosx</string>
|
||||||
<integer value="1050" key="NS.object.0"/>
|
<real value="1060" key="NS.object.0"/>
|
||||||
</object>
|
|
||||||
<object class="NSMutableDictionary" key="IBDocument.PluginDeclaredDevelopmentDependencies">
|
|
||||||
<string key="NS.key.0">com.apple.InterfaceBuilder.CocoaPlugin.InterfaceBuilder3</string>
|
|
||||||
<real value="4100" key="NS.object.0"/>
|
|
||||||
</object>
|
</object>
|
||||||
<bool key="IBDocument.PluginDeclaredDependenciesTrackSystemTargetVersion">YES</bool>
|
<bool key="IBDocument.PluginDeclaredDependenciesTrackSystemTargetVersion">YES</bool>
|
||||||
<int key="IBDocument.defaultPropertyAccessControl">3</int>
|
<int key="IBDocument.defaultPropertyAccessControl">3</int>
|
||||||
<dictionary class="NSMutableDictionary" key="IBDocument.LastKnownImageSizes">
|
<dictionary class="NSMutableDictionary" key="IBDocument.LastKnownImageSizes">
|
||||||
<string key="NSActionTemplate">{15, 15}</string>
|
<string key="NSActionTemplate">{15, 15}</string>
|
||||||
<string key="NSMenuCheckmark">{9, 8}</string>
|
<string key="NSMenuCheckmark">{11, 11}</string>
|
||||||
<string key="NSMenuMixedState">{7, 2}</string>
|
<string key="NSMenuMixedState">{10, 3}</string>
|
||||||
<string key="NSQuickLookTemplate">{21, 16}</string>
|
<string key="NSQuickLookTemplate">{21, 16}</string>
|
||||||
<string key="NSSwitch">{15, 15}</string>
|
|
||||||
<string key="folder32">{32, 32}</string>
|
<string key="folder32">{32, 32}</string>
|
||||||
</dictionary>
|
</dictionary>
|
||||||
</data>
|
</data>
|
||||||
|
|||||||
@@ -1,23 +0,0 @@
|
|||||||
"Filename" = "Filename";
|
|
||||||
"Folder" = "Folder";
|
|
||||||
"Size" = "Size";
|
|
||||||
"Size (KB)" = "Size (KB)";
|
|
||||||
"Size (MB)" = "Size (MB)";
|
|
||||||
"Kind" = "Kind";
|
|
||||||
"Modification" = "Modification";
|
|
||||||
"Match %" = "Match %";
|
|
||||||
"Words Used" = "Words Used";
|
|
||||||
"Dupe Count" = "Dupe Count";
|
|
||||||
|
|
||||||
"Time" = "Time";
|
|
||||||
"Bitrate" = "Bitrate";
|
|
||||||
"Sample Rate" = "Sample Rate";
|
|
||||||
"Title" = "Title";
|
|
||||||
"Artist" = "Artist";
|
|
||||||
"Album" = "Album";
|
|
||||||
"Genre" = "Genre";
|
|
||||||
"Year" = "Year";
|
|
||||||
"Track Number" = "Track Number";
|
|
||||||
"Comment" = "Comment";
|
|
||||||
|
|
||||||
"Dimensions" = "Dimensions";
|
|
||||||
@@ -1,39 +0,0 @@
|
|||||||
"Collecting files to scan" = "Collecting files to scan";
|
|
||||||
"%s (%d discarded)" = "%s (%d discarded)";
|
|
||||||
"Scanning for duplicates" = "Scanning for duplicates";
|
|
||||||
"Loading" = "Loading";
|
|
||||||
"Moving" = "Moving";
|
|
||||||
"Copying" = "Copying";
|
|
||||||
"Sending to Trash" = "Sending to Trash";
|
|
||||||
"0 matches found" = "0 matches found";
|
|
||||||
"%d matches found" = "%d matches found";
|
|
||||||
"Read size of %d/%d files" = "Read size of %d/%d files";
|
|
||||||
"Grouped %d/%d matches" = "Grouped %d/%d matches";
|
|
||||||
"%d / %d (%s / %s) duplicates marked." = "%d / %d (%s / %s) duplicates marked.";
|
|
||||||
" filter: %s" = " filter: %s";
|
|
||||||
"Read metadata of %d/%d files" = "Read metadata of %d/%d files";
|
|
||||||
"Removing false matches" = "Removing false matches";
|
|
||||||
"Processed %d/%d matches against the ignore list" = "Processed %d/%d matches against the ignore list";
|
|
||||||
"Doing group prioritization" = "Doing group prioritization";
|
|
||||||
|
|
||||||
"Continue" = "Continue";
|
|
||||||
"Continue ({})" = "Continue ({})";
|
|
||||||
|
|
||||||
"Analyzed %d/%d pictures" = "Analyzed %d/%d pictures";
|
|
||||||
"Preparing for matching" = "Preparing for matching";
|
|
||||||
"Performed %d/%d chunk matches" = "Performed %d/%d chunk matches";
|
|
||||||
"Verified %d/%d matches" = "Verified %d/%d matches";
|
|
||||||
|
|
||||||
"Removing dead tracks from your iTunes Library" = "Removing dead tracks from your iTunes Library";
|
|
||||||
"Scanning the iTunes Library" = "Scanning the iTunes Library";
|
|
||||||
|
|
||||||
"Probing iPhoto. Don't touch it during the operation!" = "Probing iPhoto. Don't touch it during the operation!";
|
|
||||||
"Sending dupes to the Trash" = "Sending dupes to the Trash";
|
|
||||||
|
|
||||||
/* Prioritization */
|
|
||||||
"Ends with number" = "Ends with number";
|
|
||||||
"Doesn't end with number" = "Doesn't end with number";
|
|
||||||
"Highest" = "Highest";
|
|
||||||
"Lowest" = "Lowest";
|
|
||||||
"Newest" = "Newest";
|
|
||||||
"Oldest" = "Oldest";
|
|
||||||
@@ -1,33 +0,0 @@
|
|||||||
"SelectResultToLoadMsg" = "Select a results file to load";
|
|
||||||
"SelectCopyDestinationMsg" = "Select a directory to copy marked files to";
|
|
||||||
"SelectMoveDestinationMsg" = "Select a directory to move marked files to";
|
|
||||||
"SelectResultToSaveMsg" = "Select a file to save your results to";
|
|
||||||
"SelectFolderToAddMsg" = "Select a folder to add to the scanning list";
|
|
||||||
"ReallyWantToQuitMsg" = "You have unsaved results, do you really want to quit?";
|
|
||||||
"ReallyWantToContinueMsg" = "You have unsaved results, do you really want to continue?";
|
|
||||||
"FolderAlreadyInListMsg" = "'%@' already is in the list.";
|
|
||||||
"FolderDoesNotExistMsg" = "'%@' does not exist.";
|
|
||||||
"FileRemovalConfirmMsg" = "You are about to remove %d files from results. Continue?";
|
|
||||||
"FilenameAlreadyExistsMsg" = "The name '%@' already exists.";
|
|
||||||
"NoScannableFileMsg" = "The selected directories contain no scannable file.";
|
|
||||||
"UnknownErrorMsg" = "Unknown Error.";
|
|
||||||
"SendToTrashConfirmMsg" = "You are about to send %d files to Trash. Continue?";
|
|
||||||
"HardlinkConfirmMsg" = "You are about to send %d files to Trash (and hardlink them afterwards). Continue?";
|
|
||||||
"ClearIgnoreListConfirmMsg" = "Do you really want to remove all %d items from the ignore list?";
|
|
||||||
"IgnoreConfirmMsg" = "All selected %d matches are going to be ignored in all subsequent scans. Continue?";
|
|
||||||
"NoCustomCommandMsg" = "You have no custom command set up. Set it up in your preferences.";
|
|
||||||
"CopySuccessMsg" = "All marked files were copied sucessfully.";
|
|
||||||
"MoveSuccessMsg" = "All marked files were moved sucessfully.";
|
|
||||||
"SendToTrashSuccessMsg" = "All marked files were sucessfully sent to Trash.";
|
|
||||||
"NoDuplicateFoundMsg" = "No duplicates found.";
|
|
||||||
"TaskHangingMsg" = "A previous action is still hanging in there. You can't start a new one yet. Wait a few seconds, then try again.";
|
|
||||||
|
|
||||||
"RemoveDeadTracksConfirmMsg" = "Your iTunes Library contains %d dead tracks ready to be removed. Continue?";
|
|
||||||
"NoDeadTrackMsg" = "You have no dead tracks in your iTunes Library";
|
|
||||||
|
|
||||||
"IPhotoAppNotFoundMsg" = "The iPhoto application couldn't be found.";
|
|
||||||
"ClearPictureCacheConfirmMsg" = "Do you really want to remove all your cached picture analysis?";
|
|
||||||
|
|
||||||
/* hscommon */
|
|
||||||
"FairwarePromptMsg" = "{name} is Fairware, which means \"open source software developed with expectation of fair contributions from users\". Hours have been invested in this software with the expectation that users will be fair enough to compensate them. The \"Unpaid hours\" figure you see below is the hours that have yet to be compensated for this project.\n\nIf you like this application, please make a contribution that you consider fair. Thanks!\n\nIf you cannot afford to contribute, you can either ignore this reminder or send an e-mail at support@hardcoded.net so I can send you a registration key.\n\nThis dialog doesn't show when there are no unpaid hours or when you have a valid contribution key.";
|
|
||||||
"DemoPromptMsg" = "{name} is fairware, which means \"open source software developed with expectation of fair contributions from users\". It's a very interesting concept, but one year of fairware has shown that most people just want to know how much it costs and not be bothered with theories about intellectual property.\n\nSo I won't bother you and will be very straightforward: You can try {name} for free but you have to buy it in order to use it without limitations. In demo mode, {name} {limitation}.\n\nSo it's as simple as this. If you're curious about fairware, however, I encourage you to read more about it by clicking on the \"Fairware?\" button.";
|
|
||||||
@@ -1,12 +0,0 @@
|
|||||||
|
|
||||||
/* Class = "NSPanel"; title = "Details of Selected File"; ObjectID = "5"; */
|
|
||||||
"5.title" = "Détails du fichier sélectionné";
|
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "Selected"; ObjectID = "9"; */
|
|
||||||
"9.headerCell.title" = "Sélectionné";
|
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "Reference"; ObjectID = "10"; */
|
|
||||||
"10.headerCell.title" = "Référence";
|
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "Attribute"; ObjectID = "11"; */
|
|
||||||
"11.headerCell.title" = "Attribut";
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
/* Class = "NSTableColumn"; headerCell.title = "State"; ObjectID = "13"; */
|
|
||||||
"13.headerCell.title" = "Type";
|
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "Name"; ObjectID = "15"; */
|
|
||||||
"15.headerCell.title" = "Nom";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Scan"; ObjectID = "48"; */
|
|
||||||
"48.title" = "Scan";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Normal"; ObjectID = "55"; */
|
|
||||||
"55.title" = "Normal";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Reference"; ObjectID = "56"; */
|
|
||||||
"56.title" = "Référence";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Excluded"; ObjectID = "57"; */
|
|
||||||
"57.title" = "Exclu";
|
|
||||||
|
|
||||||
/* Class = "NSTextFieldCell"; title = "Select folders to scan and press \"Scan\"."; ObjectID = "71"; */
|
|
||||||
"71.title" = "Sélectionnez les dossiers à scanner et cliquez sur Scan.";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Load Results"; ObjectID = "73"; */
|
|
||||||
"73.title" = "Charger";
|
|
||||||
@@ -1,11 +0,0 @@
|
|||||||
/* Class = "NSWindow"; title = "Sorry, I must insist"; ObjectID = "1"; */
|
|
||||||
"1.title" = "Désolé, je dois insister";
|
|
||||||
|
|
||||||
/* Class = "NSTextFieldCell"; title = "This reminder showed up because:
1. You are processing more than 100 duplicates
2. You have not yet contributed to dupeGuru
3. There are unpaid hours in the project"; ObjectID = "4"; */
|
|
||||||
"4.title" = "Ce rappel apparaît parce que:\n\n1. Plus de 100 doublons sont traités\n2. Vous n'avez pas encore contribué à dupeGuru\n3. Il y a des heures non-payées au projet";
|
|
||||||
|
|
||||||
/* Class = "NSTextFieldCell"; title = "It seems that you found a lot of duplicates. Nice! I must insist, however, that contributions are expected when there are unpaid hours on the project.
You might think \"but I'm only going to use this once, I don't have to contribute\". The problem is that most people use dupeGuru only once in a while. If everyone thinks like that, dupeGuru development cannot be funded.
If you can't afford to contribute, you can ignore this reminder or send me an e-mail at hsoft@hardcoded.net so I can give you a key to remove this popup."; ObjectID = "6"; */
|
|
||||||
"6.title" = "Il semble que vous ayez trouvé beaucoup de doublons. Super! Je dois par contre insister que des contributions sont attendues lorsqu'il y'a des heures non-payées au projet.\n\nVous pensez peut-être \"je n'utiliserai ce programme qu'une fois, pas besoin de contribuer\". Le problème c'est que la plupart des utilisateurs de dupeGuru ne l'utilisent qu'une fois. Si tous suivent ce raisonnement, le développement de dupeGuru ne peut pas continuer. C'est à cause de cette tendance inhérente à la nature de dupeGuru que je me vois contraint d'insister ici.\n\nSi vous n'avez pas les moyens de contribuer, ignorez ce message ou envoyez moi un message à hsoft@hardcoded.net pour que je vous envoie une clé d'enregistrement.";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Contribute"; ObjectID = "10"; */
|
|
||||||
"10.title" = "Contribuer";
|
|
||||||
@@ -1,9 +0,0 @@
|
|||||||
"Add New Folder..." = "Ajouter dossier...";
|
|
||||||
"Load from file..." = "Charger un fichier...";
|
|
||||||
"Reset to Default" = "Colonnes par défault";
|
|
||||||
|
|
||||||
"Add iTunes Directory" = "Ajouter librairie iTunes";
|
|
||||||
"Remove Dead Tracks in iTunes" = "Retirer les tracks mortes dans iTunes";
|
|
||||||
|
|
||||||
"Add iPhoto Library" = "Ajouter librairie iPhoto";
|
|
||||||
"Clear Picture Cache" = "Vider la cache d'images";
|
|
||||||
@@ -1,177 +0,0 @@
|
|||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Bring All to Front"; ObjectID = "5"; */
|
|
||||||
"5.title" = "Tout ramener au premier plan";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Window"; ObjectID = "19"; */
|
|
||||||
"19.title" = "Fenêtre";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Minimize"; ObjectID = "23"; */
|
|
||||||
"23.title" = "Placer dans le Dock";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Window"; ObjectID = "24"; */
|
|
||||||
"24.title" = "Fenêtre";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "About dupeGuru"; ObjectID = "58"; */
|
|
||||||
"58.title" = "À propos de dupeGuru";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Help"; ObjectID = "103"; */
|
|
||||||
"103.title" = "Aide";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Help"; ObjectID = "106"; */
|
|
||||||
"106.title" = "Aide";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "dupeGuru Help"; ObjectID = "111"; */
|
|
||||||
"111.title" = "Aide dupeGuru";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Hide dupeGuru"; ObjectID = "134"; */
|
|
||||||
"134.title" = "Masquer dupeGuru";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Quit dupeGuru"; ObjectID = "136"; */
|
|
||||||
"136.title" = "Quitter dupeGuru";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Hide Others"; ObjectID = "145"; */
|
|
||||||
"145.title" = "Masquer les autres";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Show All"; ObjectID = "150"; */
|
|
||||||
"150.title" = "Tout afficher";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Zoom"; ObjectID = "197"; */
|
|
||||||
"197.title" = "Réduire/agrandir";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Details Panel"; ObjectID = "398"; */
|
|
||||||
"398.title" = "Fenêtre de détails";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Preferences..."; ObjectID = "541"; */
|
|
||||||
"541.title" = "Préférences...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Folder Selection Window"; ObjectID = "579"; */
|
|
||||||
"579.title" = "Fenêtre de sélection de dossiers";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Actions"; ObjectID = "597"; */
|
|
||||||
"597.title" = "Actions";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Actions"; ObjectID = "598"; */
|
|
||||||
"598.title" = "Actions";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Send Marked to Trash"; ObjectID = "599"; */
|
|
||||||
"599.title" = "Envoyer marqués à la corbeille";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Move Marked to..."; ObjectID = "600"; */
|
|
||||||
"600.title" = "Déplacer marqués vers...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Copy Marked to..."; ObjectID = "601"; */
|
|
||||||
"601.title" = "Copier marqués vers...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Make Selected Reference"; ObjectID = "602"; */
|
|
||||||
"602.title" = "Transformer sélectionnés en références";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Remove Marked from Results"; ObjectID = "603"; */
|
|
||||||
"603.title" = "Retirer marqués des résultats";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Remove Selected from Results"; ObjectID = "605"; */
|
|
||||||
"605.title" = "Retirer sélectionnés des résultats";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Columns"; ObjectID = "618"; */
|
|
||||||
"618.title" = "Colonnes";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Columns"; ObjectID = "619"; */
|
|
||||||
"619.title" = "Colonnes";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Open Selected with Default Application"; ObjectID = "708"; */
|
|
||||||
"708.title" = "Ouvrir sélectionné avec l'application par défaut";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Reveal Selected in Finder"; ObjectID = "710"; */
|
|
||||||
"710.title" = "Révéler sélectionné dans Finder";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Add Selected to Ignore List"; ObjectID = "922"; */
|
|
||||||
"922.title" = "Ajouter sélectionnés à la liste de fichiers ignorés";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Close Window"; ObjectID = "924"; */
|
|
||||||
"924.title" = "Fermer";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Start Duplicate Scan"; ObjectID = "926"; */
|
|
||||||
"926.title" = "Commencer à scanner";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Clear Ignore List"; ObjectID = "927"; */
|
|
||||||
"927.title" = "Vider la liste de fichiers ignorés";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Rename Selected"; ObjectID = "933"; */
|
|
||||||
"933.title" = "Renommer sélectionné";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Export Results to XHTML"; ObjectID = "947"; */
|
|
||||||
"947.title" = "Exporter les résultats vers HTML";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Check for update..."; ObjectID = "950"; */
|
|
||||||
"950.title" = "Mise à jour...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Mode"; ObjectID = "959"; */
|
|
||||||
"959.title" = "Mode";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Mode"; ObjectID = "960"; */
|
|
||||||
"960.title" = "Mode";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Show Dupes Only"; ObjectID = "961"; */
|
|
||||||
"961.title" = "Ne pas montrer les références";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Show Delta Values"; ObjectID = "962"; */
|
|
||||||
"962.title" = "Montrer les valeurs en tant que delta";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Edit"; ObjectID = "965"; */
|
|
||||||
"965.title" = "Édition";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Edit"; ObjectID = "966"; */
|
|
||||||
"966.title" = "Édition";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Cut"; ObjectID = "985"; */
|
|
||||||
"985.title" = "Couper";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Copy"; ObjectID = "986"; */
|
|
||||||
"986.title" = "Copier";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Paste"; ObjectID = "991"; */
|
|
||||||
"991.title" = "Coller";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Mark All"; ObjectID = "1011"; */
|
|
||||||
"1011.title" = "Tout marquer";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Mark None"; ObjectID = "1012"; */
|
|
||||||
"1012.title" = "Tout démarquer";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Invert Marking"; ObjectID = "1013"; */
|
|
||||||
"1013.title" = "Inverser le marquage";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Mark Selected"; ObjectID = "1014"; */
|
|
||||||
"1014.title" = "Marquer sélectionnés";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "dupeGuru Website"; ObjectID = "1023"; */
|
|
||||||
"1023.title" = "Site web de dupeGuru";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Invoke Custom Command"; ObjectID = "1177"; */
|
|
||||||
"1177.title" = "Invoquer commande personnalisée";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "File"; ObjectID = "1203"; */
|
|
||||||
"1203.title" = "Fichier";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "File"; ObjectID = "1204"; */
|
|
||||||
"1204.title" = "Fichier";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Load Results..."; ObjectID = "1205"; */
|
|
||||||
"1205.title" = "Charger résultats...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Save Results..."; ObjectID = "1206"; */
|
|
||||||
"1206.title" = "Sauvegarder résultats...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Delete Marked and Replace with Hardlinks"; ObjectID = "1227"; */
|
|
||||||
"1227.title" = "Remplacer marqués par des hardlinks";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Load Recent Results"; ObjectID = "1239"; */
|
|
||||||
"1239.title" = "Charger résultats récents";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Load Recent Results"; ObjectID = "1240"; */
|
|
||||||
"1240.title" = "Charger résultats récents";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Results Window"; ObjectID = "1272"; */
|
|
||||||
"1272.title" = "Fenêtre de résultats";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Re-Prioritize Results"; ObjectID = "1276"; */
|
|
||||||
"1276.title" = "Re-prioriser les résultats";
|
|
||||||
@@ -1,12 +0,0 @@
|
|||||||
|
|
||||||
/* Class = "NSWindow"; title = "Re-Prioritize duplicates"; ObjectID = "1"; */
|
|
||||||
"1.title" = "Re-prioriser les doublons";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Ok"; ObjectID = "37"; */
|
|
||||||
"37.title" = "Ok";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Cancel"; ObjectID = "39"; */
|
|
||||||
"39.title" = "Annuler";
|
|
||||||
|
|
||||||
/* Class = "NSTextFieldCell"; title = "Add criteria to the right box and click OK to send the dupes that correspond the best to these criteria to their respective group's reference position. Read the help file for more information."; ObjectID = "41"; */
|
|
||||||
"41.title" = "Ajoutez des critères dans la liste de droite pour envoyer les doublons qui correspondent le plus à ces critère à la position de référence. Une lecture préalable du fichier d'aide est conseillée.";
|
|
||||||
@@ -1,19 +0,0 @@
|
|||||||
|
|
||||||
/* Class = "NSWindow"; title = "Problems!"; ObjectID = "1"; */
|
|
||||||
"1.title" = "Problèmes!";
|
|
||||||
|
|
||||||
/* Class = "NSTextFieldCell"; title = "There were problems processing some (or all) of the files. The cause of these problems are described in the table below. Those files were not removed from your results."; ObjectID = "4"; */
|
|
||||||
"4.title" = "There were problems processing some (or all) of the files. The cause of these problems are described in the table below. Those files were not removed from your results.";
|
|
||||||
"4.title" = "Il y a eu des problèmes lors du traitement de certain (ou tous) fichiers. La cause de ces problèmes est décrite ci-dessous. Ces fichiers n'ont pas été enlevés des résultats.";
|
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "File Path"; ObjectID = "10"; */
|
|
||||||
"10.headerCell.title" = "Chemin du fichier";
|
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "Error Message"; ObjectID = "11"; */
|
|
||||||
"11.headerCell.title" = "Message d'erreur";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Close"; ObjectID = "19"; */
|
|
||||||
"19.title" = "Fermer";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Reveal Selected"; ObjectID = "21"; */
|
|
||||||
"21.title" = "Révéler Fichier";
|
|
||||||
@@ -1,96 +0,0 @@
|
|||||||
|
|
||||||
/* Class = "NSWindow"; title = "dupeGuru Results"; ObjectID = "1"; */
|
|
||||||
"1.title" = "dupeGuru (Résultats)";
|
|
||||||
|
|
||||||
/* Class = "NSTextFieldCell"; title = "Marked: 0 files, 0 B. Total: 0 files, 0 B."; ObjectID = "6"; */
|
|
||||||
"6.title" = "Marqués: 0 fichiers, 0 B. Total: 0 fichiers, 0 B.";
|
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "Name"; ObjectID = "11"; */
|
|
||||||
"11.headerCell.title" = "Nom";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; label = "Options"; ObjectID = "15"; */
|
|
||||||
"15.label" = "Options";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; paletteLabel = "Options"; ObjectID = "15"; */
|
|
||||||
"15.paletteLabel" = "Options";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; label = "Filter"; ObjectID = "16"; */
|
|
||||||
"16.label" = "Filtre";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; paletteLabel = "Filter"; ObjectID = "16"; */
|
|
||||||
"16.paletteLabel" = "Filtre";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; label = "Action"; ObjectID = "17"; */
|
|
||||||
"17.label" = "Action";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; paletteLabel = "Action"; ObjectID = "17"; */
|
|
||||||
"17.paletteLabel" = "Action";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; label = "Directories"; ObjectID = "19"; */
|
|
||||||
"19.label" = "Dossiers";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; paletteLabel = "Directories"; ObjectID = "19"; */
|
|
||||||
"19.paletteLabel" = "Dossiers";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Delete Marked and Replace with Hardlinks"; ObjectID = "27"; */
|
|
||||||
"27.title" = "Remplacer marqués par des hardlinks";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Send Marked to Trash"; ObjectID = "29"; */
|
|
||||||
"29.title" = "Envoyer marqués à la corbeille";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Move Marked to..."; ObjectID = "30"; */
|
|
||||||
"30.title" = "Déplacer marqués vers...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Copy Marked to..."; ObjectID = "31"; */
|
|
||||||
"31.title" = "Copier marqués vers...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Remove Marked from Results"; ObjectID = "32"; */
|
|
||||||
"32.title" = "Retirer marqués des résultats";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Remove Selected from Results"; ObjectID = "34"; */
|
|
||||||
"34.title" = "Retirer sélectionnés des résultats";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Add Selected to Ignore List"; ObjectID = "35"; */
|
|
||||||
"35.title" = "Ajouter sélectionnés à la liste de fichiers ignorés";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Make Selected Reference"; ObjectID = "36"; */
|
|
||||||
"36.title" = "Transformer sélectionnés en références";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Open Selected with Default Application"; ObjectID = "38"; */
|
|
||||||
"38.title" = "Ouvrir sélectionné avec l'application par défaut";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Reveal Selected in Finder"; ObjectID = "39"; */
|
|
||||||
"39.title" = "Révéler sélectionné dans Finder";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Rename Selected"; ObjectID = "40"; */
|
|
||||||
"40.title" = "Renommer sélectionné";
|
|
||||||
|
|
||||||
/* Class = "NSSearchFieldCell"; placeholderString = "Filter"; ObjectID = "42"; */
|
|
||||||
"42.placeholderString" = "Filtre";
|
|
||||||
|
|
||||||
/* Class = "NSSegmentedCell"; 44.ibShadowedLabels[0] = "Details"; ObjectID = "44"; */
|
|
||||||
"44.ibShadowedLabels[0]" = "Détails";
|
|
||||||
|
|
||||||
/* Class = "NSSegmentedCell"; 44.ibShadowedLabels[1] = "Dupes Only"; ObjectID = "44"; */
|
|
||||||
"44.ibShadowedLabels[1]" = "Sans réf.";
|
|
||||||
|
|
||||||
/* Class = "NSSegmentedCell"; 44.ibShadowedLabels[2] = "Delta"; ObjectID = "44"; */
|
|
||||||
"44.ibShadowedLabels[2]" = "Delta";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Add Selected to Ignore List"; ObjectID = "68"; */
|
|
||||||
"68.title" = "Ajouter sélectionnés à la liste de fichiers ignorés";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Rename Selected"; ObjectID = "70"; */
|
|
||||||
"70.title" = "Renommer sélectionné";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Remove Selected from Results"; ObjectID = "71"; */
|
|
||||||
"71.title" = "Retirer sélectionnés des résultats";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Make Selected Reference"; ObjectID = "72"; */
|
|
||||||
"72.title" = "Transformer sélectionnés en références";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Reveal Selected in Finder"; ObjectID = "73"; */
|
|
||||||
"73.title" = "Révéler sélectionné dans Finder";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Open Selected with Default Application"; ObjectID = "74"; */
|
|
||||||
"74.title" = "Ouvrir sélectionné avec l'application par défaut";
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
"Filename" = "Nom de fichier";
|
|
||||||
"Folder" = "Dossier";
|
|
||||||
"Size" = "Taille";
|
|
||||||
"Size (KB)" = "Taille (KB)";
|
|
||||||
"Size (MB)" = "Taille (MB)";
|
|
||||||
"Kind" = "Type";
|
|
||||||
"Modification" = "Modification";
|
|
||||||
"Match %" = "Match %";
|
|
||||||
"Words Used" = "Mots";
|
|
||||||
"Dupe Count" = "# Doublons";
|
|
||||||
|
|
||||||
"Time" = "Temps";
|
|
||||||
"Bitrate" = "Bitrate";
|
|
||||||
"Sample Rate" = "Sample Rate";
|
|
||||||
"Title" = "Titre";
|
|
||||||
"Artist" = "Artiste";
|
|
||||||
"Album" = "Album";
|
|
||||||
"Genre" = "Genre";
|
|
||||||
"Year" = "Année";
|
|
||||||
"Track Number" = "Track";
|
|
||||||
"Comment" = "Commentaire";
|
|
||||||
|
|
||||||
"Dimensions" = "Dimensions";
|
|
||||||
@@ -1,39 +0,0 @@
|
|||||||
"Collecting files to scan" = "Collecte des fichiers à scanner";
|
|
||||||
"%s (%d discarded)" = "%s (%d hors-groupe)";
|
|
||||||
"Scanning for duplicates" = "Scan de doublons en cours";
|
|
||||||
"Loading" = "Chargement en cours";
|
|
||||||
"Moving" = "Déplacement en cours";
|
|
||||||
"Copying" = "Copie en cours";
|
|
||||||
"Sending to Trash" = "Envoi vers corbeille";
|
|
||||||
"0 matches found" = "0 paires trouvées";
|
|
||||||
"%d matches found" = "%d paires trouvées";
|
|
||||||
"Read size of %d/%d files" = "Lu la taille de %d/%d fichiers";
|
|
||||||
"Grouped %d/%d matches" = "%d/%d paires groupées";
|
|
||||||
"%d / %d (%s / %s) duplicates marked." = "%d / %d (%s / %s) doublons marqués.";
|
|
||||||
" filter: %s" = " filtre: %s";
|
|
||||||
"Read metadata of %d/%d files" = "Lu les métadonnées de %d/%d fichiers";
|
|
||||||
"Removing false matches" = "Retrait des paires invalides";
|
|
||||||
"Processed %d/%d matches against the ignore list" = "Vérification de %d/%d paires dans la ignore list";
|
|
||||||
"Doing group prioritization" = "Prioritization des groupes";
|
|
||||||
|
|
||||||
"Continue" = "Continuer";
|
|
||||||
"Continue ({})" = "Continuer ({})";
|
|
||||||
|
|
||||||
"Analyzed %d/%d pictures" = "Analyzé %d/%d images";
|
|
||||||
"Preparing for matching" = "Préparation pour la comparaison";
|
|
||||||
"Performed %d/%d chunk matches" = "%d/%d blocs d'images comparés";
|
|
||||||
"Verified %d/%d matches" = "Vérifié %d/%d paires";
|
|
||||||
|
|
||||||
"Removing dead tracks from your iTunes Library" = "Retrait des tracks mortes de votre librairie iTunes";
|
|
||||||
"Scanning the iTunes Library" = "Scan de la librairie iTunes en cours";
|
|
||||||
|
|
||||||
"Probing iPhoto. Don't touch it during the operation!" = "Communication avec iPhoto en cours. N'y touchez pas!";
|
|
||||||
"Sending dupes to the Trash" = "Envoi de doublons à la corbeille en cours";
|
|
||||||
|
|
||||||
/* Prioritization */
|
|
||||||
"Ends with number" = "Chiffres à la fin";
|
|
||||||
"Doesn't end with number" = "Pas de chiffres à la finr";
|
|
||||||
"Highest" = "Plus grand";
|
|
||||||
"Lowest" = "Moins grand";
|
|
||||||
"Newest" = "Plus récent";
|
|
||||||
"Oldest" = "Moins récent";
|
|
||||||
@@ -1,33 +0,0 @@
|
|||||||
"SelectResultToLoadMsg" = "Sélectionnez un fichier résultats à charger";
|
|
||||||
"SelectCopyDestinationMsg" = "Sélectionnez un dossier vers lequel copier les fichiers";
|
|
||||||
"SelectMoveDestinationMsg" = "Sélectionnez un dossier vers lequel déplacer les fichiers";
|
|
||||||
"SelectResultToSaveMsg" = "Sélectionnez un fichier résultats dans lequel sauvegarder";
|
|
||||||
"SelectFolderToAddMsg" = "Sélectionnez un dossier à ajouter à la liste";
|
|
||||||
"ReallyWantToQuitMsg" = "Vos résultats ne sont pas sauvegardés. Voulez-vous vraiment quitter?";
|
|
||||||
"ReallyWantToContinueMsg" = "Vos résultats ne sont pas sauvegardés. Voulez-vous vraiment continuer?";
|
|
||||||
"FolderAlreadyInListMsg" = "'%@' est déjà dans la liste.";
|
|
||||||
"FolderDoesNotExistMsg" = "'%@' n'existe pas.";
|
|
||||||
"FileRemovalConfirmMsg" = "%d fichiers seront retirés des résultats. Continuer?";
|
|
||||||
"FilenameAlreadyExistsMsg" = "Le nom '%@' existe déjà.";
|
|
||||||
"NoScannableFileMsg" = "Les dossiers sélectionnés ne contiennent pas de fichiers valides.";
|
|
||||||
"UnknownErrorMsg" = "Erreur inconnue.";
|
|
||||||
"SendToTrashConfirmMsg" = "%d fichiers seront envoyés à la corbeille. Continuer?";
|
|
||||||
"HardlinkConfirmMsg" = "%d fichiers seront envoyés à la corbeille (puis 'hardlinkés'). Continuer?";
|
|
||||||
"ClearIgnoreListConfirmMsg" = "Voulez-vous vider la liste de fichiers ignorés des %d items qu'elle contient?";
|
|
||||||
"IgnoreConfirmMsg" = "%d fichiers seront ignorés des prochains scans. Continuer?";
|
|
||||||
"NoCustomCommandMsg" = "Vous n'avez pas de commande personnalisée. Ajoutez-la dans vos préférences.";
|
|
||||||
"CopySuccessMsg" = "Tous les fichiers marqués ont été copiés correctement.";
|
|
||||||
"MoveSuccessMsg" = "Tous les fichiers déplacés ont été copiés correctement.";
|
|
||||||
"SendToTrashSuccessMsg" = "Tous les fichiers marqués ont été correctement envoyés à la corbeille.";
|
|
||||||
"NoDuplicateFoundMsg" = "Aucun doublon trouvé.";
|
|
||||||
"TaskHangingMsg" = "Une action précédente est encore en cours. Attendez quelques secondes avant d'en repartir une nouvelle.";
|
|
||||||
|
|
||||||
"RemoveDeadTracksConfirmMsg" = "Votre librairie iTunes contient %d tracks mortes qui seront retirées. Continuer?";
|
|
||||||
"NoDeadTrackMsg" = "Votre librairie iTunes ne contient aucune track morte.";
|
|
||||||
|
|
||||||
"IPhotoAppNotFoundMsg" = "iPhoto n'a pas pu être trouvée dans vos applications.";
|
|
||||||
"ClearPictureCacheConfirmMsg" = "Voulez-vous vraiment vider la cache de vos analyses précédentes?";
|
|
||||||
|
|
||||||
/* hscommon */
|
|
||||||
"FairwarePromptMsg" = "{name} est Fairware, ce qui signifie \"open source développé avec des attentes de contributions justes de la part des utilisateurs\". Les heures investies dans ce programme l'ont été avec l'attente que les utilisateurs seront assez honnêtes pour les compenser. Les \"Heures impayées\" que vous voyez ci-dessous sont le nombre d'heures qui n'ont pas encore été compensées.\n\nSi vous aimez cette application, veuillez faire une contribution qui vous semble juste. Merci!\n\nSi vous n'avez pas les moyens de contribuer, vous pouvez soit ignorer ce message soit envoyer un e-mail à support@hardcoded.net pour avoir une clé d'enregistrement.\n\nCette fenêtre n'apparaît pas lorsque vous avez contribué ou qu'il n'y a aucune heure impayée.";
|
|
||||||
"DemoPromptMsg" = "{name} is fairware, which means \"open source software developed with expectation of fair contributions from users\". It's a very interesting concept, but one year of fairware has shown that most people just want to know how much it costs and not be bothered with theories about intellectual property.\n\nSo I won't bother you and will be very straightforward: You can try {name} for free but you have to buy it in order to use it without limitations. In demo mode, {name} {limitation}.\n\nSo it's as simple as this. If you're curious about fairware, however, I encourage you to read more about it by clicking on the \"Fairware?\" button.";
|
|
||||||
41
cocoa/base/main.m
Normal file
41
cocoa/base/main.m
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
/*
|
||||||
|
Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
|
||||||
|
This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
|
which should be included with this package. The terms are also available at
|
||||||
|
http://www.hardcoded.net/licenses/bsd_license
|
||||||
|
*/
|
||||||
|
|
||||||
|
#import <Cocoa/Cocoa.h>
|
||||||
|
#import <Python.h>
|
||||||
|
#import <wchar.h>
|
||||||
|
#import <locale.h>
|
||||||
|
|
||||||
|
int main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
|
||||||
|
/* We have to set the locate to UTF8 for mbstowcs() to correctly convert non-ascii chars in paths */
|
||||||
|
setlocale(LC_ALL, "en_US.UTF-8");
|
||||||
|
NSString *respath = [[NSBundle mainBundle] resourcePath];
|
||||||
|
NSString *mainpy = [respath stringByAppendingPathComponent:@"dg_cocoa.py"];
|
||||||
|
wchar_t wPythonPath[PATH_MAX+1];
|
||||||
|
NSString *pypath = [respath stringByAppendingPathComponent:@"py"];
|
||||||
|
mbstowcs(wPythonPath, [pypath fileSystemRepresentation], PATH_MAX+1);
|
||||||
|
Py_SetPath(wPythonPath);
|
||||||
|
Py_SetPythonHome(wPythonPath);
|
||||||
|
Py_Initialize();
|
||||||
|
PyEval_InitThreads();
|
||||||
|
PyGILState_STATE gilState = PyGILState_Ensure();
|
||||||
|
FILE* fp = fopen([mainpy UTF8String], "r");
|
||||||
|
PyRun_SimpleFile(fp, [mainpy UTF8String]);
|
||||||
|
fclose(fp);
|
||||||
|
PyGILState_Release(gilState);
|
||||||
|
if (gilState == PyGILState_LOCKED) {
|
||||||
|
PyThreadState_Swap(NULL);
|
||||||
|
PyEval_ReleaseLock();
|
||||||
|
}
|
||||||
|
int result = NSApplicationMain(argc, (const char **) argv);
|
||||||
|
Py_Finalize();
|
||||||
|
[pool release];
|
||||||
|
return result;
|
||||||
|
}
|
||||||
@@ -1,12 +0,0 @@
|
|||||||
|
|
||||||
/* Class = "NSPanel"; title = "Details of Selected File"; ObjectID = "5"; */
|
|
||||||
"5.title" = "Details of Selected File";
|
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "Selected"; ObjectID = "9"; */
|
|
||||||
"9.headerCell.title" = "已选择";
|
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "Reference"; ObjectID = "10"; */
|
|
||||||
"10.headerCell.title" = "参照文件";
|
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "Attribute"; ObjectID = "11"; */
|
|
||||||
"11.headerCell.title" = "属性";
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
/* Class = "NSTableColumn"; headerCell.title = "State"; ObjectID = "13"; */
|
|
||||||
"13.headerCell.title" = "说明";
|
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "Name"; ObjectID = "15"; */
|
|
||||||
"15.headerCell.title" = "名称";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Scan"; ObjectID = "48"; */
|
|
||||||
"48.title" = "扫描";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Normal"; ObjectID = "55"; */
|
|
||||||
"55.title" = "正常";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Reference"; ObjectID = "56"; */
|
|
||||||
"56.title" = "参照文件";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Excluded"; ObjectID = "57"; */
|
|
||||||
"57.title" = "不包含";
|
|
||||||
|
|
||||||
/* Class = "NSTextFieldCell"; title = "Select folders to scan and press \"Scan\"."; ObjectID = "71"; */
|
|
||||||
"71.title" = "Select folders to scan and press \"Scan\".";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Load Results"; ObjectID = "73"; */
|
|
||||||
"73.title" = "载入结果";
|
|
||||||
@@ -1,11 +0,0 @@
|
|||||||
/* Class = "NSWindow"; title = "Sorry, I must insist"; ObjectID = "1"; */
|
|
||||||
"1.title" = "抱歉,现在仍要继续";
|
|
||||||
|
|
||||||
/* Class = "NSTextFieldCell"; title = "This reminder showed up because:
1. You are processing more than 100 duplicates
2. You have not yet contributed to dupeGuru
3. There are unpaid hours in the project"; ObjectID = "4"; */
|
|
||||||
"4.title" = "此提醒框弹出的原因如下:\n\n1. 您正在处理超过100个重复文件\n2. 您没有捐助过dupeGuru\n3. 此软件中还有未支付时间";
|
|
||||||
|
|
||||||
/* Class = "NSTextFieldCell"; title = "It seems that you found a lot of duplicates. Nice! I must insist, however, that contributions are expected when there are unpaid hours on the project.
You might think \"but I'm only going to use this once, I don't have to contribute\". The problem is that most people use dupeGuru only once in a while. If everyone thinks like that, dupeGuru development cannot be funded.
If you can't afford to contribute, you can ignore this reminder or send me an e-mail at hsoft@hardcoded.net so I can give you a key to remove this popup."; ObjectID = "6"; */
|
|
||||||
"6.title" = "看起来似乎您找到了很多重复文件。这也是我继续精进这个软件的动力之一。然而,我衷心的希望能够得到您的捐助,因为我会日夜奋战于这个软件并且没有任何报酬。\n\n您可能会觉得 "反正这个软件我只用一次,我不需要给开发者任何捐助". 问题是大多数人都只用一次dupeGuru。如果每一位都这样想,dupeGuru的开发也就没有资金支持了。也正是因为dupeGuru自身的性质决定了它有着仅用一次的内在倾向,所以我还必须坚持致力于这个软件的开发与精进。\n\n如果您无法承担捐助,您也可以忽略此提醒,或者发送电子邮件至 support@hardcoded.net ,我会发送给您一个注册密钥。";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Contribute"; ObjectID = "10"; */
|
|
||||||
"10.title" = "捐助";
|
|
||||||
@@ -1,9 +0,0 @@
|
|||||||
"Add New Folder..." = "Add New Folder...";
|
|
||||||
"Load from file..." = "Load from file...";
|
|
||||||
"Reset to Default" = "Reset to Default";
|
|
||||||
|
|
||||||
"Add iTunes Directory" = "Add iTunes Directory";
|
|
||||||
"Remove Dead Tracks in iTunes" = "Remove Dead Tracks in iTunes";
|
|
||||||
|
|
||||||
"Add iPhoto Library" = "Add iPhoto Library";
|
|
||||||
"Clear Picture Cache" = "清空图片缓存";
|
|
||||||
@@ -1,177 +0,0 @@
|
|||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Bring All to Front"; ObjectID = "5"; */
|
|
||||||
"5.title" = "Bring All to Front";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Window"; ObjectID = "19"; */
|
|
||||||
"19.title" = "Window";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Minimize"; ObjectID = "23"; */
|
|
||||||
"23.title" = "Minimize";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Window"; ObjectID = "24"; */
|
|
||||||
"24.title" = "Window";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "About dupeGuru"; ObjectID = "58"; */
|
|
||||||
"58.title" = "关于dupeGuru";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Help"; ObjectID = "103"; */
|
|
||||||
"103.title" = "帮助";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Help"; ObjectID = "106"; */
|
|
||||||
"106.title" = "帮助";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "dupeGuru Help"; ObjectID = "111"; */
|
|
||||||
"111.title" = "dupeGuru帮助";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Hide dupeGuru"; ObjectID = "134"; */
|
|
||||||
"134.title" = "Hide dupeGuru";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Quit dupeGuru"; ObjectID = "136"; */
|
|
||||||
"136.title" = "Quit dupeGuru";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Hide Others"; ObjectID = "145"; */
|
|
||||||
"145.title" = "Hide Others";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Show All"; ObjectID = "150"; */
|
|
||||||
"150.title" = "Show All";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Zoom"; ObjectID = "197"; */
|
|
||||||
"197.title" = "Zoom";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Details Panel"; ObjectID = "398"; */
|
|
||||||
"398.title" = "Details Panel";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Preferences..."; ObjectID = "541"; */
|
|
||||||
"541.title" = "Preferences...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Folder Selection Window"; ObjectID = "579"; */
|
|
||||||
"579.title" = "Folder Selection Window";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Actions"; ObjectID = "597"; */
|
|
||||||
"597.title" = "行为";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Actions"; ObjectID = "598"; */
|
|
||||||
"598.title" = "行为";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Send Marked to Trash"; ObjectID = "599"; */
|
|
||||||
"599.title" = "Send Marked to Trash";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Move Marked to..."; ObjectID = "600"; */
|
|
||||||
"600.title" = "将标记的文件移动到...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Copy Marked to..."; ObjectID = "601"; */
|
|
||||||
"601.title" = "将标记的文件复制到...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Make Selected Reference"; ObjectID = "602"; */
|
|
||||||
"602.title" = "将所选文件设定为参照文件";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Remove Marked from Results"; ObjectID = "603"; */
|
|
||||||
"603.title" = "从结果中移除所标记的文件";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Remove Selected from Results"; ObjectID = "605"; */
|
|
||||||
"605.title" = "从结果中移除所选的文件";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Columns"; ObjectID = "618"; */
|
|
||||||
"618.title" = "显示列";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Columns"; ObjectID = "619"; */
|
|
||||||
"619.title" = "显示列";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Open Selected with Default Application"; ObjectID = "708"; */
|
|
||||||
"708.title" = "使用默认程序打开所选文件";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Reveal Selected in Finder"; ObjectID = "710"; */
|
|
||||||
"710.title" = "Reveal Selected in Finder";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Add Selected to Ignore List"; ObjectID = "922"; */
|
|
||||||
"922.title" = "将所选文件添加到忽略列表中";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Close Window"; ObjectID = "924"; */
|
|
||||||
"924.title" = "Close Window";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Start Duplicate Scan"; ObjectID = "926"; */
|
|
||||||
"926.title" = "Start Duplicate Scan";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Clear Ignore List"; ObjectID = "927"; */
|
|
||||||
"927.title" = "清空忽略列表";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Rename Selected"; ObjectID = "933"; */
|
|
||||||
"933.title" = "重命名所选文件";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Export Results to XHTML"; ObjectID = "947"; */
|
|
||||||
"947.title" = "Export Results to XHTML";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Check for update..."; ObjectID = "950"; */
|
|
||||||
"950.title" = "Check for update...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Mode"; ObjectID = "959"; */
|
|
||||||
"959.title" = "Mode";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Mode"; ObjectID = "960"; */
|
|
||||||
"960.title" = "Mode";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Show Dupes Only"; ObjectID = "961"; */
|
|
||||||
"961.title" = "仅显示重复文件";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Show Delta Values"; ObjectID = "962"; */
|
|
||||||
"962.title" = "显示Delta值";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Edit"; ObjectID = "965"; */
|
|
||||||
"965.title" = "Edit";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Edit"; ObjectID = "966"; */
|
|
||||||
"966.title" = "Edit";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Cut"; ObjectID = "985"; */
|
|
||||||
"985.title" = "Cut";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Copy"; ObjectID = "986"; */
|
|
||||||
"986.title" = "Copy";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Paste"; ObjectID = "991"; */
|
|
||||||
"991.title" = "Paste";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Mark All"; ObjectID = "1011"; */
|
|
||||||
"1011.title" = "标记全部";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Mark None"; ObjectID = "1012"; */
|
|
||||||
"1012.title" = "全部取消标记";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Invert Marking"; ObjectID = "1013"; */
|
|
||||||
"1013.title" = "反选标记文件";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Mark Selected"; ObjectID = "1014"; */
|
|
||||||
"1014.title" = "标记所选文件";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "dupeGuru Website"; ObjectID = "1023"; */
|
|
||||||
"1023.title" = "dupeGuru Website";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Invoke Custom Command"; ObjectID = "1177"; */
|
|
||||||
"1177.title" = "调用自定义命令";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "File"; ObjectID = "1203"; */
|
|
||||||
"1203.title" = "文件";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "File"; ObjectID = "1204"; */
|
|
||||||
"1204.title" = "文件";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Load Results..."; ObjectID = "1205"; */
|
|
||||||
"1205.title" = "载入结果...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Save Results..."; ObjectID = "1206"; */
|
|
||||||
"1206.title" = "保存结果...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Delete Marked and Replace with Hardlinks"; ObjectID = "1227"; */
|
|
||||||
"1227.title" = "删除标记文件并用硬连接进行替换";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Load Recent Results"; ObjectID = "1239"; */
|
|
||||||
"1239.title" = "载入最近的结果";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Load Recent Results"; ObjectID = "1240"; */
|
|
||||||
"1240.title" = "载入最近的结果";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Results Window"; ObjectID = "1272"; */
|
|
||||||
"1272.title" = "结果窗口";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Re-Prioritize Results"; ObjectID = "1276"; */
|
|
||||||
"1276.title" = "Re-Prioritize Results";
|
|
||||||
@@ -1,12 +0,0 @@
|
|||||||
|
|
||||||
/* Class = "NSWindow"; title = "Re-Prioritize duplicates"; ObjectID = "1"; */
|
|
||||||
"1.title" = "Re-Prioritize duplicates";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Ok"; ObjectID = "37"; */
|
|
||||||
"37.title" = "Ok";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Cancel"; ObjectID = "39"; */
|
|
||||||
"39.title" = "Cancel";
|
|
||||||
|
|
||||||
/* Class = "NSTextFieldCell"; title = "Add criteria to the right box and click OK to send the dupes that correspond the best to these criteria to their respective group's reference position. Read the help file for more information."; ObjectID = "41"; */
|
|
||||||
"41.title" = "Add criteria to the right box and click OK to send the dupes that correspond the best to these criteria to their respective group's reference position. Read the help file for more information.";
|
|
||||||
@@ -1,18 +0,0 @@
|
|||||||
|
|
||||||
/* Class = "NSWindow"; title = "Problems!"; ObjectID = "1"; */
|
|
||||||
"1.title" = "有问题!";
|
|
||||||
|
|
||||||
/* Class = "NSTextFieldCell"; title = "There were problems processing some (or all) of the files. The cause of these problems are described in the table below. Those files were not removed from your results."; ObjectID = "4"; */
|
|
||||||
"4.title" = "There were problems processing some (or all) of the files. The cause of these problems are described in the table below. Those files were not removed from your results.";
|
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "File Path"; ObjectID = "10"; */
|
|
||||||
"10.headerCell.title" = "文件路径";
|
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "Error Message"; ObjectID = "11"; */
|
|
||||||
"11.headerCell.title" = "错误信息";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Close"; ObjectID = "19"; */
|
|
||||||
"19.title" = "关闭";
|
|
||||||
|
|
||||||
/* Class = "NSButtonCell"; title = "Reveal Selected"; ObjectID = "21"; */
|
|
||||||
"21.title" = "显示选择";
|
|
||||||
@@ -1,99 +0,0 @@
|
|||||||
|
|
||||||
/* Class = "NSWindow"; title = "dupeGuru Results"; ObjectID = "1"; */
|
|
||||||
"1.title" = "dupeGuru Results";
|
|
||||||
|
|
||||||
/* Class = "NSTextFieldCell"; title = "Marked: 0 files, 0 B. Total: 0 files, 0 B."; ObjectID = "6"; */
|
|
||||||
"6.title" = "Marked: 0 files, 0 B. Total: 0 files, 0 B.";
|
|
||||||
|
|
||||||
/* Class = "NSTableColumn"; headerCell.title = "Name"; ObjectID = "11"; */
|
|
||||||
"11.headerCell.title" = "名称";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; label = "Options"; ObjectID = "15"; */
|
|
||||||
"15.label" = "Options";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; paletteLabel = "Options"; ObjectID = "15"; */
|
|
||||||
"15.paletteLabel" = "Options";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; label = "Filter"; ObjectID = "16"; */
|
|
||||||
"16.label" = "Filter";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; paletteLabel = "Filter"; ObjectID = "16"; */
|
|
||||||
"16.paletteLabel" = "Filter";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; label = "Action"; ObjectID = "17"; */
|
|
||||||
"17.label" = "Action";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; paletteLabel = "Action"; ObjectID = "17"; */
|
|
||||||
"17.paletteLabel" = "Action";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; label = "Directories"; ObjectID = "19"; */
|
|
||||||
"19.label" = "Directories";
|
|
||||||
|
|
||||||
/* Class = "NSToolbarItem"; paletteLabel = "Directories"; ObjectID = "19"; */
|
|
||||||
"19.paletteLabel" = "Directories";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Delete Marked and Replace with Hardlinks"; ObjectID = "27"; */
|
|
||||||
"27.title" = "删除标记文件并用硬连接进行替换";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Send Marked to Trash"; ObjectID = "29"; */
|
|
||||||
"29.title" = "Send Marked to Trash";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Move Marked to..."; ObjectID = "30"; */
|
|
||||||
"30.title" = "将标记的文件移动到...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Copy Marked to..."; ObjectID = "31"; */
|
|
||||||
"31.title" = "将标记的文件复制到...";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Remove Marked from Results"; ObjectID = "32"; */
|
|
||||||
"32.title" = "从结果中移除所标记的文件";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Remove Selected from Results"; ObjectID = "34"; */
|
|
||||||
"34.title" = "从结果中移除所选的文件";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Add Selected to Ignore List"; ObjectID = "35"; */
|
|
||||||
"35.title" = "将所选文件添加到忽略列表中";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Make Selected Reference"; ObjectID = "36"; */
|
|
||||||
"36.title" = "将所选文件设定为参照文件";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Open Selected with Default Application"; ObjectID = "38"; */
|
|
||||||
"38.title" = "使用默认程序打开所选文件";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Reveal Selected in Finder"; ObjectID = "39"; */
|
|
||||||
"39.title" = "Reveal Selected in Finder";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Rename Selected"; ObjectID = "40"; */
|
|
||||||
"40.title" = "重命名所选文件";
|
|
||||||
|
|
||||||
/* Class = "NSSearchFieldCell"; placeholderString = "Filter"; ObjectID = "42"; */
|
|
||||||
"42.placeholderString" = "Filter";
|
|
||||||
|
|
||||||
/* Class = "NSSegmentedCell"; 44.ibShadowedLabels[0] = "Details"; ObjectID = "44"; */
|
|
||||||
"44.ibShadowedLabels[0]" = "Details";
|
|
||||||
|
|
||||||
/* Class = "NSSegmentedCell"; 44.ibShadowedLabels[1] = "Dupes Only"; ObjectID = "44"; */
|
|
||||||
"44.ibShadowedLabels[1]" = "Dupes Only";
|
|
||||||
|
|
||||||
/* Class = "NSSegmentedCell"; 44.ibShadowedLabels[2] = "Delta"; ObjectID = "44"; */
|
|
||||||
"44.ibShadowedLabels[2]" = "Delta";
|
|
||||||
|
|
||||||
/* Class = "NSMenu"; title = "Menu"; ObjectID = "67"; */
|
|
||||||
"67.title" = "Menu";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Add Selected to Ignore List"; ObjectID = "68"; */
|
|
||||||
"68.title" = "将所选文件添加到忽略列表中";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Rename Selected"; ObjectID = "70"; */
|
|
||||||
"70.title" = "重命名所选文件";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Remove Selected from Results"; ObjectID = "71"; */
|
|
||||||
"71.title" = "从结果中移除所选的文件";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Make Selected Reference"; ObjectID = "72"; */
|
|
||||||
"72.title" = "将所选文件设定为参照文件";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Reveal Selected in Finder"; ObjectID = "73"; */
|
|
||||||
"73.title" = "Reveal Selected in Finder";
|
|
||||||
|
|
||||||
/* Class = "NSMenuItem"; title = "Open Selected with Default Application"; ObjectID = "74"; */
|
|
||||||
"74.title" = "使用默认程序打开所选文件";
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
"Filename" = "Filename";
|
|
||||||
"Folder" = "文件夹";
|
|
||||||
"Size" = "大小";
|
|
||||||
"Size (KB)" = "大小 (KB)";
|
|
||||||
"Size (MB)" = "大小 (MB)";
|
|
||||||
"Kind" = "类型";
|
|
||||||
"Modification" = "编辑日期";
|
|
||||||
"Match %" = "匹配度 %";
|
|
||||||
"Words Used" = "使用过的词语";
|
|
||||||
"Dupe Count" = "重复文件数";
|
|
||||||
|
|
||||||
"Time" = "时间";
|
|
||||||
"Bitrate" = "比特";
|
|
||||||
"Sample Rate" = "采样率";
|
|
||||||
"Title" = "歌曲名";
|
|
||||||
"Artist" = "演唱者";
|
|
||||||
"Album" = "专辑";
|
|
||||||
"Genre" = "音乐类型";
|
|
||||||
"Year" = "年";
|
|
||||||
"Track Number" = "音轨号";
|
|
||||||
"Comment" = "注释";
|
|
||||||
|
|
||||||
"Dimensions" = "规格";
|
|
||||||
@@ -1,39 +0,0 @@
|
|||||||
"Collecting files to scan" = "收集文件以备扫描";
|
|
||||||
"%s (%d discarded)" = "%s (%d 无效)";
|
|
||||||
"Scanning for duplicates" = "重复文件扫描中";
|
|
||||||
"Loading" = "载入中";
|
|
||||||
"Moving" = "移动中";
|
|
||||||
"Copying" = "复制中";
|
|
||||||
"Sending to Trash" = "移到垃圾桶";
|
|
||||||
"0 matches found" = "未找到匹配项";
|
|
||||||
"%d matches found" = "找到 %d 个匹配项";
|
|
||||||
"Read size of %d/%d files" = "读取 %d/%d 文件大小";
|
|
||||||
"Grouped %d/%d matches" = "%d/%d 匹配项组合在一起";
|
|
||||||
"%d / %d (%s / %s) duplicates marked." = "已标记 %d / %d (%s / %s) 个重复项。";
|
|
||||||
" filter: %s" = " 筛选: %s";
|
|
||||||
"Read metadata of %d/%d files" = "读取 %d/%d 文件元数据";
|
|
||||||
"Removing false matches" = "移除错误匹配项";
|
|
||||||
"Processed %d/%d matches against the ignore list" = "在忽略列表之外已处理 %d/%d 匹配项";
|
|
||||||
"Doing group prioritization" = "优化分组";
|
|
||||||
|
|
||||||
"Continue" = "继续";
|
|
||||||
"Continue ({})" = "继续 ({})";
|
|
||||||
|
|
||||||
"Analyzed %d/%d pictures" = "分析 %d/%d 图像";
|
|
||||||
"Preparing for matching" = "准备进行匹配";
|
|
||||||
"Performed %d/%d chunk matches" = "Performed %d/%d chunk matches";
|
|
||||||
"Verified %d/%d matches" = "验证 %d/%d 匹配项";
|
|
||||||
|
|
||||||
"Removing dead tracks from your iTunes Library" = "从你的iTunes库中移除无效的音轨";
|
|
||||||
"Scanning the iTunes Library" = "正在扫描iTunes库";
|
|
||||||
|
|
||||||
"Probing iPhoto. Don't touch it during the operation!" = "正在对iPhoto进行搜索.请在此过程中不要触碰任何按键!";
|
|
||||||
"Sending dupes to the Trash" = "将重复文件移到垃圾桶";
|
|
||||||
|
|
||||||
/* Prioritization */
|
|
||||||
"Ends with number" = "Ends with number";
|
|
||||||
"Doesn't end with number" = "Doesn't end with number";
|
|
||||||
"Highest" = "Highest";
|
|
||||||
"Lowest" = "Lowest";
|
|
||||||
"Newest" = "Newest";
|
|
||||||
"Oldest" = "Oldest";
|
|
||||||
@@ -1,33 +0,0 @@
|
|||||||
"SelectResultToLoadMsg" = "选择一个结果文件并载入";
|
|
||||||
"SelectCopyDestinationMsg" = "Select a directory to copy marked files to";
|
|
||||||
"SelectMoveDestinationMsg" = "Select a directory to move marked files to";
|
|
||||||
"SelectResultToSaveMsg" = "将结果保存为...";
|
|
||||||
"SelectFolderToAddMsg" = "请选择一个文件夹并加入到扫描列表中";
|
|
||||||
"ReallyWantToQuitMsg" = "您还没有保存扫描结果,确定要退出吗?";
|
|
||||||
"ReallyWantToContinueMsg" = "目前还有结果尚未保存,确定要继续吗?";
|
|
||||||
"FolderAlreadyInListMsg" = "'%@' already is in the list.";
|
|
||||||
"FolderDoesNotExistMsg" = "'%@' does not exist.";
|
|
||||||
"FileRemovalConfirmMsg" = "你将从结果中移除 {} 个文件。继续吗?";
|
|
||||||
"FilenameAlreadyExistsMsg" = "The name '%@' already exists.";
|
|
||||||
"NoScannableFileMsg" = "所选文件夹中不包含可供扫描的文件。";
|
|
||||||
"UnknownErrorMsg" = "Unknown Error.";
|
|
||||||
"SendToTrashConfirmMsg" = "即将有 {} 个文件被移到回收站。继续吗?";
|
|
||||||
"HardlinkConfirmMsg" = "即将有 {} 个文件被移动垃圾桶并删除硬盘上的文件。继续吗?";
|
|
||||||
"ClearIgnoreListConfirmMsg" = "确定要从忽略列表中移除 {} 项吗?";
|
|
||||||
"IgnoreConfirmMsg" = "目前已选的 {} 个匹配项将在后续的扫描中被忽略。继续吗?";
|
|
||||||
"NoCustomCommandMsg" = "你没有设定自定义命令。请在首选项中进行设定。";
|
|
||||||
"CopySuccessMsg" = "All marked files were copied sucessfully.";
|
|
||||||
"MoveSuccessMsg" = "All marked files were moved sucessfully.";
|
|
||||||
"SendToTrashSuccessMsg" = "All marked files were sucessfully sent to Trash.";
|
|
||||||
"NoDuplicateFoundMsg" = "没有找到重复文件。";
|
|
||||||
"TaskHangingMsg" = "目前还有任务在执行,新任务无法开启。请等待几秒钟后再重新试一次。";
|
|
||||||
|
|
||||||
"RemoveDeadTracksConfirmMsg" = "Your iTunes Library contains %d dead tracks ready to be removed. Continue?";
|
|
||||||
"NoDeadTrackMsg" = "You have no dead tracks in your iTunes Library";
|
|
||||||
|
|
||||||
"IPhotoAppNotFoundMsg" = "The iPhoto application couldn't be found.";
|
|
||||||
"ClearPictureCacheConfirmMsg" = "确定要移除所有缓存图片?";
|
|
||||||
|
|
||||||
/* hscommon */
|
|
||||||
"FairwarePromptMsg" = "{name} 是一款捐助软件,也就是说 \"用户对研发开源软件所花费的时间进行符合用户意愿的捐助\"。用户可以根据研发人员花费在开发软件上的时间进行合理的补偿。用户在下面看到的 \"未支付的时间\" (Unpaid hours)表示需要对该软件进行补偿的时间。\n\n如果您喜欢这款软件,我诚挚的希望您可以进行必要的捐助。谢谢!\n\n如果您无法承担捐助,您也可以忽略此提醒,或者发送电子邮件至 support@hardcoded.net ,我会发送给您一个注册密钥。\n\n当软件没有未支付的时间或您已使用一个有效的注册密钥,此对话框将不会再显示。";
|
|
||||||
"DemoPromptMsg" = "{name} is fairware, which means \"open source software developed with expectation of fair contributions from users\". It's a very interesting concept, but one year of fairware has shown that most people just want to know how much it costs and not be bothered with theories about intellectual property.\n\nSo I won't bother you and will be very straightforward: You can try {name} for free but you have to buy it in order to use it without limitations. In demo mode, {name} {limitation}.\n\nSo it's as simple as this. If you're curious about fairware, however, I encourage you to read more about it by clicking on the \"Fairware?\" button.";
|
|
||||||
9
cocoa/inter/all.py
Normal file
9
cocoa/inter/all.py
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
from .deletion_options import PyDeletionOptions
|
||||||
|
from .details_panel import PyDetailsPanel
|
||||||
|
from .directory_outline import PyDirectoryOutline
|
||||||
|
from .prioritize_dialog import PyPrioritizeDialog
|
||||||
|
from .prioritize_list import PyPrioritizeList
|
||||||
|
from .problem_dialog import PyProblemDialog
|
||||||
|
from .ignore_list_dialog import PyIgnoreListDialog
|
||||||
|
from .result_table import PyResultTable
|
||||||
|
from .stats_label import PyStatsLabel
|
||||||
@@ -1,15 +1,16 @@
|
|||||||
import logging
|
import logging
|
||||||
|
|
||||||
|
from objp.util import pyref, dontwrap
|
||||||
from jobprogress import job
|
from jobprogress import job
|
||||||
from hscommon import cocoa
|
import cocoa
|
||||||
from hscommon.cocoa import install_exception_hook
|
from cocoa import install_exception_hook, proxy
|
||||||
from hscommon.cocoa.inter import signature, PyFairware
|
from cocoa.inter import PyFairware, FairwareView
|
||||||
from hscommon.cocoa.objcmin import (NSNotificationCenter, NSSearchPathForDirectoriesInDomains,
|
from hscommon.trans import trget
|
||||||
NSApplicationSupportDirectory, NSUserDomainMask, NSWorkspace)
|
|
||||||
from hscommon.trans import tr
|
|
||||||
|
|
||||||
from core.app import JobType
|
from core.app import JobType
|
||||||
|
|
||||||
|
tr = trget('ui')
|
||||||
|
|
||||||
JOBID2TITLE = {
|
JOBID2TITLE = {
|
||||||
JobType.Scan: tr("Scanning for duplicates"),
|
JobType.Scan: tr("Scanning for duplicates"),
|
||||||
JobType.Load: tr("Loading"),
|
JobType.Load: tr("Loading"),
|
||||||
@@ -18,132 +19,141 @@ JOBID2TITLE = {
|
|||||||
JobType.Delete: tr("Sending to Trash"),
|
JobType.Delete: tr("Sending to Trash"),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class DupeGuruView(FairwareView):
|
||||||
|
def askYesNoWithPrompt_(self, prompt: str) -> bool: pass
|
||||||
|
def showProblemDialog(self): pass
|
||||||
|
def selectDestFolderWithPrompt_(self, prompt: str) -> str: pass
|
||||||
|
|
||||||
class PyDupeGuruBase(PyFairware):
|
class PyDupeGuruBase(PyFairware):
|
||||||
|
FOLLOW_PROTOCOLS = ['Worker']
|
||||||
|
|
||||||
|
@dontwrap
|
||||||
def _init(self, modelclass):
|
def _init(self, modelclass):
|
||||||
logging.basicConfig(level=logging.WARNING, format='%(levelname)s %(message)s')
|
logging.basicConfig(level=logging.WARNING, format='%(levelname)s %(message)s')
|
||||||
install_exception_hook()
|
install_exception_hook()
|
||||||
appdata = NSSearchPathForDirectoriesInDomains(NSApplicationSupportDirectory, NSUserDomainMask, True)[0]
|
appdata = proxy.getAppdataPath()
|
||||||
self.py = modelclass(self, appdata)
|
self.model = modelclass(self, appdata)
|
||||||
self.progress = cocoa.ThreadedJobPerformer()
|
self.progress = cocoa.ThreadedJobPerformer()
|
||||||
|
|
||||||
def bindCocoa_(self, cocoa):
|
#---Sub-proxies
|
||||||
self.cocoa = cocoa
|
def detailsPanel(self) -> pyref:
|
||||||
|
return self.model.details_panel
|
||||||
|
|
||||||
|
def directoryTree(self) -> pyref:
|
||||||
|
return self.model.directory_tree
|
||||||
|
|
||||||
|
def problemDialog(self) -> pyref:
|
||||||
|
return self.model.problem_dialog
|
||||||
|
|
||||||
|
def statsLabel(self) -> pyref:
|
||||||
|
return self.model.stats_label
|
||||||
|
|
||||||
|
def resultTable(self) -> pyref:
|
||||||
|
return self.model.result_table
|
||||||
|
|
||||||
|
def ignoreListDialog(self) -> pyref:
|
||||||
|
return self.model.ignore_list_dialog
|
||||||
|
|
||||||
|
def deletionOptions(self) -> pyref:
|
||||||
|
return self.model.deletion_options
|
||||||
|
|
||||||
#---Directories
|
#---Directories
|
||||||
def addDirectory_(self, directory):
|
def addDirectory_(self, directory: str) -> int:
|
||||||
return self.py.add_directory(directory)
|
return self.model.add_directory(directory)
|
||||||
|
|
||||||
def removeDirectory_(self, index):
|
|
||||||
self.py.remove_directory(index)
|
|
||||||
|
|
||||||
#---Results
|
#---Results
|
||||||
def clearIgnoreList(self):
|
|
||||||
self.py.scanner.ignore_list.Clear()
|
|
||||||
|
|
||||||
def doScan(self):
|
def doScan(self):
|
||||||
self.py.start_scanning()
|
self.model.start_scanning()
|
||||||
|
|
||||||
def exportToXHTMLwithColumns_(self, column_ids):
|
def exportToXHTML(self) -> str:
|
||||||
return self.py.export_to_xhtml(column_ids)
|
return self.model.export_to_xhtml()
|
||||||
|
|
||||||
def loadSession(self):
|
def loadSession(self):
|
||||||
self.py.load()
|
self.model.load()
|
||||||
|
|
||||||
def loadResultsFrom_(self, filename):
|
def loadResultsFrom_(self, filename: str):
|
||||||
self.py.load_from(filename)
|
self.model.load_from(filename)
|
||||||
|
|
||||||
def markAll(self):
|
def markAll(self):
|
||||||
self.py.mark_all()
|
self.model.mark_all()
|
||||||
|
|
||||||
def markNone(self):
|
def markNone(self):
|
||||||
self.py.mark_none()
|
self.model.mark_none()
|
||||||
|
|
||||||
def markInvert(self):
|
def markInvert(self):
|
||||||
self.py.mark_invert()
|
self.model.mark_invert()
|
||||||
|
|
||||||
def purgeIgnoreList(self):
|
def purgeIgnoreList(self):
|
||||||
self.py.purge_ignore_list()
|
self.model.purge_ignore_list()
|
||||||
|
|
||||||
def toggleSelectedMark(self):
|
def toggleSelectedMark(self):
|
||||||
self.py.toggle_selected_mark_state()
|
self.model.toggle_selected_mark_state()
|
||||||
|
|
||||||
def saveSession(self):
|
def saveSession(self):
|
||||||
self.py.save()
|
self.model.save()
|
||||||
|
|
||||||
def saveResultsAs_(self, filename):
|
def saveResultsAs_(self, filename: str):
|
||||||
self.py.save_as(filename)
|
self.model.save_as(filename)
|
||||||
|
|
||||||
#---Actions
|
#---Actions
|
||||||
def addSelectedToIgnoreList(self):
|
def addSelectedToIgnoreList(self):
|
||||||
self.py.add_selected_to_ignore_list()
|
self.model.add_selected_to_ignore_list()
|
||||||
|
|
||||||
def deleteMarked(self):
|
def deleteMarked(self):
|
||||||
self.py.delete_marked()
|
self.model.delete_marked()
|
||||||
|
|
||||||
def hardlinkMarked(self):
|
def applyFilter_(self, filter: str):
|
||||||
self.py.delete_marked(replace_with_hardlinks=True)
|
self.model.apply_filter(filter)
|
||||||
|
|
||||||
def applyFilter_(self, filter):
|
|
||||||
self.py.apply_filter(filter)
|
|
||||||
|
|
||||||
def makeSelectedReference(self):
|
def makeSelectedReference(self):
|
||||||
self.py.make_selected_reference()
|
self.model.make_selected_reference()
|
||||||
|
|
||||||
def copyOrMove_markedTo_recreatePath_(self, copy, destination, recreate_path):
|
def copyMarked(self):
|
||||||
self.py.copy_or_move_marked(copy, destination, recreate_path)
|
self.model.copy_or_move_marked(copy=True)
|
||||||
|
|
||||||
|
def moveMarked(self):
|
||||||
|
self.model.copy_or_move_marked(copy=False)
|
||||||
|
|
||||||
def openSelected(self):
|
def openSelected(self):
|
||||||
self.py.open_selected()
|
self.model.open_selected()
|
||||||
|
|
||||||
def removeMarked(self):
|
def removeMarked(self):
|
||||||
self.py.remove_marked()
|
self.model.remove_marked()
|
||||||
|
|
||||||
def renameSelected_(self,newname):
|
def removeSelected(self):
|
||||||
return self.py.rename_selected(newname)
|
self.model.remove_selected()
|
||||||
|
|
||||||
def revealSelected(self):
|
def revealSelected(self):
|
||||||
self.py.reveal_selected()
|
self.model.reveal_selected()
|
||||||
|
|
||||||
def invokeCommand_(self, cmd):
|
def invokeCustomCommand(self):
|
||||||
self.py.invoke_command(cmd)
|
self.model.invoke_custom_command()
|
||||||
|
|
||||||
|
def showIgnoreList(self):
|
||||||
|
self.model.ignore_list_dialog.show()
|
||||||
|
|
||||||
#---Information
|
#---Information
|
||||||
def getIgnoreListCount(self):
|
def resultsAreModified(self) -> bool:
|
||||||
return len(self.py.scanner.ignore_list)
|
return self.model.results.is_modified
|
||||||
|
|
||||||
def getMarkCount(self):
|
|
||||||
return self.py.results.mark_count
|
|
||||||
|
|
||||||
@signature('i@:')
|
|
||||||
def scanWasProblematic(self):
|
|
||||||
return bool(self.py.results.problems)
|
|
||||||
|
|
||||||
@signature('i@:')
|
|
||||||
def resultsAreModified(self):
|
|
||||||
return self.py.results.is_modified
|
|
||||||
|
|
||||||
def deltaColumns(self):
|
|
||||||
return list(self.py.DELTA_COLUMNS)
|
|
||||||
|
|
||||||
#---Properties
|
#---Properties
|
||||||
@signature('v@:c')
|
def setMixFileKind_(self, mix_file_kind: bool):
|
||||||
def setMixFileKind_(self, mix_file_kind):
|
self.model.scanner.mix_file_kind = mix_file_kind
|
||||||
self.py.scanner.mix_file_kind = mix_file_kind
|
|
||||||
|
|
||||||
@signature('v@:c')
|
def setEscapeFilterRegexp_(self, escape_filter_regexp: bool):
|
||||||
def setEscapeFilterRegexp_(self, escape_filter_regexp):
|
self.model.options['escape_filter_regexp'] = escape_filter_regexp
|
||||||
self.py.options['escape_filter_regexp'] = escape_filter_regexp
|
|
||||||
|
|
||||||
@signature('v@:c')
|
def setRemoveEmptyFolders_(self, remove_empty_folders: bool):
|
||||||
def setRemoveEmptyFolders_(self, remove_empty_folders):
|
self.model.options['clean_empty_dirs'] = remove_empty_folders
|
||||||
self.py.options['clean_empty_dirs'] = remove_empty_folders
|
|
||||||
|
|
||||||
@signature('v@:c')
|
def setIgnoreHardlinkMatches_(self, ignore_hardlink_matches: bool):
|
||||||
def setIgnoreHardlinkMatches_(self, ignore_hardlink_matches):
|
self.model.options['ignore_hardlink_matches'] = ignore_hardlink_matches
|
||||||
self.py.options['ignore_hardlink_matches'] = ignore_hardlink_matches
|
|
||||||
|
def setCopyMoveDestType_(self, copymove_dest_type: int):
|
||||||
|
self.model.options['copymove_dest_type'] = copymove_dest_type
|
||||||
|
|
||||||
#---Worker
|
#---Worker
|
||||||
def getJobProgress(self):
|
def getJobProgress(self) -> object: # NSNumber
|
||||||
try:
|
try:
|
||||||
return self.progress.last_progress
|
return self.progress.last_progress
|
||||||
except AttributeError:
|
except AttributeError:
|
||||||
@@ -152,7 +162,7 @@ class PyDupeGuruBase(PyFairware):
|
|||||||
# is sent), but it happens anyway, so there we go. ref: #106
|
# is sent), but it happens anyway, so there we go. ref: #106
|
||||||
return -1
|
return -1
|
||||||
|
|
||||||
def getJobDesc(self):
|
def getJobDesc(self) -> str:
|
||||||
try:
|
try:
|
||||||
return self.progress.last_desc
|
return self.progress.last_desc
|
||||||
except AttributeError:
|
except AttributeError:
|
||||||
@@ -162,30 +172,48 @@ class PyDupeGuruBase(PyFairware):
|
|||||||
def cancelJob(self):
|
def cancelJob(self):
|
||||||
self.progress.job_cancelled = True
|
self.progress.job_cancelled = True
|
||||||
|
|
||||||
def jobCompleted_(self, jobid):
|
def jobCompleted_(self, jobid: str):
|
||||||
self.py._job_completed(jobid)
|
result = self.model._job_completed(jobid, self.progress.last_error)
|
||||||
|
if not result:
|
||||||
|
self.progress.reraise_if_error()
|
||||||
|
|
||||||
#--- model --> view
|
#--- model --> view
|
||||||
|
@dontwrap
|
||||||
def open_path(self, path):
|
def open_path(self, path):
|
||||||
NSWorkspace.sharedWorkspace().openFile_(str(path))
|
proxy.openPath_(str(path))
|
||||||
|
|
||||||
|
@dontwrap
|
||||||
def reveal_path(self, path):
|
def reveal_path(self, path):
|
||||||
NSWorkspace.sharedWorkspace().selectFile_inFileViewerRootedAtPath_(str(path), '')
|
proxy.revealPath_(str(path))
|
||||||
|
|
||||||
|
@dontwrap
|
||||||
def start_job(self, jobid, func, args=()):
|
def start_job(self, jobid, func, args=()):
|
||||||
try:
|
try:
|
||||||
j = self.progress.create_job()
|
j = self.progress.create_job()
|
||||||
args = tuple([j] + list(args))
|
args = tuple([j] + list(args))
|
||||||
self.progress.run_threaded(func, args=args)
|
self.progress.run_threaded(func, args=args)
|
||||||
except job.JobInProgressError:
|
except job.JobInProgressError:
|
||||||
NSNotificationCenter.defaultCenter().postNotificationName_object_('JobInProgress', self)
|
proxy.postNotification_userInfo_('JobInProgress', None)
|
||||||
else:
|
else:
|
||||||
ud = {'desc': JOBID2TITLE[jobid], 'jobid':jobid}
|
ud = {'desc': JOBID2TITLE[jobid], 'jobid':jobid}
|
||||||
NSNotificationCenter.defaultCenter().postNotificationName_object_userInfo_('JobStarted', self, ud)
|
proxy.postNotification_userInfo_('JobStarted', ud)
|
||||||
|
|
||||||
def show_extra_fairware_reminder(self):
|
@dontwrap
|
||||||
self.cocoa.showExtraFairwareReminder()
|
def ask_yes_no(self, prompt):
|
||||||
|
return self.callback.askYesNoWithPrompt_(prompt)
|
||||||
|
|
||||||
def show_message(self, msg):
|
@dontwrap
|
||||||
self.cocoa.showMessage_(msg)
|
def show_results_window(self):
|
||||||
|
# Not needed yet because our progress dialog is shown as a sheet of the results window,
|
||||||
|
# which causes it to be already visible when the scan/load ends.
|
||||||
|
# XXX Make progress sheet be a child of the folder selection window.
|
||||||
|
pass
|
||||||
|
|
||||||
|
@dontwrap
|
||||||
|
def show_problem_dialog(self):
|
||||||
|
self.callback.showProblemDialog()
|
||||||
|
|
||||||
|
@dontwrap
|
||||||
|
def select_dest_folder(self, prompt):
|
||||||
|
return self.callback.selectDestFolderWithPrompt_(prompt)
|
||||||
|
|
||||||
|
|||||||
@@ -1,22 +1,30 @@
|
|||||||
# Created By: Virgil Dupras
|
# Created By: Virgil Dupras
|
||||||
# Created On: 2006/11/16
|
# Created On: 2006/11/16
|
||||||
# Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
# Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
#
|
#
|
||||||
# This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
# This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
# which should be included with this package. The terms are also available at
|
# which should be included with this package. The terms are also available at
|
||||||
# http://www.hardcoded.net/licenses/bsd_license
|
# http://www.hardcoded.net/licenses/bsd_license
|
||||||
|
|
||||||
import logging
|
import logging
|
||||||
from appscript import app, k, CommandError
|
from appscript import app, its, k, CommandError, ApplicationNotFoundError
|
||||||
|
import plistlib
|
||||||
import time
|
import time
|
||||||
import os.path as op
|
import os.path as op
|
||||||
|
|
||||||
from hscommon.cocoa import as_fetch
|
from cocoa import as_fetch, proxy
|
||||||
from hscommon.trans import tr
|
from hscommon import io
|
||||||
|
from hscommon.trans import trget
|
||||||
|
from hscommon.path import Path
|
||||||
|
|
||||||
|
from core import directories
|
||||||
from core.app import JobType
|
from core.app import JobType
|
||||||
|
from core.scanner import ScanType
|
||||||
from core_me.app import DupeGuru as DupeGuruBase
|
from core_me.app import DupeGuru as DupeGuruBase
|
||||||
from .app import JOBID2TITLE
|
from core_me import fs
|
||||||
|
from .app import JOBID2TITLE, PyDupeGuruBase
|
||||||
|
|
||||||
|
tr = trget('ui')
|
||||||
|
|
||||||
JobType.RemoveDeadTracks = 'jobRemoveDeadTracks'
|
JobType.RemoveDeadTracks = 'jobRemoveDeadTracks'
|
||||||
JobType.ScanDeadTracks = 'jobScanDeadTracks'
|
JobType.ScanDeadTracks = 'jobScanDeadTracks'
|
||||||
@@ -26,15 +34,189 @@ JOBID2TITLE.update({
|
|||||||
JobType.ScanDeadTracks: tr("Scanning the iTunes Library"),
|
JobType.ScanDeadTracks: tr("Scanning the iTunes Library"),
|
||||||
})
|
})
|
||||||
|
|
||||||
|
ITUNES = 'iTunes'
|
||||||
|
ITUNES_PATH = Path('iTunes Library')
|
||||||
|
|
||||||
|
def get_itunes_library(a):
|
||||||
|
try:
|
||||||
|
[source] = [s for s in a.sources(timeout=0) if s.kind(timeout=0) == k.library]
|
||||||
|
[library] = source.library_playlists(timeout=0)
|
||||||
|
return library
|
||||||
|
except ValueError:
|
||||||
|
logging.warning('Some unexpected iTunes configuration encountered')
|
||||||
|
return None
|
||||||
|
|
||||||
|
class ITunesSong(fs.MusicFile):
|
||||||
|
def __init__(self, song_data):
|
||||||
|
path = Path(proxy.url2path_(song_data['Location']))
|
||||||
|
fs.MusicFile.__init__(self, path)
|
||||||
|
self.id = song_data['Track ID']
|
||||||
|
|
||||||
|
def remove_from_library(self):
|
||||||
|
try:
|
||||||
|
a = app(ITUNES)
|
||||||
|
library = get_itunes_library(a)
|
||||||
|
if library is None:
|
||||||
|
return
|
||||||
|
[song] = library.file_tracks[its.database_ID == self.id]()
|
||||||
|
a.delete(song, timeout=0)
|
||||||
|
except ValueError:
|
||||||
|
msg = "Could not find song '{}' (trackid: {}) in iTunes Library".format(str(self.path), self.id)
|
||||||
|
raise EnvironmentError(msg)
|
||||||
|
except (CommandError, RuntimeError) as e:
|
||||||
|
raise EnvironmentError(str(e))
|
||||||
|
|
||||||
|
display_folder_path = ITUNES_PATH
|
||||||
|
|
||||||
|
def get_itunes_database_path():
|
||||||
|
plisturls = proxy.prefValue_inDomain_('iTunesRecentDatabases', 'com.apple.iApps')
|
||||||
|
if not plisturls:
|
||||||
|
raise directories.InvalidPathError()
|
||||||
|
plistpath = proxy.url2path_(plisturls[0])
|
||||||
|
return Path(plistpath)
|
||||||
|
|
||||||
|
def get_itunes_songs(plistpath):
|
||||||
|
if not io.exists(plistpath):
|
||||||
|
return []
|
||||||
|
plist = plistlib.readPlist(str(plistpath))
|
||||||
|
result = []
|
||||||
|
for song_data in plist['Tracks'].values():
|
||||||
|
if song_data['Track Type'] != 'File':
|
||||||
|
continue
|
||||||
|
try:
|
||||||
|
song = ITunesSong(song_data)
|
||||||
|
except KeyError: # No "Location" or "Track ID" key in track
|
||||||
|
continue
|
||||||
|
if io.exists(song.path):
|
||||||
|
result.append(song)
|
||||||
|
return result
|
||||||
|
|
||||||
|
class Directories(directories.Directories):
|
||||||
|
def __init__(self, fileclasses):
|
||||||
|
directories.Directories.__init__(self, fileclasses)
|
||||||
|
try:
|
||||||
|
self.itunes_libpath = get_itunes_database_path()
|
||||||
|
except directories.InvalidPathError:
|
||||||
|
self.itunes_libpath = None
|
||||||
|
|
||||||
|
def _get_files(self, from_path, j):
|
||||||
|
if from_path == ITUNES_PATH:
|
||||||
|
if self.itunes_libpath is None:
|
||||||
|
return []
|
||||||
|
is_ref = self.get_state(from_path) == directories.DirectoryState.Reference
|
||||||
|
songs = get_itunes_songs(self.itunes_libpath)
|
||||||
|
for song in songs:
|
||||||
|
song.is_ref = is_ref
|
||||||
|
return songs
|
||||||
|
else:
|
||||||
|
return directories.Directories._get_files(self, from_path, j)
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def get_subfolders(path):
|
||||||
|
if path == ITUNES_PATH:
|
||||||
|
return []
|
||||||
|
else:
|
||||||
|
return directories.Directories.get_subfolders(path)
|
||||||
|
|
||||||
|
def add_path(self, path):
|
||||||
|
if path == ITUNES_PATH:
|
||||||
|
if path not in self:
|
||||||
|
self._dirs.append(path)
|
||||||
|
else:
|
||||||
|
directories.Directories.add_path(self, path)
|
||||||
|
|
||||||
|
def has_itunes_path(self):
|
||||||
|
return any(path == ITUNES_PATH for path in self._dirs)
|
||||||
|
|
||||||
|
def has_any_file(self):
|
||||||
|
# If we don't do that, it causes a hangup in the GUI when we click Start Scanning because
|
||||||
|
# checking if there's any file to scan involves reading the whole library. If we have the
|
||||||
|
# iTunes library, we assume we have at least one file.
|
||||||
|
if self.has_itunes_path():
|
||||||
|
return True
|
||||||
|
else:
|
||||||
|
return directories.Directories.has_any_file(self)
|
||||||
|
|
||||||
|
|
||||||
class DupeGuruME(DupeGuruBase):
|
class DupeGuruME(DupeGuruBase):
|
||||||
def __init__(self, view, appdata):
|
def __init__(self, view, appdata):
|
||||||
appdata = op.join(appdata, 'dupeGuru Music Edition')
|
appdata = op.join(appdata, 'dupeGuru Music Edition')
|
||||||
DupeGuruBase.__init__(self, view, appdata)
|
DupeGuruBase.__init__(self, view, appdata)
|
||||||
|
# Use fileclasses set in DupeGuruBase.__init__()
|
||||||
|
self.directories = Directories(fileclasses=self.directories.fileclasses)
|
||||||
self.dead_tracks = []
|
self.dead_tracks = []
|
||||||
|
|
||||||
|
def _do_delete(self, j, replace_with_hardlinks, direct_deletion):
|
||||||
|
# XXX If I read correctly, Python 3.3 will allow us to go fetch inner function easily, so
|
||||||
|
# we'll be able to replace "op" below with DupeGuruBase._do_delete.op.
|
||||||
|
def op(dupe):
|
||||||
|
j.add_progress()
|
||||||
|
return self._do_delete_dupe(dupe, replace_with_hardlinks, direct_deletion)
|
||||||
|
|
||||||
|
marked = [dupe for dupe in self.results.dupes if self.results.is_marked(dupe)]
|
||||||
|
j.start_job(self.results.mark_count, tr("Sending dupes to the Trash"))
|
||||||
|
if any(isinstance(dupe, ITunesSong) for dupe in marked):
|
||||||
|
j.add_progress(0, desc=tr("Talking to iTunes. Don't touch it!"))
|
||||||
|
try:
|
||||||
|
a = app(ITUNES)
|
||||||
|
a.activate(timeout=0)
|
||||||
|
except (CommandError, RuntimeError, ApplicationNotFoundError):
|
||||||
|
pass
|
||||||
|
self.results.perform_on_marked(op, True)
|
||||||
|
|
||||||
|
def _do_delete_dupe(self, dupe, replace_with_hardlinks, direct_deletion):
|
||||||
|
if isinstance(dupe, ITunesSong):
|
||||||
|
dupe.remove_from_library()
|
||||||
|
DupeGuruBase._do_delete_dupe(self, dupe, replace_with_hardlinks, direct_deletion)
|
||||||
|
|
||||||
|
def _create_file(self, path):
|
||||||
|
if (self.directories.itunes_libpath is not None) and (path in self.directories.itunes_libpath[:-1]):
|
||||||
|
if not hasattr(self, 'itunes_songs'):
|
||||||
|
songs = get_itunes_songs(self.directories.itunes_libpath)
|
||||||
|
self.itunes_songs = {song.path: song for song in songs}
|
||||||
|
if path in self.itunes_songs:
|
||||||
|
return self.itunes_songs[path]
|
||||||
|
else:
|
||||||
|
pass # We'll return the default file type, as per the last line of this method
|
||||||
|
return DupeGuruBase._create_file(self, path)
|
||||||
|
|
||||||
|
def _job_completed(self, jobid, exc):
|
||||||
|
if (jobid in {JobType.RemoveDeadTracks, JobType.ScanDeadTracks}) and (exc is not None):
|
||||||
|
msg = tr("There were communication problems with iTunes. The operation couldn't be completed.")
|
||||||
|
self.view.show_message(msg)
|
||||||
|
return True
|
||||||
|
if jobid == JobType.ScanDeadTracks:
|
||||||
|
dead_tracks_count = len(self.dead_tracks)
|
||||||
|
if dead_tracks_count > 0:
|
||||||
|
msg = tr("Your iTunes Library contains %d dead tracks ready to be removed. Continue?")
|
||||||
|
if self.view.ask_yes_no(msg % dead_tracks_count):
|
||||||
|
self.remove_dead_tracks()
|
||||||
|
else:
|
||||||
|
msg = tr("You have no dead tracks in your iTunes Library")
|
||||||
|
self.view.show_message(msg)
|
||||||
|
if jobid == JobType.Load:
|
||||||
|
if hasattr(self, 'itunes_songs'):
|
||||||
|
# If we load another file, we want a refresh song list
|
||||||
|
del self.itunes_songs
|
||||||
|
DupeGuruBase._job_completed(self, jobid, exc)
|
||||||
|
|
||||||
|
def copy_or_move(self, dupe, copy, destination, dest_type):
|
||||||
|
if isinstance(dupe, ITunesSong):
|
||||||
|
copy = True
|
||||||
|
return DupeGuruBase.copy_or_move(self, dupe, copy, destination, dest_type)
|
||||||
|
|
||||||
|
def start_scanning(self):
|
||||||
|
if self.directories.has_itunes_path():
|
||||||
|
try:
|
||||||
|
app(ITUNES)
|
||||||
|
except ApplicationNotFoundError:
|
||||||
|
self.view.show_message(tr("The iTunes application couldn't be found."))
|
||||||
|
return
|
||||||
|
DupeGuruBase.start_scanning(self)
|
||||||
|
|
||||||
def remove_dead_tracks(self):
|
def remove_dead_tracks(self):
|
||||||
def do(j):
|
def do(j):
|
||||||
a = app('iTunes')
|
a = app(ITUNES)
|
||||||
a.activate(timeout=0)
|
a.activate(timeout=0)
|
||||||
for index, track in enumerate(j.iter_with_progress(self.dead_tracks)):
|
for index, track in enumerate(j.iter_with_progress(self.dead_tracks)):
|
||||||
if index % 100 == 0:
|
if index % 100 == 0:
|
||||||
@@ -48,13 +230,10 @@ class DupeGuruME(DupeGuruBase):
|
|||||||
|
|
||||||
def scan_dead_tracks(self):
|
def scan_dead_tracks(self):
|
||||||
def do(j):
|
def do(j):
|
||||||
a = app('iTunes')
|
a = app(ITUNES)
|
||||||
a.activate(timeout=0)
|
a.activate(timeout=0)
|
||||||
try:
|
library = get_itunes_library(a)
|
||||||
[source] = [s for s in a.sources(timeout=0) if s.kind(timeout=0) == k.library]
|
if library is None:
|
||||||
[library] = source.library_playlists(timeout=0)
|
|
||||||
except ValueError:
|
|
||||||
logging.warning('Some unexpected iTunes configuration encountered')
|
|
||||||
return
|
return
|
||||||
self.dead_tracks = []
|
self.dead_tracks = []
|
||||||
tracks = as_fetch(library.file_tracks, k.file_track)
|
tracks = as_fetch(library.file_tracks, k.file_track)
|
||||||
@@ -67,3 +246,38 @@ class DupeGuruME(DupeGuruBase):
|
|||||||
|
|
||||||
self.view.start_job(JobType.ScanDeadTracks, do)
|
self.view.start_job(JobType.ScanDeadTracks, do)
|
||||||
|
|
||||||
|
class PyDupeGuru(PyDupeGuruBase):
|
||||||
|
def __init__(self):
|
||||||
|
self._init(DupeGuruME)
|
||||||
|
|
||||||
|
def scanDeadTracks(self):
|
||||||
|
self.model.scan_dead_tracks()
|
||||||
|
|
||||||
|
#---Properties
|
||||||
|
def setMinMatchPercentage_(self, percentage: int):
|
||||||
|
self.model.scanner.min_match_percentage = percentage
|
||||||
|
|
||||||
|
def setScanType_(self, scan_type: int):
|
||||||
|
try:
|
||||||
|
self.model.scanner.scan_type = [
|
||||||
|
ScanType.Filename,
|
||||||
|
ScanType.Fields,
|
||||||
|
ScanType.FieldsNoOrder,
|
||||||
|
ScanType.Tag,
|
||||||
|
ScanType.Contents,
|
||||||
|
ScanType.ContentsAudio,
|
||||||
|
][scan_type]
|
||||||
|
except IndexError:
|
||||||
|
pass
|
||||||
|
|
||||||
|
def setWordWeighting_(self, words_are_weighted: bool):
|
||||||
|
self.model.scanner.word_weighting = words_are_weighted
|
||||||
|
|
||||||
|
def setMatchSimilarWords_(self, match_similar_words: bool):
|
||||||
|
self.model.scanner.match_similar_words = match_similar_words
|
||||||
|
|
||||||
|
def enable_scanForTag_(self, enable: bool, scan_tag: str):
|
||||||
|
if enable:
|
||||||
|
self.model.scanner.scanned_tags.add(scan_tag)
|
||||||
|
else:
|
||||||
|
self.model.scanner.scanned_tags.discard(scan_tag)
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
# Created By: Virgil Dupras
|
# Created By: Virgil Dupras
|
||||||
# Created On: 2006/11/13
|
# Created On: 2006/11/13
|
||||||
# Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
# Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
#
|
#
|
||||||
# This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
# This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
# which should be included with this package. The terms are also available at
|
# which should be included with this package. The terms are also available at
|
||||||
@@ -11,20 +11,26 @@ import plistlib
|
|||||||
import logging
|
import logging
|
||||||
import re
|
import re
|
||||||
|
|
||||||
from appscript import app, its, CommandError, ApplicationNotFoundError
|
from appscript import app, its, k, CommandError, ApplicationNotFoundError
|
||||||
|
|
||||||
from hscommon import io
|
from hscommon import io
|
||||||
from hscommon.util import remove_invalid_xml
|
from hscommon.util import remove_invalid_xml, first
|
||||||
from hscommon.path import Path
|
from hscommon.path import Path
|
||||||
from hscommon.cocoa.objcmin import NSUserDefaults, NSURL
|
from hscommon.trans import trget
|
||||||
from hscommon.trans import tr, trmsg
|
from cocoa import proxy
|
||||||
|
|
||||||
|
from core.scanner import ScanType
|
||||||
from core import directories
|
from core import directories
|
||||||
|
from core.app import JobType
|
||||||
from core_pe import _block_osx
|
from core_pe import _block_osx
|
||||||
from core_pe.photo import Photo as PhotoBase
|
from core_pe.photo import Photo as PhotoBase
|
||||||
from core_pe.app import DupeGuru as DupeGuruBase
|
from core_pe.app import DupeGuru as DupeGuruBase
|
||||||
|
from .app import PyDupeGuruBase
|
||||||
|
|
||||||
|
tr = trget('ui')
|
||||||
|
|
||||||
IPHOTO_PATH = Path('iPhoto Library')
|
IPHOTO_PATH = Path('iPhoto Library')
|
||||||
|
APERTURE_PATH = Path('Aperture Library')
|
||||||
|
|
||||||
class Photo(PhotoBase):
|
class Photo(PhotoBase):
|
||||||
HANDLED_EXTS = PhotoBase.HANDLED_EXTS.copy()
|
HANDLED_EXTS = PhotoBase.HANDLED_EXTS.copy()
|
||||||
@@ -44,21 +50,25 @@ class Photo(PhotoBase):
|
|||||||
|
|
||||||
|
|
||||||
class IPhoto(Photo):
|
class IPhoto(Photo):
|
||||||
|
def __init__(self, path, db_id):
|
||||||
|
# In IPhoto, we don't care about the db_id, we find photos by path.
|
||||||
|
Photo.__init__(self, path)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def display_folder_path(self):
|
def display_folder_path(self):
|
||||||
return IPHOTO_PATH
|
return IPHOTO_PATH
|
||||||
|
|
||||||
def get_iphoto_database_path():
|
class AperturePhoto(Photo):
|
||||||
ud = NSUserDefaults.standardUserDefaults()
|
def __init__(self, path, db_id):
|
||||||
prefs = ud.persistentDomainForName_('com.apple.iApps')
|
Photo.__init__(self, path)
|
||||||
if prefs is None:
|
self.db_id = db_id
|
||||||
raise directories.InvalidPathError()
|
|
||||||
if 'iPhotoRecentDatabases' not in prefs:
|
|
||||||
raise directories.InvalidPathError()
|
|
||||||
plisturl = NSURL.URLWithString_(prefs['iPhotoRecentDatabases'][0])
|
|
||||||
return Path(plisturl.path())
|
|
||||||
|
|
||||||
def get_iphoto_pictures(plistpath):
|
@property
|
||||||
|
def display_folder_path(self):
|
||||||
|
return APERTURE_PATH
|
||||||
|
|
||||||
|
def get_iphoto_or_aperture_pictures(plistpath, photo_class):
|
||||||
|
# The structure of iPhoto and Aperture libraries for the base photo list are excactly the same.
|
||||||
if not io.exists(plistpath):
|
if not io.exists(plistpath):
|
||||||
return []
|
return []
|
||||||
s = io.open(plistpath, 'rt', encoding='utf-8').read()
|
s = io.open(plistpath, 'rt', encoding='utf-8').read()
|
||||||
@@ -72,14 +82,33 @@ def get_iphoto_pictures(plistpath):
|
|||||||
logging.warning("%d invalid XML entities replacement made", count)
|
logging.warning("%d invalid XML entities replacement made", count)
|
||||||
plist = plistlib.readPlistFromBytes(s.encode('utf-8'))
|
plist = plistlib.readPlistFromBytes(s.encode('utf-8'))
|
||||||
result = []
|
result = []
|
||||||
for photo_data in plist['Master Image List'].values():
|
for key, photo_data in plist['Master Image List'].items():
|
||||||
if photo_data['MediaType'] != 'Image':
|
if photo_data['MediaType'] != 'Image':
|
||||||
continue
|
continue
|
||||||
photo_path = Path(photo_data['ImagePath'])
|
photo_path = Path(photo_data['ImagePath'])
|
||||||
photo = IPhoto(photo_path)
|
photo = photo_class(photo_path, key)
|
||||||
result.append(photo)
|
result.append(photo)
|
||||||
return result
|
return result
|
||||||
|
|
||||||
|
def get_iphoto_pictures(plistpath):
|
||||||
|
return get_iphoto_or_aperture_pictures(plistpath, IPhoto)
|
||||||
|
|
||||||
|
def get_aperture_pictures(plistpath):
|
||||||
|
return get_iphoto_or_aperture_pictures(plistpath, AperturePhoto)
|
||||||
|
|
||||||
|
def get_iapps_database_path(prefname):
|
||||||
|
plisturls = proxy.prefValue_inDomain_(prefname, 'com.apple.iApps')
|
||||||
|
if not plisturls:
|
||||||
|
raise directories.InvalidPathError()
|
||||||
|
plistpath = proxy.url2path_(plisturls[0])
|
||||||
|
return Path(plistpath)
|
||||||
|
|
||||||
|
def get_iphoto_database_path():
|
||||||
|
return get_iapps_database_path('iPhotoRecentDatabases')
|
||||||
|
|
||||||
|
def get_aperture_database_path():
|
||||||
|
return get_iapps_database_path('ApertureLibraries')
|
||||||
|
|
||||||
class Directories(directories.Directories):
|
class Directories(directories.Directories):
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
directories.Directories.__init__(self, fileclasses=[Photo])
|
directories.Directories.__init__(self, fileclasses=[Photo])
|
||||||
@@ -88,6 +117,11 @@ class Directories(directories.Directories):
|
|||||||
self.set_state(self.iphoto_libpath[:-1], directories.DirectoryState.Excluded)
|
self.set_state(self.iphoto_libpath[:-1], directories.DirectoryState.Excluded)
|
||||||
except directories.InvalidPathError:
|
except directories.InvalidPathError:
|
||||||
self.iphoto_libpath = None
|
self.iphoto_libpath = None
|
||||||
|
try:
|
||||||
|
self.aperture_libpath = get_aperture_database_path()
|
||||||
|
self.set_state(self.aperture_libpath[:-1], directories.DirectoryState.Excluded)
|
||||||
|
except directories.InvalidPathError:
|
||||||
|
self.aperture_libpath = None
|
||||||
|
|
||||||
def _get_files(self, from_path, j):
|
def _get_files(self, from_path, j):
|
||||||
if from_path == IPHOTO_PATH:
|
if from_path == IPHOTO_PATH:
|
||||||
@@ -98,25 +132,33 @@ class Directories(directories.Directories):
|
|||||||
for photo in photos:
|
for photo in photos:
|
||||||
photo.is_ref = is_ref
|
photo.is_ref = is_ref
|
||||||
return photos
|
return photos
|
||||||
|
elif from_path == APERTURE_PATH:
|
||||||
|
if self.aperture_libpath is None:
|
||||||
|
return []
|
||||||
|
is_ref = self.get_state(from_path) == directories.DirectoryState.Reference
|
||||||
|
photos = get_aperture_pictures(self.aperture_libpath)
|
||||||
|
for photo in photos:
|
||||||
|
photo.is_ref = is_ref
|
||||||
|
return photos
|
||||||
else:
|
else:
|
||||||
return directories.Directories._get_files(self, from_path, j)
|
return directories.Directories._get_files(self, from_path, j)
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def get_subfolders(path):
|
def get_subfolders(path):
|
||||||
if path == IPHOTO_PATH:
|
if path in {IPHOTO_PATH, APERTURE_PATH}:
|
||||||
return []
|
return []
|
||||||
else:
|
else:
|
||||||
return directories.Directories.get_subfolders(path)
|
return directories.Directories.get_subfolders(path)
|
||||||
|
|
||||||
def add_path(self, path):
|
def add_path(self, path):
|
||||||
if path == IPHOTO_PATH:
|
if path in {IPHOTO_PATH, APERTURE_PATH}:
|
||||||
if path not in self:
|
if path not in self:
|
||||||
self._dirs.append(path)
|
self._dirs.append(path)
|
||||||
else:
|
else:
|
||||||
directories.Directories.add_path(self, path)
|
directories.Directories.add_path(self, path)
|
||||||
|
|
||||||
def has_iphoto_path(self):
|
def has_iphoto_path(self):
|
||||||
return any(path == IPHOTO_PATH for path in self._dirs)
|
return any(path in {IPHOTO_PATH, APERTURE_PATH} for path in self._dirs)
|
||||||
|
|
||||||
def has_any_file(self):
|
def has_any_file(self):
|
||||||
# If we don't do that, it causes a hangup in the GUI when we click Start Scanning because
|
# If we don't do that, it causes a hangup in the GUI when we click Start Scanning because
|
||||||
@@ -134,11 +176,12 @@ class DupeGuruPE(DupeGuruBase):
|
|||||||
DupeGuruBase.__init__(self, view, appdata)
|
DupeGuruBase.__init__(self, view, appdata)
|
||||||
self.directories = Directories()
|
self.directories = Directories()
|
||||||
|
|
||||||
def _do_delete(self, j, replace_with_hardlinks):
|
def _do_delete(self, j, replace_with_hardlinks, direct_deletion):
|
||||||
def op(dupe):
|
def op(dupe):
|
||||||
j.add_progress()
|
j.add_progress()
|
||||||
return self._do_delete_dupe(dupe, replace_with_hardlinks)
|
return self._do_delete_dupe(dupe, replace_with_hardlinks, direct_deletion)
|
||||||
|
|
||||||
|
self.deleted_aperture_photos = False
|
||||||
marked = [dupe for dupe in self.results.dupes if self.results.is_marked(dupe)]
|
marked = [dupe for dupe in self.results.dupes if self.results.is_marked(dupe)]
|
||||||
j.start_job(self.results.mark_count, tr("Sending dupes to the Trash"))
|
j.start_job(self.results.mark_count, tr("Sending dupes to the Trash"))
|
||||||
if any(isinstance(dupe, IPhoto) for dupe in marked):
|
if any(isinstance(dupe, IPhoto) for dupe in marked):
|
||||||
@@ -149,29 +192,86 @@ class DupeGuruPE(DupeGuruBase):
|
|||||||
a.select(a.photo_library_album(timeout=0), timeout=0)
|
a.select(a.photo_library_album(timeout=0), timeout=0)
|
||||||
except (CommandError, RuntimeError, ApplicationNotFoundError):
|
except (CommandError, RuntimeError, ApplicationNotFoundError):
|
||||||
pass
|
pass
|
||||||
|
if any(isinstance(dupe, AperturePhoto) for dupe in marked):
|
||||||
|
self.deleted_aperture_photos = True
|
||||||
|
j.add_progress(0, desc=tr("Talking to Aperture. Don't touch it!"))
|
||||||
|
try:
|
||||||
|
a = app('Aperture')
|
||||||
|
a.activate(timeout=0)
|
||||||
|
except (CommandError, RuntimeError, ApplicationNotFoundError):
|
||||||
|
pass
|
||||||
self.results.perform_on_marked(op, True)
|
self.results.perform_on_marked(op, True)
|
||||||
|
|
||||||
def _do_delete_dupe(self, dupe, replace_with_hardlinks):
|
def _do_delete_dupe(self, dupe, replace_with_hardlinks, direct_deletion):
|
||||||
if isinstance(dupe, IPhoto):
|
if isinstance(dupe, IPhoto):
|
||||||
try:
|
try:
|
||||||
a = app('iPhoto')
|
a = app('iPhoto')
|
||||||
[photo] = a.photo_library_album().photos[its.image_path == str(dupe.path)]()
|
album = a.photo_library_album()
|
||||||
|
if album is None:
|
||||||
|
msg = "There are communication problems with iPhoto. Try opening iPhoto first, it might solve it."
|
||||||
|
raise EnvironmentError(msg)
|
||||||
|
[photo] = album.photos[its.image_path == str(dupe.path)]()
|
||||||
a.remove(photo, timeout=0)
|
a.remove(photo, timeout=0)
|
||||||
except ValueError:
|
except ValueError:
|
||||||
msg = "Could not find photo '{}' in iPhoto Library".format(str(dupe.path))
|
msg = "Could not find photo '{}' in iPhoto Library".format(str(dupe.path))
|
||||||
raise EnvironmentError(msg)
|
raise EnvironmentError(msg)
|
||||||
except (CommandError, RuntimeError) as e:
|
except (CommandError, RuntimeError) as e:
|
||||||
raise EnvironmentError(str(e))
|
raise EnvironmentError(str(e))
|
||||||
|
if isinstance(dupe, AperturePhoto):
|
||||||
|
try:
|
||||||
|
a = app('Aperture')
|
||||||
|
# I'm flying blind here. In my own test library, all photos are in an album with the
|
||||||
|
# id "LibraryFolder", so I'm going to guess that it's the case at least most of the
|
||||||
|
# time. As a safeguard, if we don't find any library with that id, we'll use the
|
||||||
|
# first album.
|
||||||
|
# Now, about deleting: All attempts I've made at sending photos to trash failed,
|
||||||
|
# even with normal applescript. So, what we're going to do here is to create a
|
||||||
|
# "dupeGuru Trash" project and tell the user to manually send those photos to trash.
|
||||||
|
libraries = a.libraries()
|
||||||
|
library = first(l for l in libraries if l.id == 'LibraryFolder')
|
||||||
|
if library is None:
|
||||||
|
library = libraries[0]
|
||||||
|
trash_project = a.projects["dupeGuru Trash"]
|
||||||
|
if trash_project.exists():
|
||||||
|
trash_project = trash_project()
|
||||||
|
else:
|
||||||
|
trash_project = library.make(new=k.project, with_properties={k.name: "dupeGuru Trash"})
|
||||||
|
[photo] = library.image_versions[its.id == dupe.db_id]()
|
||||||
|
photo.move(to=trash_project)
|
||||||
|
except (IndexError, ValueError):
|
||||||
|
msg = "Could not find photo '{}' in Aperture Library".format(str(dupe.path))
|
||||||
|
raise EnvironmentError(msg)
|
||||||
|
except (CommandError, RuntimeError) as e:
|
||||||
|
raise EnvironmentError(str(e))
|
||||||
else:
|
else:
|
||||||
DupeGuruBase._do_delete_dupe(self, dupe, replace_with_hardlinks)
|
DupeGuruBase._do_delete_dupe(self, dupe, replace_with_hardlinks, direct_deletion)
|
||||||
|
|
||||||
def _create_file(self, path):
|
def _create_file(self, path):
|
||||||
if (self.directories.iphoto_libpath is not None) and (path in self.directories.iphoto_libpath[:-1]):
|
if (self.directories.iphoto_libpath is not None) and (path in self.directories.iphoto_libpath[:-1]):
|
||||||
return IPhoto(path)
|
if not hasattr(self, 'path2iphoto'):
|
||||||
|
photos = get_iphoto_pictures(self.directories.iphoto_libpath)
|
||||||
|
self.path2iphoto = {p.path: p for p in photos}
|
||||||
|
return self.path2iphoto.get(path)
|
||||||
|
if (self.directories.aperture_libpath is not None) and (path in self.directories.aperture_libpath[:-1]):
|
||||||
|
if not hasattr(self, 'path2aperture'):
|
||||||
|
photos = get_aperture_pictures(self.directories.aperture_libpath)
|
||||||
|
self.path2aperture = {p.path: p for p in photos}
|
||||||
|
return self.path2aperture.get(path)
|
||||||
return DupeGuruBase._create_file(self, path)
|
return DupeGuruBase._create_file(self, path)
|
||||||
|
|
||||||
|
def _job_completed(self, jobid, exc):
|
||||||
|
DupeGuruBase._job_completed(self, jobid, exc)
|
||||||
|
if jobid == JobType.Load:
|
||||||
|
if hasattr(self, 'path2iphoto'):
|
||||||
|
del self.path2iphoto
|
||||||
|
if hasattr(self, 'path2aperture'):
|
||||||
|
del self.path2aperture
|
||||||
|
if jobid == JobType.Delete and self.deleted_aperture_photos:
|
||||||
|
msg = tr("Deleted Aperture photos were sent to a project called \"dupeGuru Trash\".")
|
||||||
|
self.view.show_message(msg)
|
||||||
|
|
||||||
def copy_or_move(self, dupe, copy, destination, dest_type):
|
def copy_or_move(self, dupe, copy, destination, dest_type):
|
||||||
if isinstance(dupe, IPhoto):
|
if isinstance(dupe, (IPhoto, AperturePhoto)):
|
||||||
copy = True
|
copy = True
|
||||||
return DupeGuruBase.copy_or_move(self, dupe, copy, destination, dest_type)
|
return DupeGuruBase.copy_or_move(self, dupe, copy, destination, dest_type)
|
||||||
|
|
||||||
@@ -193,7 +293,36 @@ class DupeGuruPE(DupeGuruBase):
|
|||||||
try:
|
try:
|
||||||
app('iPhoto')
|
app('iPhoto')
|
||||||
except ApplicationNotFoundError:
|
except ApplicationNotFoundError:
|
||||||
self.view.show_message(trmsg("IPhotoAppNotFoundMsg"))
|
self.view.show_message(tr("The iPhoto application couldn't be found."))
|
||||||
return
|
return
|
||||||
DupeGuruBase.start_scanning(self)
|
DupeGuruBase.start_scanning(self)
|
||||||
|
|
||||||
|
class PyDupeGuru(PyDupeGuruBase):
|
||||||
|
def __init__(self):
|
||||||
|
self._init(DupeGuruPE)
|
||||||
|
|
||||||
|
def clearPictureCache(self):
|
||||||
|
self.model.scanner.clear_picture_cache()
|
||||||
|
|
||||||
|
#---Information
|
||||||
|
def getSelectedDupePath(self) -> str:
|
||||||
|
return str(self.model.selected_dupe_path())
|
||||||
|
|
||||||
|
def getSelectedDupeRefPath(self) -> str:
|
||||||
|
return str(self.model.selected_dupe_ref_path())
|
||||||
|
|
||||||
|
#---Properties
|
||||||
|
def setScanType_(self, scan_type: int):
|
||||||
|
try:
|
||||||
|
self.model.scanner.scan_type = [
|
||||||
|
ScanType.FuzzyBlock,
|
||||||
|
ScanType.ExifTimestamp,
|
||||||
|
][scan_type]
|
||||||
|
except IndexError:
|
||||||
|
pass
|
||||||
|
|
||||||
|
def setMatchScaled_(self, match_scaled: bool):
|
||||||
|
self.model.scanner.match_scaled = match_scaled
|
||||||
|
|
||||||
|
def setMinMatchPercentage_(self, percentage: int):
|
||||||
|
self.model.scanner.threshold = percentage
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
# Created By: Virgil Dupras
|
# Created By: Virgil Dupras
|
||||||
# Created On: 2009-05-24
|
# Created On: 2009-05-24
|
||||||
# Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
# Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
#
|
#
|
||||||
# This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
# This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
# which should be included with this package. The terms are also available at
|
# which should be included with this package. The terms are also available at
|
||||||
@@ -11,18 +11,19 @@ import os.path as op
|
|||||||
|
|
||||||
from hscommon import io
|
from hscommon import io
|
||||||
from hscommon.path import Path
|
from hscommon.path import Path
|
||||||
from hscommon.cocoa.objcmin import NSWorkspace
|
from cocoa import proxy
|
||||||
|
|
||||||
|
from core.scanner import ScanType
|
||||||
from core import fs
|
from core import fs
|
||||||
from core.directories import Directories as DirectoriesBase, DirectoryState
|
from core.directories import Directories as DirectoriesBase, DirectoryState
|
||||||
from core_se.app import DupeGuru as DupeGuruBase
|
from core_se.app import DupeGuru as DupeGuruBase
|
||||||
|
from .app import PyDupeGuruBase
|
||||||
|
|
||||||
def is_bundle(str_path):
|
def is_bundle(str_path):
|
||||||
sw = NSWorkspace.sharedWorkspace()
|
uti = proxy.getUTI_(str_path)
|
||||||
uti, error = sw.typeOfFile_error_(str_path, None)
|
if uti is None:
|
||||||
if error is not None:
|
|
||||||
logging.warning('There was an error trying to detect the UTI of %s', str_path)
|
logging.warning('There was an error trying to detect the UTI of %s', str_path)
|
||||||
return sw.type_conformsToType_(uti, 'com.apple.bundle') or sw.type_conformsToType_(uti, 'com.apple.package')
|
return proxy.type_conformsToType_(uti, 'com.apple.bundle') or proxy.type_conformsToType_(uti, 'com.apple.package')
|
||||||
|
|
||||||
class Bundle(fs.Folder):
|
class Bundle(fs.Folder):
|
||||||
@classmethod
|
@classmethod
|
||||||
@@ -71,3 +72,31 @@ class DupeGuru(DupeGuruBase):
|
|||||||
DupeGuruBase.__init__(self, view, appdata)
|
DupeGuruBase.__init__(self, view, appdata)
|
||||||
self.directories = Directories()
|
self.directories = Directories()
|
||||||
|
|
||||||
|
|
||||||
|
class PyDupeGuru(PyDupeGuruBase):
|
||||||
|
def __init__(self):
|
||||||
|
self._init(DupeGuru)
|
||||||
|
|
||||||
|
#---Properties
|
||||||
|
def setMinMatchPercentage_(self, percentage: int):
|
||||||
|
self.model.scanner.min_match_percentage = int(percentage)
|
||||||
|
|
||||||
|
def setScanType_(self, scan_type: int):
|
||||||
|
try:
|
||||||
|
self.model.scanner.scan_type = [
|
||||||
|
ScanType.Filename,
|
||||||
|
ScanType.Contents,
|
||||||
|
ScanType.Folders,
|
||||||
|
][scan_type]
|
||||||
|
except IndexError:
|
||||||
|
pass
|
||||||
|
|
||||||
|
def setWordWeighting_(self, words_are_weighted: bool):
|
||||||
|
self.model.scanner.word_weighting = words_are_weighted
|
||||||
|
|
||||||
|
def setMatchSimilarWords_(self, match_similar_words: bool):
|
||||||
|
self.model.scanner.match_similar_words = match_similar_words
|
||||||
|
|
||||||
|
def setSizeThreshold_(self, size_threshold: int):
|
||||||
|
self.model.scanner.size_threshold = size_threshold
|
||||||
|
|
||||||
|
|||||||
30
cocoa/inter/deletion_options.py
Normal file
30
cocoa/inter/deletion_options.py
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
# Created On: 2012-05-30
|
||||||
|
# Copyright 2012 Hardcoded Software (http://www.hardcoded.net)
|
||||||
|
#
|
||||||
|
# This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
||||||
|
# which should be included with this package. The terms are also available at
|
||||||
|
# http://www.hardcoded.net/licenses/bsd_license
|
||||||
|
|
||||||
|
from objp.util import dontwrap
|
||||||
|
from cocoa.inter import PyGUIObject, GUIObjectView
|
||||||
|
|
||||||
|
class DeletionOptionsView(GUIObjectView):
|
||||||
|
def updateMsg_(self, msg: str): pass
|
||||||
|
def show(self) -> bool: pass
|
||||||
|
|
||||||
|
class PyDeletionOptions(PyGUIObject):
|
||||||
|
def setHardlink_(self, hardlink: bool):
|
||||||
|
self.model.hardlink = hardlink
|
||||||
|
|
||||||
|
def setDirect_(self, direct: bool):
|
||||||
|
self.model.direct = direct
|
||||||
|
|
||||||
|
#--- model --> view
|
||||||
|
@dontwrap
|
||||||
|
def update_msg(self, msg):
|
||||||
|
self.callback.updateMsg_(msg)
|
||||||
|
|
||||||
|
@dontwrap
|
||||||
|
def show(self):
|
||||||
|
return self.callback.show()
|
||||||
|
|
||||||
@@ -1,13 +1,11 @@
|
|||||||
from hscommon.cocoa.inter import signature, PyGUIObject
|
from cocoa.inter import PyGUIObject, GUIObjectView
|
||||||
|
|
||||||
from core.gui.details_panel import DetailsPanel
|
class DetailsPanelView(GUIObjectView):
|
||||||
|
pass
|
||||||
|
|
||||||
class PyDetailsPanel(PyGUIObject):
|
class PyDetailsPanel(PyGUIObject):
|
||||||
py_class = DetailsPanel
|
def numberOfRows(self) -> int:
|
||||||
@signature('i@:')
|
return self.model.row_count()
|
||||||
def numberOfRows(self):
|
|
||||||
return self.py.row_count()
|
|
||||||
|
|
||||||
@signature('@@:@i')
|
def valueForColumn_row_(self, column: str, row: int) -> object:
|
||||||
def valueForColumn_row_(self, column, row):
|
return self.model.row(row)[int(column)]
|
||||||
return self.py.row(row)[int(column)]
|
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user