diff --git a/CITATION.cff b/CITATION.cff index f7c191ed..4d5aa1c2 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" + location: + name: Dubrovnik, Croatia + year: 2023 + month: 5 + start: 145 + end: 151 + publisher: + name: Association for Computational Linguistics 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

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' 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':