Compare commits
	
		
			4 Commits
		
	
	
		
			8.0.118.14
			...
			10-22-a
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 69285cac1c | |||
| 2b13c8c198 | |||
| d06d417475 | |||
| abeb1892df | 
							
								
								
									
										134
									
								
								.vscode/launch.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										134
									
								
								.vscode/launch.json
									
									
									
									
										vendored
									
									
								
							| @ -1,56 +1,82 @@ | ||||
| { | ||||
|     "version": "0.2.0", | ||||
|     "configurations": [ | ||||
|         { | ||||
|             "name": "Compare", | ||||
|             "type": "coreclr", | ||||
|             "request": "launch", | ||||
|             "preLaunchTask": "Build-Compare", | ||||
|             "program": "${workspaceFolder}/Compare/bin/Debug/net9.0/win-x64/AA.Compare.dll", | ||||
|             "args": [ | ||||
|                 "s" | ||||
|             ], | ||||
|             "env": { | ||||
|                 "ASPNETCORE_ENVIRONMENT": "Development" | ||||
|             }, | ||||
|             "cwd": "${workspaceFolder}", | ||||
|             "console": "integratedTerminal", | ||||
|             "stopAtEntry": false, | ||||
|             "requireExactSource": false | ||||
|         }, | ||||
|         { | ||||
|             "name": "Rename", | ||||
|             "type": "coreclr", | ||||
|             "request": "launch", | ||||
|             "preLaunchTask": "Build-Rename", | ||||
|             "program": "${workspaceFolder}/Rename/bin/Debug/net9.0/win-x64/AA.Rename.dll", | ||||
|             "args": [ | ||||
|                 "s" | ||||
|             ], | ||||
|             "env": { | ||||
|                 "ASPNETCORE_ENVIRONMENT": "Development" | ||||
|             }, | ||||
|             "cwd": "${workspaceFolder}", | ||||
|             "console": "integratedTerminal", | ||||
|             "stopAtEntry": false, | ||||
|             "requireExactSource": false | ||||
|         }, | ||||
|         { | ||||
|             "name": "Windows", | ||||
|             "type": "coreclr", | ||||
|             "request": "launch", | ||||
|             "preLaunchTask": "Build-Windows", | ||||
|             "program": "${workspaceFolder}/Windows/bin/Debug/net9.0/win-x64/AA.Windows.dll", | ||||
|             "args": [ | ||||
|                 "s" | ||||
|             ], | ||||
|             "env": { | ||||
|                 "ASPNETCORE_ENVIRONMENT": "Development" | ||||
|             }, | ||||
|             "cwd": "${workspaceFolder}", | ||||
|             "console": "integratedTerminal", | ||||
|             "stopAtEntry": false, | ||||
|             "requireExactSource": false | ||||
|         } | ||||
|     ] | ||||
|   "version": "0.2.0", | ||||
|   "configurations": [ | ||||
|     { | ||||
|       "name": "Compare", | ||||
|       "type": "coreclr", | ||||
|       "request": "launch", | ||||
|       "preLaunchTask": "Build-Compare", | ||||
|       "program": "${workspaceFolder}/Compare/bin/Debug/net9.0/win-x64/AA.Compare.dll", | ||||
|       "args": [ | ||||
|         "s" | ||||
|       ], | ||||
|       "env": { | ||||
|         "ASPNETCORE_ENVIRONMENT": "Development" | ||||
|       }, | ||||
|       "cwd": "${workspaceFolder}", | ||||
|       "console": "integratedTerminal", | ||||
|       "stopAtEntry": false, | ||||
|       "requireExactSource": false | ||||
|     }, | ||||
|     { | ||||
|       "name": "Rename", | ||||
|       "type": "coreclr", | ||||
|       "request": "launch", | ||||
|       "preLaunchTask": "Build-Rename", | ||||
|       "program": "${workspaceFolder}/Rename/bin/Debug/net9.0/win-x64/AA.Rename.dll", | ||||
|       "args": [ | ||||
|         "s" | ||||
|       ], | ||||
|       "env": { | ||||
|         "ASPNETCORE_ENVIRONMENT": "Development" | ||||
|       }, | ||||
|       "cwd": "${workspaceFolder}", | ||||
|       "console": "integratedTerminal", | ||||
|       "stopAtEntry": false, | ||||
|       "requireExactSource": false | ||||
|     }, | ||||
|     { | ||||
|       "name": "Windows", | ||||
|       "type": "coreclr", | ||||
|       "request": "launch", | ||||
|       "preLaunchTask": "Build-Windows", | ||||
|       "program": "${workspaceFolder}/Windows/bin/Debug/net9.0/win-x64/AA.Windows.dll", | ||||
|       "args": [ | ||||
|         "s" | ||||
|       ], | ||||
|       "env": { | ||||
|         "ASPNETCORE_ENVIRONMENT": "Development" | ||||
|       }, | ||||
|       "cwd": "${workspaceFolder}", | ||||
|       "console": "integratedTerminal", | ||||
|       "stopAtEntry": false, | ||||
|       "requireExactSource": false | ||||
|     }, | ||||
|     { | ||||
|       "type": "node", | ||||
|       "request": "launch", | ||||
|       "name": "node Launch Current Opened File", | ||||
|       "program": "${file}" | ||||
|     }, | ||||
|     { | ||||
|       "type": "bun", | ||||
|       "internalConsoleOptions": "neverOpen", | ||||
|       "request": "launch", | ||||
|       "name": "Debug File", | ||||
|       "program": "${file}", | ||||
|       "cwd": "${workspaceFolder}", | ||||
|       "stopOnEntry": false, | ||||
|       "watchMode": false | ||||
|     }, | ||||
|     { | ||||
|       "type": "bun", | ||||
|       "internalConsoleOptions": "neverOpen", | ||||
|       "request": "launch", | ||||
|       "name": "Run File", | ||||
|       "program": "${file}", | ||||
|       "cwd": "${workspaceFolder}", | ||||
|       "noDebug": true, | ||||
|       "watchMode": false | ||||
|     } | ||||
|   ] | ||||
| } | ||||
							
								
								
									
										4
									
								
								.vscode/mklink.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.vscode/mklink.md
									
									
									
									
										vendored
									
									
								
							| @ -40,3 +40,7 @@ mklink /J "L:\Git\AA\Windows\.vscode\.iCloudPhotos2025" "D:\7-Question\iCloud Ph | ||||
| { "label": "Build-Rename", "command": "dotnet", "type": "process", "args": [ "build", "${workspaceFolder}/Rename/AA.Rename.csproj", "/property:GenerateFullPaths=true", "/consoleloggerparameters:NoSummary" ], "problemMatcher": "$msCompile" }, | ||||
| { "label": "Build-Shared", "command": "dotnet", "type": "process", "args": [ "build", "${workspaceFolder}/Shared/AA.Shared.csproj", "/property:GenerateFullPaths=true", "/consoleloggerparameters:NoSummary" ], "problemMatcher": "$msCompile" }, | ||||
| ``` | ||||
|  | ||||
| ```bash 1753233168670 = 638888299686700000 = 2025-3.Summer = Tue Jul 22 2025 18:12:48 GMT-0700 (Mountain Standard Time) | ||||
| mklink /J "L:\Git\AA\.vscode\helper\.638443643487798783" "D:\5-Other-Small\DigiKam\0113C7C3FED381A-hidden-c\638443643487798783" | ||||
| ``` | ||||
|  | ||||
| @ -36,8 +36,6 @@ public class A_Metadata | ||||
|             } | ||||
|         } | ||||
|         _ResultSingletonFileGroups = new(results); | ||||
|         ReadOnlyCollection<string> directories = new([Path.Combine(aResultsFullGroupDirectory, resultSettings.ResultSingleton)]); | ||||
|         IPath.CreateDirectories(directories); | ||||
|     } | ||||
|  | ||||
|     public (MinimumYearAndPathCombined, ExifDirectory) GetMetadataCollection(ResultSettings resultSettings, MetadataSettings metadataSettings, FilePath filePath) | ||||
|  | ||||
| @ -44,7 +44,7 @@ | ||||
|   </ItemGroup> | ||||
|   <ItemGroup> | ||||
|     <PackageReference Include="CliWrap" Version="3.8.2" /> | ||||
|     <PackageReference Include="runtime.win-x64.Microsoft.DotNet.ILCompiler" Version="8.0.12" /> | ||||
|     <PackageReference Include="runtime.win-x64.Microsoft.DotNet.ILCompiler" Version="9.0.10" /> | ||||
|     <PackageReference Include="Microsoft.Extensions.Configuration.Json" Version="8.0.1" /> | ||||
|     <PackageReference Include="Microsoft.Extensions.Configuration.UserSecrets" Version="8.0.1" /> | ||||
|     <PackageReference Include="Microsoft.Extensions.Hosting" Version="8.0.1" /> | ||||
|  | ||||
| @ -7,7 +7,6 @@ namespace View_by_Distance.Rename.Models; | ||||
|  | ||||
| public record RenameSettings(string Company, | ||||
|                              string DefaultMaker, | ||||
|                              Dictionary<string, string?> DirectoryDictionary, | ||||
|                              string? FirstPassFile, | ||||
|                              bool ForceNewId, | ||||
|                              bool InPlace, | ||||
|  | ||||
| @ -273,7 +273,6 @@ public partial class Rename : IRename, IDisposable | ||||
|     { | ||||
|         List<FirstPass> results = []; | ||||
|         int index = -1; | ||||
|         TimeSpan timeSpan; | ||||
|         foreach (KeyValuePair<string, List<FileHolder>> keyValuePair in keyValuePairs) | ||||
|         { | ||||
|             index += 1; | ||||
| @ -287,9 +286,6 @@ public partial class Rename : IRename, IDisposable | ||||
|             if (keyValuePair.Value.Count > 2) | ||||
|                 throw new NotSupportedException("Too many sidecar files!"); | ||||
|             SetFirstPassCollection(logger, appSettings, rename, ids, metadata, index, keyValuePair, results); | ||||
|             timeSpan = new(DateTime.Now.Ticks - rename.Ticks); | ||||
|             if (timeSpan.TotalMilliseconds > appSettings.RenameSettings.MaxMilliSecondsPerCall) | ||||
|                 break; | ||||
|         } | ||||
|         return results; | ||||
|     } | ||||
| @ -643,7 +639,6 @@ public partial class Rename : IRename, IDisposable | ||||
|             { | ||||
|                 if (record.ExifDirectory.FilePath.FullName[..2] != directoryInfo.FullName[..2]) | ||||
|                     isWrongYear = null; | ||||
|                 string directoryName; | ||||
|                 string tfw = GetTFW(record, isWrongYear); | ||||
|                 string? maker = IMetaBase.GetMaker(record.ExifDirectory); | ||||
|                 string rootDirectory = appSettings.ResultSettings.RootDirectory; | ||||
| @ -652,14 +647,7 @@ public partial class Rename : IRename, IDisposable | ||||
|                 string? splat = checkDirectoryName.Length > 3 && checkDirectoryName[^3..][1] == '!' ? checkDirectoryName[^3..] : null; | ||||
|                 string contains = record.ExifDirectory.FilePath.Id is null || ids.Contains(record.ExifDirectory.FilePath.Id.Value) ? "_ Exists _" : "_ New-Destination _"; | ||||
|                 string makerSplit = string.IsNullOrEmpty(maker) ? string.IsNullOrEmpty(appSettings.RenameSettings.DefaultMaker) ? string.Empty : appSettings.RenameSettings.DefaultMaker : $" {maker.Split(' ')[0]}"; | ||||
|                 if (!string.IsNullOrEmpty(splat) || isWrongYear is null || isWrongYear.Value || appSettings.RenameSettings.DirectoryDictionary.Count < 2) | ||||
|                     directoryName = GetDirectoryName(year, tfw, segments[0], splat, seasonValue, seasonName, makerSplit); | ||||
|                 else | ||||
|                 { | ||||
|                     directoryName = record.DateTime.ToString("yyyy-MM-dd"); | ||||
|                     if (appSettings.RenameSettings.DirectoryDictionary.TryGetValue(directoryName, out string? value) && !string.IsNullOrEmpty(value)) | ||||
|                         directoryName = value; | ||||
|                 } | ||||
|                 string directoryName = GetDirectoryName(year, tfw, segments[0], splat, seasonValue, seasonName, makerSplit); | ||||
|                 result = Path.GetFullPath(Path.Combine(rootDirectory, contains, directoryName)); | ||||
|             } | ||||
|         } | ||||
|  | ||||
							
								
								
									
										50
									
								
								Scripts/immich.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								Scripts/immich.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,50 @@ | ||||
| const axios = require('axios'); | ||||
|  | ||||
| const url = 'https://immich.bchs.duckdns.org'; | ||||
|  | ||||
| let config = { | ||||
|   method: 'get', | ||||
|   maxBodyLength: Infinity, | ||||
|   // url: url + '/api/users', | ||||
|   url: url + '/api/assets/f89d0de1-2762-4f9e-b60e-c7eeec93c4e9', | ||||
|   headers: { | ||||
|     'Accept': 'application/json', | ||||
|     'x-api-key': 'Pm2CbhJvgStEPAFKRVclW88qrOAy79OeIEcfj3k' | ||||
|   } | ||||
| }; | ||||
|  | ||||
|  | ||||
| axios.request(config) | ||||
|   .then((response) => { | ||||
|     console.log(JSON.stringify(response.data)); | ||||
|   }) | ||||
|   .catch((error) => { | ||||
|     console.log(error); | ||||
|   }); | ||||
|  | ||||
| // let data = JSON.stringify({ | ||||
| //   "avatar": { | ||||
| //     "color": "green" | ||||
| //   } | ||||
| // }); | ||||
|  | ||||
| // let configB = { | ||||
| //   method: 'put', | ||||
| //   maxBodyLength: Infinity, | ||||
| //   url: url + '/api/users/me/preferences', | ||||
| //   headers: { | ||||
| //     'Content-Type': 'application/json', | ||||
| //     'Accept': 'application/json', | ||||
| //     'x-api-key': 'Pm2CbhJvgStEPAFKRVclW88qrOAy79OeIEcfj3k' | ||||
| //   }, | ||||
| //   data: data | ||||
| // }; | ||||
|  | ||||
| // axios.request(configB) | ||||
| //   .then((response) => { | ||||
| //     console.log(JSON.stringify(response.data)); | ||||
| //   }) | ||||
| //   .catch((error) => { | ||||
| //     console.log(error); | ||||
| //   }); | ||||
|  | ||||
							
								
								
									
										36
									
								
								Scripts/job-search.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								Scripts/job-search.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,36 @@ | ||||
| import year from '../.vscode/helper/year.job.json' with { type: 'json' }; | ||||
| import event from '../.vscode/helper/event.job.json' with { type: 'json' }; | ||||
|  | ||||
| let file; | ||||
| let fromYear = []; | ||||
| let fromEvent = []; | ||||
| let fromYearEventPresent = []; | ||||
| let fromEventYearPresent = []; | ||||
| const pathA = 'L:/Git/AA/.vscode/helper/from-year-event-present.json'; | ||||
| const pathB = 'L:/Git/AA/.vscode/helper/from-event-year-present.json'; | ||||
|  | ||||
| year.Files.forEach(element => { | ||||
|     file = element.RelativePath.split('\\')[1]; | ||||
|     fromYear.push(file); | ||||
| }); | ||||
|  | ||||
| event.Files.forEach(element => { | ||||
|     file = element.RelativePath.split('\\')[1]; | ||||
|     fromEvent.push(file); | ||||
|     if (fromYear.includes(file)){ | ||||
|         fromYearEventPresent.push(file); | ||||
|     } | ||||
| }); | ||||
|  | ||||
| year.Files.forEach(element => { | ||||
|     file = element.RelativePath.split('\\')[1]; | ||||
|     if (fromEvent.includes(file)){ | ||||
|         fromEventYearPresent.push(file); | ||||
|     }; | ||||
| }); | ||||
|  | ||||
| const jsonA = JSON.stringify(fromYearEventPresent); | ||||
| await Bun.write(pathA, jsonA); | ||||
|  | ||||
| const jsonB = JSON.stringify(fromEventYearPresent); | ||||
| await Bun.write(pathB, jsonB); | ||||
							
								
								
									
										8
									
								
								Scripts/lsblk.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								Scripts/lsblk.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,8 @@ | ||||
|  | ||||
| fetch('https://html.affirm.duckdns.org/lsblk.json') | ||||
|     .then((res:any) => res.text()) | ||||
|     .then((text:any) => { | ||||
|         const data = JSON.parse(text); | ||||
|         console.log(data); | ||||
|     }) | ||||
|     .catch((e:any) => console.error(e)); | ||||
							
								
								
									
										27
									
								
								Scripts/people-to-sql.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								Scripts/people-to-sql.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,27 @@ | ||||
| import people from '../.vscode/helper/.638443643487798783/people.json' with { type: 'json' }; | ||||
|  | ||||
| const pathA = 'L:/Git/AA/.vscode/helper/.638443643487798783/id-name.sql'; | ||||
| const pathB = 'L:/Git/AA/.vscode/helper/.638443643487798783/id-name.json'; | ||||
|  | ||||
| let results = []; | ||||
| let name = ''; | ||||
| let person = {}; | ||||
| let line = ''; | ||||
| let lines = []; | ||||
| for (const property in people) { | ||||
|     person = people[property]; | ||||
|     name = person.Name.Suffix == undefined || person.Name.Suffix.length === 0 | ||||
|         ? person.Name.ForwardSlashFull | ||||
|         : person.Name.ForwardSlashFull + ' ' + person.Name.Suffix; | ||||
|         line = `update Tags set name = '${name}' where name = '${person.Birth.Note}';` | ||||
|         lines.push(line); | ||||
|         line = `update TagProperties set value = '${name}' where value = '${person.Birth.Note}';` | ||||
|         lines.push(line); | ||||
|     results.push({ id: person.Birth.Note, name: name }); | ||||
| } | ||||
|  | ||||
| const text = lines.join('\n'); | ||||
| await Bun.write(pathA, text); | ||||
|  | ||||
| const json = JSON.stringify(results); | ||||
| await Bun.write(pathB, json); | ||||
							
								
								
									
										115
									
								
								Scripts/podman.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										115
									
								
								Scripts/podman.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,115 @@ | ||||
| const server = 'jmlc'; | ||||
| let debug: Array<string> = []; | ||||
| let warning: Array<string> = []; | ||||
| let volumes: Array<string> = []; | ||||
| let volumeExportLines: Array<string> = []; | ||||
| const pathA = 'L:/Git/AA/.vscode/helper/podman.txt'; | ||||
|  | ||||
| await fetch(`https://html.${server}.duckdns.org/root.txt`) | ||||
|     .then((res: any) => res.text()) | ||||
|     .then((text: any) => { | ||||
|         const lines = text.trim().split('\n'); | ||||
|         for (let index = 0; index < lines.length; index++) { | ||||
|             const element = lines[index]; | ||||
|             if (element == undefined || element.length === 0 || element[0] === '#' || !element.includes('podman volume export')) { | ||||
|                 continue; | ||||
|             } | ||||
|             volumeExportLines.push(`${server}: root: ${element}`); | ||||
|             debug.push(`${server}: volume [${element}] is exported.`); | ||||
|         } | ||||
|     }) | ||||
|     .catch((e: any) => console.error(e)); | ||||
|  | ||||
| await fetch(`https://html.${server}.duckdns.org/podman.txt`) | ||||
|     .then((res: any) => res.text()) | ||||
|     .then((text: any) => { | ||||
|         const lines = text.trim().split('\n'); | ||||
|         for (let index = 0; index < lines.length; index++) { | ||||
|             const element = lines[index]; | ||||
|             if (element == undefined || element.length === 0 || element[0] === '#' || !element.includes('podman volume export')) { | ||||
|                 continue; | ||||
|             } | ||||
|             volumeExportLines.push(`${server}: podman: ${element}`); | ||||
|             debug.push(`${server}: volume [${element}] is exported.`); | ||||
|         } | ||||
|     }) | ||||
|     .catch((e: any) => console.error(e)); | ||||
|  | ||||
| await fetch(`https://html.${server}.duckdns.org/images-dangling-false.jsonl`) | ||||
|     .then((res: any) => res.text()) | ||||
|     .then((text: any) => { | ||||
|         const json = '[' + text.trim().split('\n').join(',') + ']'; | ||||
|         const data = JSON.parse(json); | ||||
|         for (let index = 0; index < data.length; index++) { | ||||
|             const element = data[index]; | ||||
|             debug.push(`${server}: image ${element.Name} is in use.`); | ||||
|         } | ||||
|     }) | ||||
|     .catch((e: any) => console.error(e)); | ||||
|  | ||||
| await fetch(`https://html.${server}.duckdns.org/volumes-dangling-false.jsonl`) | ||||
|     .then((res: any) => res.text()) | ||||
|     .then((text: any) => { | ||||
|         const json = '[' + text.trim().split('\n').join(',') + ']'; | ||||
|         const data = JSON.parse(json); | ||||
|         for (let index = 0; index < data.length; index++) { | ||||
|             const element = data[index]; | ||||
|             volumes.push(element.Name); | ||||
|             debug.push(`${server}: volume [${element.Name}] is in use.`); | ||||
|         } | ||||
|     }) | ||||
|     .catch((e: any) => console.error(e)); | ||||
|  | ||||
| await fetch(`https://html.${server}.duckdns.org/containers.jsonl`) | ||||
|     .then((res: any) => res.text()) | ||||
|     .then((text: any) => { | ||||
|         const json = '[' + text.trim().split('\n').join(',') + ']'; | ||||
|         const data = JSON.parse(json); | ||||
|         for (let index = 0; index < data.length; index++) { | ||||
|             const element = data[index]; | ||||
|             debug.push(`${server}: container [${element.Name}] is in use.`); | ||||
|         } | ||||
|     }) | ||||
|     .catch((e: any) => console.error(e)); | ||||
|  | ||||
| for (let index = 0; index < volumes.length; index++) { | ||||
|     let check: boolean = false; | ||||
|     const volumeExportLine: string | any = volumes[index]; | ||||
|     volumeExportLines.forEach(element => { | ||||
|         if (element.includes(volumeExportLine)) { | ||||
|             check = true; | ||||
|         } | ||||
|     }); | ||||
|     if (check) { | ||||
|         debug.push(`${server}: volume [${volumes[index]}] is being exported.`); | ||||
|     } | ||||
|     else { | ||||
|         warning.push(`${server}: ## 11 * * * podman volume export ${volumes[index]} --output /home/podman/cron-backup/${server}-${volumes[index]}-$(date +"\%Y-\%m-\%d--\%H-\%M-\%S").tar`); | ||||
|     } | ||||
| } | ||||
|  | ||||
| await fetch(`https://html.${server}.duckdns.org/volumes-dangling-true.jsonl`) | ||||
|     .then((res: any) => res.text()) | ||||
|     .then((text: any) => { | ||||
|         const json = '[' + text.trim().split('\n').join(',') + ']'; | ||||
|         const data = JSON.parse(json); | ||||
|         for (let index = 0; index < data.length; index++) { | ||||
|             const element = data[index]; | ||||
|             debug.push(`${server}: podman volume rm ${element.Name}`); | ||||
|         } | ||||
|     }) | ||||
|     .catch((e: any) => console.error(e)); | ||||
|  | ||||
| await fetch(`https://html.${server}.duckdns.org/images-dangling-true.jsonl`) | ||||
|     .then((res: any) => res.text()) | ||||
|     .then((text: any) => { | ||||
|         const json = '[' + text.trim().split('\n').join(',') + ']'; | ||||
|         const data = JSON.parse(json); | ||||
|         for (let index = 0; index < data.length; index++) { | ||||
|             const element = data[index]; | ||||
|             debug.push(`${server}: podman image rm ${element.ID}`); | ||||
|         } | ||||
|     }) | ||||
|     .catch((e: any) => console.error(e)); | ||||
|  | ||||
| await Bun.write(pathA, `${debug.join('\n')}\n${warning.join('\n')}`); | ||||
| @ -23,9 +23,6 @@ public interface IPath | ||||
|     public static void MakeHiddenIfAllItemsAreHidden(string rootDirectory) => | ||||
|         XPath.MakeHiddenIfAllItemsAreHidden(rootDirectory); | ||||
|  | ||||
|     public static void CreateDirectories(ReadOnlyCollection<string> directories) => | ||||
|         XPath.CreateDirectories(directories); | ||||
|  | ||||
|     public static void ChangeDateForEmptyDirectories(string rootDirectory, long ticks) => | ||||
|         XPath.ChangeDateForEmptyDirectories(rootDirectory, ticks); | ||||
|  | ||||
| @ -68,9 +65,6 @@ public interface IPath | ||||
|     internal void TestStatic_MakeHiddenIfAllItemsAreHidden(string rootDirectory) => | ||||
|         MakeHiddenIfAllItemsAreHidden(rootDirectory); | ||||
|  | ||||
|     internal void TestStatic_CreateDirectories(ReadOnlyCollection<string> directories) => | ||||
|         CreateDirectories(directories); | ||||
|  | ||||
|     internal void TestStatic_ChangeDateForEmptyDirectories(string rootDirectory, long ticks) => | ||||
|         ChangeDateForEmptyDirectories(rootDirectory, ticks); | ||||
|  | ||||
|  | ||||
| @ -202,20 +202,6 @@ internal abstract class XPath | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     internal static void CreateDirectories(ReadOnlyCollection<string> directories) | ||||
|     { | ||||
|         string checkDirectory; | ||||
|         foreach (string directory in directories) | ||||
|         { | ||||
|             for (int i = 0; i < 101; i++) | ||||
|             { | ||||
|                 checkDirectory = Path.Combine(directory, i.ToString("000")); | ||||
|                 if (!Directory.Exists(checkDirectory)) | ||||
|                     _ = Directory.CreateDirectory(checkDirectory); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     internal static void ChangeDateForEmptyDirectories(string rootDirectory, long ticks) | ||||
|     { | ||||
|         DateTime dateTime = new(ticks); | ||||
|  | ||||
							
								
								
									
										15
									
								
								package.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								package.json
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,15 @@ | ||||
| { | ||||
|   "name": "adaptation", | ||||
|   "module": "index.ts", | ||||
|   "type": "module", | ||||
|   "private": true, | ||||
|   "devDependencies": { | ||||
|     "@types/bun": "latest" | ||||
|   }, | ||||
|   "peerDependencies": { | ||||
|     "typescript": "^5" | ||||
|   }, | ||||
|   "scripts": { | ||||
|     "garbage-collect": "git gc" | ||||
|   } | ||||
| } | ||||
							
								
								
									
										29
									
								
								tsconfig.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								tsconfig.json
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,29 @@ | ||||
| { | ||||
|   "compilerOptions": { | ||||
|     // Environment setup & latest features | ||||
|     "lib": ["dom", "ESNext"], | ||||
|     "target": "ESNext", | ||||
|     "module": "Preserve", | ||||
|     "moduleDetection": "force", | ||||
|     "jsx": "react-jsx", | ||||
|     "allowJs": true, | ||||
|  | ||||
|     // Bundler mode | ||||
|     "moduleResolution": "bundler", | ||||
|     "allowImportingTsExtensions": true, | ||||
|     "verbatimModuleSyntax": true, | ||||
|     "noEmit": true, | ||||
|  | ||||
|     // Best practices | ||||
|     "strict": true, | ||||
|     "skipLibCheck": true, | ||||
|     "noFallthroughCasesInSwitch": true, | ||||
|     "noUncheckedIndexedAccess": true, | ||||
|     "noImplicitOverride": true, | ||||
|  | ||||
|     // Some stricter flags (disabled by default) | ||||
|     "noUnusedLocals": false, | ||||
|     "noUnusedParameters": false, | ||||
|     "noPropertyAccessFromIndexSignature": false | ||||
|   } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user