Skip to content

Commit

Permalink
[modgen] maxdepth = 3 lors de la recherche d'un fichier de config + f…
Browse files Browse the repository at this point in the history
…ix build pour samples
  • Loading branch information
JabX committed Sep 24, 2024
1 parent 67f27db commit 7f2947a
Show file tree
Hide file tree
Showing 9 changed files with 67 additions and 36 deletions.
87 changes: 51 additions & 36 deletions TopModel.Generator/Program.cs
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
using System.Text;
using System.Text.Encodings.Web;
using System.Text.Json.Nodes;
using System.Text.RegularExpressions;
using System.Xml;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
Expand Down Expand Up @@ -88,12 +89,30 @@ void HandleFile(FileInfo file)
else
{
var dir = Directory.GetCurrentDirectory();
var pattern = "topmodel*.config";
foreach (var fileName in Directory.EnumerateFiles(dir, pattern, SearchOption.AllDirectories))
var pattern = new Regex("topmodel\\.?([a-zA-Z-_.]*)\\.config$");

void SearchConfigFile(string dirName, int depth = 0)
{
HandleFile(new FileInfo(fileName));
if (depth > 3)
{
return;
}

foreach (var entryName in Directory.EnumerateFileSystemEntries(dirName))
{
if (Directory.Exists(entryName))
{
SearchConfigFile(entryName, depth + 1);
}
else if (pattern.IsMatch(entryName))
{
HandleFile(new FileInfo(entryName));
}
}
}

SearchConfigFile(dir);

if (configs.Count == 0)
{
var found = false;
Expand All @@ -102,7 +121,7 @@ void HandleFile(FileInfo file)
dir = Directory.GetParent(dir)?.FullName;
if (dir != null)
{
foreach (var fileName in Directory.EnumerateFiles(dir, pattern))
foreach (var fileName in Directory.EnumerateFiles(dir).Where(f => pattern.IsMatch(f)))
{
HandleFile(new FileInfo(fileName));
found = true;
Expand Down Expand Up @@ -233,17 +252,18 @@ void HandleFile(FileInfo file)

foreach (var cg in config.CustomGenerators)
{
var customDir = Path.GetFullPath(Path.Combine(new FileInfo(Path.GetFullPath(fullName)).DirectoryName!, cg));

string GetCgHash()
{
return GetHash(
GetCustomAssemblies(cg, fullName).Select(f => f.FullName)
.Concat(Directory.EnumerateFiles(
Directory
.EnumerateFiles(
Path.GetFullPath(cg, new FileInfo(fullName).DirectoryName!),
"*.cs",
SearchOption.AllDirectories)
.Where(f => !f.Contains($"{Path.DirectorySeparatorChar}obj{Path.DirectorySeparatorChar}")))
.ToList(),
cg) ?? string.Empty;
.Where(f => !f.Contains($"{Path.DirectorySeparatorChar}obj{Path.DirectorySeparatorChar}")),
customDir) ?? string.Empty;
}

var customHash = GetCgHash();
Expand All @@ -254,9 +274,9 @@ string GetCgHash()
{
CreateNoWindow = true,
WindowStyle = ProcessWindowStyle.Hidden,
FileName = "dotnet.exe",
FileName = "dotnet",
Arguments = "build -v q",
WorkingDirectory = cg,
WorkingDirectory = customDir,
RedirectStandardOutput = true,
StandardOutputEncoding = Encoding.UTF8
});
Expand Down Expand Up @@ -285,13 +305,25 @@ string GetCgHash()
config.CustomGenerators.AddRange(modules.Select(m => Path.GetRelativePath(new FileInfo(fullName).DirectoryName!, m).Replace("\\", "/")));
}

var modgenRoot = Path.GetFullPath(".modgen", config.ModelRoot);

if (updateMode == "all")
{
topModelLock.Modules = [];

if (Directory.Exists(modgenRoot))
{
Directory.Delete(modgenRoot, true);
}
}
else if (updateMode != null)
{
topModelLock.Modules.Remove(updateMode);

foreach (var module in Directory.GetFileSystemEntries(modgenRoot).Where(p => p.Split('/').Last().Contains(updateMode)))
{
Directory.Delete(module, true);
}
}

foreach (var cg in config.CustomGenerators)
Expand Down Expand Up @@ -351,7 +383,10 @@ string GetCgHash()

if (returnCode == 0)
{
var assemblies = GetCustomAssemblies(cg, fullName)
var assemblies = new DirectoryInfo(Path.Combine(Path.GetFullPath(cg, new FileInfo(fullName).DirectoryName!), "bin"))
.GetFiles($"*.dll", SearchOption.AllDirectories)
.Where(a => a.FullName.Contains(framework) && !modgenAssemblies.Contains(a.Name))
.DistinctBy(a => a.Name)
.Select(f => Assembly.LoadFrom(f.FullName))
.ToList();

Expand Down Expand Up @@ -397,19 +432,6 @@ string GetCgHash()
}

var hasInstalled = false;
var modgenRoot = Path.GetFullPath(".modgen", config.ModelRoot);

if (updateMode == "all" && Directory.Exists(modgenRoot))
{
Directory.Delete(modgenRoot, true);
}
else if (updateMode != null)
{
foreach (var module in Directory.GetFileSystemEntries(modgenRoot).Where(p => p.Split('/').Last().Contains(updateMode)))
{
Directory.Delete(module, true);
}
}

if (deps.Count > 0)
{
Expand Down Expand Up @@ -674,25 +696,18 @@ string GetCgHash()

return returnCode;

IEnumerable<FileInfo> GetCustomAssemblies(string cg, string fullName)
{
return new DirectoryInfo(Path.Combine(Path.GetFullPath(cg, new FileInfo(fullName).DirectoryName!), "bin"))
.GetFiles($"*.dll", SearchOption.AllDirectories)
.Where(a => a.FullName.Contains(framework) && !modgenAssemblies.Contains(a.Name))
.DistinctBy(a => a.Name);
}

static string? GetFolderHash(string path)
{
return GetHash(Directory.EnumerateFiles(path, "*", SearchOption.AllDirectories).OrderBy(p => p).ToList(), path);
return GetHash(Directory.EnumerateFiles(path, "*", SearchOption.AllDirectories), path);
}

static string? GetHash(IList<string> files, string path)
static string? GetHash(IEnumerable<string> f, string path)
{
var md5 = MD5.Create();
var files = f.OrderBy(f => f).ToList();
foreach (var file in files)
{
var relativePath = file[(path.Length + 1)..];
var relativePath = Path.GetRelativePath(path, file).Replace("\\", "/");
var pathBytes = Encoding.UTF8.GetBytes(relativePath.ToLower());
md5.TransformBlock(pathBytes, 0, pathBytes.Length, pathBytes, 0);

Expand Down
2 changes: 2 additions & 0 deletions samples/model/angular.topmodel.lock
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@

version: 2.1.0
modules: {}
custom:
../../../TopModel.Generator.Javascript: e39801d826bcb9c740ebb356ac0b7fbb
generatedFiles:
- ../generators/angular/src/appgenerated/api/securite/profil/profil.service.ts
- ../generators/angular/src/appgenerated/api/securite/utilisateur/utilisateur.service.ts
Expand Down
2 changes: 2 additions & 0 deletions samples/model/csharp.topmodel.lock
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@

version: 2.1.0
modules: {}
custom:
../../../TopModel.Generator.Csharp: 121e8b5ce6a8be344945262bf8960580
generatedFiles:
- ../generators/csharp/src/Clients/CSharp.Clients.Db/generated/CSharpDbContext.comments.cs
- ../generators/csharp/src/Clients/CSharp.Clients.Db/generated/CSharpDbContext.cs
Expand Down
2 changes: 2 additions & 0 deletions samples/model/focus.topmodel.lock
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@

version: 2.1.0
modules: {}
custom:
../../../TopModel.Generator.Javascript: e39801d826bcb9c740ebb356ac0b7fbb
generatedFiles:
- ../generators/focus/src/locale/common.ts
- ../generators/focus/src/locale/securite.ts
Expand Down
2 changes: 2 additions & 0 deletions samples/model/jpa.topmodel.lock
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@

version: 2.1.0
modules: {}
custom:
../../../TopModel.Generator.Jpa: 3df4f5992b92ce79d5bfddf465926bd2
generatedFiles:
- ../generators/jpa/src/main/javagen/topmodel/jpa/sample/demo/api/client/securite/profil/ProfilClient.java
- ../generators/jpa/src/main/javagen/topmodel/jpa/sample/demo/api/client/securite/utilisateur/UtilisateurClient.java
Expand Down
2 changes: 2 additions & 0 deletions samples/model/pg.topmodel.lock
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@

version: 2.1.0
modules: {}
custom:
../../../TopModel.Generator.Sql: a7d6d70714c8ee38aeac8e9447ed12fd
generatedFiles:
- ../generators/pg/src/01_tables.sql
- ../generators/pg/src/02_fk_indexes.sql
Expand Down
2 changes: 2 additions & 0 deletions samples/model/php.topmodel.lock
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@

version: 2.1.0
modules: {}
custom:
../../../TopModel.Generator.Php: 8029e36a5806c385b25b725c2e00ecdc
generatedFiles:
- ../generators/php/src/Entity/Securite/Profil/Droit.php
- ../generators/php/src/Entity/Securite/Profil/Profil.php
Expand Down
2 changes: 2 additions & 0 deletions samples/model/ssdt.topmodel.lock
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@

version: 2.1.0
modules: {}
custom:
../../../TopModel.Generator.Sql: a7d6d70714c8ee38aeac8e9447ed12fd
generatedFiles:
- ../generators/ssdt/src/init/DROIT.insert.sql
- ../generators/ssdt/src/init/main.sql
Expand Down
2 changes: 2 additions & 0 deletions samples/model/translation.topmodel.lock
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@

version: 2.1.0
modules: {}
custom:
../../../TopModel.Generator.Translation: 9f15a161c1cd09a554e17eb18f624495
generatedFiles:
- ../generators/translation/i18n/de_DE/out/common_de_DE.properties
- ../generators/translation/i18n/de_DE/out/securite_de_DE.properties
Expand Down

0 comments on commit 7f2947a

Please sign in to comment.