string_resource_builder.dart 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. import 'dart:async';
  2. import 'dart:io';
  3. import 'package:build/build.dart';
  4. import 'package:xml/xml.dart';
  5. const baseType = 'zh_CN';
  6. Builder builds(BuilderOptions options) => StringResourceBuilder();
  7. class StringResourceBuilder implements Builder {
  8. @override
  9. Future<void> build(BuildStep buildStep) async {
  10. generateStringResources();
  11. }
  12. @override
  13. Map<String, List<String>> get buildExtensions => {
  14. '.xml': ['.s.dart'],
  15. };
  16. }
  17. void main() {
  18. generateStringResources();
  19. }
  20. void generateStringResources() {
  21. print('generateStringResources...start');
  22. final directory = Directory('assets/string/');
  23. final buffer = StringBuffer();
  24. final multiBuffer = StringBuffer();
  25. buffer.writeln('class StringName {');
  26. buffer.writeln('StringName._();');
  27. multiBuffer.writeln('class StringMultiSource {');
  28. multiBuffer.writeln('StringMultiSource._();');
  29. multiBuffer
  30. .writeln(' static const Map<String, Map<String, String>> values = {');
  31. directory.listSync(recursive: true).forEach((element) {
  32. if (element is Directory) {
  33. final files =
  34. element.listSync().where((file) => file.path.endsWith('.xml'));
  35. bool isBase = element.path.endsWith('base');
  36. String node = isBase ? baseType : element.path.split('/').last;
  37. for (var file in files) {
  38. final content = File(file.path).readAsStringSync();
  39. final document = XmlDocument.parse(content);
  40. final strings = document.findAllElements('string');
  41. multiBuffer.writeln(' \'$node\': {');
  42. for (var string in strings) {
  43. final name = string.getAttribute('name');
  44. String value = string.text;
  45. if (string.text.contains('\r\n')) {
  46. value = string.text.replaceAll('\r\n', '').trim();
  47. }
  48. if (isBase) {
  49. final camelCaseName = toCamelCase(name);
  50. buffer.writeln(
  51. ' static const String $camelCaseName = \'$name\';// $value');
  52. }
  53. multiBuffer.writeln(' \'$name\': \'$value\',');
  54. }
  55. multiBuffer.writeln(' },');
  56. }
  57. }
  58. });
  59. multiBuffer.writeln(' };');
  60. multiBuffer.writeln('}');
  61. buffer.writeln('}');
  62. buffer.writeln();
  63. buffer.writeln(multiBuffer.toString());
  64. createDirectory('lib/resource');
  65. final outputFile = File('lib/resource/string.gen.dart');
  66. outputFile.writeAsStringSync(buffer.toString());
  67. print('Strings file generated successfully!');
  68. }
  69. void createDirectory(String path) {
  70. final directory = Directory(path);
  71. if (!directory.existsSync()) {
  72. directory.createSync(recursive: true);
  73. print('Directory created: $path');
  74. }
  75. }
  76. String toCamelCase(String? snakeCase) {
  77. if (snakeCase == null) {
  78. return '';
  79. }
  80. return snakeCase.split('_').map((word) {
  81. if (word == snakeCase.split('_').first) {
  82. return word;
  83. } else {
  84. return word[0].toUpperCase() + word.substring(1);
  85. }
  86. }).join('');
  87. }