38 lines
		
	
	
		
			993 B
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			38 lines
		
	
	
		
			993 B
		
	
	
	
		
			Python
		
	
	
	
	
	
| import xmltodict
 | |
| import yaml
 | |
| import re
 | |
| import json
 | |
| import os
 | |
| import re
 | |
| import toml
 | |
| from collections import OrderedDict
 | |
| from glob import glob
 | |
| 
 | |
| abspath = os.path.abspath(__file__)
 | |
| dname = os.path.dirname(abspath)
 | |
| os.chdir(dname)
 | |
| 
 | |
| # ======= load chip list
 | |
| 
 | |
| features = {}
 | |
| 
 | |
| for f in sorted(glob('../stm32-data/data/chips/*.yaml')):
 | |
|     # Use the filename to get the chip name. Ultra fast, we don't have to read YAML!
 | |
|     name = os.path.splitext(os.path.basename(f))[0].lower()
 | |
|     features[name] = []
 | |
| 
 | |
| 
 | |
| # ========= Update Cargo features
 | |
| 
 | |
| SEPARATOR_START = '# BEGIN GENERATED FEATURES\n'
 | |
| SEPARATOR_END = '# END GENERATED FEATURES\n'
 | |
| HELP = '# Generated by gen_features.py. DO NOT EDIT.\n'
 | |
| with open('Cargo.toml', 'r') as f:
 | |
|     cargo = f.read()
 | |
| before, cargo = cargo.split(SEPARATOR_START, maxsplit=1)
 | |
| _, after = cargo.split(SEPARATOR_END, maxsplit=1)
 | |
| cargo = before + SEPARATOR_START + HELP + \
 | |
|     toml.dumps(features) + SEPARATOR_END + after
 | |
| with open('Cargo.toml', 'w') as f:
 | |
|     f.write(cargo)
 |