2022-06-07 20:22:33 -07:00
[![CI ](https://github.com/comictagger/comictagger/actions/workflows/build.yaml/badge.svg?branch=develop&event=push )](https://github.com/comictagger/comictagger/actions/workflows/build.yaml)
[![GitHub release (latest by date) ](https://img.shields.io/github/downloads/comictagger/comictagger/latest/total )](https://github.com/comictagger/comictagger/releases/latest)
[![PyPI ](https://img.shields.io/pypi/v/comictagger )](https://pypi.org/project/comictagger/)
[![PyPI - Downloads ](https://img.shields.io/pypi/dm/comictagger )](https://pypistats.org/packages/comictagger)
2022-08-13 02:52:09 -07:00
[![Chocolatey package ](https://img.shields.io/chocolatey/dt/comictagger?color=blue&label=chocolatey )](https://community.chocolatey.org/packages/comictagger)
2022-06-07 20:22:33 -07:00
[![PyPI - License ](https://img.shields.io/pypi/l/comictagger )](https://opensource.org/licenses/Apache-2.0)
[![GitHub Discussions ](https://img.shields.io/github/discussions/comictagger/comictagger )](https://github.com/comictagger/comictagger/discussions)
Code cleanup
Remove no longer used google scripts
Remove convenience files from comicataggerlib and import comicapi directly
Add type-hints to facilitate auto-complete tools
Make PyQt5 code more compatible with PyQt6
Implement automatic tooling
isort and black for code formatting
Line length has been set to 120
flake8 for code standards with exceptions:
E203 - Whitespace before ':' - format compatiblity with black
E501 - Line too long - flake8 line limit cannot be set
E722 - Do not use bare except - fixing bare except statements is a
lot of overhead and there are already
many in the codebase
These changes, along with some manual fixes creates much more readable code.
See examples below:
diff --git a/comicapi/comet.py b/comicapi/comet.py
index d1741c5..52dc195 100644
--- a/comicapi/comet.py
+++ b/comicapi/comet.py
@@ -166,7 +166,2 @@ class CoMet:
- if credit['role'].lower() in set(self.editor_synonyms):
- ET.SubElement(
- root,
- 'editor').text = "{0}".format(
- credit['person'])
@@ -174,2 +169,4 @@ class CoMet:
self.indent(root)
+ if credit["role"].lower() in set(self.editor_synonyms):
+ ET.SubElement(root, "editor").text = str(credit["person"])
diff --git a/comictaggerlib/autotagmatchwindow.py b/comictaggerlib/autotagmatchwindow.py
index 4338176..9219f01 100644
--- a/comictaggerlib/autotagmatchwindow.py
+++ b/comictaggerlib/autotagmatchwindow.py
@@ -63,4 +63,3 @@ class AutoTagMatchWindow(QtWidgets.QDialog):
self.skipButton, QtWidgets.QDialogButtonBox.ActionRole)
- self.buttonBox.button(QtWidgets.QDialogButtonBox.Ok).setText(
- "Accept and Write Tags")
+ self.buttonBox.button(QtWidgets.QDialogButtonBox.StandardButton.Ok).setText("Accept and Write Tags")
diff --git a/comictaggerlib/cli.py b/comictaggerlib/cli.py
index 688907d..dbd0c2e 100644
--- a/comictaggerlib/cli.py
+++ b/comictaggerlib/cli.py
@@ -293,7 +293,3 @@ def process_file_cli(filename, opts, settings, match_results):
if opts.raw:
- print((
- "{0}".format(
- str(
- ca.readRawCIX(),
- errors='ignore'))))
+ print(ca.read_raw_cix())
else:
2022-04-01 16:50:46 -07:00
[![Gitter chat ](https://badges.gitter.im/gitterHQ/gitter.png )](https://gitter.im/comictagger/community)
[![Google Group ](https://img.shields.io/badge/discuss-on%20groups-%23207de5 )](https://groups.google.com/forum/#!forum/comictagger)
[![Twitter ](https://img.shields.io/badge/%40comictagger-twitter-lightgrey )](https://twitter.com/comictagger)
[![Facebook ](https://img.shields.io/badge/comictagger-facebook-lightgrey )](https://www.facebook.com/ComicTagger-139615369550787/)
# ComicTagger
ComicTagger is a **multi-platform** app for **writing metadata to digital comics** , written in Python and PyQt.
![ComicTagger logo ](https://raw.githubusercontent.com/comictagger/comictagger/develop/comictaggerlib/graphics/app.png )
## Features
* Runs on macOS, Microsoft Windows, and Linux systems
* Get comic information from [Comic Vine ](https://comicvine.gamespot.com/ )
* **Automatic issue matching** using advanced image processing techniques
* **Batch processing** in the GUI for tagging hundreds or more comics at a time
* Support for **ComicRack** and **ComicBookLover** tagging formats
* Native full support for **CBZ** digital comics
* Native read only support for **CBR** digital comics: full support enabled installing additional [rar tools ](https://www.rarlab.com/download.htm )
* Command line interface (CLI) enabling **custom scripting** and **batch operations on large collections**
2022-04-19 21:55:34 -07:00
For details, screen-shots, and more, visit [the Wiki ](https://github.com/comictagger/comictagger/wiki )
Code cleanup
Remove no longer used google scripts
Remove convenience files from comicataggerlib and import comicapi directly
Add type-hints to facilitate auto-complete tools
Make PyQt5 code more compatible with PyQt6
Implement automatic tooling
isort and black for code formatting
Line length has been set to 120
flake8 for code standards with exceptions:
E203 - Whitespace before ':' - format compatiblity with black
E501 - Line too long - flake8 line limit cannot be set
E722 - Do not use bare except - fixing bare except statements is a
lot of overhead and there are already
many in the codebase
These changes, along with some manual fixes creates much more readable code.
See examples below:
diff --git a/comicapi/comet.py b/comicapi/comet.py
index d1741c5..52dc195 100644
--- a/comicapi/comet.py
+++ b/comicapi/comet.py
@@ -166,7 +166,2 @@ class CoMet:
- if credit['role'].lower() in set(self.editor_synonyms):
- ET.SubElement(
- root,
- 'editor').text = "{0}".format(
- credit['person'])
@@ -174,2 +169,4 @@ class CoMet:
self.indent(root)
+ if credit["role"].lower() in set(self.editor_synonyms):
+ ET.SubElement(root, "editor").text = str(credit["person"])
diff --git a/comictaggerlib/autotagmatchwindow.py b/comictaggerlib/autotagmatchwindow.py
index 4338176..9219f01 100644
--- a/comictaggerlib/autotagmatchwindow.py
+++ b/comictaggerlib/autotagmatchwindow.py
@@ -63,4 +63,3 @@ class AutoTagMatchWindow(QtWidgets.QDialog):
self.skipButton, QtWidgets.QDialogButtonBox.ActionRole)
- self.buttonBox.button(QtWidgets.QDialogButtonBox.Ok).setText(
- "Accept and Write Tags")
+ self.buttonBox.button(QtWidgets.QDialogButtonBox.StandardButton.Ok).setText("Accept and Write Tags")
diff --git a/comictaggerlib/cli.py b/comictaggerlib/cli.py
index 688907d..dbd0c2e 100644
--- a/comictaggerlib/cli.py
+++ b/comictaggerlib/cli.py
@@ -293,7 +293,3 @@ def process_file_cli(filename, opts, settings, match_results):
if opts.raw:
- print((
- "{0}".format(
- str(
- ca.readRawCIX(),
- errors='ignore'))))
+ print(ca.read_raw_cix())
else:
2022-04-01 16:50:46 -07:00
## Installation
2023-04-18 21:03:50 -07:00
It is reccomended to either use the Binaries or a package manager for the best experience
Code cleanup
Remove no longer used google scripts
Remove convenience files from comicataggerlib and import comicapi directly
Add type-hints to facilitate auto-complete tools
Make PyQt5 code more compatible with PyQt6
Implement automatic tooling
isort and black for code formatting
Line length has been set to 120
flake8 for code standards with exceptions:
E203 - Whitespace before ':' - format compatiblity with black
E501 - Line too long - flake8 line limit cannot be set
E722 - Do not use bare except - fixing bare except statements is a
lot of overhead and there are already
many in the codebase
These changes, along with some manual fixes creates much more readable code.
See examples below:
diff --git a/comicapi/comet.py b/comicapi/comet.py
index d1741c5..52dc195 100644
--- a/comicapi/comet.py
+++ b/comicapi/comet.py
@@ -166,7 +166,2 @@ class CoMet:
- if credit['role'].lower() in set(self.editor_synonyms):
- ET.SubElement(
- root,
- 'editor').text = "{0}".format(
- credit['person'])
@@ -174,2 +169,4 @@ class CoMet:
self.indent(root)
+ if credit["role"].lower() in set(self.editor_synonyms):
+ ET.SubElement(root, "editor").text = str(credit["person"])
diff --git a/comictaggerlib/autotagmatchwindow.py b/comictaggerlib/autotagmatchwindow.py
index 4338176..9219f01 100644
--- a/comictaggerlib/autotagmatchwindow.py
+++ b/comictaggerlib/autotagmatchwindow.py
@@ -63,4 +63,3 @@ class AutoTagMatchWindow(QtWidgets.QDialog):
self.skipButton, QtWidgets.QDialogButtonBox.ActionRole)
- self.buttonBox.button(QtWidgets.QDialogButtonBox.Ok).setText(
- "Accept and Write Tags")
+ self.buttonBox.button(QtWidgets.QDialogButtonBox.StandardButton.Ok).setText("Accept and Write Tags")
diff --git a/comictaggerlib/cli.py b/comictaggerlib/cli.py
index 688907d..dbd0c2e 100644
--- a/comictaggerlib/cli.py
+++ b/comictaggerlib/cli.py
@@ -293,7 +293,3 @@ def process_file_cli(filename, opts, settings, match_results):
if opts.raw:
- print((
- "{0}".format(
- str(
- ca.readRawCIX(),
- errors='ignore'))))
+ print(ca.read_raw_cix())
else:
2022-04-01 16:50:46 -07:00
2023-04-18 21:03:50 -07:00
### Binaries
Code cleanup
Remove no longer used google scripts
Remove convenience files from comicataggerlib and import comicapi directly
Add type-hints to facilitate auto-complete tools
Make PyQt5 code more compatible with PyQt6
Implement automatic tooling
isort and black for code formatting
Line length has been set to 120
flake8 for code standards with exceptions:
E203 - Whitespace before ':' - format compatiblity with black
E501 - Line too long - flake8 line limit cannot be set
E722 - Do not use bare except - fixing bare except statements is a
lot of overhead and there are already
many in the codebase
These changes, along with some manual fixes creates much more readable code.
See examples below:
diff --git a/comicapi/comet.py b/comicapi/comet.py
index d1741c5..52dc195 100644
--- a/comicapi/comet.py
+++ b/comicapi/comet.py
@@ -166,7 +166,2 @@ class CoMet:
- if credit['role'].lower() in set(self.editor_synonyms):
- ET.SubElement(
- root,
- 'editor').text = "{0}".format(
- credit['person'])
@@ -174,2 +169,4 @@ class CoMet:
self.indent(root)
+ if credit["role"].lower() in set(self.editor_synonyms):
+ ET.SubElement(root, "editor").text = str(credit["person"])
diff --git a/comictaggerlib/autotagmatchwindow.py b/comictaggerlib/autotagmatchwindow.py
index 4338176..9219f01 100644
--- a/comictaggerlib/autotagmatchwindow.py
+++ b/comictaggerlib/autotagmatchwindow.py
@@ -63,4 +63,3 @@ class AutoTagMatchWindow(QtWidgets.QDialog):
self.skipButton, QtWidgets.QDialogButtonBox.ActionRole)
- self.buttonBox.button(QtWidgets.QDialogButtonBox.Ok).setText(
- "Accept and Write Tags")
+ self.buttonBox.button(QtWidgets.QDialogButtonBox.StandardButton.Ok).setText("Accept and Write Tags")
diff --git a/comictaggerlib/cli.py b/comictaggerlib/cli.py
index 688907d..dbd0c2e 100644
--- a/comictaggerlib/cli.py
+++ b/comictaggerlib/cli.py
@@ -293,7 +293,3 @@ def process_file_cli(filename, opts, settings, match_results):
if opts.raw:
- print((
- "{0}".format(
- str(
- ca.readRawCIX(),
- errors='ignore'))))
+ print(ca.read_raw_cix())
else:
2022-04-01 16:50:46 -07:00
2023-04-18 21:03:50 -07:00
Windows, Linux and MacOS binaries are provided in the [Releases Page ](https://github.com/comictagger/comictagger/releases ).
Code cleanup
Remove no longer used google scripts
Remove convenience files from comicataggerlib and import comicapi directly
Add type-hints to facilitate auto-complete tools
Make PyQt5 code more compatible with PyQt6
Implement automatic tooling
isort and black for code formatting
Line length has been set to 120
flake8 for code standards with exceptions:
E203 - Whitespace before ':' - format compatiblity with black
E501 - Line too long - flake8 line limit cannot be set
E722 - Do not use bare except - fixing bare except statements is a
lot of overhead and there are already
many in the codebase
These changes, along with some manual fixes creates much more readable code.
See examples below:
diff --git a/comicapi/comet.py b/comicapi/comet.py
index d1741c5..52dc195 100644
--- a/comicapi/comet.py
+++ b/comicapi/comet.py
@@ -166,7 +166,2 @@ class CoMet:
- if credit['role'].lower() in set(self.editor_synonyms):
- ET.SubElement(
- root,
- 'editor').text = "{0}".format(
- credit['person'])
@@ -174,2 +169,4 @@ class CoMet:
self.indent(root)
+ if credit["role"].lower() in set(self.editor_synonyms):
+ ET.SubElement(root, "editor").text = str(credit["person"])
diff --git a/comictaggerlib/autotagmatchwindow.py b/comictaggerlib/autotagmatchwindow.py
index 4338176..9219f01 100644
--- a/comictaggerlib/autotagmatchwindow.py
+++ b/comictaggerlib/autotagmatchwindow.py
@@ -63,4 +63,3 @@ class AutoTagMatchWindow(QtWidgets.QDialog):
self.skipButton, QtWidgets.QDialogButtonBox.ActionRole)
- self.buttonBox.button(QtWidgets.QDialogButtonBox.Ok).setText(
- "Accept and Write Tags")
+ self.buttonBox.button(QtWidgets.QDialogButtonBox.StandardButton.Ok).setText("Accept and Write Tags")
diff --git a/comictaggerlib/cli.py b/comictaggerlib/cli.py
index 688907d..dbd0c2e 100644
--- a/comictaggerlib/cli.py
+++ b/comictaggerlib/cli.py
@@ -293,7 +293,3 @@ def process_file_cli(filename, opts, settings, match_results):
if opts.raw:
- print((
- "{0}".format(
- str(
- ca.readRawCIX(),
- errors='ignore'))))
+ print(ca.read_raw_cix())
else:
2022-04-01 16:50:46 -07:00
2023-04-18 21:03:50 -07:00
Unzip the archive in any folder and run, no additional installation steps are required.
2022-04-19 21:55:34 -07:00
2022-08-13 02:52:09 -07:00
### Chocolatey installation (Windows only)
2022-08-14 10:45:51 -07:00
A [Chocolatey package ](https://community.chocolatey.org/packages/comictagger ), maintained by @Xav83 , is provided, you can install it with:
2022-08-13 02:52:09 -07:00
```powershell
choco install comictagger
2022-08-14 10:51:08 -07:00
```
2023-04-18 21:03:50 -07:00
### PyPi installation
! Please note that pages may not be sorted correctly if ICU is not installed on Linux and MacOS.
If you have issues installing ICU please see the PyICU documentation [here ](https://pyicu.org )
A PyPi package is provided, you can install it with:
```
$ pip3 install comictagger[GUI,ICU]
```
There are several optional dependencies GUI, CBR, 7Z and ICU. You can install the optional dependencies by specifying one or more of `GUI` ,`CBR` or `all` in braces e.g. `comictagger[CBR,GUI,ICU]`
Code cleanup
Remove no longer used google scripts
Remove convenience files from comicataggerlib and import comicapi directly
Add type-hints to facilitate auto-complete tools
Make PyQt5 code more compatible with PyQt6
Implement automatic tooling
isort and black for code formatting
Line length has been set to 120
flake8 for code standards with exceptions:
E203 - Whitespace before ':' - format compatiblity with black
E501 - Line too long - flake8 line limit cannot be set
E722 - Do not use bare except - fixing bare except statements is a
lot of overhead and there are already
many in the codebase
These changes, along with some manual fixes creates much more readable code.
See examples below:
diff --git a/comicapi/comet.py b/comicapi/comet.py
index d1741c5..52dc195 100644
--- a/comicapi/comet.py
+++ b/comicapi/comet.py
@@ -166,7 +166,2 @@ class CoMet:
- if credit['role'].lower() in set(self.editor_synonyms):
- ET.SubElement(
- root,
- 'editor').text = "{0}".format(
- credit['person'])
@@ -174,2 +169,4 @@ class CoMet:
self.indent(root)
+ if credit["role"].lower() in set(self.editor_synonyms):
+ ET.SubElement(root, "editor").text = str(credit["person"])
diff --git a/comictaggerlib/autotagmatchwindow.py b/comictaggerlib/autotagmatchwindow.py
index 4338176..9219f01 100644
--- a/comictaggerlib/autotagmatchwindow.py
+++ b/comictaggerlib/autotagmatchwindow.py
@@ -63,4 +63,3 @@ class AutoTagMatchWindow(QtWidgets.QDialog):
self.skipButton, QtWidgets.QDialogButtonBox.ActionRole)
- self.buttonBox.button(QtWidgets.QDialogButtonBox.Ok).setText(
- "Accept and Write Tags")
+ self.buttonBox.button(QtWidgets.QDialogButtonBox.StandardButton.Ok).setText("Accept and Write Tags")
diff --git a/comictaggerlib/cli.py b/comictaggerlib/cli.py
index 688907d..dbd0c2e 100644
--- a/comictaggerlib/cli.py
+++ b/comictaggerlib/cli.py
@@ -293,7 +293,3 @@ def process_file_cli(filename, opts, settings, match_results):
if opts.raw:
- print((
- "{0}".format(
- str(
- ca.readRawCIX(),
- errors='ignore'))))
+ print(ca.read_raw_cix())
else:
2022-04-01 16:50:46 -07:00
### From source
2022-04-19 21:55:34 -07:00
1. Ensure you have python 3.9 installed
Code cleanup
Remove no longer used google scripts
Remove convenience files from comicataggerlib and import comicapi directly
Add type-hints to facilitate auto-complete tools
Make PyQt5 code more compatible with PyQt6
Implement automatic tooling
isort and black for code formatting
Line length has been set to 120
flake8 for code standards with exceptions:
E203 - Whitespace before ':' - format compatiblity with black
E501 - Line too long - flake8 line limit cannot be set
E722 - Do not use bare except - fixing bare except statements is a
lot of overhead and there are already
many in the codebase
These changes, along with some manual fixes creates much more readable code.
See examples below:
diff --git a/comicapi/comet.py b/comicapi/comet.py
index d1741c5..52dc195 100644
--- a/comicapi/comet.py
+++ b/comicapi/comet.py
@@ -166,7 +166,2 @@ class CoMet:
- if credit['role'].lower() in set(self.editor_synonyms):
- ET.SubElement(
- root,
- 'editor').text = "{0}".format(
- credit['person'])
@@ -174,2 +169,4 @@ class CoMet:
self.indent(root)
+ if credit["role"].lower() in set(self.editor_synonyms):
+ ET.SubElement(root, "editor").text = str(credit["person"])
diff --git a/comictaggerlib/autotagmatchwindow.py b/comictaggerlib/autotagmatchwindow.py
index 4338176..9219f01 100644
--- a/comictaggerlib/autotagmatchwindow.py
+++ b/comictaggerlib/autotagmatchwindow.py
@@ -63,4 +63,3 @@ class AutoTagMatchWindow(QtWidgets.QDialog):
self.skipButton, QtWidgets.QDialogButtonBox.ActionRole)
- self.buttonBox.button(QtWidgets.QDialogButtonBox.Ok).setText(
- "Accept and Write Tags")
+ self.buttonBox.button(QtWidgets.QDialogButtonBox.StandardButton.Ok).setText("Accept and Write Tags")
diff --git a/comictaggerlib/cli.py b/comictaggerlib/cli.py
index 688907d..dbd0c2e 100644
--- a/comictaggerlib/cli.py
+++ b/comictaggerlib/cli.py
@@ -293,7 +293,3 @@ def process_file_cli(filename, opts, settings, match_results):
if opts.raw:
- print((
- "{0}".format(
- str(
- ca.readRawCIX(),
- errors='ignore'))))
+ print(ca.read_raw_cix())
else:
2022-04-01 16:50:46 -07:00
2. Clone this repository `git clone https://github.com/comictagger/comictagger.git`
3. `pip3 install -r requirements_dev.txt`
2023-04-18 21:03:50 -07:00
7. `pip3 install .` or `pip3 install .[GUI,ICU]`
2023-02-16 16:33:35 -08:00
## Contributors
<!-- readme: beville,davide - romanini,collaborators,contributors - start -->
2023-02-16 17:14:27 -08:00
< table >
< tr >
< td align = "center" >
< a href = "https://github.com/beville" >
< img src = "https://avatars.githubusercontent.com/u/7294848?v=4" width = "100;" alt = "beville" / >
< br / >
< sub > < b > beville< / b > < / sub >
< / a >
< / td >
< td align = "center" >
< a href = "https://github.com/davide-romanini" >
< img src = "https://avatars.githubusercontent.com/u/731199?v=4" width = "100;" alt = "davide-romanini" / >
< br / >
< sub > < b > davide-romanini< / b > < / sub >
< / a >
< / td >
< td align = "center" >
< a href = "https://github.com/fcanc" >
< img src = "https://avatars.githubusercontent.com/u/4999486?v=4" width = "100;" alt = "fcanc" / >
< br / >
< sub > < b > fcanc< / b > < / sub >
< / a >
< / td >
< td align = "center" >
< a href = "https://github.com/lordwelch" >
< img src = "https://avatars.githubusercontent.com/u/7547075?v=4" width = "100;" alt = "lordwelch" / >
< br / >
< sub > < b > lordwelch< / b > < / sub >
< / a >
< / td >
< td align = "center" >
< a href = "https://github.com/mizaki" >
< img src = "https://avatars.githubusercontent.com/u/1141189?v=4" width = "100;" alt = "mizaki" / >
< br / >
< sub > < b > mizaki< / b > < / sub >
< / a >
< / td >
< td align = "center" >
< a href = "https://github.com/MichaelFitzurka" >
< img src = "https://avatars.githubusercontent.com/u/27830765?v=4" width = "100;" alt = "MichaelFitzurka" / >
< br / >
< sub > < b > MichaelFitzurka< / b > < / sub >
< / a >
< / td > < / tr >
< tr >
< td align = "center" >
< a href = "https://github.com/abuchanan920" >
< img src = "https://avatars.githubusercontent.com/u/368793?v=4" width = "100;" alt = "abuchanan920" / >
< br / >
< sub > < b > abuchanan920< / b > < / sub >
< / a >
< / td >
< td align = "center" >
< a href = "https://github.com/AlbanSeurat" >
< img src = "https://avatars.githubusercontent.com/u/500180?v=4" width = "100;" alt = "AlbanSeurat" / >
< br / >
< sub > < b > AlbanSeurat< / b > < / sub >
< / a >
< / td >
< td align = "center" >
< a href = "https://github.com/rhaussmann" >
< img src = "https://avatars.githubusercontent.com/u/7084007?v=4" width = "100;" alt = "rhaussmann" / >
< br / >
< sub > < b > rhaussmann< / b > < / sub >
< / a >
< / td >
< td align = "center" >
< a href = "https://github.com/jpcranford" >
< img src = "https://avatars.githubusercontent.com/u/21347202?v=4" width = "100;" alt = "jpcranford" / >
< br / >
< sub > < b > jpcranford< / b > < / sub >
< / a >
< / td >
< td align = "center" >
< a href = "https://github.com/PawlakMarek" >
< img src = "https://avatars.githubusercontent.com/u/26022173?v=4" width = "100;" alt = "PawlakMarek" / >
< br / >
< sub > < b > PawlakMarek< / b > < / sub >
< / a >
< / td >
< td align = "center" >
< a href = "https://github.com/Xav83" >
< img src = "https://avatars.githubusercontent.com/u/6787157?v=4" width = "100;" alt = "Xav83" / >
< br / >
< sub > < b > Xav83< / b > < / sub >
< / a >
< / td > < / tr >
< tr >
< td align = "center" >
< a href = "https://github.com/thFrgttn" >
< img src = "https://avatars.githubusercontent.com/u/39759781?v=4" width = "100;" alt = "thFrgttn" / >
< br / >
< sub > < b > thFrgttn< / b > < / sub >
< / a >
< / td >
< td align = "center" >
< a href = "https://github.com/tlc" >
< img src = "https://avatars.githubusercontent.com/u/19436?v=4" width = "100;" alt = "tlc" / >
< br / >
< sub > < b > tlc< / b > < / sub >
< / a >
< / td > < / tr >
< / table >
2023-02-16 16:33:35 -08:00
<!-- readme: beville,davide - romanini,collaborators,contributors - end -->