Fixed init
This commit is contained in:
parent
7e4aa24ce0
commit
5fc441825e
7 changed files with 131 additions and 53 deletions
26
.gitignore
vendored
26
.gitignore
vendored
|
@ -3,27 +3,7 @@
|
||||||
# Covers JetBrains IDEs: IntelliJ, RubyMine, PhpStorm, AppCode, PyCharm, CLion, Android Studio and Webstorm
|
# Covers JetBrains IDEs: IntelliJ, RubyMine, PhpStorm, AppCode, PyCharm, CLion, Android Studio and Webstorm
|
||||||
# Reference: https://intellij-support.jetbrains.com/hc/en-us/articles/206544839
|
# Reference: https://intellij-support.jetbrains.com/hc/en-us/articles/206544839
|
||||||
|
|
||||||
# User-specific stuff:
|
|
||||||
.idea/workspace.xml
|
|
||||||
.idea/tasks.xml
|
|
||||||
.idea/dictionaries
|
|
||||||
.idea/vcs.xml
|
|
||||||
.idea/jsLibraryMappings.xml
|
|
||||||
|
|
||||||
# Sensitive or high-churn files:
|
|
||||||
.idea/dataSources.ids
|
|
||||||
.idea/dataSources.xml
|
|
||||||
.idea/dataSources.local.xml
|
|
||||||
.idea/sqlDataSources.xml
|
|
||||||
.idea/dynamic.xml
|
|
||||||
.idea/uiDesigner.xml
|
|
||||||
|
|
||||||
# Gradle:
|
|
||||||
.idea/gradle.xml
|
|
||||||
.idea/libraries
|
|
||||||
|
|
||||||
# Mongo Explorer plugin:
|
|
||||||
.idea/mongoSettings.xml
|
|
||||||
|
|
||||||
## File-based project format:
|
## File-based project format:
|
||||||
*.iws
|
*.iws
|
||||||
|
@ -33,8 +13,6 @@
|
||||||
# IntelliJ
|
# IntelliJ
|
||||||
/out/
|
/out/
|
||||||
|
|
||||||
# mpeltonen/sbt-idea plugin
|
|
||||||
.idea_modules/
|
|
||||||
|
|
||||||
# JIRA plugin
|
# JIRA plugin
|
||||||
atlassian-ide-plugin.xml
|
atlassian-ide-plugin.xml
|
||||||
|
@ -78,3 +56,7 @@ pubspec.lock
|
||||||
sample_project/
|
sample_project/
|
||||||
sample-project
|
sample-project
|
||||||
.dart_tool
|
.dart_tool
|
||||||
|
.metals
|
||||||
|
|
||||||
|
.vscode
|
||||||
|
!settings.json
|
5
.vscode/settings.json
vendored
Normal file
5
.vscode/settings.json
vendored
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
{
|
||||||
|
"files.watcherExclude": {
|
||||||
|
"**/target": true
|
||||||
|
}
|
||||||
|
}
|
|
@ -4,6 +4,7 @@
|
||||||
|
|
||||||
* Fixed NNBD issues
|
* Fixed NNBD issues
|
||||||
* Updated to use `angel3` packages
|
* Updated to use `angel3` packages
|
||||||
|
* Fixed incorrect import for new project
|
||||||
|
|
||||||
## 3.0.0-beta.2
|
## 3.0.0-beta.2
|
||||||
|
|
||||||
|
|
|
@ -149,6 +149,7 @@ class InitCommand extends Command {
|
||||||
|
|
||||||
// var boilerplate = basicBoilerplate;
|
// var boilerplate = basicBoilerplate;
|
||||||
print('Choose a project type before continuing:');
|
print('Choose a project type before continuing:');
|
||||||
|
|
||||||
var boilerplate = prompts.choose(
|
var boilerplate = prompts.choose(
|
||||||
'Choose a project type before continuing', boilerplates) ??
|
'Choose a project type before continuing', boilerplates) ??
|
||||||
basicBoilerplate;
|
basicBoilerplate;
|
||||||
|
|
|
@ -89,9 +89,8 @@ Future renameDartFiles(Directory dir, String oldName, String newName) async {
|
||||||
|
|
||||||
// Try to replace MongoDB URL
|
// Try to replace MongoDB URL
|
||||||
// Replace name in config directory
|
// Replace name in config directory
|
||||||
var configGlob = Glob('config/**/*.yaml');
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
var configGlob = Glob('config/**/*.yaml');
|
||||||
await for (var yamlFile in configGlob.list(root: dir.absolute.path)) {
|
await for (var yamlFile in configGlob.list(root: dir.absolute.path)) {
|
||||||
if (yamlFile is File) {
|
if (yamlFile is File) {
|
||||||
print(
|
print(
|
||||||
|
@ -105,23 +104,6 @@ Future renameDartFiles(Directory dir, String oldName, String newName) async {
|
||||||
}
|
}
|
||||||
} catch (_) {}
|
} catch (_) {}
|
||||||
|
|
||||||
// Replace name in bin directory
|
|
||||||
var binGlob = Glob('bin/**/*.dart');
|
|
||||||
|
|
||||||
try {
|
|
||||||
await for (var dartFile in binGlob.list(root: dir.absolute.path)) {
|
|
||||||
if (dartFile is File) {
|
|
||||||
print(
|
|
||||||
'Replacing occurrences of "$oldName" with "$newName" in file "${dartFile.absolute.path}"...');
|
|
||||||
if (dartFile is File) {
|
|
||||||
var contents = (dartFile as File).readAsStringSync();
|
|
||||||
contents = contents.replaceAll(oldName, newName);
|
|
||||||
(dartFile as File).writeAsStringSync(contents);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} catch (_) {}
|
|
||||||
|
|
||||||
var entry = File.fromUri(dir.uri.resolve('lib/$oldName.dart'));
|
var entry = File.fromUri(dir.uri.resolve('lib/$oldName.dart'));
|
||||||
|
|
||||||
if (await entry.exists()) {
|
if (await entry.exists()) {
|
||||||
|
@ -129,12 +111,58 @@ Future renameDartFiles(Directory dir, String oldName, String newName) async {
|
||||||
print('Renaming library file `${entry.absolute.path}`...');
|
print('Renaming library file `${entry.absolute.path}`...');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Replace package:oldName/oldName.dart with package:newName/newName.dart
|
||||||
|
// Replace package:oldName/ with package:newName/
|
||||||
|
String updateImport(String content, String oldName, String newName) {
|
||||||
|
if (!content.startsWith('import')) {
|
||||||
|
return content;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (content.contains('package:$oldName/$oldName.dart')) {
|
||||||
|
return content.replaceFirst(
|
||||||
|
'package:$oldName/$oldName.dart', 'package:$newName/$newName.dart');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (content.contains('package:$oldName/')) {
|
||||||
|
return content.replaceFirst('package:$oldName/', 'package:$newName/');
|
||||||
|
}
|
||||||
|
|
||||||
|
return content;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Replace mustache {{oldName}} with newName
|
||||||
|
String updateMustacheBinding(String content, String oldName, String newName) {
|
||||||
|
if (content.contains('{{$oldName}}')) {
|
||||||
|
return content.replaceAll('{{$oldName}}', '$newName');
|
||||||
|
}
|
||||||
|
|
||||||
|
return content;
|
||||||
|
}
|
||||||
|
|
||||||
|
var fmt = DartFormatter();
|
||||||
|
await for (FileSystemEntity file in dir.list(recursive: true)) {
|
||||||
|
if (file is File && file.path.endsWith('.dart')) {
|
||||||
|
var lineList = await file.readAsLines();
|
||||||
|
|
||||||
|
if (oldName.isNotEmpty && newName.isNotEmpty) {
|
||||||
|
var contents = lineList.fold<String>('', (prev, cur) {
|
||||||
|
var updatedCur = updateImport(cur, oldName, newName);
|
||||||
|
updatedCur = updateMustacheBinding(updatedCur, oldName, newName);
|
||||||
|
return prev + '\n' + updatedCur;
|
||||||
|
});
|
||||||
|
await file.writeAsString(fmt.format(contents));
|
||||||
|
|
||||||
|
print('Updated file `${file.absolute.path}`.');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Deprecated, Not working
|
||||||
var fmt = DartFormatter();
|
var fmt = DartFormatter();
|
||||||
await for (FileSystemEntity file in dir.list(recursive: true)) {
|
await for (FileSystemEntity file in dir.list(recursive: true)) {
|
||||||
if (file is File && file.path.endsWith('.dart')) {
|
if (file is File && file.path.endsWith('.dart')) {
|
||||||
var contents = await file.readAsString();
|
var contents = await file.readAsString();
|
||||||
|
|
||||||
// TODO: Issue to be fixed: parseCompilationUnit uses Hubbub library which uses discontinued Google front_end library
|
|
||||||
// front_end package. Temporarily commeted out
|
// front_end package. Temporarily commeted out
|
||||||
//var ast = parseCompilationUnit(contents);
|
//var ast = parseCompilationUnit(contents);
|
||||||
var visitor = RenamingVisitor(oldName, newName);
|
var visitor = RenamingVisitor(oldName, newName);
|
||||||
|
@ -144,9 +172,9 @@ Future renameDartFiles(Directory dir, String oldName, String newName) async {
|
||||||
visitor.replace.forEach((range, replacement) {
|
visitor.replace.forEach((range, replacement) {
|
||||||
if (range.first is int) {
|
if (range.first is int) {
|
||||||
contents = contents.replaceRange(
|
contents = contents.replaceRange(
|
||||||
range.first as int, range.last as int?, replacement!);
|
range.first as int, range.last as int?, replacement);
|
||||||
} else if (range.first is String) {
|
} else if (range.first is String) {
|
||||||
contents = contents.replaceAll(range.first as String, replacement!);
|
contents = contents.replaceAll(range.first as String, replacement);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -155,20 +183,21 @@ Future renameDartFiles(Directory dir, String oldName, String newName) async {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
class RenamingVisitor extends RecursiveAstVisitor {
|
class RenamingVisitor extends RecursiveAstVisitor {
|
||||||
final String oldName, newName;
|
final String oldName, newName;
|
||||||
final Map<List, String?> replace = {};
|
final Map<List, String> replace = {};
|
||||||
|
|
||||||
RenamingVisitor(this.oldName, this.newName) {
|
RenamingVisitor(this.oldName, this.newName) {
|
||||||
replace[['{{$oldName}}']] = newName;
|
replace[['{{$oldName}}']] = newName;
|
||||||
}
|
}
|
||||||
|
|
||||||
String? updateUri(String? uri) {
|
String updateUri(String uri) {
|
||||||
if (uri == 'package:$oldName/$oldName.dart') {
|
if (uri == 'package:$oldName/$oldName.dart') {
|
||||||
return 'package:$newName/$newName.dart';
|
return 'package:$newName/$newName.dart';
|
||||||
} else if (uri!.startsWith('package:$oldName/')) {
|
} else if (uri.startsWith('package:$oldName/')) {
|
||||||
return 'package:$newName/' + uri.replaceFirst('package:$oldName/', '');
|
return 'package:$newName/' + uri.replaceFirst('package:$oldName/', '');
|
||||||
} else {
|
} else {
|
||||||
return uri;
|
return uri;
|
||||||
|
@ -177,15 +206,22 @@ class RenamingVisitor extends RecursiveAstVisitor {
|
||||||
|
|
||||||
@override
|
@override
|
||||||
void visitExportDirective(ExportDirective ctx) {
|
void visitExportDirective(ExportDirective ctx) {
|
||||||
var uri = ctx.uri.stringValue, updated = updateUri(uri);
|
var uri = ctx.uri.stringValue;
|
||||||
|
if (uri != null) {
|
||||||
|
var updated = updateUri(uri);
|
||||||
if (uri != updated) replace[[uri]] = updated;
|
if (uri != updated) replace[[uri]] = updated;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
void visitImportDirective(ImportDirective ctx) {
|
void visitImportDirective(ImportDirective ctx) {
|
||||||
var uri = ctx.uri.stringValue, updated = updateUri(uri);
|
var uri = ctx.uri.stringValue;
|
||||||
|
|
||||||
|
if (uri != null) {
|
||||||
|
var updated = updateUri(uri);
|
||||||
if (uri != updated) replace[[uri]] = updated;
|
if (uri != updated) replace[[uri]] = updated;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
void visitLibraryDirective(LibraryDirective ctx) {
|
void visitLibraryDirective(LibraryDirective ctx) {
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
name: angel3_cli
|
name: angel3_cli
|
||||||
version: 3.0.0-beta.2
|
version: 3.0.0
|
||||||
description: Command line tools for the Angel3 framework, including scaffolding.
|
description: Command line tools for the Angel3 framework, including scaffolding.
|
||||||
homepage: https://angel3-framework.web.app/
|
homepage: https://angel3-framework.web.app/
|
||||||
repository: https://github.com/dukefirehawk/angel3-cli
|
repository: https://github.com/dukefirehawk/angel3-cli
|
||||||
|
|
53
test/replace_name.dart
Normal file
53
test/replace_name.dart
Normal file
|
@ -0,0 +1,53 @@
|
||||||
|
import 'dart:io';
|
||||||
|
|
||||||
|
import 'package:dart_style/dart_style.dart';
|
||||||
|
|
||||||
|
void main() async {
|
||||||
|
String updateImport(String content, String oldName, String newName) {
|
||||||
|
if (!content.startsWith('import')) {
|
||||||
|
return content;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (content.contains('package:$oldName/$oldName.dart')) {
|
||||||
|
return content.replaceFirst(
|
||||||
|
'package:$oldName/$oldName.dart', 'package:$newName/$newName.dart');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (content.contains('package:$oldName/')) {
|
||||||
|
return content.replaceFirst('package:$oldName/', 'package:$newName/');
|
||||||
|
}
|
||||||
|
|
||||||
|
return content;
|
||||||
|
}
|
||||||
|
|
||||||
|
String updateMustacheBinding(String content, String oldName, String newName) {
|
||||||
|
if (content.contains('{{$oldName}}')) {
|
||||||
|
return content.replaceAll('{{$oldName}}', '$newName');
|
||||||
|
}
|
||||||
|
|
||||||
|
return content;
|
||||||
|
}
|
||||||
|
|
||||||
|
var fmt = DartFormatter();
|
||||||
|
var dir = Directory('graph');
|
||||||
|
await for (FileSystemEntity file in dir.list(recursive: true)) {
|
||||||
|
if (file is File && file.path.endsWith('.dart')) {
|
||||||
|
var lineList = await file.readAsLines();
|
||||||
|
|
||||||
|
var oldName = 'angel';
|
||||||
|
var newName = 'graph';
|
||||||
|
var replace = {oldName: newName};
|
||||||
|
|
||||||
|
if (replace.isNotEmpty) {
|
||||||
|
var contents = lineList.fold<String>('', (prev, cur) {
|
||||||
|
var updatedCur = updateImport(cur, oldName, newName);
|
||||||
|
updatedCur = updateMustacheBinding(updatedCur, oldName, newName);
|
||||||
|
return prev + '\n' + updatedCur;
|
||||||
|
});
|
||||||
|
await file.writeAsString(fmt.format(contents));
|
||||||
|
|
||||||
|
print('Updated file `${file.absolute.path}`.');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue