mirror of
				https://github.com/esphome/esphome.git
				synced 2025-10-25 05:03:52 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			105 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			105 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/env python3
 | |
| """Extract memory usage statistics from ESPHome build output.
 | |
| 
 | |
| This script parses the PlatformIO build output to extract RAM and flash
 | |
| usage statistics for a compiled component. It's used by the CI workflow to
 | |
| compare memory usage between branches.
 | |
| 
 | |
| The script reads compile output from stdin and looks for the standard
 | |
| PlatformIO output format:
 | |
|     RAM:   [====      ]  36.1% (used 29548 bytes from 81920 bytes)
 | |
|     Flash: [===       ]  34.0% (used 348511 bytes from 1023984 bytes)
 | |
| """
 | |
| 
 | |
| from __future__ import annotations
 | |
| 
 | |
| import argparse
 | |
| from pathlib import Path
 | |
| import re
 | |
| import sys
 | |
| 
 | |
| # Add esphome to path
 | |
| sys.path.insert(0, str(Path(__file__).parent.parent))
 | |
| 
 | |
| # pylint: disable=wrong-import-position
 | |
| from script.ci_helpers import write_github_output
 | |
| 
 | |
| 
 | |
| def extract_from_compile_output(output_text: str) -> tuple[int | None, int | None]:
 | |
|     """Extract memory usage from PlatformIO compile output.
 | |
| 
 | |
|     Looks for lines like:
 | |
|         RAM:   [====      ]  36.1% (used 29548 bytes from 81920 bytes)
 | |
|         Flash: [===       ]  34.0% (used 348511 bytes from 1023984 bytes)
 | |
| 
 | |
|     Args:
 | |
|         output_text: Compile output text
 | |
| 
 | |
|     Returns:
 | |
|         Tuple of (ram_bytes, flash_bytes) or (None, None) if not found
 | |
|     """
 | |
|     ram_match = re.search(
 | |
|         r"RAM:\s+\[.*?\]\s+\d+\.\d+%\s+\(used\s+(\d+)\s+bytes", output_text
 | |
|     )
 | |
|     flash_match = re.search(
 | |
|         r"Flash:\s+\[.*?\]\s+\d+\.\d+%\s+\(used\s+(\d+)\s+bytes", output_text
 | |
|     )
 | |
| 
 | |
|     if ram_match and flash_match:
 | |
|         return int(ram_match.group(1)), int(flash_match.group(1))
 | |
| 
 | |
|     return None, None
 | |
| 
 | |
| 
 | |
| def main() -> int:
 | |
|     """Main entry point."""
 | |
|     parser = argparse.ArgumentParser(
 | |
|         description="Extract memory usage from ESPHome build output"
 | |
|     )
 | |
|     parser.add_argument(
 | |
|         "--output-env",
 | |
|         action="store_true",
 | |
|         help="Output to GITHUB_OUTPUT environment file",
 | |
|     )
 | |
| 
 | |
|     args = parser.parse_args()
 | |
| 
 | |
|     # Read compile output from stdin
 | |
|     compile_output = sys.stdin.read()
 | |
| 
 | |
|     # Extract memory usage
 | |
|     ram_bytes, flash_bytes = extract_from_compile_output(compile_output)
 | |
| 
 | |
|     if ram_bytes is None or flash_bytes is None:
 | |
|         print("Failed to extract memory usage from compile output", file=sys.stderr)
 | |
|         print("Expected lines like:", file=sys.stderr)
 | |
|         print(
 | |
|             "  RAM:   [====      ]  36.1% (used 29548 bytes from 81920 bytes)",
 | |
|             file=sys.stderr,
 | |
|         )
 | |
|         print(
 | |
|             "  Flash: [===       ]  34.0% (used 348511 bytes from 1023984 bytes)",
 | |
|             file=sys.stderr,
 | |
|         )
 | |
|         return 1
 | |
| 
 | |
|     print(f"RAM: {ram_bytes} bytes", file=sys.stderr)
 | |
|     print(f"Flash: {flash_bytes} bytes", file=sys.stderr)
 | |
| 
 | |
|     if args.output_env:
 | |
|         # Output to GitHub Actions
 | |
|         write_github_output(
 | |
|             {
 | |
|                 "ram_usage": ram_bytes,
 | |
|                 "flash_usage": flash_bytes,
 | |
|             }
 | |
|         )
 | |
|     else:
 | |
|         print(f"{ram_bytes},{flash_bytes}")
 | |
| 
 | |
|     return 0
 | |
| 
 | |
| 
 | |
| if __name__ == "__main__":
 | |
|     sys.exit(main())
 |