From 91777881c751094a9a189f8ecbe8e033cddbc135 Mon Sep 17 00:00:00 2001 From: jarbasai Date: Mon, 9 May 2022 21:16:54 +0100 Subject: [PATCH] move helpers.py to ovos_utils --- ovos_workshop/app.py | 3 +- ovos_workshop/helpers.py | 160 ---------------------------- ovos_workshop/patches/base_skill.py | 2 +- ovos_workshop/skills/ovos.py | 3 +- requirements/requirements.txt | 2 +- 5 files changed, 6 insertions(+), 164 deletions(-) delete mode 100644 ovos_workshop/helpers.py diff --git a/ovos_workshop/app.py b/ovos_workshop/app.py index 7039f348..40103564 100644 --- a/ovos_workshop/app.py +++ b/ovos_workshop/app.py @@ -23,7 +23,8 @@ from ovos_utils.skills.settings import PrivateSettings from ovos_utils.sound import wait_while_speaking -from ovos_workshop.helpers import Intent, IntentBuilder, get_non_properties +from ovos_utils.skills import get_non_properties +from ovos_utils.intents import IntentBuilder, Intent, AdaptIntent from ovos_workshop.skills.decorators import * from ovos_workshop.skills.decorators.killable import killable_event, \ AbortEvent, AbortQuestion diff --git a/ovos_workshop/helpers.py b/ovos_workshop/helpers.py deleted file mode 100644 index ac30926c..00000000 --- a/ovos_workshop/helpers.py +++ /dev/null @@ -1,160 +0,0 @@ -try: - from adapt.intent import IntentBuilder, Intent -except ImportError: - # adapt is optional, OVOSAbstractApplication might not use intents - - class Intent: - def __init__(self, name, requires, at_least_one, optional): - """Create Intent object - Args: - name(str): Name for Intent - requires(list): Entities that are required - at_least_one(list): One of these Entities are required - optional(list): Optional Entities used by the intent - """ - self.name = name - self.requires = requires - self.at_least_one = at_least_one - self.optional = optional - - def validate(self, tags, confidence): - """Using this method removes tags from the result of validate_with_tags - Returns: - intent(intent): Results from validate_with_tags - """ - raise NotImplementedError("please install adapt-parser") - - def validate_with_tags(self, tags, confidence): - """Validate whether tags has required entites for this intent to fire - Args: - tags(list): Tags and Entities used for validation - confidence(float): The weight associate to the parse result, - as indicated by the parser. This is influenced by a parser - that uses edit distance or context. - Returns: - intent, tags: Returns intent and tags used by the intent on - failure to meat required entities then returns intent with - confidence - of 0.0 and an empty list for tags. - """ - raise NotImplementedError("please install adapt-parser") - - - class IntentBuilder: - """ - IntentBuilder, used to construct intent parsers. - Attributes: - at_least_one(list): A list of Entities where one is required. - These are separated into lists so you can have one of (A or B) and - then require one of (D or F). - requires(list): A list of Required Entities - optional(list): A list of optional Entities - name(str): Name of intent - Notes: - This is designed to allow construction of intents in one line. - Example: - IntentBuilder("Intent")\ - .requires("A")\ - .one_of("C","D")\ - .optional("G").build() - """ - - def __init__(self, intent_name): - """ - Constructor - Args: - intent_name(str): the name of the intents that this parser - parses/validates - """ - self.at_least_one = [] - self.requires = [] - self.optional = [] - self.name = intent_name - - def one_of(self, *args): - """ - The intent parser should require one of the provided entity types to - validate this clause. - Args: - args(args): *args notation list of entity names - Returns: - self: to continue modifications. - """ - self.at_least_one.append(args) - return self - - def require(self, entity_type, attribute_name=None): - """ - The intent parser should require an entity of the provided type. - Args: - entity_type(str): an entity type - attribute_name(str): the name of the attribute on the parsed intent. - Defaults to match entity_type. - Returns: - self: to continue modifications. - """ - if not attribute_name: - attribute_name = entity_type - self.requires += [(entity_type, attribute_name)] - return self - - def optionally(self, entity_type, attribute_name=None): - """ - Parsed intents from this parser can optionally include an entity of the - provided type. - Args: - entity_type(str): an entity type - attribute_name(str): the name of the attribute on the parsed intent. - Defaults to match entity_type. - Returns: - self: to continue modifications. - """ - if not attribute_name: - attribute_name = entity_type - self.optional += [(entity_type, attribute_name)] - return self - - def build(self): - """ - Constructs an intent from the builder's specifications. - :return: an Intent instance. - """ - return Intent(self.name, self.requires, - self.at_least_one, self.optional) - - -class AdaptIntent(IntentBuilder): - """Wrapper for IntentBuilder setting a blank name. - - Args: - name (str): Optional name of intent - """ - - def __init__(self, name=''): - super().__init__(name) - - -def get_non_properties(obj): - """Get attributes that are not properties from object. - - Will return members of object class along with bases down to MycroftSkill. - - Args: - obj: object to scan - - Returns: - Set of attributes that are not a property. - """ - - def check_class(cls): - """Find all non-properties in a class.""" - # Current class - d = cls.__dict__ - np = [k for k in d if not isinstance(d[k], property)] - # Recurse through base classes excluding MycroftSkill and object - for b in [b for b in cls.__bases__ if b.__name__ not in ("object", "MycroftSkill")]: - np += check_class(b) - return np - - return set(check_class(obj.__class__)) - diff --git a/ovos_workshop/patches/base_skill.py b/ovos_workshop/patches/base_skill.py index 2cfc6f52..1a76b98f 100644 --- a/ovos_workshop/patches/base_skill.py +++ b/ovos_workshop/patches/base_skill.py @@ -14,7 +14,7 @@ from mycroft.skills.skill_data import read_vocab_file, load_vocabulary, \ load_regex from mycroft.dialog import load_dialogs -from ovos_workshop.helpers import get_non_properties +from ovos_utils.skills import get_non_properties class MycroftSkill(_MycroftSkill): diff --git a/ovos_workshop/skills/ovos.py b/ovos_workshop/skills/ovos.py index 4cd20f43..bb514aaf 100644 --- a/ovos_workshop/skills/ovos.py +++ b/ovos_workshop/skills/ovos.py @@ -11,7 +11,8 @@ from mycroft import dialog from mycroft.skills.mycroft_skill.event_container import create_wrapper -from ovos_workshop.helpers import get_non_properties, Intent, IntentBuilder +from ovos_utils.skills import get_non_properties +from ovos_utils.intents import IntentBuilder, Intent, AdaptIntent from ovos_workshop.patches.base_skill import MycroftSkill, FallbackSkill from ovos_workshop.skills.decorators.killable import killable_event, \ AbortEvent, AbortQuestion diff --git a/requirements/requirements.txt b/requirements/requirements.txt index 105b4d6f..3e8fadde 100644 --- a/requirements/requirements.txt +++ b/requirements/requirements.txt @@ -1,4 +1,4 @@ -ovos_utils>=0.0.12 +ovos_utils~=0.0, >=0.0.21a4 ovos_plugin_common_play # optional but improves fuzzy matching and silences logs