refac decorator, add configure_logt_formatting helper, fixed variable scope & pep8

This commit is contained in:
Taylor Wilsdon
2025-08-23 12:04:04 -04:00
parent 57748df9c2
commit 788e39368d
6 changed files with 155 additions and 89 deletions

27
main.py
View File

@@ -27,29 +27,12 @@ logging.basicConfig(
)
logger = logging.getLogger(__name__)
# Skip file logging in stateless mode
# Configure file logging based on stateless mode
from core.log_formatter import configure_file_logging
configure_file_logging()
# Define stateless_mode for use in main() function
stateless_mode = os.getenv("WORKSPACE_MCP_STATELESS_MODE", "false").lower() == "true"
if not stateless_mode:
try:
root_logger = logging.getLogger()
log_file_dir = os.path.dirname(os.path.abspath(__file__))
log_file_path = os.path.join(log_file_dir, 'mcp_server_debug.log')
file_handler = logging.FileHandler(log_file_path, mode='a')
file_handler.setLevel(logging.DEBUG)
file_formatter = logging.Formatter(
'%(asctime)s - %(name)s - %(levelname)s - %(process)d - %(threadName)s '
'[%(module)s.%(funcName)s:%(lineno)d] - %(message)s'
)
file_handler.setFormatter(file_formatter)
root_logger.addHandler(file_handler)
logger.debug(f"Detailed file logging configured to: {log_file_path}")
except Exception as e:
sys.stderr.write(f"CRITICAL: Failed to set up file logging to '{log_file_path}': {e}\n")
else:
logger.debug("File logging disabled in stateless mode")
def safe_print(text):
# Don't print to stderr when running as MCP server via uvx to avoid JSON parsing errors