Compare commits
43 Commits
Author | SHA1 | Date | |
---|---|---|---|
cc579102cb | |||
e3d37988c9 | |||
61f26e69af | |||
528dcabf59 | |||
baed3c9e08 | |||
edb3069bb0 | |||
a5249f8fac | |||
b4e17972b9 | |||
65fdcdc12c | |||
69f5534523 | |||
4296649dca | |||
126632b4c9 | |||
2b40c85203 | |||
8606362ed7 | |||
b449223514 | |||
c313994aeb | |||
b184187e21 | |||
affe298cf9 | |||
62b0d478c5 | |||
dcfb0e6272 | |||
37d3b8c5a8 | |||
7b298b591b | |||
6f7632aa3d | |||
51ee703bd4 | |||
47fb4f8c27 | |||
f2706b2b29 | |||
ab40973980 | |||
f8f28105d9 | |||
f310d2a1df | |||
bf047a58e3 | |||
22d8a9ff2a | |||
de32d997fb | |||
6ac8ec0cfa | |||
c215d27841 | |||
2e05bde250 | |||
f8cf31c941 | |||
73ea61487e | |||
b3b9ceb283 | |||
45f40263ad | |||
d84add4871 | |||
884a59b206 | |||
6f8cebc25d | |||
185b4bc00c |
3
.gitignore
vendored
Normal file
3
.gitignore
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
/.vs
|
||||||
|
/Utils/obj
|
||||||
|
/Utils/bin
|
92
CONTRIBUTING.md
Normal file
92
CONTRIBUTING.md
Normal file
@ -0,0 +1,92 @@
|
|||||||
|
# Contributing
|
||||||
|
|
||||||
|
When contributing to this repository, please first discuss the change you wish to make via issue,
|
||||||
|
email, or any other method with the owners of this repository before making a change.
|
||||||
|
|
||||||
|
Please note we have a code of conduct, please follow it in all your interactions with the project.
|
||||||
|
|
||||||
|
## Pull Request Process
|
||||||
|
|
||||||
|
1. Ensure any install or build dependencies are removed before the end of the layer when doing a
|
||||||
|
build.
|
||||||
|
2. Update the README.md with details of changes to the interface, this includes new environment
|
||||||
|
variables, exposed ports, useful file locations and container parameters.
|
||||||
|
3. Increase the version numbers in any examples files and the README.md to the new version that this
|
||||||
|
Pull Request would represent. The versioning scheme we use is [SemVer](http://semver.org/).
|
||||||
|
4. You may merge the Pull Request in once you have the sign-off of two other developers, or if you
|
||||||
|
do not have permission to do that, you may request the second reviewer to merge it for you.
|
||||||
|
|
||||||
|
## Code of Conduct
|
||||||
|
|
||||||
|
### Our Pledge
|
||||||
|
|
||||||
|
In the interest of fostering an open and welcoming environment, we as
|
||||||
|
contributors and maintainers pledge to making participation in our project and
|
||||||
|
our community a harassment-free experience for everyone, regardless of age, body
|
||||||
|
size, disability, ethnicity, gender identity and expression, level of experience,
|
||||||
|
nationality, personal appearance, race, religion, or sexual identity and
|
||||||
|
orientation.
|
||||||
|
|
||||||
|
### Our Standards
|
||||||
|
|
||||||
|
Examples of behavior that contributes to creating a positive environment
|
||||||
|
include:
|
||||||
|
|
||||||
|
* Using welcoming and inclusive language
|
||||||
|
* Being respectful of differing viewpoints and experiences
|
||||||
|
* Gracefully accepting constructive criticism
|
||||||
|
* Focusing on what is best for the community
|
||||||
|
* Showing empathy towards other community members
|
||||||
|
|
||||||
|
Examples of unacceptable behavior by participants include:
|
||||||
|
|
||||||
|
* The use of sexualized language or imagery and unwelcome sexual attention or
|
||||||
|
advances
|
||||||
|
* Trolling, insulting/derogatory comments, and personal or political attacks
|
||||||
|
* Public or private harassment
|
||||||
|
* Publishing others' private information, such as a physical or electronic
|
||||||
|
address, without explicit permission
|
||||||
|
* Other conduct which could reasonably be considered inappropriate in a
|
||||||
|
professional setting
|
||||||
|
|
||||||
|
### Our Responsibilities
|
||||||
|
|
||||||
|
Project maintainers are responsible for clarifying the standards of acceptable
|
||||||
|
behavior and are expected to take appropriate and fair corrective action in
|
||||||
|
response to any instances of unacceptable behavior.
|
||||||
|
|
||||||
|
Project maintainers have the right and responsibility to remove, edit, or
|
||||||
|
reject comments, commits, code, wiki edits, issues, and other contributions
|
||||||
|
that are not aligned to this Code of Conduct, or to ban temporarily or
|
||||||
|
permanently any contributor for other behaviors that they deem inappropriate,
|
||||||
|
threatening, offensive, or harmful.
|
||||||
|
|
||||||
|
### Scope
|
||||||
|
|
||||||
|
This Code of Conduct applies both within project spaces and in public spaces
|
||||||
|
when an individual is representing the project or its community. Examples of
|
||||||
|
representing a project or community include using an official project e-mail
|
||||||
|
address, posting via an official social media account, or acting as an appointed
|
||||||
|
representative at an online or offline event. Representation of a project may be
|
||||||
|
further defined and clarified by project maintainers.
|
||||||
|
|
||||||
|
### Enforcement
|
||||||
|
|
||||||
|
Instances of abusive, harassing, or otherwise unacceptable behavior may be
|
||||||
|
reported by contacting the project team at git ATTTT blubbfish.net. All
|
||||||
|
complaints will be reviewed and investigated and will result in a response that
|
||||||
|
is deemed necessary and appropriate to the circumstances. The project team is
|
||||||
|
obligated to maintain confidentiality with regard to the reporter of an incident.
|
||||||
|
Further details of specific enforcement policies may be posted separately.
|
||||||
|
|
||||||
|
Project maintainers who do not follow or enforce the Code of Conduct in good
|
||||||
|
faith may face temporary or permanent repercussions as determined by other
|
||||||
|
members of the project's leadership.
|
||||||
|
|
||||||
|
### Attribution
|
||||||
|
|
||||||
|
This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4,
|
||||||
|
available at [http://contributor-covenant.org/version/1/4][version]
|
||||||
|
|
||||||
|
[homepage]: http://contributor-covenant.org
|
||||||
|
[version]: http://contributor-covenant.org/version/1/4/
|
188
Changelog.md
Normal file
188
Changelog.md
Normal file
@ -0,0 +1,188 @@
|
|||||||
|
# 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
|
||||||
|
### New Features
|
||||||
|
* Add HttpEndpoint
|
||||||
|
### Bugfixes
|
||||||
|
### Changes
|
||||||
|
* Change Readme that its link to the normal repo
|
||||||
|
* Codingstyles
|
||||||
|
* Fixing history
|
||||||
|
|
||||||
|
## 1.5.0 - 2021-04-10 - Add GetEvent so you can call events by string; Add OwnSingeton class
|
||||||
|
### New Features
|
||||||
|
* More allowed Chars for Chapters in inifile
|
||||||
|
* Add Contribution, Licence and readme
|
||||||
|
* Adding netcore
|
||||||
|
* Add changelog
|
||||||
|
* Filedhelper to helpter
|
||||||
|
* CmdArgs improvements
|
||||||
|
* Make netcore to default
|
||||||
|
* Add OwnSingleton
|
||||||
|
### Bugfixes
|
||||||
|
* WriteLine in Programmlogger sometimes make nonesense
|
||||||
|
* Writeline event are wrong
|
||||||
|
### Changes
|
||||||
|
* Remove the binary files
|
||||||
|
* Move all Classes to subfolder
|
||||||
|
* Codingstyles
|
||||||
|
|
||||||
|
## 1.4.0 - 2018-11-27 - Add Helper to Utils
|
||||||
|
### New Features
|
||||||
|
* Add Helper
|
||||||
|
### Bugfixes
|
||||||
|
### Changes
|
||||||
|
|
||||||
|
## 1.1.3 - 2018-10-02 - Improve CmdArgs
|
||||||
|
### New Features
|
||||||
|
* CmdArgs now throw extensions if there is something wrong
|
||||||
|
### Bugfixes
|
||||||
|
### Changes
|
||||||
|
|
||||||
|
## 1.1.2 - 2018-09-11 - Tiny Codingstyles
|
||||||
|
### New Features
|
||||||
|
### Bugfixes
|
||||||
|
### Changes
|
||||||
|
* Codingstyles
|
||||||
|
|
||||||
|
## 1.1.1 - 2018-05-29 - ProgrammLogger neets to cleanup
|
||||||
|
### New Features
|
||||||
|
* Delete the Mess behind
|
||||||
|
### Bugfixes
|
||||||
|
### Changes
|
||||||
|
|
||||||
|
## 1.1.0 - 2018-05-15 - ProgrammLogger
|
||||||
|
### New Features
|
||||||
|
* Add Programmlogger
|
||||||
|
### Bugfixes
|
||||||
|
### Changes
|
||||||
|
* Codingstyles
|
||||||
|
|
||||||
|
## 1.0.7.0 - 2018-05-08 - Yet another IniReader improvemnt round again
|
||||||
|
### New Features
|
||||||
|
### Bugfixes
|
||||||
|
### Changes
|
||||||
|
* Move searchpath to its own function
|
||||||
|
|
||||||
|
## 1.0.6.0 - 2017-12-22 - Yet another IniReader improvemnt round
|
||||||
|
### New Features
|
||||||
|
* Posibillity to add complete sections to an ini file
|
||||||
|
### Bugfixes
|
||||||
|
### Changes
|
||||||
|
|
||||||
|
## 1.0.5.2 - 2017-09-26 - And Improve IniReader again
|
||||||
|
### New Features
|
||||||
|
* IniReader returns the Sections with or without Brackets now
|
||||||
|
### Bugfixes
|
||||||
|
### Changes
|
||||||
|
|
||||||
|
## 1.0.5.1 - 2017-09-24 - Improve IniReader again
|
||||||
|
### New Features
|
||||||
|
### Bugfixes
|
||||||
|
* IniReader now supports umlaute
|
||||||
|
* IniReader matches with Brackets and without
|
||||||
|
### Changes
|
||||||
|
|
||||||
|
## 1.0.5.0 - 2017-08-09 - Improve IniReader
|
||||||
|
### New Features
|
||||||
|
* IniReader can now return a whole segemt
|
||||||
|
### Bugfixes
|
||||||
|
### Changes
|
||||||
|
|
||||||
|
## 1.0.4.1 - 2017-08-08 - Cleanup OwnView
|
||||||
|
### New Features
|
||||||
|
### Bugfixes
|
||||||
|
### Changes
|
||||||
|
* remove Init from OwnView
|
||||||
|
|
||||||
|
## 1.0.4.0 - 2017-04-30 - More Updater
|
||||||
|
### New Features
|
||||||
|
* continue Development of Updater
|
||||||
|
### Bugfixes
|
||||||
|
### Changes
|
||||||
|
|
||||||
|
## 1.0.3.2 - 2017-04-26 - Next Updater
|
||||||
|
### New Features
|
||||||
|
* continue Development of Updater
|
||||||
|
### Bugfixes
|
||||||
|
### Changes
|
||||||
|
|
||||||
|
## 1.0.3.1 - 2017-04-25 - EventArgsHelper
|
||||||
|
### New Features
|
||||||
|
* Add EventArgsHelper
|
||||||
|
### Bugfixes
|
||||||
|
### Changes
|
||||||
|
* Codingstyles
|
||||||
|
* Moves LogEventArgs to EventArgsHelper
|
||||||
|
* Moves UpdaterEventArgs to EventArgsHelper
|
||||||
|
|
||||||
|
## 1.0.2.6 - 2017-04-24 - Better Updater
|
||||||
|
### New Features
|
||||||
|
* Add Updater
|
||||||
|
* Add Disposable Interface
|
||||||
|
* Using LogEventArgs now for Logging
|
||||||
|
* Make UpdaterEventArgs as Child of EventArgs
|
||||||
|
* Updater now using Ownobject as Parent
|
||||||
|
* Add VersionsInfo to Updater
|
||||||
|
* Updater spawns a Background Task to Check for Updates
|
||||||
|
### Bugfixes
|
||||||
|
### Changes
|
||||||
|
|
||||||
|
## 1.0.2.5 - 2017-04-19 - Logging in OwnObject
|
||||||
|
### New Features
|
||||||
|
* Add Logging to OwnObject
|
||||||
|
### Bugfixes
|
||||||
|
* Avoid nullpointer exception in FileMutex
|
||||||
|
### Changes
|
||||||
|
* Codingstyles
|
||||||
|
|
||||||
|
## 1.0.2.3 - 2017-04-16 - OwnModel better
|
||||||
|
### New Features
|
||||||
|
* Add Remove observer on OwnModel
|
||||||
|
### Bugfixes
|
||||||
|
### Changes
|
||||||
|
* Codingstyles
|
||||||
|
|
||||||
|
## 1.0.2.2 - 2017-03-09 - Make it nice
|
||||||
|
### New Features
|
||||||
|
### Bugfixes
|
||||||
|
### Changes
|
||||||
|
* Codingstyles
|
||||||
|
|
||||||
|
## 1.0.2.1 - 2017-03-09 - Filemutex
|
||||||
|
### New Features
|
||||||
|
* Add Filemutex
|
||||||
|
### Bugfixes
|
||||||
|
* Filelogger backet on wrong pos
|
||||||
|
### Changes
|
||||||
|
|
||||||
|
## 1.0.0.1 - 2016-12-03 - Filelogger improvements
|
||||||
|
### New Features
|
||||||
|
* Check Directory and if not exist add it
|
||||||
|
* Now logs with timestamp
|
||||||
|
* Can select logdir
|
||||||
|
* Add Abstract dispose to OwnController
|
||||||
|
### Bugfixes
|
||||||
|
### Changes
|
||||||
|
|
||||||
|
## 1.0.0.0 - 2015-11-16 - Init
|
||||||
|
### New Features
|
||||||
|
* Add CmdArgs, FileLogger, IniReader, OwnController, OwnModel, OwnObject, OwnView,
|
||||||
|
### Bugfixes
|
||||||
|
### Changes
|
||||||
|
|
165
LICENSE
Normal file
165
LICENSE
Normal file
@ -0,0 +1,165 @@
|
|||||||
|
GNU LESSER GENERAL PUBLIC LICENSE
|
||||||
|
Version 3, 29 June 2007
|
||||||
|
|
||||||
|
Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/>
|
||||||
|
Everyone is permitted to copy and distribute verbatim copies
|
||||||
|
of this license document, but changing it is not allowed.
|
||||||
|
|
||||||
|
|
||||||
|
This version of the GNU Lesser General Public License incorporates
|
||||||
|
the terms and conditions of version 3 of the GNU General Public
|
||||||
|
License, supplemented by the additional permissions listed below.
|
||||||
|
|
||||||
|
0. Additional Definitions.
|
||||||
|
|
||||||
|
As used herein, "this License" refers to version 3 of the GNU Lesser
|
||||||
|
General Public License, and the "GNU GPL" refers to version 3 of the GNU
|
||||||
|
General Public License.
|
||||||
|
|
||||||
|
"The Library" refers to a covered work governed by this License,
|
||||||
|
other than an Application or a Combined Work as defined below.
|
||||||
|
|
||||||
|
An "Application" is any work that makes use of an interface provided
|
||||||
|
by the Library, but which is not otherwise based on the Library.
|
||||||
|
Defining a subclass of a class defined by the Library is deemed a mode
|
||||||
|
of using an interface provided by the Library.
|
||||||
|
|
||||||
|
A "Combined Work" is a work produced by combining or linking an
|
||||||
|
Application with the Library. The particular version of the Library
|
||||||
|
with which the Combined Work was made is also called the "Linked
|
||||||
|
Version".
|
||||||
|
|
||||||
|
The "Minimal Corresponding Source" for a Combined Work means the
|
||||||
|
Corresponding Source for the Combined Work, excluding any source code
|
||||||
|
for portions of the Combined Work that, considered in isolation, are
|
||||||
|
based on the Application, and not on the Linked Version.
|
||||||
|
|
||||||
|
The "Corresponding Application Code" for a Combined Work means the
|
||||||
|
object code and/or source code for the Application, including any data
|
||||||
|
and utility programs needed for reproducing the Combined Work from the
|
||||||
|
Application, but excluding the System Libraries of the Combined Work.
|
||||||
|
|
||||||
|
1. Exception to Section 3 of the GNU GPL.
|
||||||
|
|
||||||
|
You may convey a covered work under sections 3 and 4 of this License
|
||||||
|
without being bound by section 3 of the GNU GPL.
|
||||||
|
|
||||||
|
2. Conveying Modified Versions.
|
||||||
|
|
||||||
|
If you modify a copy of the Library, and, in your modifications, a
|
||||||
|
facility refers to a function or data to be supplied by an Application
|
||||||
|
that uses the facility (other than as an argument passed when the
|
||||||
|
facility is invoked), then you may convey a copy of the modified
|
||||||
|
version:
|
||||||
|
|
||||||
|
a) under this License, provided that you make a good faith effort to
|
||||||
|
ensure that, in the event an Application does not supply the
|
||||||
|
function or data, the facility still operates, and performs
|
||||||
|
whatever part of its purpose remains meaningful, or
|
||||||
|
|
||||||
|
b) under the GNU GPL, with none of the additional permissions of
|
||||||
|
this License applicable to that copy.
|
||||||
|
|
||||||
|
3. Object Code Incorporating Material from Library Header Files.
|
||||||
|
|
||||||
|
The object code form of an Application may incorporate material from
|
||||||
|
a header file that is part of the Library. You may convey such object
|
||||||
|
code under terms of your choice, provided that, if the incorporated
|
||||||
|
material is not limited to numerical parameters, data structure
|
||||||
|
layouts and accessors, or small macros, inline functions and templates
|
||||||
|
(ten or fewer lines in length), you do both of the following:
|
||||||
|
|
||||||
|
a) Give prominent notice with each copy of the object code that the
|
||||||
|
Library is used in it and that the Library and its use are
|
||||||
|
covered by this License.
|
||||||
|
|
||||||
|
b) Accompany the object code with a copy of the GNU GPL and this license
|
||||||
|
document.
|
||||||
|
|
||||||
|
4. Combined Works.
|
||||||
|
|
||||||
|
You may convey a Combined Work under terms of your choice that,
|
||||||
|
taken together, effectively do not restrict modification of the
|
||||||
|
portions of the Library contained in the Combined Work and reverse
|
||||||
|
engineering for debugging such modifications, if you also do each of
|
||||||
|
the following:
|
||||||
|
|
||||||
|
a) Give prominent notice with each copy of the Combined Work that
|
||||||
|
the Library is used in it and that the Library and its use are
|
||||||
|
covered by this License.
|
||||||
|
|
||||||
|
b) Accompany the Combined Work with a copy of the GNU GPL and this license
|
||||||
|
document.
|
||||||
|
|
||||||
|
c) For a Combined Work that displays copyright notices during
|
||||||
|
execution, include the copyright notice for the Library among
|
||||||
|
these notices, as well as a reference directing the user to the
|
||||||
|
copies of the GNU GPL and this license document.
|
||||||
|
|
||||||
|
d) Do one of the following:
|
||||||
|
|
||||||
|
0) Convey the Minimal Corresponding Source under the terms of this
|
||||||
|
License, and the Corresponding Application Code in a form
|
||||||
|
suitable for, and under terms that permit, the user to
|
||||||
|
recombine or relink the Application with a modified version of
|
||||||
|
the Linked Version to produce a modified Combined Work, in the
|
||||||
|
manner specified by section 6 of the GNU GPL for conveying
|
||||||
|
Corresponding Source.
|
||||||
|
|
||||||
|
1) Use a suitable shared library mechanism for linking with the
|
||||||
|
Library. A suitable mechanism is one that (a) uses at run time
|
||||||
|
a copy of the Library already present on the user's computer
|
||||||
|
system, and (b) will operate properly with a modified version
|
||||||
|
of the Library that is interface-compatible with the Linked
|
||||||
|
Version.
|
||||||
|
|
||||||
|
e) Provide Installation Information, but only if you would otherwise
|
||||||
|
be required to provide such information under section 6 of the
|
||||||
|
GNU GPL, and only to the extent that such information is
|
||||||
|
necessary to install and execute a modified version of the
|
||||||
|
Combined Work produced by recombining or relinking the
|
||||||
|
Application with a modified version of the Linked Version. (If
|
||||||
|
you use option 4d0, the Installation Information must accompany
|
||||||
|
the Minimal Corresponding Source and Corresponding Application
|
||||||
|
Code. If you use option 4d1, you must provide the Installation
|
||||||
|
Information in the manner specified by section 6 of the GNU GPL
|
||||||
|
for conveying Corresponding Source.)
|
||||||
|
|
||||||
|
5. Combined Libraries.
|
||||||
|
|
||||||
|
You may place library facilities that are a work based on the
|
||||||
|
Library side by side in a single library together with other library
|
||||||
|
facilities that are not Applications and are not covered by this
|
||||||
|
License, and convey such a combined library under terms of your
|
||||||
|
choice, if you do both of the following:
|
||||||
|
|
||||||
|
a) Accompany the combined library with a copy of the same work based
|
||||||
|
on the Library, uncombined with any other library facilities,
|
||||||
|
conveyed under the terms of this License.
|
||||||
|
|
||||||
|
b) Give prominent notice with the combined library that part of it
|
||||||
|
is a work based on the Library, and explaining where to find the
|
||||||
|
accompanying uncombined form of the same work.
|
||||||
|
|
||||||
|
6. Revised Versions of the GNU Lesser General Public License.
|
||||||
|
|
||||||
|
The Free Software Foundation may publish revised and/or new versions
|
||||||
|
of the GNU Lesser General Public License from time to time. Such new
|
||||||
|
versions will be similar in spirit to the present version, but may
|
||||||
|
differ in detail to address new problems or concerns.
|
||||||
|
|
||||||
|
Each version is given a distinguishing version number. If the
|
||||||
|
Library as you received it specifies that a certain numbered version
|
||||||
|
of the GNU Lesser General Public License "or any later version"
|
||||||
|
applies to it, you have the option of following the terms and
|
||||||
|
conditions either of that published version or of any later version
|
||||||
|
published by the Free Software Foundation. If the Library as you
|
||||||
|
received it does not specify a version number of the GNU Lesser
|
||||||
|
General Public License, you may choose any version of the GNU Lesser
|
||||||
|
General Public License ever published by the Free Software Foundation.
|
||||||
|
|
||||||
|
If the Library as you received it specifies that a proxy can decide
|
||||||
|
whether future versions of the GNU Lesser General Public License shall
|
||||||
|
apply, that proxy's public statement of acceptance of any version is
|
||||||
|
permanent authorization for you to choose that version for the
|
||||||
|
Library.
|
@ -1,22 +0,0 @@
|
|||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Linq;
|
|
||||||
using System.Text;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
using System.Windows.Forms;
|
|
||||||
|
|
||||||
namespace BlubbFish.Utils
|
|
||||||
{
|
|
||||||
public abstract class OwnController
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// Führt den Controller aus.
|
|
||||||
/// </summary>
|
|
||||||
public void Execute()
|
|
||||||
{
|
|
||||||
this.Init();
|
|
||||||
}
|
|
||||||
abstract protected void Init();
|
|
||||||
abstract public void Dispose();
|
|
||||||
}
|
|
||||||
}
|
|
39
OwnModel.cs
39
OwnModel.cs
@ -1,39 +0,0 @@
|
|||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Linq;
|
|
||||||
using System.Text;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
|
|
||||||
namespace BlubbFish.Utils
|
|
||||||
{
|
|
||||||
public abstract class OwnModel<T> where T : class
|
|
||||||
{
|
|
||||||
private static readonly Lazy<T> _instance = new Lazy<T>(() => CreateInstanceOfT());
|
|
||||||
private List<OwnView> observer = new List<OwnView>();
|
|
||||||
public static T Instance
|
|
||||||
{
|
|
||||||
get {
|
|
||||||
return _instance.Value;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private static T CreateInstanceOfT()
|
|
||||||
{
|
|
||||||
return Activator.CreateInstance(typeof(T), true) as T;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void SetObserver(OwnView view)
|
|
||||||
{
|
|
||||||
this.observer.Add(view);
|
|
||||||
view.Update();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void RemoveObserver(OwnView view) {
|
|
||||||
this.observer.Remove(view);
|
|
||||||
}
|
|
||||||
protected void Update()
|
|
||||||
{
|
|
||||||
this.observer.ForEach(delegate (OwnView view) { view.Update(); });
|
|
||||||
}
|
|
||||||
abstract protected void Init();
|
|
||||||
}
|
|
||||||
}
|
|
4
README.md
Normal file
4
README.md
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
# BlubbFish.Utils (Utils)
|
||||||
|
Library containing helpfull utils
|
||||||
|
|
||||||
|
Maybe you find this Repo on Github. This is a mirror from [here](https://git.blubbfish.net/vs_utils/Utils).
|
22
Utils-4.7.1.sln
Normal file
22
Utils-4.7.1.sln
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
|
||||||
|
Microsoft Visual Studio Solution File, Format Version 12.00
|
||||||
|
# Visual Studio Version 16
|
||||||
|
VisualStudioVersion = 16.0.29215.179
|
||||||
|
MinimumVisualStudioVersion = 10.0.40219.1
|
||||||
|
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Utils", "Utils\Utils-4.7.1.csproj", "{FAC8CE64-BF13-4ECE-8097-AEB5DD060098}"
|
||||||
|
EndProject
|
||||||
|
Global
|
||||||
|
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||||
|
Debug|Any CPU = Debug|Any CPU
|
||||||
|
Release|Any CPU = Release|Any CPU
|
||||||
|
EndGlobalSection
|
||||||
|
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
||||||
|
{FAC8CE64-BF13-4ECE-8097-AEB5DD060098}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
|
{FAC8CE64-BF13-4ECE-8097-AEB5DD060098}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
|
{FAC8CE64-BF13-4ECE-8097-AEB5DD060098}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
|
{FAC8CE64-BF13-4ECE-8097-AEB5DD060098}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||||
|
EndGlobalSection
|
||||||
|
GlobalSection(SolutionProperties) = preSolution
|
||||||
|
HideSolutionNode = FALSE
|
||||||
|
EndGlobalSection
|
||||||
|
EndGlobal
|
25
Utils.sln
Normal file
25
Utils.sln
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
|
||||||
|
Microsoft Visual Studio Solution File, Format Version 12.00
|
||||||
|
# Visual Studio Version 16
|
||||||
|
VisualStudioVersion = 16.0.29215.179
|
||||||
|
MinimumVisualStudioVersion = 10.0.40219.1
|
||||||
|
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Utils", "Utils\Utils.csproj", "{A289C67C-BC49-46A0-8657-B444C605079E}"
|
||||||
|
EndProject
|
||||||
|
Global
|
||||||
|
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||||
|
Debug|Any CPU = Debug|Any CPU
|
||||||
|
Release|Any CPU = Release|Any CPU
|
||||||
|
EndGlobalSection
|
||||||
|
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
||||||
|
{A289C67C-BC49-46A0-8657-B444C605079E}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
|
{A289C67C-BC49-46A0-8657-B444C605079E}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
|
{A289C67C-BC49-46A0-8657-B444C605079E}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
|
{A289C67C-BC49-46A0-8657-B444C605079E}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||||
|
EndGlobalSection
|
||||||
|
GlobalSection(SolutionProperties) = preSolution
|
||||||
|
HideSolutionNode = FALSE
|
||||||
|
EndGlobalSection
|
||||||
|
GlobalSection(ExtensibilityGlobals) = postSolution
|
||||||
|
SolutionGuid = {A7224DC4-69F1-4273-BE78-3D9DC80A28C5}
|
||||||
|
EndGlobalSection
|
||||||
|
EndGlobal
|
@ -1,186 +1,199 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
|
|
||||||
namespace BlubbFish.Utils
|
namespace BlubbFish.Utils
|
||||||
{
|
{
|
||||||
public class CmdArgs
|
public class CmdArgs
|
||||||
{
|
{
|
||||||
public enum ArgLength
|
public enum ArgLength
|
||||||
{
|
{
|
||||||
Single,
|
Single,
|
||||||
Touple
|
Touple
|
||||||
}
|
}
|
||||||
#region Classes
|
#region Classes
|
||||||
public struct VaildArguments
|
public struct VaildArguments
|
||||||
{
|
{
|
||||||
public VaildArguments(ArgLength length, Boolean required)
|
public VaildArguments(ArgLength length, Boolean required, String @default = "", String description = "")
|
||||||
{
|
{
|
||||||
this.Required = required;
|
this.Required = required;
|
||||||
this.Length = length;
|
this.Length = length;
|
||||||
}
|
this.Description = description;
|
||||||
public VaildArguments(ArgLength length)
|
this.@Default = @default;
|
||||||
{
|
}
|
||||||
this.Required = false;
|
public VaildArguments(ArgLength length, String @default = "", String description = "")
|
||||||
this.Length = length;
|
{
|
||||||
}
|
this.Required = false;
|
||||||
|
this.Length = length;
|
||||||
public ArgLength Length { get; private set; }
|
this.Description = description;
|
||||||
public Boolean Required { get; private set; }
|
this.@Default = @default;
|
||||||
}
|
}
|
||||||
private struct ArgTouple
|
|
||||||
{
|
public ArgLength Length { get; private set; }
|
||||||
public ArgTouple(String type, String data)
|
public Boolean Required { get; private set; }
|
||||||
{
|
public String Description { get; private set; }
|
||||||
this.Type = type;
|
public String Default { get; private set; }
|
||||||
this.Data = data;
|
}
|
||||||
}
|
private struct ArgTouple
|
||||||
public ArgTouple(String type)
|
{
|
||||||
{
|
public ArgTouple(String type, String data)
|
||||||
this.Type = type;
|
{
|
||||||
this.Data = "";
|
this.Type = type;
|
||||||
}
|
this.Data = data;
|
||||||
public String Type { get; private set; }
|
}
|
||||||
public String Data { get; private set; }
|
public ArgTouple(String type)
|
||||||
|
{
|
||||||
internal void SetData(String data)
|
this.Type = type;
|
||||||
{
|
this.Data = null;
|
||||||
if (data != "") {
|
}
|
||||||
this.Data = data;
|
public String Type { get; private set; }
|
||||||
|
public String Data { get; private set; }
|
||||||
|
|
||||||
|
internal void SetData(String data)
|
||||||
|
{
|
||||||
|
if (data != "") {
|
||||||
|
this.Data = data;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
private String[] args;
|
||||||
|
private List<ArgTouple> argList;
|
||||||
|
private Dictionary<String, VaildArguments> argsPosible = new Dictionary<String, VaildArguments>();
|
||||||
|
private static CmdArgs instances = null;
|
||||||
|
private Boolean isSetArguments = false;
|
||||||
|
|
||||||
|
private CmdArgs()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gibt eine Instanz der Klasse zurück
|
||||||
|
/// </summary>
|
||||||
|
/// <returns>Klasse</returns>
|
||||||
|
public static CmdArgs Instance
|
||||||
|
{
|
||||||
|
get {
|
||||||
|
if (instances == null) {
|
||||||
|
instances = new CmdArgs();
|
||||||
|
}
|
||||||
|
return instances;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Übernimmt die Argumente für die Klasse
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="arguments">Mögliche Komandozeilenargumente</param>
|
||||||
|
/// <param name="args">Tatsächliche Komandozeilenargumente</param>
|
||||||
|
public void SetArguments(Dictionary<String, VaildArguments> arguments, String[] args)
|
||||||
|
{
|
||||||
|
this.args = args;
|
||||||
|
if (!this.isSetArguments) {
|
||||||
|
this.isSetArguments = true;
|
||||||
|
this.argsPosible = arguments;
|
||||||
|
this.Init();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void Init()
|
||||||
|
{
|
||||||
|
this.argList = new List<ArgTouple>();
|
||||||
|
for (Int32 i = 0; i < this.args.Length; i++) {
|
||||||
|
if (this.argsPosible.Keys.Contains(this.args[i])) {
|
||||||
|
ArgTouple arg = new ArgTouple(this.args[i]);
|
||||||
|
if (this.argsPosible[this.args[i]].Length == ArgLength.Touple) {
|
||||||
|
if (this.args.Length > i + 1) {
|
||||||
|
arg.SetData(this.args[++i]);
|
||||||
|
} else {
|
||||||
|
Console.WriteLine(this.GetUsageList(""));
|
||||||
|
throw new ArgumentException("Argument: "+this.args[i]+" missing second argument.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.argList.Add(arg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
foreach(KeyValuePair<String, VaildArguments> item in this.argsPosible) {
|
||||||
|
if(!this.HasArgumentType(item.Key) && item.Value.Length == ArgLength.Touple && item.Value.Default != "") {
|
||||||
|
this.argList.Add(new ArgTouple(item.Key, item.Value.Default));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endregion
|
|
||||||
private String[] args;
|
/// <summary>
|
||||||
private List<ArgTouple> argList;
|
/// Menge der angegebenen Komandozeilen-Argumente
|
||||||
private Dictionary<String, VaildArguments> argsPosible = new Dictionary<String, VaildArguments>();
|
/// </summary>
|
||||||
private static CmdArgs instances = null;
|
/// <returns>Menge</returns>
|
||||||
private Boolean isSetArguments = false;
|
public Int32 GetArgsLength() => this.argList.Count;
|
||||||
|
|
||||||
private CmdArgs()
|
/// <summary>
|
||||||
{
|
/// Gibt zurück ob ein Argument angegeben wurde
|
||||||
}
|
/// </summary>
|
||||||
|
/// <param name="name">Name des Arguments</param>
|
||||||
/// <summary>
|
/// <returns>true wenn angegeben</returns>
|
||||||
/// Gibt eine Instanz der Klasse zurück
|
public Boolean HasArgumentType(String name)
|
||||||
/// </summary>
|
{
|
||||||
/// <returns>Klasse</returns>
|
foreach (ArgTouple t in this.argList) {
|
||||||
public static CmdArgs Instance
|
if (t.Type == name) {
|
||||||
{
|
return true;
|
||||||
get {
|
}
|
||||||
if (instances == null) {
|
}
|
||||||
instances = new CmdArgs();
|
return false;
|
||||||
}
|
}
|
||||||
return instances;
|
|
||||||
}
|
/// <summary>
|
||||||
}
|
/// Gibt den Inhalt des angegeben Arguments zurück, nur bei zweiteiligen Argumenten möglich
|
||||||
|
/// </summary>
|
||||||
/// <summary>
|
/// <param name="name">Name des Arguments</param>
|
||||||
/// Übernimmt die Argumente für die Klasse
|
/// <returns>Inhalt des Arguments oder ArgumentNullException</returns>
|
||||||
/// </summary>
|
public String GetArgumentData(String name)
|
||||||
/// <param name="arguments">Mögliche Komandozeilenargumente</param>
|
{
|
||||||
/// <param name="args">Tatsächliche Komandozeilenargumente</param>
|
foreach (ArgTouple t in this.argList) {
|
||||||
public void SetArguments(Dictionary<String, VaildArguments> arguments, String[] args)
|
if (t.Type == name && t.Data != null) {
|
||||||
{
|
return t.Data;
|
||||||
this.args = args;
|
}
|
||||||
if (!this.isSetArguments) {
|
}
|
||||||
this.isSetArguments = true;
|
throw new ArgumentNullException();
|
||||||
this.argsPosible = arguments;
|
}
|
||||||
this.Init();
|
|
||||||
}
|
public Boolean HasAllRequiredArguments()
|
||||||
}
|
{
|
||||||
|
foreach (KeyValuePair<String, VaildArguments> item in this.argsPosible) {
|
||||||
private void Init()
|
if (item.Value.Required && !this.HasArgumentType(item.Key)) {
|
||||||
{
|
return false;
|
||||||
this.argList = new List<ArgTouple>();
|
}
|
||||||
for (Int32 i = 0; i < this.args.Length; i++) {
|
}
|
||||||
if (this.argsPosible.Keys.Contains(this.args[i])) {
|
return true;
|
||||||
ArgTouple arg = new ArgTouple(this.args[i]);
|
}
|
||||||
if (this.argsPosible[this.args[i]].Length == ArgLength.Touple) {
|
|
||||||
if (this.args.Length > i + 1) {
|
public String GetUsageList(String name)
|
||||||
arg.SetData(this.args[++i]);
|
{
|
||||||
} else {
|
String ret = "Usage: " + name + " Parameter\nParameter:\n";
|
||||||
throw new ArgumentException();
|
String req = "";
|
||||||
}
|
String opt = "";
|
||||||
}
|
foreach (KeyValuePair<String, VaildArguments> item in this.argsPosible) {
|
||||||
this.argList.Add(arg);
|
if (item.Value.Required) {
|
||||||
}
|
req += item.Key + " " + ((item.Value.Length == ArgLength.Touple) ? (item.Value.Default != "" ? " " + item.Value.Default + "\n" : " [data]\n") : "\n");
|
||||||
}
|
if(item.Value.Description != "") {
|
||||||
}
|
req += "\t" + item.Value.Description + "\n";
|
||||||
|
}
|
||||||
/// <summary>
|
}
|
||||||
/// Menge der angegebenen Komandozeilen-Argumente
|
}
|
||||||
/// </summary>
|
if (req != "") {
|
||||||
/// <returns>Menge</returns>
|
ret += "Benötigte Parameter:\n" + req;
|
||||||
public Int32 GetArgsLength()
|
}
|
||||||
{
|
foreach (KeyValuePair<String, VaildArguments> item in this.argsPosible) {
|
||||||
return this.argList.Count;
|
if (!item.Value.Required) {
|
||||||
}
|
opt += item.Key + " " + ((item.Value.Length == ArgLength.Touple) ? (item.Value.Default != "" ? " " + item.Value.Default + "\n" : " [data]\n") : "\n");
|
||||||
|
if (item.Value.Description != "") {
|
||||||
/// <summary>
|
opt += "\t" + item.Value.Description + "\n";
|
||||||
/// Gibt zurück ob ein Argument angegeben wurde
|
}
|
||||||
/// </summary>
|
}
|
||||||
/// <param name="name">Name des Arguments</param>
|
}
|
||||||
/// <returns>true wenn angegeben</returns>
|
if (opt != "") {
|
||||||
public Boolean HasArgumentType(String name)
|
ret += "Optionale Parameter:\n" + opt;
|
||||||
{
|
}
|
||||||
foreach (ArgTouple t in this.argList) {
|
return ret;
|
||||||
if (t.Type == name) {
|
}
|
||||||
return true;
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Gibt den Inhalt des angegeben Arguments zurück, nur bei zweiteiligen Argumenten möglich
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="name">Name des Arguments</param>
|
|
||||||
/// <returns>Inhalt des Arguments oder ArgumentNullException</returns>
|
|
||||||
public String GetArgumentData(String name)
|
|
||||||
{
|
|
||||||
foreach (ArgTouple t in this.argList) {
|
|
||||||
if (t.Type == name && t.Data != null) {
|
|
||||||
return t.Data;
|
|
||||||
} else {
|
|
||||||
throw new ArgumentNullException();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Boolean HasAllRequiredArguments()
|
|
||||||
{
|
|
||||||
foreach (KeyValuePair<String, VaildArguments> item in this.argsPosible) {
|
|
||||||
if (item.Value.Required && !this.HasArgumentType(item.Key)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String GetUsageList(String name)
|
|
||||||
{
|
|
||||||
String ret = "Usage: " + name + " Parameter\nParameter:\n";
|
|
||||||
String req = "";
|
|
||||||
String opt = "";
|
|
||||||
foreach (KeyValuePair<String, VaildArguments> item in this.argsPosible) {
|
|
||||||
if (item.Value.Required) {
|
|
||||||
req += item.Key + " " + ((item.Value.Length == ArgLength.Touple) ? " [data]\n" : "\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (req != "") {
|
|
||||||
ret += "Benötigte Parameter:\n" + req;
|
|
||||||
}
|
|
||||||
foreach (KeyValuePair<String, VaildArguments> item in this.argsPosible) {
|
|
||||||
if (!item.Value.Required) {
|
|
||||||
opt += item.Key + " " + ((item.Value.Length == ArgLength.Touple) ? " [data]\n" : "\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (opt != "") {
|
|
||||||
ret += "Optionale Parameter:\n" + opt;
|
|
||||||
}
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,34 +1,32 @@
|
|||||||
using System;
|
using System;
|
||||||
|
|
||||||
namespace BlubbFish.Utils {
|
namespace BlubbFish.Utils {
|
||||||
public class UpdaterEventArgs : EventArgs {
|
public class UpdaterEventArgs : EventArgs {
|
||||||
public UpdaterEventArgs(Boolean hasUpdates, String message) {
|
public UpdaterEventArgs(Boolean hasUpdates, String message) {
|
||||||
this.HasUpdates = hasUpdates;
|
this.HasUpdates = hasUpdates;
|
||||||
this.Message = message;
|
this.Message = message;
|
||||||
}
|
}
|
||||||
public String Message { get; private set; }
|
public String Message { get; private set; }
|
||||||
public Boolean HasUpdates { get; private set; }
|
public Boolean HasUpdates { get; private set; }
|
||||||
}
|
}
|
||||||
|
|
||||||
public class UpdaterFailEventArgs : EventArgs {
|
public class UpdaterFailEventArgs : EventArgs {
|
||||||
public UpdaterFailEventArgs(Exception e) {
|
public UpdaterFailEventArgs(Exception e) => this.Except = e;
|
||||||
this.Except = e;
|
|
||||||
}
|
public Exception Except { get; private set; }
|
||||||
|
}
|
||||||
public Exception Except { get; private set; }
|
|
||||||
}
|
public class LogEventArgs : EventArgs {
|
||||||
|
public LogEventArgs(String location, String message, OwnObject.LogLevel level, DateTime date) {
|
||||||
public class LogEventArgs : EventArgs {
|
this.Location = location;
|
||||||
public LogEventArgs(String location, String message, OwnObject.LogLevel level, DateTime date) {
|
this.Message = message;
|
||||||
this.Location = location;
|
this.Level = level;
|
||||||
this.Message = message;
|
this.Date = date;
|
||||||
this.Level = level;
|
}
|
||||||
this.Date = date;
|
|
||||||
}
|
public String Location { get; private set; }
|
||||||
|
public String Message { get; private set; }
|
||||||
public String Location { get; private set; }
|
public OwnObject.LogLevel Level { get; private set; }
|
||||||
public String Message { get; private set; }
|
public DateTime Date { get; private set; }
|
||||||
public OwnObject.LogLevel Level { get; private set; }
|
}
|
||||||
public DateTime Date { get; private set; }
|
}
|
||||||
}
|
|
||||||
}
|
|
@ -1,67 +1,64 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Reflection;
|
using System.Reflection;
|
||||||
|
|
||||||
namespace BlubbFish.Utils
|
namespace BlubbFish.Utils
|
||||||
{
|
{
|
||||||
public class FileLogger
|
public class FileLogger
|
||||||
{
|
{
|
||||||
private static Dictionary<String, FileLogger> instances = new Dictionary<String, FileLogger>();
|
private static readonly Dictionary<String, FileLogger> instances = new Dictionary<String, FileLogger>();
|
||||||
private static String logDir = Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location) + Path.DirectorySeparatorChar;
|
private static String logDir = Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location) + Path.DirectorySeparatorChar;
|
||||||
private readonly StreamWriter file;
|
private readonly StreamWriter file;
|
||||||
private FileLogger(String filename, Boolean append)
|
private FileLogger(String filename, Boolean append)
|
||||||
{
|
{
|
||||||
filename = logDir + filename;
|
filename = logDir + filename;
|
||||||
if (!File.Exists(filename)) {
|
if (!File.Exists(filename)) {
|
||||||
String folder = Path.GetDirectoryName(Path.GetFullPath(filename));
|
String folder = Path.GetDirectoryName(Path.GetFullPath(filename));
|
||||||
if (!Directory.Exists(folder)) {
|
if (!Directory.Exists(folder)) {
|
||||||
Directory.CreateDirectory(folder);
|
_ = Directory.CreateDirectory(folder);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this.file = new StreamWriter(filename, append, Encoding.UTF8) {
|
this.file = new StreamWriter(filename, append, Encoding.UTF8) {
|
||||||
AutoFlush = true
|
AutoFlush = true
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
public static FileLogger GetInstance(String filename, Boolean append)
|
public static FileLogger GetInstance(String filename, Boolean append)
|
||||||
{
|
{
|
||||||
if (!instances.Keys.Contains(filename)) {
|
if (!instances.Keys.Contains(filename)) {
|
||||||
instances.Add(filename, new FileLogger(filename, append));
|
instances.Add(filename, new FileLogger(filename, append));
|
||||||
}
|
}
|
||||||
return instances[filename];
|
return instances[filename];
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void SetLogDir(String v)
|
public static void SetLogDir(String v)
|
||||||
{
|
{
|
||||||
v = v.Replace("..", "");
|
v = v.Replace("..", "");
|
||||||
v = Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location) + Path.DirectorySeparatorChar + v;
|
v = Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location) + Path.DirectorySeparatorChar + v;
|
||||||
if (Directory.Exists(v)) {
|
if (Directory.Exists(v)) {
|
||||||
logDir = v;
|
logDir = v;
|
||||||
} else {
|
} else {
|
||||||
Directory.CreateDirectory(v);
|
_ = Directory.CreateDirectory(v);
|
||||||
logDir = v;
|
logDir = v;
|
||||||
}
|
}
|
||||||
if (logDir.Substring(logDir.Length - 1) != Path.DirectorySeparatorChar.ToString()) {
|
if (logDir[^1..] != Path.DirectorySeparatorChar.ToString()) {
|
||||||
logDir = logDir + Path.DirectorySeparatorChar;
|
logDir += Path.DirectorySeparatorChar;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void SetArray(String[] text)
|
public void SetArray(String[] text)
|
||||||
{
|
{
|
||||||
this.file.Write(String.Join(this.file.NewLine, text) + this.file.NewLine);
|
this.file.Write(String.Join(this.file.NewLine, text) + this.file.NewLine);
|
||||||
this.file.Flush();
|
this.file.Flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void SetLine(String text)
|
public void SetLine(String text)
|
||||||
{
|
{
|
||||||
this.file.WriteLine(text);
|
this.file.WriteLine(text);
|
||||||
this.file.Flush();
|
this.file.Flush();
|
||||||
}
|
}
|
||||||
public void SetLine(String text, DateTime d)
|
public void SetLine(String text, DateTime d) => this.SetLine(d.ToString("[yyyy-MM-dd HH:mm:ss.ffff] ") + text);
|
||||||
{
|
}
|
||||||
this.SetLine(d.ToString("[yyyy-MM-dd HH:mm:ss.ffff] ") + text);
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,71 +1,73 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Security.Cryptography;
|
using System.Security.Cryptography;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
|
|
||||||
namespace BlubbFish.Utils
|
namespace BlubbFish.Utils
|
||||||
{
|
{
|
||||||
public class FileMutex : IDisposable
|
public class FileMutex : IDisposable
|
||||||
{
|
{
|
||||||
private static FileMutex instance;
|
private static FileMutex instance;
|
||||||
private String filename;
|
private String filename;
|
||||||
private StreamWriter file;
|
private StreamWriter file;
|
||||||
private FileMutex() { }
|
private FileMutex() { }
|
||||||
|
|
||||||
public static FileMutex Instance
|
public static FileMutex Instance
|
||||||
{
|
{
|
||||||
get {
|
get {
|
||||||
if (instance == null) {
|
if (instance == null) {
|
||||||
instance = new FileMutex();
|
instance = new FileMutex();
|
||||||
}
|
}
|
||||||
return instance;
|
return instance;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void SetName(String name)
|
public void SetName(String name)
|
||||||
{
|
{
|
||||||
String path = AppDomain.CurrentDomain.BaseDirectory;
|
String path = AppDomain.CurrentDomain.BaseDirectory;
|
||||||
this.filename = path + String.Join(String.Empty, Array.ConvertAll(new SHA512Managed().ComputeHash(Encoding.UTF8.GetBytes(name)), b => b.ToString("X2"))) + ".lock.txt";
|
SHA512Managed sha = new SHA512Managed();
|
||||||
}
|
this.filename = path + String.Join(String.Empty, Array.ConvertAll(sha.ComputeHash(Encoding.UTF8.GetBytes(name)), b => b.ToString("X2"))) + ".lock.txt";
|
||||||
|
sha.Dispose();
|
||||||
public Boolean Create()
|
}
|
||||||
{
|
|
||||||
if (File.Exists(this.filename)) {
|
public Boolean Create()
|
||||||
return false;
|
{
|
||||||
}
|
if (File.Exists(this.filename)) {
|
||||||
|
return false;
|
||||||
this.file = new StreamWriter(this.filename);
|
}
|
||||||
InitFile();
|
|
||||||
return File.Exists(this.filename) && this.file != null;
|
this.file = new StreamWriter(this.filename);
|
||||||
}
|
this.InitFile();
|
||||||
|
return File.Exists(this.filename) && this.file != null;
|
||||||
private void InitFile()
|
}
|
||||||
{
|
|
||||||
this.file.Write("Created: " + DateTime.Now.ToUniversalTime() + "\n");
|
private void InitFile()
|
||||||
this.file.Flush();
|
{
|
||||||
}
|
this.file.Write("Created: " + DateTime.Now.ToUniversalTime() + "\n");
|
||||||
|
this.file.Flush();
|
||||||
public Boolean Delete()
|
}
|
||||||
{
|
|
||||||
if(this.file != null) {
|
public Boolean Delete()
|
||||||
this.file.Close();
|
{
|
||||||
}
|
if(this.file != null) {
|
||||||
|
this.file.Close();
|
||||||
File.Delete(this.filename);
|
}
|
||||||
return !File.Exists(this.filename);
|
|
||||||
}
|
File.Delete(this.filename);
|
||||||
|
return !File.Exists(this.filename);
|
||||||
protected virtual void Dispose(Boolean disposing) {
|
}
|
||||||
if (disposing) {
|
|
||||||
if(this.file != null) {
|
protected virtual void Dispose(Boolean disposing) {
|
||||||
this.file.Close();
|
if (disposing) {
|
||||||
}
|
if(this.file != null) {
|
||||||
}
|
this.file.Close();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
public void Dispose() {
|
}
|
||||||
Dispose(true);
|
|
||||||
GC.SuppressFinalize(this);
|
public void Dispose() {
|
||||||
}
|
this.Dispose(true);
|
||||||
}
|
GC.SuppressFinalize(this);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
93
Utils/Helper.cs
Normal file
93
Utils/Helper.cs
Normal file
@ -0,0 +1,93 @@
|
|||||||
|
using System;
|
||||||
|
using System.ComponentModel;
|
||||||
|
using System.Reflection;
|
||||||
|
|
||||||
|
namespace BlubbFish.Utils {
|
||||||
|
public static class Helper {
|
||||||
|
#region PropertyHelper
|
||||||
|
public static Boolean HasProperty(this Object o, String type) {
|
||||||
|
Type t = o.GetType();
|
||||||
|
foreach (PropertyInfo item in t.GetProperties()) {
|
||||||
|
if (item.Name == type) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Object GetProperty(this Object o, String name) {
|
||||||
|
PropertyInfo prop = o.GetType().GetProperty(name);
|
||||||
|
return prop.CanRead ? prop.GetValue(o) : null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void SetProperty(this Object o, String name, String value) {
|
||||||
|
PropertyInfo prop = o.GetType().GetProperty(name);
|
||||||
|
if (prop.CanWrite) {
|
||||||
|
if (prop.PropertyType == typeof(Boolean) && Boolean.TryParse(value, out Boolean vb)) {
|
||||||
|
prop.SetValue(o, vb);
|
||||||
|
} else if (prop.PropertyType == typeof(Byte) && Byte.TryParse(value, out Byte v8)) {
|
||||||
|
prop.SetValue(o, v8);
|
||||||
|
} else if (prop.PropertyType == typeof(Int32) && Int32.TryParse(value, out Int32 v32)) {
|
||||||
|
prop.SetValue(o, v32);
|
||||||
|
} else if (prop.PropertyType == typeof(Single) && Single.TryParse(value, out Single vs)) {
|
||||||
|
prop.SetValue(o, vs);
|
||||||
|
} else if (prop.PropertyType == typeof(Double) && Double.TryParse(value, out Double vd)) {
|
||||||
|
prop.SetValue(o, vd);
|
||||||
|
} else if (prop.PropertyType == typeof(Int64) && Int64.TryParse(value, out Int64 v64)) {
|
||||||
|
prop.SetValue(o, v64);
|
||||||
|
} else if (prop.PropertyType.BaseType == typeof(Enum)) {
|
||||||
|
try {
|
||||||
|
prop.SetValue(o, Enum.Parse(prop.PropertyType, value));
|
||||||
|
} catch (Exception) { }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region FieldHelper
|
||||||
|
public static Object GetField(this Object o, String name) {
|
||||||
|
FieldInfo field = o.GetType().GetField(name);
|
||||||
|
return field.IsPublic ? field.GetValue(o) : null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Object GetField(this Type o, String name) {
|
||||||
|
FieldInfo field = o.GetField(name);
|
||||||
|
return field.IsPublic ? field.GetValue(o) : null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static T GetEvent<T>(this Object o, String name) {
|
||||||
|
FieldInfo field = o.GetType().GetField(name, BindingFlags.Instance | BindingFlags.NonPublic);
|
||||||
|
return (T)field?.GetValue(o);
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region InterfaceHelper
|
||||||
|
public static Boolean HasInterface(this Type o, Type interf) {
|
||||||
|
foreach (Type item in o.GetInterfaces()) {
|
||||||
|
if (item == interf) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Boolean HasAbstract(this Type o, Type type) => o.BaseType == type;
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region StringHelper
|
||||||
|
public static String GetEnumDescription(Enum value) {
|
||||||
|
FieldInfo fi = value.GetType().GetField(value.ToString());
|
||||||
|
DescriptionAttribute[] attributes = (DescriptionAttribute[])fi.GetCustomAttributes(typeof(DescriptionAttribute), false);
|
||||||
|
return attributes != null && attributes.Length > 0 ? attributes[0].Description : value.ToString();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String ToUpperLower(this String s) => s.Length == 0 ? "" : s.Length == 1 ? s.ToUpper() : s[0].ToString().ToUpper() + s[1..].ToLower();
|
||||||
|
|
||||||
|
public static void WriteError(String text) {
|
||||||
|
Console.ForegroundColor = ConsoleColor.Red;
|
||||||
|
Console.Error.WriteLine("ERROR: " + text);
|
||||||
|
Console.ResetColor();
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
}
|
59
Utils/HttpEndpoint.cs
Normal file
59
Utils/HttpEndpoint.cs
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
using System;
|
||||||
|
using System.Net;
|
||||||
|
using System.Net.Http;
|
||||||
|
using System.Net.Http.Headers;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace BlubbFish.Utils {
|
||||||
|
public class HttpEndpoint {
|
||||||
|
private readonly HttpClient client = new HttpClient();
|
||||||
|
private readonly String server = "";
|
||||||
|
|
||||||
|
public enum RequestMethod {
|
||||||
|
GET,
|
||||||
|
POST,
|
||||||
|
PUT
|
||||||
|
}
|
||||||
|
|
||||||
|
public HttpEndpoint(String server, String auth = null) {
|
||||||
|
this.server = server;
|
||||||
|
if(auth != null) {
|
||||||
|
this.client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue(auth);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public HttpEndpoint(String server, (String scheme, String parameter) auth) {
|
||||||
|
this.server = server;
|
||||||
|
this.client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue(auth.scheme, auth.parameter);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task<String> RequestString(String address, String json = "", Boolean withoutput = true, RequestMethod method = RequestMethod.GET) {
|
||||||
|
String ret = null;
|
||||||
|
try {
|
||||||
|
HttpResponseMessage response = null;
|
||||||
|
if(method == RequestMethod.POST || method == RequestMethod.PUT) {
|
||||||
|
HttpContent content = new StringContent(json);
|
||||||
|
content.Headers.ContentType = new MediaTypeHeaderValue("application/json");
|
||||||
|
//content.Headers.Add("Content-Type", "application/json");
|
||||||
|
if(method == RequestMethod.POST) {
|
||||||
|
response = await this.client.PostAsync(this.server + address, content);
|
||||||
|
} else if(method == RequestMethod.PUT) {
|
||||||
|
response = await this.client.PutAsync(this.server + address, content);
|
||||||
|
}
|
||||||
|
content.Dispose();
|
||||||
|
} else if(method == RequestMethod.GET) {
|
||||||
|
response = await this.client.GetAsync(this.server + address);
|
||||||
|
}
|
||||||
|
if(!response.IsSuccessStatusCode) {
|
||||||
|
throw new Exception(response.StatusCode + ": " + response.ReasonPhrase);
|
||||||
|
}
|
||||||
|
if(withoutput && response != null) {
|
||||||
|
ret = await response.Content.ReadAsStringAsync();
|
||||||
|
}
|
||||||
|
} catch(Exception e) {
|
||||||
|
throw new WebException(String.Format("Error while opening resource: \"{0}\" Method {1} Data {2} Fehler {3}", this.server + address, method, json, e.Message));
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -8,17 +8,15 @@ namespace BlubbFish.Utils {
|
|||||||
public class InIReader : IDisposable
|
public class InIReader : IDisposable
|
||||||
{
|
{
|
||||||
private Dictionary<String, Dictionary<String, String>> inifile;
|
private Dictionary<String, Dictionary<String, String>> inifile;
|
||||||
private FileSystemWatcher k;
|
private readonly FileSystemWatcher k;
|
||||||
private readonly String filename;
|
private readonly String filename;
|
||||||
private static List<String> search_path = new List<String>() {
|
private static readonly List<String> search_path = new List<String>() {
|
||||||
Directory.GetCurrentDirectory()
|
Directory.GetCurrentDirectory()
|
||||||
};
|
};
|
||||||
|
|
||||||
private static Dictionary<String, InIReader> instances = new Dictionary<String, InIReader>();
|
private static readonly Dictionary<String, InIReader> instances = new Dictionary<String, InIReader>();
|
||||||
|
|
||||||
public static void SetSearchPath(List<String> directorys) {
|
public static void SetSearchPath(List<String> directorys) => search_path.AddRange(directorys);
|
||||||
search_path.AddRange(directorys);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static Boolean ConfigExist(String filename) {
|
public static Boolean ConfigExist(String filename) {
|
||||||
foreach (String path in search_path) {
|
foreach (String path in search_path) {
|
||||||
@ -33,8 +31,7 @@ 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;
|
||||||
@ -54,7 +51,7 @@ namespace BlubbFish.Utils {
|
|||||||
throw new ArgumentException(filename + " not found!");
|
throw new ArgumentException(filename + " not found!");
|
||||||
}
|
}
|
||||||
this.k.Changed += new FileSystemEventHandler(this.ReadAgain);
|
this.k.Changed += new FileSystemEventHandler(this.ReadAgain);
|
||||||
LoadFile();
|
this.LoadFile();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -62,21 +59,16 @@ 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));
|
||||||
}
|
}
|
||||||
return instances[filename];
|
return instances[filename];
|
||||||
}
|
}
|
||||||
|
|
||||||
private void ReadAgain(Object sender, EventArgs e)
|
private void ReadAgain(Object sender, EventArgs e) => this.LoadFile();
|
||||||
{
|
|
||||||
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>();
|
||||||
@ -91,7 +83,7 @@ namespace BlubbFish.Utils {
|
|||||||
Dictionary<String, String> sub = new Dictionary<String, String>();
|
Dictionary<String, String> sub = new Dictionary<String, String>();
|
||||||
String cap = "";
|
String cap = "";
|
||||||
foreach (String line in buf) {
|
foreach (String line in buf) {
|
||||||
Match match = Regex.Match(line, @"^\[[a-zA-ZäöüÄÖÜ0-9\-_ ]+\]\w*$", RegexOptions.IgnoreCase);
|
Match match = Regex.Match(line, @"^\[[a-zA-ZäöüÄÖÜ0-9\-\._/ ]+\]\w*$", RegexOptions.IgnoreCase);
|
||||||
if (match.Success) {
|
if (match.Success) {
|
||||||
if (sub.Count != 0 && cap != "") {
|
if (sub.Count != 0 && cap != "") {
|
||||||
this.inifile.Add(cap, sub);
|
this.inifile.Add(cap, sub);
|
||||||
@ -101,7 +93,7 @@ namespace BlubbFish.Utils {
|
|||||||
} else {
|
} else {
|
||||||
if (line != "" && cap != "") {
|
if (line != "" && cap != "") {
|
||||||
String key = line.Substring(0, line.IndexOf('='));
|
String key = line.Substring(0, line.IndexOf('='));
|
||||||
String value = line.Substring(line.IndexOf('=') + 1);
|
String value = line[(line.IndexOf('=') + 1)..];
|
||||||
sub.Add(key, value);
|
sub.Add(key, value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -123,7 +115,7 @@ namespace BlubbFish.Utils {
|
|||||||
} else {
|
} else {
|
||||||
List<String> ret = new List<String>();
|
List<String> ret = new List<String>();
|
||||||
foreach (String item in this.inifile.Keys) {
|
foreach (String item in this.inifile.Keys) {
|
||||||
ret.Add(item.Substring(1, item.Length - 2));
|
ret.Add(item[1..^1]);
|
||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -140,22 +132,16 @@ namespace BlubbFish.Utils {
|
|||||||
if(!key.StartsWith("[")) {
|
if(!key.StartsWith("[")) {
|
||||||
key = "[" + key + "]";
|
key = "[" + key + "]";
|
||||||
}
|
}
|
||||||
if (Regex.Match(key, @"^\[[a-zA-ZäöüÄÖÜ0-9\-_ ]+\]\w*$", RegexOptions.IgnoreCase).Success) {
|
if (Regex.Match(key, @"^\[[a-zA-ZäöüÄÖÜ0-9\-\._/ ]+\]\w*$", RegexOptions.IgnoreCase).Success) {
|
||||||
this.inifile.Add(key, item.Value);
|
this.inifile.Add(key, item.Value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this.Changed();
|
this.Changed();
|
||||||
}
|
}
|
||||||
|
|
||||||
public Dictionary<String, String> GetSection(String section) {
|
public Dictionary<String, String> GetSection(String section) => this.inifile.Keys.Contains(section) ?
|
||||||
if(this.inifile.Keys.Contains(section)) {
|
this.inifile[section] : this.inifile.Keys.Contains("[" + section + "]") ?
|
||||||
return this.inifile[section];
|
this.inifile["[" + section + "]"] : new Dictionary<String, String>();
|
||||||
}
|
|
||||||
if(this.inifile.Keys.Contains("["+section+"]")) {
|
|
||||||
return this.inifile["[" + section + "]"];
|
|
||||||
}
|
|
||||||
return new Dictionary<String, String>();
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Gibt einen einzelnen Wert zurück
|
/// Gibt einen einzelnen Wert zurück
|
||||||
@ -163,17 +149,11 @@ 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)
|
public String GetValue(String section, String key, String @default = null) {
|
||||||
{
|
|
||||||
if (!section.StartsWith("[")) {
|
if (!section.StartsWith("[")) {
|
||||||
section = "[" + section + "]";
|
section = "[" + section + "]";
|
||||||
}
|
}
|
||||||
if (this.inifile.Keys.Contains(section)) {
|
return this.inifile.Keys.Contains(section) && this.inifile[section].Keys.Contains(key) ? this.inifile[section][key] : @default;
|
||||||
if (this.inifile[section].Keys.Contains(key)) {
|
|
||||||
return this.inifile[section][key];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -205,8 +185,8 @@ namespace BlubbFish.Utils {
|
|||||||
private void Changed()
|
private void Changed()
|
||||||
{
|
{
|
||||||
this.k.Changed -= null;
|
this.k.Changed -= null;
|
||||||
SaveSettings();
|
this.SaveSettings();
|
||||||
LoadFile();
|
this.LoadFile();
|
||||||
this.k.Changed += new FileSystemEventHandler(this.ReadAgain);
|
this.k.Changed += new FileSystemEventHandler(this.ReadAgain);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -215,7 +195,7 @@ namespace BlubbFish.Utils {
|
|||||||
StreamWriter file = new StreamWriter(this.filename);
|
StreamWriter file = new StreamWriter(this.filename);
|
||||||
file.BaseStream.SetLength(0);
|
file.BaseStream.SetLength(0);
|
||||||
file.BaseStream.Flush();
|
file.BaseStream.Flush();
|
||||||
file.BaseStream.Seek(0, SeekOrigin.Begin);
|
_ = file.BaseStream.Seek(0, SeekOrigin.Begin);
|
||||||
foreach (KeyValuePair<String, Dictionary<String, String>> cap in this.inifile) {
|
foreach (KeyValuePair<String, Dictionary<String, String>> cap in this.inifile) {
|
||||||
file.WriteLine(cap.Key);
|
file.WriteLine(cap.Key);
|
||||||
foreach (KeyValuePair<String, String> sub in cap.Value) {
|
foreach (KeyValuePair<String, String> sub in cap.Value) {
|
||||||
@ -258,10 +238,11 @@ namespace BlubbFish.Utils {
|
|||||||
if (!this.inifile.Keys.Contains(name)) {
|
if (!this.inifile.Keys.Contains(name)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
this.inifile.Remove(name);
|
_ = this.inifile.Remove(name);
|
||||||
this.Changed();
|
this.Changed();
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected virtual void Dispose(Boolean disposing) {
|
protected virtual void Dispose(Boolean disposing) {
|
||||||
if (disposing) {
|
if (disposing) {
|
||||||
this.k.Dispose();
|
this.k.Dispose();
|
||||||
@ -269,7 +250,7 @@ namespace BlubbFish.Utils {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void Dispose() {
|
public void Dispose() {
|
||||||
Dispose(true);
|
this.Dispose(true);
|
||||||
GC.SuppressFinalize(this);
|
GC.SuppressFinalize(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
11
Utils/OwnController.cs
Normal file
11
Utils/OwnController.cs
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
namespace BlubbFish.Utils {
|
||||||
|
public abstract class OwnController
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Führt den Controller aus.
|
||||||
|
/// </summary>
|
||||||
|
public void Execute() => this.Init();
|
||||||
|
abstract protected void Init();
|
||||||
|
abstract public void Dispose();
|
||||||
|
}
|
||||||
|
}
|
25
Utils/OwnModel.cs
Normal file
25
Utils/OwnModel.cs
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
|
||||||
|
namespace BlubbFish.Utils {
|
||||||
|
public abstract class OwnModel<T> where T : class
|
||||||
|
{
|
||||||
|
private static readonly Lazy<T> _instance = new Lazy<T>(() => CreateInstanceOfT());
|
||||||
|
private readonly List<OwnView> observer = new List<OwnView>();
|
||||||
|
public static T Instance => _instance.Value;
|
||||||
|
private static T CreateInstanceOfT() => Activator.CreateInstance(typeof(T), true) as T;
|
||||||
|
|
||||||
|
public void SetObserver(OwnView view)
|
||||||
|
{
|
||||||
|
this.observer.Add(view);
|
||||||
|
view.Update();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void RemoveObserver(OwnView view) => _ = this.observer.Remove(view);
|
||||||
|
protected void Update() => this.observer.ForEach(delegate (OwnView view) {
|
||||||
|
view.Update();
|
||||||
|
});
|
||||||
|
abstract protected void Init();
|
||||||
|
abstract public void Dispose();
|
||||||
|
}
|
||||||
|
}
|
@ -1,110 +1,103 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
|
||||||
namespace BlubbFish.Utils
|
namespace BlubbFish.Utils
|
||||||
{
|
{
|
||||||
abstract public class OwnObject
|
abstract public class OwnObject
|
||||||
{
|
{
|
||||||
public struct LogObject {
|
public struct LogObject {
|
||||||
public LogObject(DateTime date, String location, String message, LogLevel level) {
|
public LogObject(DateTime date, String location, String message, LogLevel level) {
|
||||||
this.Date = date;
|
this.Date = date;
|
||||||
this.Location = location;
|
this.Location = location;
|
||||||
this.Message = message;
|
this.Message = message;
|
||||||
this.Level = level;
|
this.Level = level;
|
||||||
}
|
}
|
||||||
|
|
||||||
public DateTime Date { get; set; }
|
public DateTime Date { get; set; }
|
||||||
public String Location { get; set; }
|
public String Location { get; set; }
|
||||||
public String Message { get; set; }
|
public String Message { get; set; }
|
||||||
public LogLevel Level { get; set; }
|
public LogLevel Level { get; set; }
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Formates a LogMessage to a String
|
/// Formates a LogMessage to a String
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <returns>Formated String</returns>
|
/// <returns>Formated String</returns>
|
||||||
public override String ToString() {
|
public override String ToString() => "[" + this.Date.ToString("R") + "]: " + this.Level.ToString() + " " + this.Location + ", " + this.Message;
|
||||||
return "[" + this.Date.ToString("R") + "]: " + this.Level.ToString() + " "+ this.Location + ", " + this.Message;
|
/// <summary>
|
||||||
}
|
/// Formates a LogMessage to a String
|
||||||
/// <summary>
|
/// </summary>
|
||||||
/// Formates a LogMessage to a String
|
/// <param name="classNames">Enables the output of the location</param>
|
||||||
/// </summary>
|
/// <param name="timeStamps">Enables the output of the date</param>
|
||||||
/// <param name="classNames">Enables the output of the location</param>
|
/// <returns>Formated String</returns>
|
||||||
/// <param name="timeStamps">Enables the output of the date</param>
|
public String ToString(Boolean classNames, Boolean timeStamps) => (timeStamps ? "[" + this.Date.ToString("R") + "]: " + this.Level.ToString() + " " : "") + (classNames ? this.Location + ", " : "") + this.Message;
|
||||||
/// <returns>Formated String</returns>
|
}
|
||||||
public String ToString(Boolean classNames, Boolean timeStamps) {
|
|
||||||
return (timeStamps ? "[" + this.Date.ToString("R") + "]: " + this.Level.ToString() + " " : "") + (classNames ? this.Location + ", " : "") + this.Message;
|
private readonly List<LogObject> loglist = new List<LogObject>();
|
||||||
}
|
|
||||||
}
|
public delegate void LogEvent(Object sender, LogEventArgs e);
|
||||||
|
public enum LogLevel : Int32 {
|
||||||
private List<LogObject> loglist = new List<LogObject>();
|
Debug = 1,
|
||||||
|
Notice = 2,
|
||||||
public delegate void LogEvent(Object sender, LogEventArgs e);
|
Info = 4,
|
||||||
public enum LogLevel : Int32 {
|
Warn = 8,
|
||||||
Debug = 1,
|
Error = 16
|
||||||
Notice = 2,
|
}
|
||||||
Info = 4,
|
|
||||||
Warn = 8,
|
public event LogEvent EventDebug;
|
||||||
Error = 16
|
public event LogEvent EventNotice;
|
||||||
}
|
public event LogEvent EventInfo;
|
||||||
|
public event LogEvent EventWarn;
|
||||||
public event LogEvent EventDebug;
|
public event LogEvent EventError;
|
||||||
public event LogEvent EventNotice;
|
public event LogEvent EventLog;
|
||||||
public event LogEvent EventInfo;
|
|
||||||
public event LogEvent EventWarn;
|
/// <summary>
|
||||||
public event LogEvent EventError;
|
/// Get the Complete Log
|
||||||
public event LogEvent EventLog;
|
/// </summary>
|
||||||
|
public List<String> GetLog(LogLevel level, Boolean classNames, Boolean timeStamps) {
|
||||||
/// <summary>
|
List<String> ret = new List<String>();
|
||||||
/// Get the Complete Log
|
foreach (LogObject t in this.loglist) {
|
||||||
/// </summary>
|
if (t.Level >= level) {
|
||||||
public List<String> GetLog(LogLevel level, Boolean classNames, Boolean timeStamps) {
|
ret.Add(t.ToString(classNames, timeStamps));
|
||||||
List<String> ret = new List<String>();
|
}
|
||||||
foreach (LogObject t in this.loglist) {
|
}
|
||||||
if (t.Level >= level) {
|
return ret;
|
||||||
ret.Add(t.ToString(classNames, timeStamps));
|
}
|
||||||
}
|
|
||||||
}
|
/// <summary>
|
||||||
return ret;
|
/// Put a message in the log
|
||||||
}
|
/// </summary>
|
||||||
|
/// <param name="location">Where the event arrives</param>
|
||||||
/// <summary>
|
/// <param name="message">The logmessage itselfs</param>
|
||||||
/// Put a message in the log
|
/// <param name="level">Level of the message</param>
|
||||||
/// </summary>
|
protected void AddLog(String location, String message, LogLevel level) => this.AddLog(location, message, level, DateTime.Now);
|
||||||
/// <param name="location">Where the event arrives</param>
|
|
||||||
/// <param name="message">The logmessage itselfs</param>
|
/// <summary>
|
||||||
/// <param name="level">Level of the message</param>
|
/// Put a message in the log
|
||||||
protected void AddLog(String location, String message, LogLevel level)
|
/// </summary>
|
||||||
{
|
/// <param name="location">Where the event arrives</param>
|
||||||
this.AddLog(location, message, level, DateTime.Now);
|
/// <param name="message">The logmessage itselfs</param>
|
||||||
}
|
/// <param name="level">Level of the message</param>
|
||||||
|
/// <param name="date">Date of the message</param>
|
||||||
/// <summary>
|
protected void AddLog(String location, String message, LogLevel level, DateTime date)
|
||||||
/// Put a message in the log
|
{
|
||||||
/// </summary>
|
LogEventArgs e = new LogEventArgs(location, message, level, date);
|
||||||
/// <param name="location">Where the event arrives</param>
|
if (level >= LogLevel.Debug) {
|
||||||
/// <param name="message">The logmessage itselfs</param>
|
EventDebug?.Invoke(this, e);
|
||||||
/// <param name="level">Level of the message</param>
|
}
|
||||||
/// <param name="date">Date of the message</param>
|
if (level >= LogLevel.Notice) {
|
||||||
protected void AddLog(String location, String message, LogLevel level, DateTime date)
|
EventNotice?.Invoke(this, e);
|
||||||
{
|
}
|
||||||
LogEventArgs e = new LogEventArgs(location, message, level, date);
|
if (level >= LogLevel.Info) {
|
||||||
if (EventDebug != null && level >= LogLevel.Debug) {
|
EventInfo?.Invoke(this, e);
|
||||||
EventDebug(this, e);
|
}
|
||||||
}
|
if (level >= LogLevel.Warn) {
|
||||||
if (EventNotice != null && level >= LogLevel.Notice) {
|
EventWarn?.Invoke(this, e);
|
||||||
EventNotice(this, e);
|
}
|
||||||
}
|
if (level >= LogLevel.Error) {
|
||||||
if (EventInfo != null && level >= LogLevel.Info) {
|
EventError?.Invoke(this, e);
|
||||||
EventInfo(this, e);
|
}
|
||||||
}
|
EventLog?.Invoke(this, e);
|
||||||
if (EventWarn != null && level >= LogLevel.Warn) {
|
|
||||||
EventWarn(this, e);
|
this.loglist.Add(new LogObject(date, location, message, level));
|
||||||
}
|
}
|
||||||
if (EventError != null && level >= LogLevel.Error) {
|
}
|
||||||
EventError(this, e);
|
}
|
||||||
}
|
|
||||||
EventLog?.Invoke(this, e);
|
|
||||||
|
|
||||||
this.loglist.Add(new LogObject(date, location, message, level));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
11
Utils/OwnSingeton.cs
Normal file
11
Utils/OwnSingeton.cs
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Text;
|
||||||
|
|
||||||
|
namespace BlubbFish.Utils {
|
||||||
|
public abstract class OwnSingeton<T> where T : class {
|
||||||
|
private static readonly Lazy<T> _instance = new Lazy<T>(() => CreateInstanceOfT());
|
||||||
|
public static T Instance => _instance.Value;
|
||||||
|
private static T CreateInstanceOfT() => Activator.CreateInstance(typeof(T), true) as T;
|
||||||
|
}
|
||||||
|
}
|
@ -1,24 +1,18 @@
|
|||||||
using System;
|
namespace BlubbFish.Utils {
|
||||||
using System.Collections.Generic;
|
public abstract class OwnView {
|
||||||
using System.Linq;
|
|
||||||
using System.Text;
|
protected OwnView() { }
|
||||||
using System.Threading.Tasks;
|
/// <summary>
|
||||||
|
/// Called if the Oberver (Model) updates its View
|
||||||
namespace BlubbFish.Utils {
|
/// </summary>
|
||||||
public abstract class OwnView {
|
public abstract void Update();
|
||||||
|
/// <summary>
|
||||||
protected OwnView() { }
|
/// Called if view is viewed
|
||||||
/// <summary>
|
/// </summary>
|
||||||
/// Called if the Oberver (Model) updates its View
|
//protected abstract void Init();
|
||||||
/// </summary>
|
/// <summary>
|
||||||
public abstract void Update();
|
/// Called if Form is Disposed
|
||||||
/// <summary>
|
/// </summary>
|
||||||
/// Called if view is viewed
|
public abstract void Dispose();
|
||||||
/// </summary>
|
}
|
||||||
//protected abstract void Init();
|
}
|
||||||
/// <summary>
|
|
||||||
/// Called if Form is Disposed
|
|
||||||
/// </summary>
|
|
||||||
public abstract void Dispose();
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,8 +1,6 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Reflection;
|
using System.Runtime.InteropServices;
|
||||||
using System.Security;
|
|
||||||
using System.Security.Permissions;
|
|
||||||
using System.Text;
|
using System.Text;
|
||||||
|
|
||||||
namespace BlubbFish.Utils {
|
namespace BlubbFish.Utils {
|
||||||
@ -12,8 +10,8 @@ namespace BlubbFish.Utils {
|
|||||||
private ConsoleWriter errout;
|
private ConsoleWriter errout;
|
||||||
private String loggerfile;
|
private String loggerfile;
|
||||||
|
|
||||||
public ProgramLogger() {
|
public ProgramLogger(String path = null) {
|
||||||
this.loggerfile = Directory.GetCurrentDirectory() + Path.DirectorySeparatorChar + "output.log";
|
this.loggerfile = path ?? Directory.GetCurrentDirectory() + Path.DirectorySeparatorChar + "output.log";
|
||||||
this.Init(this.loggerfile);
|
this.Init(this.loggerfile);
|
||||||
this.AttachToFw();
|
this.AttachToFw();
|
||||||
this.SetOutputs();
|
this.SetOutputs();
|
||||||
@ -29,23 +27,16 @@ 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(file);
|
this.fw = new FileWriter(FileWriter.GetFileSteam(file, false));
|
||||||
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);
|
||||||
}
|
}
|
||||||
|
|
||||||
private Boolean IsWritable(String filename) {
|
private Boolean IsWritable(String filename) {
|
||||||
FileIOPermission writePermission = new FileIOPermission(FileIOPermissionAccess.Write, filename);
|
|
||||||
PermissionSet p = new PermissionSet(PermissionState.None);
|
|
||||||
p.AddPermission(writePermission);
|
|
||||||
if (!p.IsSubsetOf(AppDomain.CurrentDomain.PermissionSet)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
try {
|
try {
|
||||||
using (FileStream fstream = new FileStream(filename, FileMode.Append))
|
using FileStream fstream = new FileStream(filename, FileMode.Append);
|
||||||
using (TextWriter writer = new StreamWriter(fstream)) {
|
using TextWriter writer = new StreamWriter(fstream);
|
||||||
writer.Write("");
|
writer.Write("");
|
||||||
}
|
|
||||||
} catch (UnauthorizedAccessException) {
|
} catch (UnauthorizedAccessException) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -63,39 +54,63 @@ 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) {
|
||||||
File.Move(this.loggerfile, file);
|
if(File.Exists(file)) {
|
||||||
|
this.FileCopy(this.loggerfile, file);
|
||||||
|
File.Delete(this.loggerfile);
|
||||||
|
} else {
|
||||||
|
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(this.loggerfile);
|
this.fw = new FileWriter(FileWriter.GetFileSteam(this.loggerfile, true));
|
||||||
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;
|
||||||
this.errout.WriteEvent -= this.fw.WriteLine;
|
this.errout.WriteEvent -= this.fw.Write;
|
||||||
this.errout.WriteLineEvent -= this.fw.WriteLine;
|
this.errout.WriteLineEvent -= this.fw.WriteLine;
|
||||||
}
|
}
|
||||||
private void AttachToFw() {
|
private void AttachToFw() {
|
||||||
this.stdout.WriteEvent += this.fw.Write;
|
this.stdout.WriteEvent += this.fw.Write;
|
||||||
this.stdout.WriteLineEvent += this.fw.WriteLine;
|
this.stdout.WriteLineEvent += this.fw.WriteLine;
|
||||||
this.errout.WriteEvent += this.fw.WriteLine;
|
this.errout.WriteEvent += this.fw.Write;
|
||||||
this.errout.WriteLineEvent += this.fw.WriteLine;
|
this.errout.WriteLineEvent += this.fw.WriteLine;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
internal class FileWriter : StreamWriter {
|
internal class FileWriter : StreamWriter {
|
||||||
private Boolean newline = true;
|
private Boolean newline = true;
|
||||||
public FileWriter(String path) : base(path) {
|
public FileWriter(FileStream fs) : base(fs) {
|
||||||
}
|
}
|
||||||
|
|
||||||
public override Encoding Encoding { get { return Encoding.UTF8; } }
|
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 Boolean AutoFlush { get { return true; } set { base.AutoFlush = value; } }
|
|
||||||
|
public override Encoding Encoding => Encoding.UTF8;
|
||||||
|
public override Boolean AutoFlush { get => true; set => base.AutoFlush = value; }
|
||||||
|
|
||||||
private void Write(String value, TextWriter origstream, ConsoleWriterEventArgs.ConsoleType type) {
|
private void Write(String value, TextWriter origstream, ConsoleWriterEventArgs.ConsoleType type) {
|
||||||
String text = "";
|
String text;
|
||||||
if (this.newline) {
|
if (this.newline) {
|
||||||
text = "[" + DateTime.Now.ToString("o") + "]-" + type.ToString() + ": " + value;
|
text = "[" + DateTime.Now.ToString("o") + "]-" + type.ToString() + ": " + value;
|
||||||
this.newline = false;
|
this.newline = false;
|
||||||
@ -108,20 +123,16 @@ namespace BlubbFish.Utils {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void WriteLine(String value, TextWriter origstream, ConsoleWriterEventArgs.ConsoleType type) {
|
private void WriteLine(String value, TextWriter origstream, ConsoleWriterEventArgs.ConsoleType type) {
|
||||||
String text = "[" + DateTime.Now.ToString("o") + "]-" + type.ToString() + ": " + value;
|
String text = this.newline ? "[" + DateTime.Now.ToString("o") + "]-" + type.ToString() + ": " + value : value;
|
||||||
|
this.newline = true;
|
||||||
origstream.WriteLine(text);
|
origstream.WriteLine(text);
|
||||||
base.WriteLine(text);
|
base.WriteLine(text);
|
||||||
this.newline = true;
|
|
||||||
base.Flush();
|
base.Flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void Write(Object sender, ConsoleWriterEventArgs e) {
|
internal void Write(Object sender, ConsoleWriterEventArgs e) => this.Write(e.Value, e.Writer, e.StreamType);
|
||||||
this.Write(e.Value, e.Writer, e.StreamType);
|
|
||||||
}
|
|
||||||
|
|
||||||
internal void WriteLine(Object sender, ConsoleWriterEventArgs e) {
|
internal void WriteLine(Object sender, ConsoleWriterEventArgs e) => this.WriteLine(e.Value, e.Writer, e.StreamType);
|
||||||
this.WriteLine(e.Value, e.Writer, e.StreamType);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
internal class ConsoleWriterEventArgs : EventArgs {
|
internal class ConsoleWriterEventArgs : EventArgs {
|
||||||
@ -150,15 +161,14 @@ namespace BlubbFish.Utils {
|
|||||||
this.streamtype = type;
|
this.streamtype = type;
|
||||||
}
|
}
|
||||||
|
|
||||||
public override Encoding Encoding { get { return Encoding.UTF8; } }
|
public override Encoding Encoding => Encoding.UTF8;
|
||||||
public override void Write(String value) {
|
|
||||||
this.WriteEvent?.Invoke(this, new ConsoleWriterEventArgs(value, this.stream, this.streamtype));
|
public override void Write(String value) => this.WriteEvent?.Invoke(this, new ConsoleWriterEventArgs(value, this.stream, this.streamtype));
|
||||||
base.Write(value);
|
//base.Write(value);
|
||||||
}
|
|
||||||
public override void WriteLine(String value) {
|
public override void WriteLine(String value) => this.WriteLineEvent?.Invoke(this, new ConsoleWriterEventArgs(value, this.stream, this.streamtype));
|
||||||
this.WriteLineEvent?.Invoke(this, new ConsoleWriterEventArgs(value, this.stream, this.streamtype));
|
//base.WriteLine(value);
|
||||||
base.WriteLine(value);
|
|
||||||
}
|
|
||||||
public event EventHandler<ConsoleWriterEventArgs> WriteEvent;
|
public event EventHandler<ConsoleWriterEventArgs> WriteEvent;
|
||||||
public event EventHandler<ConsoleWriterEventArgs> WriteLineEvent;
|
public event EventHandler<ConsoleWriterEventArgs> WriteLineEvent;
|
||||||
}
|
}
|
@ -1,18 +1,21 @@
|
|||||||
using System.Reflection;
|
#if !NETCOREAPP
|
||||||
using System.Runtime.CompilerServices;
|
using System.Reflection;
|
||||||
|
using System.Resources;
|
||||||
using System.Runtime.InteropServices;
|
using System.Runtime.InteropServices;
|
||||||
|
|
||||||
// Allgemeine Informationen über eine Assembly werden über die folgenden
|
// Allgemeine Informationen über eine Assembly werden über die folgenden
|
||||||
// Attribute gesteuert. Ändern Sie diese Attributwerte, um die Informationen zu ändern,
|
// Attribute gesteuert. Ändern Sie diese Attributwerte, um die Informationen zu ändern,
|
||||||
// die mit einer Assembly verknüpft sind.
|
// die mit einer Assembly verknüpft sind.
|
||||||
[assembly: AssemblyTitle("Utils")]
|
[assembly: AssemblyTitle("Utils")]
|
||||||
[assembly: AssemblyDescription("")]
|
[assembly: AssemblyDescription("Provides useful classes for other projects")]
|
||||||
[assembly: AssemblyConfiguration("")]
|
[assembly: AssemblyConfiguration("")]
|
||||||
[assembly: AssemblyCompany("")]
|
[assembly: AssemblyCompany("BlubbFish")]
|
||||||
[assembly: AssemblyProduct("Utils")]
|
[assembly: AssemblyProduct("Utils")]
|
||||||
[assembly: AssemblyCopyright("Copyright © 2014 - 15.05.2018")]
|
[assembly: AssemblyCopyright("Copyright © BlubbFish 2014 - 10.04.2021")]
|
||||||
[assembly: AssemblyTrademark("")]
|
[assembly: AssemblyTrademark("BlubbFish")]
|
||||||
[assembly: AssemblyCulture("")]
|
[assembly: AssemblyCulture("")]
|
||||||
|
[assembly: NeutralResourcesLanguage("de-DE")]
|
||||||
|
|
||||||
|
|
||||||
// Durch Festlegen von ComVisible auf "false" werden die Typen in dieser Assembly unsichtbar
|
// Durch Festlegen von ComVisible auf "false" werden die Typen in dieser Assembly unsichtbar
|
||||||
// für COM-Komponenten. Wenn Sie auf einen Typ in dieser Assembly von
|
// für COM-Komponenten. Wenn Sie auf einen Typ in dieser Assembly von
|
||||||
@ -32,5 +35,11 @@ using System.Runtime.InteropServices;
|
|||||||
// Sie können alle Werte angeben oder die standardmäßigen Build- und Revisionsnummern
|
// Sie können alle Werte angeben oder die standardmäßigen Build- und Revisionsnummern
|
||||||
// übernehmen, indem Sie "*" eingeben:
|
// übernehmen, indem Sie "*" eingeben:
|
||||||
// [assembly: AssemblyVersion("1.0.*")]
|
// [assembly: AssemblyVersion("1.0.*")]
|
||||||
[assembly: AssemblyVersion("1.1.1")]
|
[assembly: AssemblyVersion("1.5.0")]
|
||||||
[assembly: AssemblyFileVersion("1.1.1")]
|
[assembly: AssemblyFileVersion("1.5.0")]
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1.5.0 Add GetEvent so you can call events by string; Add OwnSingeton class
|
||||||
|
* 1.4.0 Add Helper to Utils
|
||||||
|
*/
|
@ -1,192 +1,195 @@
|
|||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Net;
|
using System.Net;
|
||||||
using System.Reflection;
|
using System.Reflection;
|
||||||
using System.Runtime.InteropServices;
|
using System.Runtime.InteropServices;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
using System.Xml;
|
using System.Xml;
|
||||||
|
|
||||||
namespace BlubbFish.Utils {
|
namespace BlubbFish.Utils {
|
||||||
public class Updater : OwnObject {
|
public class Updater : OwnObject {
|
||||||
private static Updater instances;
|
private static Updater instances;
|
||||||
private String url;
|
private String url;
|
||||||
private VersionInfo[] versions;
|
private VersionInfo[] versions;
|
||||||
private Thread t;
|
private Thread t;
|
||||||
|
|
||||||
public struct VersionInfo {
|
public struct VersionInfo {
|
||||||
public VersionInfo(Type type) {
|
public VersionInfo(Type type) {
|
||||||
this.Name = type.Assembly.GetName().Name;
|
this.Name = type.Assembly.GetName().Name;
|
||||||
this.Version = type.Assembly.GetName().Version.ToString();
|
this.Version = type.Assembly.GetName().Version.ToString();
|
||||||
this.Filename = type.Assembly.ManifestModule.Name;
|
this.Filename = type.Assembly.ManifestModule.Name;
|
||||||
this.GUID = ((GuidAttribute)type.Assembly.GetCustomAttribute(typeof(GuidAttribute))).Value;
|
this.GUID = ((GuidAttribute)type.Assembly.GetCustomAttribute(typeof(GuidAttribute))).Value;
|
||||||
this.HasUpdate = false;
|
this.HasUpdate = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String Name { get; private set; }
|
public String Name { get; private set; }
|
||||||
public String Version { get; private set; }
|
public String Version { get; private set; }
|
||||||
public String Filename { get; private set; }
|
public String Filename { get; private set; }
|
||||||
public String GUID { get; private set; }
|
public String GUID { get; private set; }
|
||||||
public Boolean HasUpdate { get; set; }
|
public Boolean HasUpdate { get; set; }
|
||||||
}
|
}
|
||||||
|
|
||||||
public delegate void UpdateStatus(Object sender, UpdaterEventArgs e);
|
public delegate void UpdateStatus(Object sender, UpdaterEventArgs e);
|
||||||
public delegate void UpdateFail(Object sender, UpdaterFailEventArgs e);
|
public delegate void UpdateFail(Object sender, UpdaterFailEventArgs e);
|
||||||
|
|
||||||
public event UpdateStatus UpdateResult;
|
public event UpdateStatus UpdateResult;
|
||||||
public event UpdateFail ErrorRaised;
|
public event UpdateFail ErrorRaised;
|
||||||
|
|
||||||
private Updater() { }
|
private Updater() { }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Get Instance of Updater
|
/// Get Instance of Updater
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public static Updater Instance {
|
public static Updater Instance {
|
||||||
get {
|
get {
|
||||||
if(instances == null) {
|
if(instances == null) {
|
||||||
instances = new Updater();
|
instances = new Updater();
|
||||||
}
|
}
|
||||||
return instances;
|
return instances;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Waits for the Result of the Updater thread.
|
/// Waits for the Result of the Updater thread.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public void WaitForExit(Boolean exceuteUpdate = true) {
|
public void WaitForExit(Boolean exceuteUpdate = true) {
|
||||||
while (this.t.ThreadState == ThreadState.Running) { }
|
while (this.t.ThreadState == ThreadState.Running) { }
|
||||||
if(exceuteUpdate) {
|
if(exceuteUpdate) {
|
||||||
if(File.Exists("update.bat")) {
|
if(File.Exists("update.bat")) {
|
||||||
System.Diagnostics.Process.Start("update.bat");
|
_ = System.Diagnostics.Process.Start("update.bat");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Set Path to check for Updates
|
/// Set Path to check for Updates
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="url">HTTP URI</param>
|
/// <param name="url">HTTP URI</param>
|
||||||
public void SetUpdateInfo(String url, VersionInfo[] versions) {
|
public void SetUpdateInfo(String url, VersionInfo[] versions) {
|
||||||
this.url = url;
|
this.url = url;
|
||||||
this.versions = versions;
|
this.versions = versions;
|
||||||
FileStream file = new FileStream("version.xml",FileMode.Create);
|
FileStream file = new FileStream("version.xml",FileMode.Create);
|
||||||
XmlTextWriter xml = new XmlTextWriter(file, Encoding.UTF8);
|
XmlTextWriter xml = new XmlTextWriter(file, Encoding.UTF8);
|
||||||
xml.WriteStartDocument();
|
xml.WriteStartDocument();
|
||||||
xml.WriteWhitespace("\n");
|
xml.WriteWhitespace("\n");
|
||||||
xml.WriteStartElement("filelist");
|
xml.WriteStartElement("filelist");
|
||||||
xml.WriteWhitespace("\n");
|
xml.WriteWhitespace("\n");
|
||||||
foreach (VersionInfo version in versions) {
|
foreach (VersionInfo version in versions) {
|
||||||
xml.WriteWhitespace("\t");
|
xml.WriteWhitespace("\t");
|
||||||
xml.WriteStartElement("file");
|
xml.WriteStartElement("file");
|
||||||
xml.WriteAttributeString("Version", version.Version);
|
xml.WriteAttributeString("Version", version.Version);
|
||||||
xml.WriteAttributeString("Filename", version.Filename);
|
xml.WriteAttributeString("Filename", version.Filename);
|
||||||
xml.WriteAttributeString("GUID", version.GUID);
|
xml.WriteAttributeString("GUID", version.GUID);
|
||||||
xml.WriteString(version.Name);
|
xml.WriteString(version.Name);
|
||||||
xml.WriteEndElement();
|
xml.WriteEndElement();
|
||||||
xml.WriteWhitespace("\n");
|
xml.WriteWhitespace("\n");
|
||||||
}
|
}
|
||||||
xml.WriteEndElement();
|
xml.WriteEndElement();
|
||||||
xml.Flush();
|
xml.Flush();
|
||||||
file.Flush();
|
file.Flush();
|
||||||
file.Close();
|
file.Close();
|
||||||
}
|
xml.Close();
|
||||||
|
}
|
||||||
/// <summary>
|
|
||||||
/// Check for Updates
|
/// <summary>
|
||||||
/// </summary>
|
/// Check for Updates
|
||||||
/// <exception cref="ArgumentException"></exception>
|
/// </summary>
|
||||||
public void Check() {
|
/// <exception cref="ArgumentException"></exception>
|
||||||
if(this.url == "") {
|
public void Check() {
|
||||||
throw new ArgumentException("Zuerst eine URL setzen!");
|
if(this.url == "") {
|
||||||
}
|
throw new ArgumentException("Zuerst eine URL setzen!");
|
||||||
if(this.versions.Length == 0) {
|
}
|
||||||
throw new ArgumentException("Zuerst Dateien registrieren!");
|
if(this.versions.Length == 0) {
|
||||||
}
|
throw new ArgumentException("Zuerst Dateien registrieren!");
|
||||||
if(this.UpdateResult == null) {
|
}
|
||||||
throw new ArgumentNullException("Zuerst das Update Event anhängen.");
|
if(this.UpdateResult == null) {
|
||||||
}
|
throw new ArgumentNullException("Zuerst das Update Event anhängen.");
|
||||||
this.t = new Thread(this.Runner);
|
}
|
||||||
this.t.Start();
|
this.t = new Thread(this.Runner);
|
||||||
}
|
this.t.Start();
|
||||||
|
}
|
||||||
private void Runner() {
|
|
||||||
Thread.Sleep(1000);
|
private void Runner() {
|
||||||
try {
|
Thread.Sleep(1000);
|
||||||
Stream stream = WebRequest.Create(this.url + "version.xml").GetResponse().GetResponseStream();
|
try {
|
||||||
String content = new StreamReader(stream).ReadToEnd();
|
Stream stream = WebRequest.Create(this.url + "version.xml").GetResponse().GetResponseStream();
|
||||||
Boolean update = false;
|
StreamReader sr = new StreamReader(stream);
|
||||||
XmlDocument doc = new XmlDocument();
|
String content = sr.ReadToEnd();
|
||||||
doc.LoadXml(content);
|
sr.Close();
|
||||||
foreach (XmlNode node in doc.DocumentElement.ChildNodes) {
|
Boolean update = false;
|
||||||
String guid = node.Attributes["GUID"].Value;
|
XmlDocument doc = new XmlDocument();
|
||||||
String version = node.Attributes["Version"].Value;
|
doc.LoadXml(content);
|
||||||
for(Int32 i=0;i<this.versions.Length;i++) {
|
foreach (XmlNode node in doc.DocumentElement.ChildNodes) {
|
||||||
if (this.versions[i].GUID == guid && this.versions[i].Version != version) {
|
String guid = node.Attributes["GUID"].Value;
|
||||||
this.versions[i].HasUpdate = true;
|
String version = node.Attributes["Version"].Value;
|
||||||
update = true;
|
for(Int32 i=0;i<this.versions.Length;i++) {
|
||||||
}
|
if (this.versions[i].GUID == guid && this.versions[i].Version != version) {
|
||||||
}
|
this.versions[i].HasUpdate = true;
|
||||||
}
|
update = true;
|
||||||
if (update) {
|
}
|
||||||
this.UpdateResult(this, new UpdaterEventArgs(true, "Update verfügbar"));
|
}
|
||||||
return;
|
}
|
||||||
}
|
if (update) {
|
||||||
} catch (Exception e) {
|
this.UpdateResult(this, new UpdaterEventArgs(true, "Update verfügbar"));
|
||||||
this.ErrorRaised?.Invoke(this, new UpdaterFailEventArgs(e));
|
return;
|
||||||
return;
|
}
|
||||||
}
|
} catch (Exception e) {
|
||||||
this.UpdateResult(this, new UpdaterEventArgs(false, "Kein Update verfügbar"));
|
this.ErrorRaised?.Invoke(this, new UpdaterFailEventArgs(e));
|
||||||
}
|
return;
|
||||||
|
}
|
||||||
/// <summary>
|
this.UpdateResult(this, new UpdaterEventArgs(false, "Kein Update verfügbar"));
|
||||||
/// Update the file
|
}
|
||||||
/// </summary>
|
|
||||||
/// <param name="afterExit">Updates the Programm after it has been closed</param>
|
/// <summary>
|
||||||
/// <returns></returns>
|
/// Update the file
|
||||||
public Boolean Update(Boolean afterExit = true) {
|
/// </summary>
|
||||||
try {
|
/// <param name="afterExit">Updates the Programm after it has been closed</param>
|
||||||
if (afterExit) {
|
/// <returns></returns>
|
||||||
this.UpdateAfter();
|
public Boolean Update(Boolean afterExit = true) {
|
||||||
} else {
|
try {
|
||||||
this.UpdateNow();
|
if (afterExit) {
|
||||||
}
|
this.UpdateAfter();
|
||||||
} catch (Exception e) {
|
} else {
|
||||||
this.ErrorRaised?.Invoke(this, new UpdaterFailEventArgs(e));
|
this.UpdateNow();
|
||||||
return false;
|
}
|
||||||
}
|
} catch (Exception e) {
|
||||||
return true;
|
this.ErrorRaised?.Invoke(this, new UpdaterFailEventArgs(e));
|
||||||
}
|
return false;
|
||||||
|
}
|
||||||
private void UpdateAfter() {
|
return true;
|
||||||
this.UpdateNow(true);
|
}
|
||||||
StreamWriter update = new StreamWriter("update.bat", false);
|
|
||||||
update.WriteLine("echo off");
|
private void UpdateAfter() {
|
||||||
update.WriteLine("echo \"Warte 10s\"");
|
this.UpdateNow(true);
|
||||||
update.WriteLine("ping 127.0.0.1 -n 10");
|
StreamWriter update = new StreamWriter("update.bat", false);
|
||||||
update.WriteLine("echo \"Kopiere Dateien....\"");
|
update.WriteLine("echo off");
|
||||||
foreach (VersionInfo file in this.versions) {
|
update.WriteLine("echo \"Warte 10s\"");
|
||||||
if (file.HasUpdate) {
|
update.WriteLine("ping 127.0.0.1 -n 10");
|
||||||
update.WriteLine("echo \"Kopiere " + file.Filename + "\"");
|
update.WriteLine("echo \"Kopiere Dateien....\"");
|
||||||
update.WriteLine("del " + file.Filename);
|
foreach (VersionInfo file in this.versions) {
|
||||||
update.WriteLine("move " + file.Filename + "_ " + file.Filename);
|
if (file.HasUpdate) {
|
||||||
}
|
update.WriteLine("echo \"Kopiere " + file.Filename + "\"");
|
||||||
}
|
update.WriteLine("del " + file.Filename);
|
||||||
update.WriteLine("start cmd /C ping 127.0.0.1 -n 10 & del update.bat");
|
update.WriteLine("move " + file.Filename + "_ " + file.Filename);
|
||||||
update.Flush();
|
}
|
||||||
update.Close();
|
}
|
||||||
}
|
update.WriteLine("start cmd /C ping 127.0.0.1 -n 10 & del update.bat");
|
||||||
|
update.Flush();
|
||||||
private void UpdateNow(Boolean forAfter = false) {
|
update.Close();
|
||||||
foreach (VersionInfo file in this.versions) {
|
}
|
||||||
if (file.HasUpdate) {
|
|
||||||
Stream stream = WebRequest.Create(this.url + file.Filename).GetResponse().GetResponseStream();
|
private void UpdateNow(Boolean forAfter = false) {
|
||||||
FileStream target = new FileStream(file.Filename + (forAfter ? "_" : ""), FileMode.Create);
|
foreach (VersionInfo file in this.versions) {
|
||||||
stream.CopyTo(target);
|
if (file.HasUpdate) {
|
||||||
target.Flush();
|
Stream stream = WebRequest.Create(this.url + file.Filename).GetResponse().GetResponseStream();
|
||||||
target.Close();
|
FileStream target = new FileStream(file.Filename + (forAfter ? "_" : ""), FileMode.Create);
|
||||||
}
|
stream.CopyTo(target);
|
||||||
}
|
target.Flush();
|
||||||
}
|
target.Close();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -1,65 +1,72 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<Project ToolsVersion="12.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
<Project ToolsVersion="12.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||||
<Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
|
<Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
|
<Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
|
||||||
<Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
|
<Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
|
||||||
<ProjectGuid>{FAC8CE64-BF13-4ECE-8097-AEB5DD060098}</ProjectGuid>
|
<ProjectGuid>{FAC8CE64-BF13-4ECE-8097-AEB5DD060098}</ProjectGuid>
|
||||||
<OutputType>Library</OutputType>
|
<OutputType>Library</OutputType>
|
||||||
<AppDesignerFolder>Properties</AppDesignerFolder>
|
<AppDesignerFolder>Properties</AppDesignerFolder>
|
||||||
<RootNamespace>BlubbFish.Utils</RootNamespace>
|
<RootNamespace>BlubbFish.Utils</RootNamespace>
|
||||||
<AssemblyName>Utils</AssemblyName>
|
<AssemblyName>Utils</AssemblyName>
|
||||||
<TargetFrameworkVersion>v4.7.1</TargetFrameworkVersion>
|
<TargetFrameworkVersion>v4.7.1</TargetFrameworkVersion>
|
||||||
<FileAlignment>512</FileAlignment>
|
<FileAlignment>512</FileAlignment>
|
||||||
<TargetFrameworkProfile />
|
<TargetFrameworkProfile />
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
|
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
|
||||||
<DebugSymbols>true</DebugSymbols>
|
<DebugSymbols>true</DebugSymbols>
|
||||||
<DebugType>full</DebugType>
|
<DebugType>full</DebugType>
|
||||||
<Optimize>false</Optimize>
|
<Optimize>false</Optimize>
|
||||||
<OutputPath>bin\Debug\</OutputPath>
|
<OutputPath>bin\Debug\</OutputPath>
|
||||||
<DefineConstants>DEBUG;TRACE</DefineConstants>
|
<DefineConstants>DEBUG;TRACE</DefineConstants>
|
||||||
<ErrorReport>prompt</ErrorReport>
|
<ErrorReport>prompt</ErrorReport>
|
||||||
<WarningLevel>4</WarningLevel>
|
<WarningLevel>4</WarningLevel>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
|
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
|
||||||
<DebugType>pdbonly</DebugType>
|
<DebugType>pdbonly</DebugType>
|
||||||
<Optimize>true</Optimize>
|
<Optimize>true</Optimize>
|
||||||
<OutputPath>bin\Release\</OutputPath>
|
<OutputPath>bin\Release\</OutputPath>
|
||||||
<DefineConstants>TRACE</DefineConstants>
|
<DefineConstants>TRACE</DefineConstants>
|
||||||
<ErrorReport>prompt</ErrorReport>
|
<ErrorReport>prompt</ErrorReport>
|
||||||
<WarningLevel>4</WarningLevel>
|
<WarningLevel>4</WarningLevel>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<Reference Include="System" />
|
<Reference Include="System" />
|
||||||
<Reference Include="System.Core" />
|
<Reference Include="System.Core" />
|
||||||
<Reference Include="System.Windows.Forms" />
|
<Reference Include="System.Windows.Forms" />
|
||||||
<Reference Include="System.Xml.Linq" />
|
<Reference Include="System.Xml.Linq" />
|
||||||
<Reference Include="System.Data.DataSetExtensions" />
|
<Reference Include="System.Data.DataSetExtensions" />
|
||||||
<Reference Include="Microsoft.CSharp" />
|
<Reference Include="Microsoft.CSharp" />
|
||||||
<Reference Include="System.Data" />
|
<Reference Include="System.Data" />
|
||||||
<Reference Include="System.Xml" />
|
<Reference Include="System.Xml" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<Compile Include="CmdArgs.cs" />
|
<Compile Include="CmdArgs.cs" />
|
||||||
<Compile Include="EventArgsHelper.cs" />
|
<Compile Include="EventArgsHelper.cs" />
|
||||||
<Compile Include="FileLogger.cs" />
|
<Compile Include="FileLogger.cs" />
|
||||||
<Compile Include="FileMutex.cs" />
|
<Compile Include="FileMutex.cs" />
|
||||||
<Compile Include="InIReader.cs" />
|
<Compile Include="Helper.cs" />
|
||||||
<Compile Include="OwnController.cs" />
|
<Compile Include="InIReader.cs" />
|
||||||
<Compile Include="OwnModel.cs" />
|
<Compile Include="OwnController.cs" />
|
||||||
<Compile Include="OwnObject.cs" />
|
<Compile Include="OwnModel.cs" />
|
||||||
<Compile Include="OwnView.cs" />
|
<Compile Include="OwnObject.cs" />
|
||||||
<Compile Include="ProgramLogger.cs" />
|
<Compile Include="OwnView.cs" />
|
||||||
<Compile Include="Properties\AssemblyInfo.cs" />
|
<Compile Include="ProgramLogger.cs" />
|
||||||
<Compile Include="Updater.cs" />
|
<Compile Include="Properties\AssemblyInfo.cs" />
|
||||||
</ItemGroup>
|
<Compile Include="Updater.cs" />
|
||||||
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
|
</ItemGroup>
|
||||||
<!-- To modify your build process, add your task inside one of the targets below and uncomment it.
|
<ItemGroup>
|
||||||
Other similar extension points exist, see Microsoft.Common.targets.
|
<Content Include="..\CHANGELOG.md" />
|
||||||
<Target Name="BeforeBuild">
|
<Content Include="..\CONTRIBUTING.md" />
|
||||||
</Target>
|
<Content Include="..\LICENSE" />
|
||||||
<Target Name="AfterBuild">
|
<Content Include="..\README.md" />
|
||||||
</Target>
|
</ItemGroup>
|
||||||
-->
|
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
|
||||||
|
<!-- To modify your build process, add your task inside one of the targets below and uncomment it.
|
||||||
|
Other similar extension points exist, see Microsoft.Common.targets.
|
||||||
|
<Target Name="BeforeBuild">
|
||||||
|
</Target>
|
||||||
|
<Target Name="AfterBuild">
|
||||||
|
</Target>
|
||||||
|
-->
|
||||||
</Project>
|
</Project>
|
60
Utils/Utils.csproj
Normal file
60
Utils/Utils.csproj
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
<Project Sdk="Microsoft.NET.Sdk">
|
||||||
|
|
||||||
|
<PropertyGroup>
|
||||||
|
<TargetFramework>netcoreapp3.1</TargetFramework>
|
||||||
|
<AssemblyName>Utils</AssemblyName>
|
||||||
|
<RootNamespace>BlubbFish.Utils</RootNamespace>
|
||||||
|
<Description>Provides useful classes for other projects</Description>
|
||||||
|
<Company>BlubbFish</Company>
|
||||||
|
<Authors>BlubbFish</Authors>
|
||||||
|
<PackageId>Utils.BlubbFish</PackageId>
|
||||||
|
<Copyright>Copyright © BlubbFish 2014 - 30.01.2022</Copyright>
|
||||||
|
<Version>1.6.2</Version>
|
||||||
|
<NeutralLanguage>de-DE</NeutralLanguage>
|
||||||
|
<PackageLicenseFile>LICENSE</PackageLicenseFile>
|
||||||
|
<PackageProjectUrl>http://git.blubbfish.net/vs_utils/Utils</PackageProjectUrl>
|
||||||
|
<RepositoryUrl>http://git.blubbfish.net/vs_utils/Utils.git</RepositoryUrl>
|
||||||
|
<RepositoryType>git</RepositoryType>
|
||||||
|
<PackageReleaseNotes>
|
||||||
|
1.6.2 - 2022-01-30 - ProgrammLogger improved
|
||||||
|
1.6.1 - 2022-01-20 - ProgrammLogger Fixed
|
||||||
|
1.6.0 - 2022-01-09 - HttpEndpoint added
|
||||||
|
1.5.0 - 2021-04-10 - Add GetEvent so you can call events by string; Add OwnSingeton class
|
||||||
|
1.4.0 - 2018-11-27 - Add Helper to Utils
|
||||||
|
1.1.3 - 2018-10-02 - Improve CmdArgs
|
||||||
|
1.1.2 - 2018-09-11 - Tiny Codingstyles
|
||||||
|
1.1.1 - 2018-05-29 - ProgrammLogger neets to cleanup
|
||||||
|
1.1.0 - 2018-05-15 - ProgrammLogger
|
||||||
|
1.0.7.0 - 2018-05-08 - Yet another IniReader improvemnt round again
|
||||||
|
1.0.6.0 - 2017-12-22 - Yet another IniReader improvemnt round
|
||||||
|
1.0.5.2 - 2017-09-26 - And Improve IniReader again
|
||||||
|
1.0.5.1 - 2017-09-24 - Improve IniReader again
|
||||||
|
1.0.5.0 - 2017-08-09 - Improve IniReader
|
||||||
|
1.0.4.1 - 2017-08-08 - Cleanup OwnView
|
||||||
|
1.0.4.0 - 2017-04-30 - More Updater
|
||||||
|
1.0.3.2 - 2017-04-26 - Next Updater
|
||||||
|
1.0.3.1 - 2017-04-25 - EventArgsHelper
|
||||||
|
1.0.2.6 - 2017-04-24 - Better Updater
|
||||||
|
1.0.2.5 - 2017-04-19 - Logging in OwnObject
|
||||||
|
1.0.2.3 - 2017-04-16 - OwnModel better
|
||||||
|
1.0.2.2 - 2017-03-09 - Make it nice
|
||||||
|
1.0.2.1 - 2017-03-09 - Filemutex
|
||||||
|
1.0.0.1 - 2016-12-03 - Filelogger improvements
|
||||||
|
1.0.0.0 - 2015-11-16 - Init
|
||||||
|
</PackageReleaseNotes>
|
||||||
|
</PropertyGroup>
|
||||||
|
|
||||||
|
<ItemGroup>
|
||||||
|
<Content Include="../CHANGELOG.md" />
|
||||||
|
<Content Include="../CONTRIBUTING.md" />
|
||||||
|
<Content Include="../LICENSE" />
|
||||||
|
<Content Include="../README.md" />
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<None Include="..\LICENSE">
|
||||||
|
<Pack>True</Pack>
|
||||||
|
<PackagePath></PackagePath>
|
||||||
|
</None>
|
||||||
|
</ItemGroup>
|
||||||
|
|
||||||
|
</Project>
|
Binary file not shown.
Loading…
Reference in New Issue
Block a user