From ead05cfad451d1c3d12c907c8b372f42a804e80d Mon Sep 17 00:00:00 2001 From: Joe Ferraro Date: Thu, 13 Aug 2015 00:20:33 -0400 Subject: [PATCH] update release notes, replace user settings if legacy settings are contained within --- messages/5.0.0.txt | 20 +++++++++++++++++++- sublime/settings-help.txt | 2 +- util.py | 5 +++++ 3 files changed, 25 insertions(+), 2 deletions(-) diff --git a/messages/5.0.0.txt b/messages/5.0.0.txt index 400ca3d..03ef066 100644 --- a/messages/5.0.0.txt +++ b/messages/5.0.0.txt @@ -4,4 +4,22 @@ MavensMate-SublimeText 5.0.0 changelog ### IMPORTANT ### -Version 5 of MavensMate for Sublime Text no longer depends on the "mm" API, rather it depends on a brand new app called "mavensmate-app" (https://github.com/joeferraro/mavensmate-app). mavensmate-app is the MavensMate UI and the MavensMate local server packaged with a pretty bow. In keeping with our commitment to never expose your source code/intellectual property to any server other than Salesforce.com, mavensmate-app's local server facilitates communication between your local machine and Salesforce.com, *only*. Your source code never passes through any (nonexistent) MavensMate remote server. If you're interested in reviewing the source code of the local MavensMate server, you can find it at https://github.com/joeferraro/MavensMate. \ No newline at end of file +Version 5 of MavensMate for Sublime Text no longer depends on the "mm" API, rather it depends on a brand new app called "mavensmate-app" (https://github.com/joeferraro/mavensmate-app). mavensmate-app is the MavensMate UI and the MavensMate local server packaged with a pretty bow. In keeping with our commitment to never expose your source code/intellectual property to any server other than Salesforce.com, mavensmate-app's local server facilitates communication between your local machine and Salesforce.com, *only*. Your source code never passes through any (nonexistent) MavensMate remote server. If you're interested in reviewing the source code of the local MavensMate server, you can find it at https://github.com/joeferraro/MavensMate. + +### UPDATED SETTINGS MANAGEMENT ### + +Version 5 of the MavensMate for Sublime Text plugin introduces the concept of "global" settings which are accessed via MavensMate > Settings > Global Settings. You'll notice that many of the global settings are those formerly managed by JSON files in Sublime Text. The reason they have moved is so that those users with Sublime Text, Atom, Visual Studio Code, etc. installed can manage core MavensMate settings in a single place. For example, mm_workspace is NO LONGER managed within Sublime Text; rather it is a global setting managed by the MavensMate app (mavensmate-app). + +-- Managing MavensMate for Sublime Text Settings -- + +There are three types of settings you need to be aware of: default plugin settings, user plugin settings, and global settings + +DEFAULT PLUGIN SETTINGS - the default settings for MavensMate for Sublime Text. DO NOT modify these settings, as they will be overwritten anytime you update MavensMate for Sublime Text. + +USER PLUGIN SETTINGS - the user-specific settings for MavensMAte for Sublime Text. You are strongly encouraged to copy the default settings to this file and update any settings within this file. + +GLOBAL SETTINGS - the core MavensMate settings, which are managed by the MavensMate app. + +-- Troubleshooting -- + +If you are updating a setting and it doesn't seem to be working, be sure you are updating the right settings. USER PLUGIN SETTINGS are ONLY those settings SPECIFIC to the MavensMate for Sublime Text plugin (for example, mm_compile_on_save). GLOBAL SETTINGS are different altogether and can only be managed within the MavensMate app. \ No newline at end of file diff --git a/sublime/settings-help.txt b/sublime/settings-help.txt index 8025235..36ffa3f 100644 --- a/sublime/settings-help.txt +++ b/sublime/settings-help.txt @@ -4,7 +4,7 @@ Settings Help Version 5 of the MavensMate for Sublime Text plugin introduces the concept of "global" settings which are accessed via MavensMate > Settings > Global Settings. You'll notice that many of the global settings are those formerly managed by JSON files in Sublime Text. The reason they have moved is so that those users with Sublime Text, Atom, Visual Studio Code, etc. installed can manage core MavensMate settings in a single place. -For those users upgrading from Version 4 of the MavensMate for Sublime Text plugin, you are strongly encouraged to overwrite your MavensMate for Sublime Text "User Plugin Settings" with those found in "Global Plugin Settings" as the list of settings managed by Sublime Text is now a much shorter. For example, mm_workspace is NO LONGER managed within Sublime Text; rather it is a global setting managed by the MavensMate app. +For those users upgrading from Version 4 of the MavensMate for Sublime Text plugin, you are strongly encouraged to overwrite your MavensMate for Sublime Text "User Plugin Settings" with those found in "Global Plugin Settings" as the list of settings managed by Sublime Text is now a much shorter. For example, mm_workspace is NO LONGER managed within Sublime Text; rather it is a global setting managed by the MavensMate app (mavensmate-app). -- Managing MavensMate for Sublime Text Settings -- diff --git a/util.py b/util.py index dd25b7e..32f3464 100644 --- a/util.py +++ b/util.py @@ -31,6 +31,11 @@ def package_check(): try: if not os.path.isfile(os.path.join(sublime.packages_path(),"User","mavensmate.sublime-settings")): shutil.copyfile(os.path.join(sublime.packages_path(),"MavensMate","mavensmate.sublime-settings"), os.path.join(sublime.packages_path(),"User","mavensmate.sublime-settings")) + elif os.path.isfile(os.path.join(sublime.packages_path(),"User","mavensmate.sublime-settings")): + user_settings = get_file_as_string(os.path.join(sublime.packages_path(),"User","mavensmate.sublime-settings")) + if 'mm_use_keyring' in user_settings or 'mm_workspace' in user_settings or 'mm_api_version' in user_settings: + shutil.copyfile(os.path.join(sublime.packages_path(),"MavensMate","mavensmate.sublime-settings"), os.path.join(sublime.packages_path(),"User","mavensmate.sublime-settings")) + except: debug('could not migrate default settings to user settings') pass