def sanitize(settings_object): if "base_directory" in settings_object and settings_object.get( "base_directory"): settings_object["base_directory"] = Path.sanitize_base_directory( settings_object.get("base_directory")) if "project_directory" in settings_object and settings_object.get( "project_directory"): settings_object["project_directory"] = Path.sanitize_base_directory( settings_object.get("project_directory")) return settings_object
def update(): """ merges plugin settings with user settings by default """ ffp_settings = sublime.load_settings(config["FFP_SETTINGS_FILE"]) global_settings = merge(config, ffp_settings) if global_settings["BASE_DIRECTORY"]: global_settings["BASE_DIRECTORY"] = Path.sanitize_base_directory(global_settings["BASE_DIRECTORY"]) if global_settings["PROJECT_DIRECTORY"]: global_settings["PROJECT_DIRECTORY"] = Path.sanitize_base_directory(global_settings["PROJECT_DIRECTORY"]) return global_settings
def build(needle, trigger, current_folder): """ updates state object for given trigger. The state object is then used to query the file cache: @see completion ProjectManager.search_completions( query.get_needle(), current_file.get_project_directory(), query.get_extensions(), query.get_base_path() ) """ needle = Path.sanitize(needle) needle_is_absolute = Path.is_absolute(needle) needle_is_path = needle_is_absolute or Path.is_relative(needle) if not trigger or not ( by_command() or (settings.get("auto_trigger") if needle_is_path else trigger.get( "auto", settings.get("auto_trigger")))): return False """ Adjust current folder by specified base folder: BASE-FOLDER -> CURRENT_FOLDER ------------------------------------------------------------ True use settings base_directory String use string as base_directory False use current file's directory (parameter) """ base_path = resolve_value("base_directory", trigger, False) if base_path is True: current_folder = settings.get("base_directory") elif base_path: current_folder = Path.sanitize_base_directory(base_path) state["post_remove_path"] = current_folder if ( base_path and needle_is_absolute) else False state["base_directory"] = current_folder if resolve_path_type( needle, trigger) == "relative" else False state["replace_on_insert"] = resolve_value("replace_on_insert", trigger, []) state["extensions"] = resolve_value("extensions", trigger, ["*"]) state["needle"] = sanitize_needle(needle, current_folder) return True
def build(needle, trigger, current_folder, project_folder): query = {} force_type = Query.get("filepath_type", False) triggered = Query.by_command() filepath_type = "relative" needle = Path.sanitize(needle) needle_is_absolute = Path.is_absolute(needle) needle_is_relative = Path.is_relative(needle) needle_is_path = needle_is_absolute or needle_is_relative # abort if autocomplete is not available if not triggered and trigger.get("auto", False) is False and needle_is_path is False: # verbose("FFP no autocomplete") return False # test path to trigger auto-completion by needle if not triggered and trigger["auto"] is False and config["AUTO_TRIGGER"] and needle_is_absolute: force_type = "absolute" # base_directory: override - trigger - False base_directory = trigger.get("base_directory", False) base_directory = Query.get("base_directory", base_directory) # # set current directory by force, else by trigger: # # trigger | # --------------|-------------------- # False | use current file's directory # True | use settings: base_directory # String | use string as base_directory # change base folder to base directory # if base_directory is True: current_folder = config["BASE_DIRECTORY"] elif base_directory: current_folder = Path.sanitize_base_directory(base_directory) # notify completion to replace path if base_directory and needle_is_absolute: Completion.base_directory = current_folder # # filepath_type # # needle | trigger rel | force | RESULT # ----------|---------------|-----------|--------- # ? | relative | False | relative # ? | absolute | False | absolute # absolute | * | False | absolute # relative | * | False | relative # * | * | relative | relative # * | * | absolute | absolute # if force_type: filepath_type = force_type elif needle_is_absolute: filepath_type = "absolute" elif needle_is_relative: filepath_type = "relative" elif trigger.get("relative") is True: filepath_type = "relative" elif trigger.get("relative") is False: filepath_type = "absolute" Query.base_path = current_folder if filepath_type == "relative" else False # replacements: override - trigger - None Query.replace_on_insert = trigger.get("replace_on_insert", []) Query.replace_on_insert = Query.get("replace_on_insert", Query.replace_on_insert) # extensions: override - trigger - "js" extensions = trigger.get("extensions", ["*"]) extensions = Query.get("extensions", extensions) Query.extensions = extensions Query.needle = Query.build_needle_query(needle, current_folder) # strip any starting dots or slashes Query.needle = re.sub("^[\.\/]*", "", Query.needle) # -------------------------------------------------------------------- # tests throw error if results are set to class # Require refactoring of static classes with dynamic properties? # -------------------------------------------------------------------- query["extensions"] = extensions query["base_path"] = current_folder if filepath_type == "relative" else False query["needle"] = Query.build_needle_query(needle, current_folder) if triggered or (config["AUTO_TRIGGER"] if needle_is_path else trigger.get("auto", config["AUTO_TRIGGER"])): return query return False
def build(needle, trigger, current_folder, project_folder): query = {} force_type = Query.get("filepath_type", False) triggered = Query.by_command() filepath_type = "relative" needle = Path.sanitize(needle) needle_is_absolute = Path.is_absolute(needle) needle_is_relative = Path.is_relative(needle) needle_is_path = needle_is_absolute or needle_is_relative # abort if autocomplete is not available if not triggered and trigger.get( "auto", False) is False and needle_is_path is False: # verbose("FFP no autocomplete") return False # test path to trigger auto-completion by needle if not triggered and trigger["auto"] is False and config[ "AUTO_TRIGGER"] and needle_is_absolute: force_type = "absolute" # base_directory: override - trigger - False base_directory = trigger.get("base_directory", False) base_directory = Query.get("base_directory", base_directory) # # set current directory by force, else by trigger: # # trigger | # --------------|-------------------- # False | use current file's directory # True | use settings: base_directory # String | use string as base_directory # change base folder to base directory # if base_directory is True: current_folder = config["BASE_DIRECTORY"] elif base_directory: current_folder = Path.sanitize_base_directory(base_directory) # notify completion to replace path if base_directory and needle_is_absolute: Completion.base_directory = current_folder # # filepath_type # # needle | trigger rel | force | RESULT # ----------|---------------|-----------|--------- # ? | relative | False | relative # ? | absolute | False | absolute # absolute | * | False | absolute # relative | * | False | relative # * | * | relative | relative # * | * | absolute | absolute # if force_type: filepath_type = force_type elif needle_is_absolute: filepath_type = "absolute" elif needle_is_relative: filepath_type = "relative" elif trigger.get("relative") is True: filepath_type = "relative" elif trigger.get("relative") is False: filepath_type = "absolute" Query.base_path = current_folder if filepath_type == "relative" else False # replacements: override - trigger - None Query.replace_on_insert = trigger.get("replace_on_insert", []) Query.replace_on_insert = Query.get("replace_on_insert", Query.replace_on_insert) # extensions: override - trigger - "js" extensions = trigger.get("extensions", ["*"]) extensions = Query.get("extensions", extensions) Query.extensions = extensions Query.needle = Query.build_needle_query(needle, current_folder) # strip any starting dots or slashes Query.needle = re.sub("^[\.\/]*", "", Query.needle) # -------------------------------------------------------------------- # tests throw error if results are set to class # Require refactoring of static classes with dynamic properties? # -------------------------------------------------------------------- query["extensions"] = extensions query[ "base_path"] = current_folder if filepath_type == "relative" else False query["needle"] = Query.build_needle_query(needle, current_folder) if triggered or (config["AUTO_TRIGGER"] if needle_is_path else trigger.get("auto", config["AUTO_TRIGGER"])): return query return False