mirror of
https://github.com/noDRM/DeDRM_tools.git
synced 2025-01-12 11:24:43 +06:00
tools v6.0.4
This commit is contained in:
parent
51919284ca
commit
cd2d74601a
Binary file not shown.
@ -24,7 +24,7 @@
|
|||||||
<key>CFBundleExecutable</key>
|
<key>CFBundleExecutable</key>
|
||||||
<string>droplet</string>
|
<string>droplet</string>
|
||||||
<key>CFBundleGetInfoString</key>
|
<key>CFBundleGetInfoString</key>
|
||||||
<string>DeDRM AppleScript 6.0.3. Written 2010–2013 by Apprentice Alf and others.</string>
|
<string>DeDRM AppleScript 6.0.4. Written 2010–2013 by Apprentice Alf and others.</string>
|
||||||
<key>CFBundleIconFile</key>
|
<key>CFBundleIconFile</key>
|
||||||
<string>DeDRM</string>
|
<string>DeDRM</string>
|
||||||
<key>CFBundleIdentifier</key>
|
<key>CFBundleIdentifier</key>
|
||||||
@ -36,7 +36,7 @@
|
|||||||
<key>CFBundlePackageType</key>
|
<key>CFBundlePackageType</key>
|
||||||
<string>APPL</string>
|
<string>APPL</string>
|
||||||
<key>CFBundleShortVersionString</key>
|
<key>CFBundleShortVersionString</key>
|
||||||
<string>6.0.3</string>
|
<string>6.0.4</string>
|
||||||
<key>CFBundleSignature</key>
|
<key>CFBundleSignature</key>
|
||||||
<string>dplt</string>
|
<string>dplt</string>
|
||||||
<key>LSRequiresCarbon</key>
|
<key>LSRequiresCarbon</key>
|
||||||
@ -52,7 +52,7 @@
|
|||||||
<key>positionOfDivider</key>
|
<key>positionOfDivider</key>
|
||||||
<real>0.0</real>
|
<real>0.0</real>
|
||||||
<key>savedFrame</key>
|
<key>savedFrame</key>
|
||||||
<string>320 125 1002 753 0 0 1440 878 </string>
|
<string>85 100 1002 753 0 0 1440 878 </string>
|
||||||
<key>selectedTabView</key>
|
<key>selectedTabView</key>
|
||||||
<string>event log</string>
|
<string>event log</string>
|
||||||
</dict>
|
</dict>
|
||||||
|
Binary file not shown.
@ -54,8 +54,9 @@ from __future__ import with_statement
|
|||||||
# 5.0 - Extraction of info from Kindle for PC/Mac moved into kindlekey.py
|
# 5.0 - Extraction of info from Kindle for PC/Mac moved into kindlekey.py
|
||||||
# - tweaked GetDecryptedBook interface to leave passed parameters unchanged
|
# - tweaked GetDecryptedBook interface to leave passed parameters unchanged
|
||||||
# 5.1 - moved unicode_argv call inside main for Windows DeDRM compatibility
|
# 5.1 - moved unicode_argv call inside main for Windows DeDRM compatibility
|
||||||
|
# 5.2 - Fixed error in command line processing of unicode arguments
|
||||||
|
|
||||||
__version__ = '5.1'
|
__version__ = '5.2'
|
||||||
|
|
||||||
|
|
||||||
import sys, os, re
|
import sys, os, re
|
||||||
@ -283,7 +284,7 @@ def cli_main():
|
|||||||
print u"K4MobiDeDrm v{0}.\nCopyright © 2008-2013 The Dark Reverser et al.".format(__version__)
|
print u"K4MobiDeDrm v{0}.\nCopyright © 2008-2013 The Dark Reverser et al.".format(__version__)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
opts, args = getopt.getopt(sys.argv[1:], "k:p:s:")
|
opts, args = getopt.getopt(argv[1:], "k:p:s:")
|
||||||
except getopt.GetoptError, err:
|
except getopt.GetoptError, err:
|
||||||
print u"Error in options or arguments: {0}".format(err.args[0])
|
print u"Error in options or arguments: {0}".format(err.args[0])
|
||||||
usage(progname)
|
usage(progname)
|
||||||
|
@ -68,9 +68,10 @@
|
|||||||
# 0.38 - Unicode used wherever possible, cope with absent alfcrypto
|
# 0.38 - Unicode used wherever possible, cope with absent alfcrypto
|
||||||
# 0.39 - Fixed problem with TEXtREAd and getBookType interface
|
# 0.39 - Fixed problem with TEXtREAd and getBookType interface
|
||||||
# 0.40 - moved unicode_argv call inside main for Windows DeDRM compatibility
|
# 0.40 - moved unicode_argv call inside main for Windows DeDRM compatibility
|
||||||
|
# 0.41 - Fixed potential unicode problem in command line calls
|
||||||
|
|
||||||
|
|
||||||
__version__ = u"0.40"
|
__version__ = u"0.41"
|
||||||
|
|
||||||
import sys
|
import sys
|
||||||
import os
|
import os
|
||||||
@ -514,7 +515,7 @@ def cli_main():
|
|||||||
print u"MobiDeDrm v{0}.\nCopyright © 2008-2012 The Dark Reverser et al.".format(__version__)
|
print u"MobiDeDrm v{0}.\nCopyright © 2008-2012 The Dark Reverser et al.".format(__version__)
|
||||||
print u"Removes protection from Kindle/Mobipocket, Kindle/KF8 and Kindle/Print Replica ebooks"
|
print u"Removes protection from Kindle/Mobipocket, Kindle/KF8 and Kindle/Print Replica ebooks"
|
||||||
print u"Usage:"
|
print u"Usage:"
|
||||||
print u" {0} <infile> <outfile> [<Comma separated list of PIDs to try>]".format(os.path.basename(sys.argv[0]))
|
print u" {0} <infile> <outfile> [<Comma separated list of PIDs to try>]".format(progname)
|
||||||
return 1
|
return 1
|
||||||
else:
|
else:
|
||||||
infile = argv[1]
|
infile = argv[1]
|
||||||
|
@ -6,8 +6,9 @@
|
|||||||
|
|
||||||
# Changelog
|
# Changelog
|
||||||
# 4.9 - moved unicode_argv call inside main for Windows DeDRM compatibility
|
# 4.9 - moved unicode_argv call inside main for Windows DeDRM compatibility
|
||||||
|
# 5.0 - Fixed potential unicode problem with command line interface
|
||||||
|
|
||||||
__version__ = '4.9'
|
__version__ = '5.0'
|
||||||
|
|
||||||
import sys
|
import sys
|
||||||
import os, csv, getopt
|
import os, csv, getopt
|
||||||
@ -451,7 +452,7 @@ def cli_main():
|
|||||||
print u"TopazExtract v{0}.".format(__version__)
|
print u"TopazExtract v{0}.".format(__version__)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
opts, args = getopt.getopt(sys.argv[1:], "k:p:s:x")
|
opts, args = getopt.getopt(argv[1:], "k:p:s:x")
|
||||||
except getopt.GetoptError, err:
|
except getopt.GetoptError, err:
|
||||||
print u"Error in options or arguments: {0}".format(err.args[0])
|
print u"Error in options or arguments: {0}".format(err.args[0])
|
||||||
usage(progname)
|
usage(progname)
|
||||||
|
@ -9,8 +9,9 @@
|
|||||||
# 6.0.1 - Bug Fixes for Windows App
|
# 6.0.1 - Bug Fixes for Windows App
|
||||||
# 6.0.2 - Fixed problem with spaces in paths and the bat file
|
# 6.0.2 - Fixed problem with spaces in paths and the bat file
|
||||||
# 6.0.3 - Fix for Windows non-ascii user names
|
# 6.0.3 - Fix for Windows non-ascii user names
|
||||||
|
# 6.0.4 - Fix for other potential unicode problems
|
||||||
|
|
||||||
__version__ = '6.0.3'
|
__version__ = '6.0.4'
|
||||||
|
|
||||||
import sys
|
import sys
|
||||||
import os, os.path
|
import os, os.path
|
||||||
|
@ -54,8 +54,9 @@ from __future__ import with_statement
|
|||||||
# 5.0 - Extraction of info from Kindle for PC/Mac moved into kindlekey.py
|
# 5.0 - Extraction of info from Kindle for PC/Mac moved into kindlekey.py
|
||||||
# - tweaked GetDecryptedBook interface to leave passed parameters unchanged
|
# - tweaked GetDecryptedBook interface to leave passed parameters unchanged
|
||||||
# 5.1 - moved unicode_argv call inside main for Windows DeDRM compatibility
|
# 5.1 - moved unicode_argv call inside main for Windows DeDRM compatibility
|
||||||
|
# 5.2 - Fixed error in command line processing of unicode arguments
|
||||||
|
|
||||||
__version__ = '5.1'
|
__version__ = '5.2'
|
||||||
|
|
||||||
|
|
||||||
import sys, os, re
|
import sys, os, re
|
||||||
@ -283,7 +284,7 @@ def cli_main():
|
|||||||
print u"K4MobiDeDrm v{0}.\nCopyright © 2008-2013 The Dark Reverser et al.".format(__version__)
|
print u"K4MobiDeDrm v{0}.\nCopyright © 2008-2013 The Dark Reverser et al.".format(__version__)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
opts, args = getopt.getopt(sys.argv[1:], "k:p:s:")
|
opts, args = getopt.getopt(argv[1:], "k:p:s:")
|
||||||
except getopt.GetoptError, err:
|
except getopt.GetoptError, err:
|
||||||
print u"Error in options or arguments: {0}".format(err.args[0])
|
print u"Error in options or arguments: {0}".format(err.args[0])
|
||||||
usage(progname)
|
usage(progname)
|
||||||
|
@ -68,9 +68,10 @@
|
|||||||
# 0.38 - Unicode used wherever possible, cope with absent alfcrypto
|
# 0.38 - Unicode used wherever possible, cope with absent alfcrypto
|
||||||
# 0.39 - Fixed problem with TEXtREAd and getBookType interface
|
# 0.39 - Fixed problem with TEXtREAd and getBookType interface
|
||||||
# 0.40 - moved unicode_argv call inside main for Windows DeDRM compatibility
|
# 0.40 - moved unicode_argv call inside main for Windows DeDRM compatibility
|
||||||
|
# 0.41 - Fixed potential unicode problem in command line calls
|
||||||
|
|
||||||
|
|
||||||
__version__ = u"0.40"
|
__version__ = u"0.41"
|
||||||
|
|
||||||
import sys
|
import sys
|
||||||
import os
|
import os
|
||||||
@ -514,7 +515,7 @@ def cli_main():
|
|||||||
print u"MobiDeDrm v{0}.\nCopyright © 2008-2012 The Dark Reverser et al.".format(__version__)
|
print u"MobiDeDrm v{0}.\nCopyright © 2008-2012 The Dark Reverser et al.".format(__version__)
|
||||||
print u"Removes protection from Kindle/Mobipocket, Kindle/KF8 and Kindle/Print Replica ebooks"
|
print u"Removes protection from Kindle/Mobipocket, Kindle/KF8 and Kindle/Print Replica ebooks"
|
||||||
print u"Usage:"
|
print u"Usage:"
|
||||||
print u" {0} <infile> <outfile> [<Comma separated list of PIDs to try>]".format(os.path.basename(sys.argv[0]))
|
print u" {0} <infile> <outfile> [<Comma separated list of PIDs to try>]".format(progname)
|
||||||
return 1
|
return 1
|
||||||
else:
|
else:
|
||||||
infile = argv[1]
|
infile = argv[1]
|
||||||
|
@ -6,8 +6,9 @@
|
|||||||
|
|
||||||
# Changelog
|
# Changelog
|
||||||
# 4.9 - moved unicode_argv call inside main for Windows DeDRM compatibility
|
# 4.9 - moved unicode_argv call inside main for Windows DeDRM compatibility
|
||||||
|
# 5.0 - Fixed potential unicode problem with command line interface
|
||||||
|
|
||||||
__version__ = '4.9'
|
__version__ = '5.0'
|
||||||
|
|
||||||
import sys
|
import sys
|
||||||
import os, csv, getopt
|
import os, csv, getopt
|
||||||
@ -451,7 +452,7 @@ def cli_main():
|
|||||||
print u"TopazExtract v{0}.".format(__version__)
|
print u"TopazExtract v{0}.".format(__version__)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
opts, args = getopt.getopt(sys.argv[1:], "k:p:s:x")
|
opts, args = getopt.getopt(argv[1:], "k:p:s:x")
|
||||||
except getopt.GetoptError, err:
|
except getopt.GetoptError, err:
|
||||||
print u"Error in options or arguments: {0}".format(err.args[0])
|
print u"Error in options or arguments: {0}".format(err.args[0])
|
||||||
usage(progname)
|
usage(progname)
|
||||||
|
Binary file not shown.
@ -29,13 +29,15 @@ __docformat__ = 'restructuredtext en'
|
|||||||
# 6.0.1 - Bug Fixes for Windows App, Kindle for Mac and Windows Adobe Digital Editions
|
# 6.0.1 - Bug Fixes for Windows App, Kindle for Mac and Windows Adobe Digital Editions
|
||||||
# 6.0.2 - Restored call to Wine to get Kindle for PC keys, added for ADE
|
# 6.0.2 - Restored call to Wine to get Kindle for PC keys, added for ADE
|
||||||
# 6.0.3 - Fixes for Kindle for Mac and Windows non-ascii user names
|
# 6.0.3 - Fixes for Kindle for Mac and Windows non-ascii user names
|
||||||
|
# 6.0.4 - Fixes for stand-alone scripts and applications
|
||||||
|
# and pdb files in plugin and initial conversion of prefs.
|
||||||
|
|
||||||
"""
|
"""
|
||||||
Decrypt DRMed ebooks.
|
Decrypt DRMed ebooks.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
PLUGIN_NAME = u"DeDRM"
|
PLUGIN_NAME = u"DeDRM"
|
||||||
PLUGIN_VERSION_TUPLE = (6, 0, 3)
|
PLUGIN_VERSION_TUPLE = (6, 0, 4)
|
||||||
PLUGIN_VERSION = u".".join([unicode(str(x)) for x in PLUGIN_VERSION_TUPLE])
|
PLUGIN_VERSION = u".".join([unicode(str(x)) for x in PLUGIN_VERSION_TUPLE])
|
||||||
# Include an html helpfile in the plugin's zipfile with the following name.
|
# Include an html helpfile in the plugin's zipfile with the following name.
|
||||||
RESOURCE_NAME = PLUGIN_NAME + '_Help.htm'
|
RESOURCE_NAME = PLUGIN_NAME + '_Help.htm'
|
||||||
@ -427,7 +429,7 @@ class DeDRM(FileTypePlugin):
|
|||||||
import calibre_plugins.dedrm.prefs as prefs
|
import calibre_plugins.dedrm.prefs as prefs
|
||||||
import calibre_plugins.dedrm.erdr2pml
|
import calibre_plugins.dedrm.erdr2pml
|
||||||
|
|
||||||
dedrmrefs = prefs.DeDRM_Prefs()
|
dedrmprefs = prefs.DeDRM_Prefs()
|
||||||
# Attempt to decrypt epub with each encryption key (generated or provided).
|
# Attempt to decrypt epub with each encryption key (generated or provided).
|
||||||
for keyname, userkey in dedrmprefs['ereaderkeys'].items():
|
for keyname, userkey in dedrmprefs['ereaderkeys'].items():
|
||||||
keyname_masked = u"".join((u'X' if (x.isdigit()) else x) for x in keyname)
|
keyname_masked = u"".join((u'X' if (x.isdigit()) else x) for x in keyname)
|
||||||
|
@ -54,8 +54,9 @@ from __future__ import with_statement
|
|||||||
# 5.0 - Extraction of info from Kindle for PC/Mac moved into kindlekey.py
|
# 5.0 - Extraction of info from Kindle for PC/Mac moved into kindlekey.py
|
||||||
# - tweaked GetDecryptedBook interface to leave passed parameters unchanged
|
# - tweaked GetDecryptedBook interface to leave passed parameters unchanged
|
||||||
# 5.1 - moved unicode_argv call inside main for Windows DeDRM compatibility
|
# 5.1 - moved unicode_argv call inside main for Windows DeDRM compatibility
|
||||||
|
# 5.2 - Fixed error in command line processing of unicode arguments
|
||||||
|
|
||||||
__version__ = '5.1'
|
__version__ = '5.2'
|
||||||
|
|
||||||
|
|
||||||
import sys, os, re
|
import sys, os, re
|
||||||
@ -283,7 +284,7 @@ def cli_main():
|
|||||||
print u"K4MobiDeDrm v{0}.\nCopyright © 2008-2013 The Dark Reverser et al.".format(__version__)
|
print u"K4MobiDeDrm v{0}.\nCopyright © 2008-2013 The Dark Reverser et al.".format(__version__)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
opts, args = getopt.getopt(sys.argv[1:], "k:p:s:")
|
opts, args = getopt.getopt(argv[1:], "k:p:s:")
|
||||||
except getopt.GetoptError, err:
|
except getopt.GetoptError, err:
|
||||||
print u"Error in options or arguments: {0}".format(err.args[0])
|
print u"Error in options or arguments: {0}".format(err.args[0])
|
||||||
usage(progname)
|
usage(progname)
|
||||||
|
@ -68,9 +68,10 @@
|
|||||||
# 0.38 - Unicode used wherever possible, cope with absent alfcrypto
|
# 0.38 - Unicode used wherever possible, cope with absent alfcrypto
|
||||||
# 0.39 - Fixed problem with TEXtREAd and getBookType interface
|
# 0.39 - Fixed problem with TEXtREAd and getBookType interface
|
||||||
# 0.40 - moved unicode_argv call inside main for Windows DeDRM compatibility
|
# 0.40 - moved unicode_argv call inside main for Windows DeDRM compatibility
|
||||||
|
# 0.41 - Fixed potential unicode problem in command line calls
|
||||||
|
|
||||||
|
|
||||||
__version__ = u"0.40"
|
__version__ = u"0.41"
|
||||||
|
|
||||||
import sys
|
import sys
|
||||||
import os
|
import os
|
||||||
@ -514,7 +515,7 @@ def cli_main():
|
|||||||
print u"MobiDeDrm v{0}.\nCopyright © 2008-2012 The Dark Reverser et al.".format(__version__)
|
print u"MobiDeDrm v{0}.\nCopyright © 2008-2012 The Dark Reverser et al.".format(__version__)
|
||||||
print u"Removes protection from Kindle/Mobipocket, Kindle/KF8 and Kindle/Print Replica ebooks"
|
print u"Removes protection from Kindle/Mobipocket, Kindle/KF8 and Kindle/Print Replica ebooks"
|
||||||
print u"Usage:"
|
print u"Usage:"
|
||||||
print u" {0} <infile> <outfile> [<Comma separated list of PIDs to try>]".format(os.path.basename(sys.argv[0]))
|
print u" {0} <infile> <outfile> [<Comma separated list of PIDs to try>]".format(progname)
|
||||||
return 1
|
return 1
|
||||||
else:
|
else:
|
||||||
infile = argv[1]
|
infile = argv[1]
|
||||||
|
@ -231,21 +231,20 @@ def convertprefs(always = False):
|
|||||||
dedrmprefs.addnamedvaluetoprefs('bandnkeys', name, value)
|
dedrmprefs.addnamedvaluetoprefs('bandnkeys', name, value)
|
||||||
addedkeycount = len(dedrmprefs['bandnkeys'])-priorkeycount
|
addedkeycount = len(dedrmprefs['bandnkeys'])-priorkeycount
|
||||||
if addedkeycount > 0:
|
if addedkeycount > 0:
|
||||||
print u"{0} v{1}: {2:d} Barnes and Noble {3} imported from config folder.".format(PLUGIN_NAME, PLUGIN_VERSION, ignoblecount, u"key file" if ignoblecount==1 else u"key files")
|
print u"{0} v{1}: {2:d} Barnes and Noble {3} imported from config folder.".format(PLUGIN_NAME, PLUGIN_VERSION, addedkeycount, u"key file" if addedkeycount==1 else u"key files")
|
||||||
# Make the json write all the prefs to disk
|
# Make the json write all the prefs to disk
|
||||||
dedrmprefs.writeprefs(False)
|
dedrmprefs.writeprefs(False)
|
||||||
|
|
||||||
# get any .der files in the config dir
|
# get any .der files in the config dir
|
||||||
priorkeycount = len(dedrmprefs['adeptkeys'])
|
priorkeycount = len(dedrmprefs['adeptkeys'])
|
||||||
adeptfilekeys = getConfigFiles('.der','hex')
|
adeptfilekeys = getConfigFiles('.der','hex')
|
||||||
ineptcount = addConfigFiles('.der', 'adeptkeys')
|
|
||||||
for keypair in adeptfilekeys:
|
for keypair in adeptfilekeys:
|
||||||
name = keypair[0]
|
name = keypair[0]
|
||||||
value = keypair[1]
|
value = keypair[1]
|
||||||
dedrmprefs.addnamedvaluetoprefs('adeptkeys', name, value)
|
dedrmprefs.addnamedvaluetoprefs('adeptkeys', name, value)
|
||||||
addedkeycount = len(dedrmprefs['adeptkeys'])-priorkeycount
|
addedkeycount = len(dedrmprefs['adeptkeys'])-priorkeycount
|
||||||
if addedkeycount > 0:
|
if addedkeycount > 0:
|
||||||
print u"{0} v{1}: {2:d} Adobe Adept {3} imported from config folder.".format(PLUGIN_NAME, PLUGIN_VERSION, ineptcount, u"keyfile" if ineptcount==1 else u"keyfiles")
|
print u"{0} v{1}: {2:d} Adobe Adept {3} imported from config folder.".format(PLUGIN_NAME, PLUGIN_VERSION, addedkeycount, u"keyfile" if addedkeycount==1 else u"keyfiles")
|
||||||
# Make the json write all the prefs to disk
|
# Make the json write all the prefs to disk
|
||||||
dedrmprefs.writeprefs(False)
|
dedrmprefs.writeprefs(False)
|
||||||
|
|
||||||
@ -280,7 +279,7 @@ def convertprefs(always = False):
|
|||||||
if addedserialcount > 0:
|
if addedserialcount > 0:
|
||||||
print u"{0} v{1}: {2:d} {3} imported from Kindle plugin preferences".format(PLUGIN_NAME, PLUGIN_VERSION, addedserialcount, u"serial number" if addedserialcount==1 else u"serial numbers")
|
print u"{0} v{1}: {2:d} {3} imported from Kindle plugin preferences".format(PLUGIN_NAME, PLUGIN_VERSION, addedserialcount, u"serial number" if addedserialcount==1 else u"serial numbers")
|
||||||
try:
|
try:
|
||||||
if kindleprefs['wineprefix'] != "":
|
if 'wineprefix' in kindleprefs and kindleprefs['wineprefix'] != "":
|
||||||
dedrmprefs.set('adobewineprefix',kindleprefs['wineprefix'])
|
dedrmprefs.set('adobewineprefix',kindleprefs['wineprefix'])
|
||||||
dedrmprefs.set('kindlewineprefix',kindleprefs['wineprefix'])
|
dedrmprefs.set('kindlewineprefix',kindleprefs['wineprefix'])
|
||||||
print u"{0} v{1}: WINEPREFIX ‘(2)’ imported from Kindle plugin preferences".format(PLUGIN_NAME, PLUGIN_VERSION, kindleprefs['wineprefix'])
|
print u"{0} v{1}: WINEPREFIX ‘(2)’ imported from Kindle plugin preferences".format(PLUGIN_NAME, PLUGIN_VERSION, kindleprefs['wineprefix'])
|
||||||
|
@ -6,8 +6,9 @@
|
|||||||
|
|
||||||
# Changelog
|
# Changelog
|
||||||
# 4.9 - moved unicode_argv call inside main for Windows DeDRM compatibility
|
# 4.9 - moved unicode_argv call inside main for Windows DeDRM compatibility
|
||||||
|
# 5.0 - Fixed potential unicode problem with command line interface
|
||||||
|
|
||||||
__version__ = '4.9'
|
__version__ = '5.0'
|
||||||
|
|
||||||
import sys
|
import sys
|
||||||
import os, csv, getopt
|
import os, csv, getopt
|
||||||
@ -451,7 +452,7 @@ def cli_main():
|
|||||||
print u"TopazExtract v{0}.".format(__version__)
|
print u"TopazExtract v{0}.".format(__version__)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
opts, args = getopt.getopt(sys.argv[1:], "k:p:s:x")
|
opts, args = getopt.getopt(argv[1:], "k:p:s:x")
|
||||||
except getopt.GetoptError, err:
|
except getopt.GetoptError, err:
|
||||||
print u"Error in options or arguments: {0}".format(err.args[0])
|
print u"Error in options or arguments: {0}".format(err.args[0])
|
||||||
usage(progname)
|
usage(progname)
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
Welcome to the tools!
|
Welcome to the tools!
|
||||||
=====================
|
=====================
|
||||||
|
|
||||||
This ReadMe_First.txt is meant to give users a quick overview of what is available and how to get started. This document is part of the Tools v6.0.3 archive from Apprentice Alf's Blog: http://apprenticealf.wordpress.com/
|
This ReadMe_First.txt is meant to give users a quick overview of what is available and how to get started. This document is part of the Tools v6.0.4 archive from Apprentice Alf's Blog: http://apprenticealf.wordpress.com/
|
||||||
|
|
||||||
The is archive includes tools to remove DRM from:
|
The is archive includes tools to remove DRM from:
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user