Compare commits

..

No commits in common. "master" and "v1.6.0" have entirely different histories.

4 changed files with 177 additions and 215 deletions

View File

@ -1,20 +1,5 @@
# Changelog # Changelog
## 1.6.2 - 2022-01-30 - ProgrammLogger improved
### New Features
* ProgrammLogger can now have a path while init, so not need to move the file
* Make it possible that two instances can use the same logfile
* IniReader GetValue can now have a default that returns if no setting is found
### Bugfixes
### Changes
* Codingstyles
## 1.6.1 - 2022-01-20 - ProgrammLogger Fixed
### New Features
### Bugfixes
* Unhandled exception. System.IO.IOException: The file '/var/log/zwaybot/debug.log' already exists.
### Changes
## 1.6.0 - 2022-01-09 - HttpEndpoint added ## 1.6.0 - 2022-01-09 - HttpEndpoint added
### New Features ### New Features
* Add HttpEndpoint * Add HttpEndpoint

View File

@ -31,7 +31,8 @@ namespace BlubbFish.Utils {
return false; return false;
} }
private InIReader(String filename) { private InIReader(String filename)
{
foreach (String path in search_path) { foreach (String path in search_path) {
if (File.Exists(path + Path.DirectorySeparatorChar + filename)) { if (File.Exists(path + Path.DirectorySeparatorChar + filename)) {
this.filename = path + Path.DirectorySeparatorChar + filename; this.filename = path + Path.DirectorySeparatorChar + filename;
@ -59,7 +60,8 @@ namespace BlubbFish.Utils {
/// </summary> /// </summary>
/// <param name="filename">Dateiname</param> /// <param name="filename">Dateiname</param>
/// <returns></returns> /// <returns></returns>
public static InIReader GetInstance(String filename) { public static InIReader GetInstance(String filename)
{
if (!instances.Keys.Contains(filename)) { if (!instances.Keys.Contains(filename)) {
instances.Add(filename, new InIReader(filename)); instances.Add(filename, new InIReader(filename));
} }
@ -68,7 +70,8 @@ namespace BlubbFish.Utils {
private void ReadAgain(Object sender, EventArgs e) => this.LoadFile(); private void ReadAgain(Object sender, EventArgs e) => this.LoadFile();
private void LoadFile() { private void LoadFile()
{
this.inifile = new Dictionary<String, Dictionary<String, String>>(); this.inifile = new Dictionary<String, Dictionary<String, String>>();
StreamReader file = new StreamReader(this.filename); StreamReader file = new StreamReader(this.filename);
List<String> buf = new List<String>(); List<String> buf = new List<String>();
@ -149,11 +152,12 @@ namespace BlubbFish.Utils {
/// <param name="section">Name der Sektion</param> /// <param name="section">Name der Sektion</param>
/// <param name="key">Name des Wertes</param> /// <param name="key">Name des Wertes</param>
/// <returns></returns> /// <returns></returns>
public String GetValue(String section, String key, String @default = null) { public String GetValue(String section, String key)
{
if (!section.StartsWith("[")) { if (!section.StartsWith("[")) {
section = "[" + section + "]"; section = "[" + section + "]";
} }
return this.inifile.Keys.Contains(section) && this.inifile[section].Keys.Contains(key) ? this.inifile[section][key] : @default; return this.inifile.Keys.Contains(section) && this.inifile[section].Keys.Contains(key) ? this.inifile[section][key] : null;
} }
/// <summary> /// <summary>

View File

@ -1,6 +1,5 @@
using System; using System;
using System.IO; using System.IO;
using System.Runtime.InteropServices;
using System.Text; using System.Text;
namespace BlubbFish.Utils { namespace BlubbFish.Utils {
@ -10,8 +9,8 @@ namespace BlubbFish.Utils {
private ConsoleWriter errout; private ConsoleWriter errout;
private String loggerfile; private String loggerfile;
public ProgramLogger(String path = null) { public ProgramLogger() {
this.loggerfile = path ?? Directory.GetCurrentDirectory() + Path.DirectorySeparatorChar + "output.log"; this.loggerfile = Directory.GetCurrentDirectory() + Path.DirectorySeparatorChar + "output.log";
this.Init(this.loggerfile); this.Init(this.loggerfile);
this.AttachToFw(); this.AttachToFw();
this.SetOutputs(); this.SetOutputs();
@ -27,7 +26,7 @@ namespace BlubbFish.Utils {
Console.Error.WriteLine("Cannot write to " + file); Console.Error.WriteLine("Cannot write to " + file);
throw new ArgumentException("Cannot write to " + file); throw new ArgumentException("Cannot write to " + file);
} }
this.fw = new FileWriter(FileWriter.GetFileSteam(file, false)); this.fw = new FileWriter(file);
this.stdout = new ConsoleWriter(Console.Out, ConsoleWriterEventArgs.ConsoleType.Info); this.stdout = new ConsoleWriter(Console.Out, ConsoleWriterEventArgs.ConsoleType.Info);
this.errout = new ConsoleWriter(Console.Error, ConsoleWriterEventArgs.ConsoleType.Error); this.errout = new ConsoleWriter(Console.Error, ConsoleWriterEventArgs.ConsoleType.Error);
} }
@ -54,37 +53,15 @@ namespace BlubbFish.Utils {
this.DisattachToFw(); this.DisattachToFw();
this.fw.Close(); this.fw.Close();
if(new FileInfo(this.loggerfile).Length > 0) { if(new FileInfo(this.loggerfile).Length > 0) {
if(File.Exists(file)) {
this.FileCopy(this.loggerfile, file);
File.Delete(this.loggerfile);
} else {
File.Move(this.loggerfile, file); File.Move(this.loggerfile, file);
}
} else { } else {
File.Delete(this.loggerfile); File.Delete(this.loggerfile);
} }
this.loggerfile = file; this.loggerfile = file;
this.fw = new FileWriter(FileWriter.GetFileSteam(this.loggerfile, true)); this.fw = new FileWriter(this.loggerfile);
this.AttachToFw(); this.AttachToFw();
} }
public void Dispose() {
this.DisattachToFw();
this.fw.Dispose();
}
private void FileCopy(String source, String target) {
using FileStream fread = new FileStream(source, FileMode.Open);
using FileStream fwrite = new FileStream(target, FileMode.Create);
using TextReader reader = new StreamReader(fread);
using TextWriter writer = new StreamWriter(fwrite);
writer.Write(reader.ReadToEnd());
writer.Flush();
writer.Close();
reader.Close();
}
private void DisattachToFw() { private void DisattachToFw() {
this.stdout.WriteEvent -= this.fw.Write; this.stdout.WriteEvent -= this.fw.Write;
this.stdout.WriteLineEvent -= this.fw.WriteLine; this.stdout.WriteLineEvent -= this.fw.WriteLine;
@ -101,11 +78,9 @@ namespace BlubbFish.Utils {
internal class FileWriter : StreamWriter { internal class FileWriter : StreamWriter {
private Boolean newline = true; private Boolean newline = true;
public FileWriter(FileStream fs) : base(fs) { public FileWriter(String path) : base(path) {
} }
public static FileStream GetFileSteam(String path, Boolean append) => File.Open(path, append ? FileMode.Append : FileMode.Create, FileAccess.Write, RuntimeInformation.IsOSPlatform(OSPlatform.Linux) ? FileShare.Write : FileShare.ReadWrite);
public override Encoding Encoding => Encoding.UTF8; public override Encoding Encoding => Encoding.UTF8;
public override Boolean AutoFlush { get => true; set => base.AutoFlush = value; } public override Boolean AutoFlush { get => true; set => base.AutoFlush = value; }

View File

@ -8,39 +8,37 @@
<Company>BlubbFish</Company> <Company>BlubbFish</Company>
<Authors>BlubbFish</Authors> <Authors>BlubbFish</Authors>
<PackageId>Utils.BlubbFish</PackageId> <PackageId>Utils.BlubbFish</PackageId>
<Copyright>Copyright © BlubbFish 2014 - 30.01.2022</Copyright> <Copyright>Copyright © BlubbFish 2014 - 09.01.2022</Copyright>
<Version>1.6.2</Version> <Version>1.6.0</Version>
<NeutralLanguage>de-DE</NeutralLanguage> <NeutralLanguage>de-DE</NeutralLanguage>
<PackageLicenseFile>LICENSE</PackageLicenseFile> <PackageLicenseFile>LICENSE</PackageLicenseFile>
<PackageProjectUrl>http://git.blubbfish.net/vs_utils/Utils</PackageProjectUrl> <PackageProjectUrl>http://git.blubbfish.net/vs_utils/Utils</PackageProjectUrl>
<RepositoryUrl>http://git.blubbfish.net/vs_utils/Utils.git</RepositoryUrl> <RepositoryUrl>http://git.blubbfish.net/vs_utils/Utils.git</RepositoryUrl>
<RepositoryType>git</RepositoryType> <RepositoryType>git</RepositoryType>
<PackageReleaseNotes> <PackageReleaseNotes>
1.6.2 - 2022-01-30 - ProgrammLogger improved 1.6.0 HttpEndpoint added
1.6.1 - 2022-01-20 - ProgrammLogger Fixed 1.5.0 Add GetEvent so you can call events by string; Add OwnSingeton class
1.6.0 - 2022-01-09 - HttpEndpoint added 1.4.0 Add Helper to Utils
1.5.0 - 2021-04-10 - Add GetEvent so you can call events by string; Add OwnSingeton class 1.1.3 Improve CmdArgs
1.4.0 - 2018-11-27 - Add Helper to Utils 1.1.2 Tiny Codingstyles
1.1.3 - 2018-10-02 - Improve CmdArgs 1.1.1 ProgrammLogger neets to cleanup
1.1.2 - 2018-09-11 - Tiny Codingstyles 1.1.0 ProgrammLogger
1.1.1 - 2018-05-29 - ProgrammLogger neets to cleanup 1.0.7.0 Yet another IniReader improvemnt round again
1.1.0 - 2018-05-15 - ProgrammLogger 1.0.6.0 Yet another IniReader improvemnt round
1.0.7.0 - 2018-05-08 - Yet another IniReader improvemnt round again 1.0.5.2 And Improve IniReader again
1.0.6.0 - 2017-12-22 - Yet another IniReader improvemnt round 1.0.5.1 Improve IniReader again
1.0.5.2 - 2017-09-26 - And Improve IniReader again 1.0.5.0 Improve IniReader
1.0.5.1 - 2017-09-24 - Improve IniReader again 1.0.4.1 Cleanup OwnView
1.0.5.0 - 2017-08-09 - Improve IniReader 1.0.4.0 More Updater
1.0.4.1 - 2017-08-08 - Cleanup OwnView 1.0.3.2 Next Updater
1.0.4.0 - 2017-04-30 - More Updater 1.0.3.1 EventArgsHelper
1.0.3.2 - 2017-04-26 - Next Updater 1.0.2.6 Better Updater
1.0.3.1 - 2017-04-25 - EventArgsHelper 1.0.2.5 Logging in OwnObject
1.0.2.6 - 2017-04-24 - Better Updater 1.0.2.3 OwnModel better
1.0.2.5 - 2017-04-19 - Logging in OwnObject 1.0.2.2 Make it nice
1.0.2.3 - 2017-04-16 - OwnModel better 1.0.2.1 Filemutex
1.0.2.2 - 2017-03-09 - Make it nice 1.0.0.1 Filelogger improvements
1.0.2.1 - 2017-03-09 - Filemutex 1.0.0.0 Init
1.0.0.1 - 2016-12-03 - Filelogger improvements
1.0.0.0 - 2015-11-16 - Init
</PackageReleaseNotes> </PackageReleaseNotes>
</PropertyGroup> </PropertyGroup>