From 2582c2d58178b8d00132fff21ab6007cf4e403bb Mon Sep 17 00:00:00 2001 From: Ian Roberts Date: Mon, 2 Oct 2023 18:17:31 +0100 Subject: [PATCH 1/8] Fix syntax error in install script Apparently at least some versions of bash don't like parentheses inside a square bracket test expression, changed to use if ! [ ... ] instead of if [ ! ( ... ) ] --- install/get-teamware.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/install/get-teamware.sh b/install/get-teamware.sh index 9cf804b5..e7a5e30a 100644 --- a/install/get-teamware.sh +++ b/install/get-teamware.sh @@ -55,7 +55,7 @@ set -a if [ -f .env -a -f docker-compose.yml ]; then - if [ ! ( -f create-django-db.sh -a -f generate-docker-env.sh ) ]; then + if ! [ -f create-django-db.sh -a -f generate-docker-env.sh ]; then echo 'You have run this upgrade script in a folder that contains a docker compose' echo 'application stack, but it does not appear to be an installation of GATE' echo 'Teamware. You should run this script either in a completely empty directory' From dda749bccac87e7b5b771680951d75d192a73948 Mon Sep 17 00:00:00 2001 From: Freddy Heppell Date: Fri, 12 Jan 2024 12:25:28 +0000 Subject: [PATCH 2/8] Update citation to demo paper and zenodo reference --- CITATION.cff | 41 +++++++++++++++++++++++++++++++++++- README.md | 5 +++-- docs/docs/README.md | 6 +++--- frontend/src/views/About.vue | 11 +++++++--- 4 files changed, 54 insertions(+), 9 deletions(-) diff --git a/CITATION.cff b/CITATION.cff index f7c191ed..1b30d037 100644 --- a/CITATION.cff +++ b/CITATION.cff @@ -1,6 +1,6 @@ abstract: A web application for collaborative document annotation. GATE teamware provides a flexible web app platform for managing classification of documents by human annotators. -authors: +authors: - affiliation: The University of Sheffield email: t.karmakharm@sheffield.ac.uk family-names: Karmakharm @@ -38,3 +38,42 @@ title: GATE Teamware type: software url: https://gatenlp.github.io/gate-teamware/ version: 2.1.1 +preferred-citation: + type: conference-paper + authors: + - affiliation: The University of Sheffield + email: d.wilby@sheffield.ac.uk + family-names: Wilby + given-names: David + orcid: https://orcid.org/0000-0002-6553-8739 + - affiliation: The University of Sheffield + email: t.karmakharm@sheffield.ac.uk + family-names: Karmakharm + given-names: Twin + orcid: https://orcid.org/0000-0002-1888-7098 + - affiliation: The University of Sheffield + email: i.roberts@sheffield.ac.uk + family-names: Roberts + given-names: Ian + orcid: https://orcid.org/0000-0002-7296-5851 + - affiliation: The University of Sheffield + email: x.song@sheffield.ac.uk + family-names: Song + given-names: Xingyi + orcid: https://orcid.org/0000-0002-4188-6974 + - affiliation: The University of Sheffield + email: k.bontcheva@sheffield.ac.uk + family-names: Bontcheva + given-names: Kalina + orcid: https://orcid.org/0000-0001-6152-9600 + doi: 10.18653/v1/2023.eacl-demo.17 + title: "GATE Teamware 2: An open-source tool for collaborative document classification annotation" + collection-title: "Proceedings of the 17th Conference of the European Chapter of the Association for Computational Linguistics: System Demonstrations" + year: 2023 + month: 5 + start: 145 + end: 151 + publisher: + name: Association for Computational Linguistics + conference: + location: Dubrovnik, Croatia \ No newline at end of file diff --git a/README.md b/README.md index 34cfc267..3ad1140a 100644 --- a/README.md +++ b/README.md @@ -71,12 +71,13 @@ We welcome contributions to this open source project. Please [create a fork](htt Teamware is developed by the [GATE](https://gate.ac.uk) team, an academic research group at The University of Sheffield. As a result, future funding relies on evidence of the impact that the software provides. If you use Teamware, please let us know using the contact form at [gate.ac.uk](https://gate.ac.uk/g8/contact). Please include details on grants, publications, commercial products etc. Any information that can help us to secure future funding for our work is greatly appreciated. ## Citation -For published work that has used Teamware, please cite this repository. One way is to include a citation such as: +For published work that has used Teamware, please cite the [EACL23 demo paper](https://aclanthology.org/2023.eacl-demo.17/). One way is to include a citation such as: -> Karmakharm, T., Wilby, D., Roberts, I., & Bontcheva, K. (2022). GATE Teamware (Version 2.1.1) [Computer software]. https://github.com/GateNLP/gate-teamware +> Wilby, D., Karmakharm, T., Roberts, I., Song, X. & Bontcheva, K. (2023). GATE Teamware 2: An open-source tool for collaborative document classification annotation. In Proceedings of the 17th Conference of the European Chapter of the Association for Computational Linguistics: System Demonstrations, pages 145–151, Dubrovnik, Croatia. Association for Computational Linguistics. https://aclanthology.org/2023.eacl-demo.17/ Please use the `Cite this repository` button at the top of the [project's GitHub repository](https://github.com/GATENLP/gate-teamware) to get an up to date citation. +Permanent references to each version of the software are available from [Zenodo](https://doi.org/10.5281/zenodo.7899193). [docs]: https://gatenlp.github.io/gate-teamware/ [dev-docs]: https://gatenlp.github.io/gate-teamware/development/developerguide/ diff --git a/docs/docs/README.md b/docs/docs/README.md index 3586c291..d12b9b88 100644 --- a/docs/docs/README.md +++ b/docs/docs/README.md @@ -129,10 +129,10 @@ Please make bug reports and feature requests as Issues on the [GATE Teamware Git Teamware is developed by the [GATE](https://gate.ac.uk) team, an academic research group at The University of Sheffield. As a result, future funding relies on evidence of the impact that the software provides. If you use Teamware, please let us know using the contact form at [gate.ac.uk](https://gate.ac.uk/g8/contact). Please include details on grants, publications, commercial products etc. Any information that can help us to secure future funding for our work is greatly appreciated. ## Citation -For published work that has used Teamware, please cite this repository. One way is to include a citation such as: +For published work that has used Teamware, please cite the [EACL23 demo paper](https://aclanthology.org/2023.eacl-demo.17/). One way is to include a citation such as: -> Karmakharm, T., Wilby, D., Roberts, I., & Bontcheva, K. (2022). GATE Teamware (Version 0.1.4) [Computer software]. https://github.com/GateNLP/gate-teamware +> Wilby, D., Karmakharm, T., Roberts, I., Song, X. & Bontcheva, K. (2023). GATE Teamware 2: An open-source tool for collaborative document classification annotation. In Proceedings of the 17th Conference of the European Chapter of the Association for Computational Linguistics: System Demonstrations, pages 145–151, Dubrovnik, Croatia. Association for Computational Linguistics. https://aclanthology.org/2023.eacl-demo.17/ Please use the `Cite this repository` button at the top of the [project's GitHub repository](https://github.com/GATENLP/gate-teamware) to get an up to date citation. -The Teamware version can be found on the 'About' page of your Teamware instance. +Permanent references to each version of the software are available from [Zenodo](https://doi.org/10.5281/zenodo.7899193). The Teamware version can be found on the 'About' page of your Teamware instance. diff --git a/frontend/src/views/About.vue b/frontend/src/views/About.vue index d5d6283f..5dbb94b0 100644 --- a/frontend/src/views/About.vue +++ b/frontend/src/views/About.vue @@ -12,16 +12,21 @@

Citation

- For published work that has used Teamware, please cite the project's GitHub repository. One way is to include a citation such as: + For published work that has used Teamware, please cite the EACL23 demo paper. One way is to include a citation such as:

- Karmakharm, T., Wilby, D., Roberts, I., & Bontcheva, K. (2022). GATE Teamware (Version {{ appVersion }}) [Computer software]. https://github.com/GateNLP/gate-teamware + Wilby, D., Karmakharm, T., Roberts, I., Song, X. & Bontcheva, K. (2023). GATE Teamware 2: An open-source tool for collaborative document classification annotation. In Proceedings of the 17th Conference of the European Chapter of the Association for Computational Linguistics: System Demonstrations, pages 145–151, Dubrovnik, Croatia. Association for Computational Linguistics. https://aclanthology.org/2023.eacl-demo.17/

- Please use the Cite this repository button at the top of the project's GitHub repository to get an up to date citation. +

+ Please use the Cite this repository button at the top of the project's GitHub repository to get an up to date citation. +

+

+ Permanent references to each version of the software are available from Zenodo. +

Version

From 8bd287a4a8af0bd40b563e41eb8a5ea127885f7a Mon Sep 17 00:00:00 2001 From: Freddy Heppell Date: Fri, 12 Jan 2024 12:29:06 +0000 Subject: [PATCH 3/8] attempt to get conference location in bibtex --- CITATION.cff | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CITATION.cff b/CITATION.cff index 1b30d037..9acddba1 100644 --- a/CITATION.cff +++ b/CITATION.cff @@ -76,4 +76,4 @@ preferred-citation: publisher: name: Association for Computational Linguistics conference: - location: Dubrovnik, Croatia \ No newline at end of file + address: Dubrovnik, Croatia \ No newline at end of file From bb885f625518fa54a1e359f024621aca28e4e721 Mon Sep 17 00:00:00 2001 From: Freddy Heppell Date: Fri, 12 Jan 2024 12:32:38 +0000 Subject: [PATCH 4/8] add required conference fields --- CITATION.cff | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/CITATION.cff b/CITATION.cff index 9acddba1..903ef613 100644 --- a/CITATION.cff +++ b/CITATION.cff @@ -74,6 +74,4 @@ preferred-citation: start: 145 end: 151 publisher: - name: Association for Computational Linguistics - conference: - address: Dubrovnik, Croatia \ No newline at end of file + name: Association for Computational Linguistics \ No newline at end of file From 6021c2d2c4f23bad8129c03052feec0b56f8f76c Mon Sep 17 00:00:00 2001 From: Freddy Heppell Date: Fri, 12 Jan 2024 12:50:25 +0000 Subject: [PATCH 5/8] try setting top-level location --- CITATION.cff | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/CITATION.cff b/CITATION.cff index 903ef613..fa61f6a0 100644 --- a/CITATION.cff +++ b/CITATION.cff @@ -69,9 +69,13 @@ preferred-citation: doi: 10.18653/v1/2023.eacl-demo.17 title: "GATE Teamware 2: An open-source tool for collaborative document classification annotation" collection-title: "Proceedings of the 17th Conference of the European Chapter of the Association for Computational Linguistics: System Demonstrations" + location: Dubrovnik, Croatia year: 2023 month: 5 start: 145 end: 151 publisher: - name: Association for Computational Linguistics \ No newline at end of file + name: Association for Computational Linguistics + conference: + name: 17th Conference of the European Chapter of the Association for Computational Linguistics + year: 2023 \ No newline at end of file From e00dd0a5f9d642c6fcab846b1be210315c51d5a1 Mon Sep 17 00:00:00 2001 From: Freddy Heppell Date: Fri, 12 Jan 2024 12:53:35 +0000 Subject: [PATCH 6/8] try publisher address --- CITATION.cff | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/CITATION.cff b/CITATION.cff index fa61f6a0..c92a2caa 100644 --- a/CITATION.cff +++ b/CITATION.cff @@ -76,6 +76,4 @@ preferred-citation: end: 151 publisher: name: Association for Computational Linguistics - conference: - name: 17th Conference of the European Chapter of the Association for Computational Linguistics - year: 2023 \ No newline at end of file + address: Dubrovnik, Croatia \ No newline at end of file From ed2b942bd8c6ddef54f5654a2149b79a3ece6e98 Mon Sep 17 00:00:00 2001 From: Freddy Heppell Date: Fri, 12 Jan 2024 12:55:11 +0000 Subject: [PATCH 7/8] fix top-level location --- CITATION.cff | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/CITATION.cff b/CITATION.cff index c92a2caa..4d5aa1c2 100644 --- a/CITATION.cff +++ b/CITATION.cff @@ -69,11 +69,11 @@ preferred-citation: doi: 10.18653/v1/2023.eacl-demo.17 title: "GATE Teamware 2: An open-source tool for collaborative document classification annotation" collection-title: "Proceedings of the 17th Conference of the European Chapter of the Association for Computational Linguistics: System Demonstrations" - location: Dubrovnik, Croatia + location: + name: Dubrovnik, Croatia year: 2023 month: 5 start: 145 end: 151 publisher: name: Association for Computational Linguistics - address: Dubrovnik, Croatia \ No newline at end of file From e1849540e32df104697d8b518316775e0f5d638c Mon Sep 17 00:00:00 2001 From: Freddy Heppell Date: Fri, 12 Jan 2024 13:14:27 +0000 Subject: [PATCH 8/8] Remove README version check and update --- version.py | 37 +------------------------------------ 1 file changed, 1 insertion(+), 36 deletions(-) diff --git a/version.py b/version.py index 51faf08f..0eeb1825 100644 --- a/version.py +++ b/version.py @@ -8,8 +8,6 @@ DOCS_PACKAGE_JSON_FILE_PATH = "docs/package.json" CITATION_FILE_PATH = "CITATION.cff" MASTER_VERSION_FILE = "VERSION" -README_FILE_PATH = "README.md" -README_VERSION_REGEX = r"\(Version ([^)]*)\)" def check(): """ @@ -30,13 +28,10 @@ def check(): citation_version = citation_file['version'] print(f"{CITATION_FILE_PATH} version is {citation_version}") - readme_version = get_readme_version(README_FILE_PATH) - print(f"{README_FILE_PATH} version is {readme_version}") - master_version = get_master_version() print(f"VERSION file version is {master_version}") - if js_version != master_version or docs_js_version != master_version or citation_version != master_version or readme_version != master_version: + if js_version != master_version or docs_js_version != master_version or citation_version != master_version: print("One or more versions does not match") sys.exit(1) else: @@ -49,21 +44,6 @@ def get_package_json_version(file_path: str) -> str: js_version = package_json['version'] return js_version -def get_readme_version(file_path: str) -> str: - with open(file_path, 'r') as f: - readme_text = f.read() - - match = re.search(README_VERSION_REGEX, readme_text) - - if match is None: - print(f"No version found in {README_FILE_PATH}.") - return - elif len(match.groups()) > 1: - print(f"{len(match.groups())} matches found in {README_FILE_PATH}, expected 1.") - return - else: - return match.groups(1)[0] - def get_master_version(): with open(MASTER_VERSION_FILE, "r") as f: master_version = f.readline().strip() @@ -83,8 +63,6 @@ def update(master_version:str = None): update_package_json_version(DOCS_PACKAGE_JSON_FILE_PATH, master_version) - update_readme_version(README_FILE_PATH, master_version) - with open(CITATION_FILE_PATH, "r") as f: citation_file = yaml.safe_load(f) print(f"Writing master version {master_version} to {CITATION_FILE_PATH}") @@ -102,19 +80,6 @@ def update_package_json_version(file_path:str, version_no:str): package_json['version'] = version_no json.dump(package_json, f, indent=2) -def update_readme_version(file_path:str, version_no:str): - with open(file_path, 'r') as f: - readme_text = f.read() - - readme_text = re.sub( - README_VERSION_REGEX, - f'(Version {version_no})', - readme_text - ) - - with open(file_path, 'w') as f: - f.write(readme_text) - if __name__ == "__main__": if sys.argv[1] == 'check':