diff --git a/README.md b/README.md index c9b51bd..c252c6d 100644 --- a/README.md +++ b/README.md @@ -65,7 +65,7 @@ def get_new_function(symbol: str) -> dict: return {} ``` -After defining your new function, make sure to add it to the `get_openai_tools()` function in the `functions.py` script: +After defining your new function, make sure it's added to the `functions` array in the `get_openai_tools()` function in the `functions.py` script. ```python def get_openai_tools() -> List[dict]: @@ -77,6 +77,7 @@ def get_openai_tools() -> List[dict]: tools = [convert_to_openai_tool(f) for f in functions] return tools ``` +Note, this should be automatic via some `inspect` syntax but it's worth checking that `old_funtions` and the automatically derived `functions` arrays are the same. This will ensure that your new function is included in the list of available tools for the model to use. diff --git a/functions.py b/functions.py index 794627a..997b238 100644 --- a/functions.py +++ b/functions.py @@ -296,7 +296,7 @@ def get_company_profile(symbol: str) -> dict: return {} def get_openai_tools() -> List[dict]: - functions = [ + old_functions = [ code_interpreter, google_search_and_scrape, get_current_stock_price, @@ -309,6 +309,16 @@ def get_openai_tools() -> List[dict]: get_dividend_data, get_technical_indicators ] + ### Should be the same as above + functions = [func for func in dir(__main__) if inspect.isfunction(getattr(__main__, func)) and getattr(__main__, func).__module__ == '__main__'] + + try: + assert ( set(functions) == set(old_functions) ) + except Exception as e: + print(f"Error building automatic `functions` array: {e}") + print(f"It's likely that the function you added is either in a sub-module or has amother issue") + functions = old_functions + pass tools = [convert_to_openai_tool(f) for f in functions] - return tools \ No newline at end of file + return tools