add mtp eta
This commit is contained in:
		
							parent
							
								
									1a5c66edd3
								
							
						
					
					
						commit
						5d6c61a861
					
				
							
								
								
									
										6
									
								
								.vscode/tasks.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.vscode/tasks.json
									
									
									
									
										vendored
									
									
								
							| @ -8,8 +8,10 @@ | |||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|             "label": "no_dbg", |             "label": "no_dbg", | ||||||
|             "command": "${config:python.pythonPath} -m copyparty -ed -emp -e2dsa -e2ts -a ed:wark -v srv::r:aed:cnodupe -v dist:dist:r ;exit 1", |             "type": "shell", | ||||||
|             "type": "shell" |             "command": "${config:python.pythonPath} -m copyparty -ed -emp -e2dsa -e2ts -a ed:wark -v srv::r:aed:cnodupe -v dist:dist:r ;exit 1" | ||||||
|  |             // -v ~/Music/mt:mt:r:cmtp=.bpm=~/dev/copyparty/bin/mtag/audio-bpm.py:cmtp=key=~/dev/copyparty/bin/mtag/audio-key.py:ce2tsr  | ||||||
|  |             // -v ~/Music/mt:mt:r:cmtp=.bpm=~/dev/copyparty/bin/mtag/audio-bpm.py:ce2tsr | ||||||
|         } |         } | ||||||
|     ] |     ] | ||||||
| } | } | ||||||
| @ -323,6 +323,7 @@ class MTag(object): | |||||||
|         ret = {} |         ret = {} | ||||||
|         for tagname, binpath in parsers.items(): |         for tagname, binpath in parsers.items(): | ||||||
|             try: |             try: | ||||||
|  |                 binpath = os.path.expanduser(binpath) | ||||||
|                 cmd = [sys.executable, binpath, abspath] |                 cmd = [sys.executable, binpath, abspath] | ||||||
|                 cmd = [fsenc(x) for x in cmd] |                 cmd = [fsenc(x) for x in cmd] | ||||||
|                 v = sp.check_output(cmd, env=env).strip() |                 v = sp.check_output(cmd, env=env).strip() | ||||||
|  | |||||||
| @ -223,7 +223,7 @@ class Up2k(object): | |||||||
| 
 | 
 | ||||||
|             _, flags = self._expr_idx_filter(flags) |             _, flags = self._expr_idx_filter(flags) | ||||||
| 
 | 
 | ||||||
|             a = ["\033[36m{}:\033[0m{}".format(k, v) for k, v in flags.items()] |             a = ["\033[36m{}:\033[0m{}".format(k, v) for k, v in sorted(flags.items())] | ||||||
|             self.log(" ".join(a)) |             self.log(" ".join(a)) | ||||||
| 
 | 
 | ||||||
|             reg = {} |             reg = {} | ||||||
| @ -495,6 +495,9 @@ class Up2k(object): | |||||||
|                 self._run_one_mtp(ptop) |                 self._run_one_mtp(ptop) | ||||||
| 
 | 
 | ||||||
|     def _run_one_mtp(self, ptop): |     def _run_one_mtp(self, ptop): | ||||||
|  |         db_path = os.path.join(ptop, ".hist", "up2k.db") | ||||||
|  |         sz0 = os.path.getsize(db_path) | ||||||
|  | 
 | ||||||
|         force = {} |         force = {} | ||||||
|         parsers = {} |         parsers = {} | ||||||
|         for parser in self.flags[ptop]["mtp"]: |         for parser in self.flags[ptop]["mtp"]: | ||||||
| @ -513,15 +516,14 @@ class Up2k(object): | |||||||
|             n_left = cur.execute(q).fetchone()[0] |             n_left = cur.execute(q).fetchone()[0] | ||||||
| 
 | 
 | ||||||
|         mpool = self._start_mpool() |         mpool = self._start_mpool() | ||||||
|         batch_sz = mpool.maxsize * 4 |         batch_sz = mpool.maxsize * 3 | ||||||
|         seen = [] |         t_prev = time.time() | ||||||
|  |         n_prev = n_left | ||||||
|         while True: |         while True: | ||||||
|             with self.mutex: |             with self.mutex: | ||||||
|                 q = "select w from mt where k = 't:mtp' limit ?" |                 q = "select w from mt where k = 't:mtp' limit ?" | ||||||
|                 warks = cur.execute(q, (batch_sz,)).fetchall() |                 warks = cur.execute(q, (batch_sz,)).fetchall() | ||||||
|                 warks = [x[0] for x in warks] |                 warks = [x[0] for x in warks] | ||||||
|                 warks = [x for x in warks if x not in seen] |  | ||||||
|                 seen = warks |  | ||||||
|                 jobs = [] |                 jobs = [] | ||||||
|                 for w in warks: |                 for w in warks: | ||||||
|                     q = "delete from mt where w = ? and k = 't:mtp'" |                     q = "delete from mt where w = ? and k = 't:mtp'" | ||||||
| @ -546,12 +548,27 @@ class Up2k(object): | |||||||
|                     } |                     } | ||||||
|                     jobs.append([task_parsers, wcur, None, w, abspath]) |                     jobs.append([task_parsers, wcur, None, w, abspath]) | ||||||
| 
 | 
 | ||||||
|             if not jobs: |             if not warks: | ||||||
|                 break |                 break | ||||||
| 
 | 
 | ||||||
|  |             if not jobs: | ||||||
|  |                 continue | ||||||
|  | 
 | ||||||
|  |             try: | ||||||
|  |                 now = time.time() | ||||||
|  |                 s = ((now - t_prev) / (n_prev - n_left)) * n_left | ||||||
|  |                 h, s = divmod(s, 3600) | ||||||
|  |                 m, s = divmod(s, 60) | ||||||
|  |                 n_prev = n_left | ||||||
|  |                 t_prev = now | ||||||
|  |             except: | ||||||
|  |                 h = 1 | ||||||
|  |                 m = 1 | ||||||
|  | 
 | ||||||
|  |             msg = "mtp: {} done, {} left, eta {}h {:02d}m" | ||||||
|             with self.mutex: |             with self.mutex: | ||||||
|                 msg = "mtp: {} done, {} left" |                 msg = msg.format(self.n_mtag_tags_added, n_left, int(h), int(m)) | ||||||
|                 self.log(msg.format(self.n_mtag_tags_added, n_left)) |                 self.log(msg, c=6) | ||||||
| 
 | 
 | ||||||
|             for j in jobs: |             for j in jobs: | ||||||
|                 n_left -= 1 |                 n_left -= 1 | ||||||
| @ -563,6 +580,9 @@ class Up2k(object): | |||||||
|         self._stop_mpool(mpool) |         self._stop_mpool(mpool) | ||||||
|         with self.mutex: |         with self.mutex: | ||||||
|             cur.connection.commit() |             cur.connection.commit() | ||||||
|  |             if self.n_mtag_tags_added: | ||||||
|  |                 self.vac(cur, db_path, self.n_mtag_tags_added, 0, sz0) | ||||||
|  |              | ||||||
|             wcur.close() |             wcur.close() | ||||||
|             cur.close() |             cur.close() | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 ed
						ed