mirror of
				https://github.com/wakatime/sublime-wakatime.git
				synced 2023-08-10 21:13:02 +03:00 
			
		
		
		
	use sublime project from sublime-project file when no revision control project found
This commit is contained in:
		
							
								
								
									
										21
									
								
								WakaTime.py
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								WakaTime.py
									
									
									
									
									
								
							| @@ -18,7 +18,7 @@ import sys | |||||||
| import time | import time | ||||||
| import threading | import threading | ||||||
| import uuid | import uuid | ||||||
| from os.path import expanduser, dirname, realpath, isfile, join, exists | from os.path import expanduser, dirname, basename, realpath, isfile, join, exists | ||||||
|  |  | ||||||
|  |  | ||||||
| # globals | # globals | ||||||
| @@ -53,7 +53,9 @@ if HAS_SSL: | |||||||
|  |  | ||||||
| def prompt_api_key(): | def prompt_api_key(): | ||||||
|     global SETTINGS |     global SETTINGS | ||||||
|     if not SETTINGS.get('api_key'): |     if SETTINGS.get('api_key'): | ||||||
|  |         return True | ||||||
|  |     else: | ||||||
|         def got_key(text): |         def got_key(text): | ||||||
|             if text: |             if text: | ||||||
|                 SETTINGS.set('api_key', str(text)) |                 SETTINGS.set('api_key', str(text)) | ||||||
| @@ -91,7 +93,10 @@ def handle_action(view, is_write=False): | |||||||
|     with LOCK: |     with LOCK: | ||||||
|         target_file = view.file_name() |         target_file = view.file_name() | ||||||
|         if target_file: |         if target_file: | ||||||
|             thread = SendActionThread(target_file, is_write=is_write) |             project = view.window().project_file_name() | ||||||
|  |             if project: | ||||||
|  |                 project = basename(project).replace('.sublime-project', '', 1) | ||||||
|  |             thread = SendActionThread(target_file, is_write=is_write, project=project) | ||||||
|             thread.start() |             thread.start() | ||||||
|             LAST_ACTION = { |             LAST_ACTION = { | ||||||
|                 'file': target_file, |                 'file': target_file, | ||||||
| @@ -102,10 +107,11 @@ def handle_action(view, is_write=False): | |||||||
|  |  | ||||||
| class SendActionThread(threading.Thread): | class SendActionThread(threading.Thread): | ||||||
|  |  | ||||||
|     def __init__(self, target_file, is_write=False, force=False): |     def __init__(self, target_file, is_write=False, project=None, force=False): | ||||||
|         threading.Thread.__init__(self) |         threading.Thread.__init__(self) | ||||||
|         self.target_file = target_file |         self.target_file = target_file | ||||||
|         self.is_write = is_write |         self.is_write = is_write | ||||||
|  |         self.project = project | ||||||
|         self.force = force |         self.force = force | ||||||
|         self.debug = SETTINGS.get('debug') |         self.debug = SETTINGS.get('debug') | ||||||
|         self.api_key = SETTINGS.get('api_key', '') |         self.api_key = SETTINGS.get('api_key', '') | ||||||
| @@ -132,13 +138,15 @@ class SendActionThread(threading.Thread): | |||||||
|         ] |         ] | ||||||
|         if self.is_write: |         if self.is_write: | ||||||
|             cmd.append('--write') |             cmd.append('--write') | ||||||
|  |         if self.project: | ||||||
|  |             cmd.extend(['--project', self.project]) | ||||||
|         for pattern in self.ignore: |         for pattern in self.ignore: | ||||||
|             cmd.extend(['--ignore', pattern]) |             cmd.extend(['--ignore', pattern]) | ||||||
|         if self.debug: |         if self.debug: | ||||||
|             cmd.append('--verbose') |             cmd.append('--verbose') | ||||||
|         if HAS_SSL: |         if HAS_SSL: | ||||||
|             if self.debug: |             if self.debug: | ||||||
|                 print(cmd) |                 print('[WakaTime] %s' % ' '.join(cmd)) | ||||||
|             code = wakatime.main(cmd) |             code = wakatime.main(cmd) | ||||||
|             if code != 0: |             if code != 0: | ||||||
|                 print('[WakaTime] Error: Response code %d from wakatime package.' % code) |                 print('[WakaTime] Error: Response code %d from wakatime package.' % code) | ||||||
| @@ -147,7 +155,7 @@ class SendActionThread(threading.Thread): | |||||||
|             if python: |             if python: | ||||||
|                 cmd.insert(0, python) |                 cmd.insert(0, python) | ||||||
|                 if self.debug: |                 if self.debug: | ||||||
|                     print(cmd) |                     print('[WakaTime] %s' % ' '.join(cmd)) | ||||||
|                 if platform.system() == 'Windows': |                 if platform.system() == 'Windows': | ||||||
|                     Popen(cmd, shell=False) |                     Popen(cmd, shell=False) | ||||||
|                 else: |                 else: | ||||||
| @@ -159,6 +167,7 @@ class SendActionThread(threading.Thread): | |||||||
|  |  | ||||||
| def plugin_loaded(): | def plugin_loaded(): | ||||||
|     global SETTINGS |     global SETTINGS | ||||||
|  |     print('[WakaTime] Initializing WakaTime plugin v%s' % __version__) | ||||||
|     SETTINGS = sublime.load_settings(SETTINGS_FILE) |     SETTINGS = sublime.load_settings(SETTINGS_FILE) | ||||||
|     after_loaded() |     after_loaded() | ||||||
|  |  | ||||||
|   | |||||||
| @@ -3,6 +3,19 @@ History | |||||||
| ------- | ------- | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 2.0.3 (2014-06-18) | ||||||
|  | ++++++++++++++++++ | ||||||
|  |  | ||||||
|  | - use project from command line arg when no revision control project is found | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 2.0.2 (2014-06-09) | ||||||
|  | ++++++++++++++++++ | ||||||
|  |  | ||||||
|  | - include python3.2 compatible versions of simplejson, pytz, and tzlocal | ||||||
|  | - disable offline logging when Python was not compiled with sqlite3 module | ||||||
|  |  | ||||||
|  |  | ||||||
| 2.0.1 (2014-05-26) | 2.0.1 (2014-05-26) | ||||||
| ++++++++++++++++++ | ++++++++++++++++++ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ | |||||||
| from __future__ import print_function | from __future__ import print_function | ||||||
|  |  | ||||||
| __title__ = 'wakatime' | __title__ = 'wakatime' | ||||||
| __version__ = '2.0.2' | __version__ = '2.0.3' | ||||||
| __author__ = 'Alan Hamlett' | __author__ = 'Alan Hamlett' | ||||||
| __license__ = 'BSD' | __license__ = 'BSD' | ||||||
| __copyright__ = 'Copyright 2014 Alan Hamlett' | __copyright__ = 'Copyright 2014 Alan Hamlett' | ||||||
| @@ -348,10 +348,10 @@ def main(argv=None): | |||||||
|  |  | ||||||
|         project = find_project(args.targetFile, configs=configs) |         project = find_project(args.targetFile, configs=configs) | ||||||
|         branch = None |         branch = None | ||||||
|         project_name = None |         project_name = args.project_name | ||||||
|         if project: |         if project: | ||||||
|             branch = project.branch() |             branch = project.branch() | ||||||
|             project_name = args.project_name or project.name() |             project_name = project.name() | ||||||
|  |  | ||||||
|         if send_action( |         if send_action( | ||||||
|                 project=project_name, |                 project=project_name, | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Alan Hamlett
					Alan Hamlett