mirror of
				https://github.com/kovidgoyal/calibre.git
				synced 2025-10-26 00:02:25 -04:00 
			
		
		
		
	...
This commit is contained in:
		
							parent
							
								
									ccba32d733
								
							
						
					
					
						commit
						abb8d5adc1
					
				| @ -93,7 +93,7 @@ def freeze(): | |||||||
|                 'dateutil', 'dns', 'email'] |                 'dateutil', 'dns', 'email'] | ||||||
| 
 | 
 | ||||||
|     includes += ['calibre.web.feeds.recipes.'+r for r in recipe_modules] |     includes += ['calibre.web.feeds.recipes.'+r for r in recipe_modules] | ||||||
|     includes += [x.split('/')[-1].rpartition('.')[0] for x in \ |     includes += ['calibre.gui2.convert.'+x.split('/')[-1].rpartition('.')[0] for x in \ | ||||||
|             glob.glob('src/calibre/gui2/convert/*.py')] |             glob.glob('src/calibre/gui2/convert/*.py')] | ||||||
| 
 | 
 | ||||||
|     LOADER = '/tmp/loader.py' |     LOADER = '/tmp/loader.py' | ||||||
|  | |||||||
| @ -7,6 +7,7 @@ device. This class handles device detection. | |||||||
| ''' | ''' | ||||||
| 
 | 
 | ||||||
| import os, subprocess, time, re | import os, subprocess, time, re | ||||||
|  | from itertools import repeat | ||||||
| 
 | 
 | ||||||
| from calibre.devices.interface import DevicePlugin | from calibre.devices.interface import DevicePlugin | ||||||
| from calibre.devices.errors import DeviceError | from calibre.devices.errors import DeviceError | ||||||
| @ -290,6 +291,72 @@ class Device(DeviceConfig, DevicePlugin): | |||||||
|         self._card_a_prefix = get_card_prefix(card_a_pat) |         self._card_a_prefix = get_card_prefix(card_a_pat) | ||||||
|         self._card_b_prefix = get_card_prefix(card_b_pat) |         self._card_b_prefix = get_card_prefix(card_b_pat) | ||||||
| 
 | 
 | ||||||
|  |     def find_device_nodes(self): | ||||||
|  | 
 | ||||||
|  |         def walk(base): | ||||||
|  |             base = os.path.abspath(os.path.realpath(base)) | ||||||
|  |             for x in os.listdir(base): | ||||||
|  |                 p = os.path.join(base, x) | ||||||
|  |                 if os.path.islink(p) or not os.access(p, os.R_OK): | ||||||
|  |                     continue | ||||||
|  |                 isfile = os.path.isfile(p) | ||||||
|  |                 yield p, isfile | ||||||
|  |                 if not isfile: | ||||||
|  |                     for y, q in walk(p): | ||||||
|  |                         yield y, q | ||||||
|  | 
 | ||||||
|  |         def raw2num(raw): | ||||||
|  |             raw = raw.lower() | ||||||
|  |             if not raw.startswith('0x'): | ||||||
|  |                 raw = '0x' + raw | ||||||
|  |             return int(raw, 16) | ||||||
|  | 
 | ||||||
|  |         # Find device node based on vendor, product and bcd | ||||||
|  |         d, j = os.path.dirname, os.path.join | ||||||
|  |         usb_dir = None | ||||||
|  | 
 | ||||||
|  |         def test(val, attr): | ||||||
|  |             q = getattr(self, attr) | ||||||
|  |             if q is None: return True | ||||||
|  |             return q == val or val in q | ||||||
|  | 
 | ||||||
|  |         for x, isfile in walk('/sys/devices'): | ||||||
|  |             if isfile and x.endswith('idVendor'): | ||||||
|  |                 usb_dir = d(x) | ||||||
|  |                 for y in ('idProduct',): | ||||||
|  |                     if not os.access(j(usb_dir, y), os.R_OK): | ||||||
|  |                         usb_dir = None | ||||||
|  |                         continue | ||||||
|  |                 e = lambda q : raw2num(open(j(usb_dir, q)).read()) | ||||||
|  |                 ven, prod = map(e, ('idVendor', 'idProduct')) | ||||||
|  |                 if not (test(ven, 'VENDOR_ID') and test(prod, 'PRODUCT_ID')): | ||||||
|  |                     usb_dir = None | ||||||
|  |                     continue | ||||||
|  |                 if self.BCD is not None: | ||||||
|  |                     if not os.access(j(usb_dir, 'bcdDevice'), os.R_OK) or \ | ||||||
|  |                             not test(e('bcdDevice'), 'BCD'): | ||||||
|  |                         usb_dir = None | ||||||
|  |                         continue | ||||||
|  |                     else: | ||||||
|  |                         break | ||||||
|  |                 else: | ||||||
|  |                     break | ||||||
|  |         if usb_dir is None: | ||||||
|  |             raise DeviceError(_('Unable to detect the %s disk drive.') | ||||||
|  |                     %self.__class__.__name__) | ||||||
|  | 
 | ||||||
|  |         devnodes = [] | ||||||
|  |         for x, isfile in walk(usb_dir): | ||||||
|  |             if not isfile and '/block/' in x: | ||||||
|  |                 parts = x.split('/') | ||||||
|  |                 idx = parts.index('block') | ||||||
|  |                 if idx == len(parts)-2: | ||||||
|  |                     devnodes.append(parts[idx+1]) | ||||||
|  |         devnodes.sort() | ||||||
|  |         devnodes += list(repeat(None, 2)) | ||||||
|  |         return devnodes[:3] | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|     def open_linux(self): |     def open_linux(self): | ||||||
|         import dbus |         import dbus | ||||||
|         bus = dbus.SystemBus() |         bus = dbus.SystemBus() | ||||||
|  | |||||||
| @ -23,7 +23,7 @@ class DRMError(ValueError): | |||||||
|     pass |     pass | ||||||
| 
 | 
 | ||||||
| BOOK_EXTENSIONS = ['lrf', 'rar', 'zip', 'rtf', 'lit', 'txt', 'htm', 'xhtm', | BOOK_EXTENSIONS = ['lrf', 'rar', 'zip', 'rtf', 'lit', 'txt', 'htm', 'xhtm', | ||||||
|                    'html', 'xhtml', 'pdf', 'prc', 'mobi', 'azw', |                    'html', 'xhtml', 'pdf', 'prc', 'mobi', 'azw', 'doc', | ||||||
|                    'epub', 'fb2', 'djvu', 'lrx', 'cbr', 'cbz', 'oebzip', |                    'epub', 'fb2', 'djvu', 'lrx', 'cbr', 'cbz', 'oebzip', | ||||||
|                    'rb', 'imp', 'odt'] |                    'rb', 'imp', 'odt'] | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user