Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Could you please make the tag regularly after every update? #2696

Open
alimd opened this issue Nov 24, 2023 · 19 comments
Open

Could you please make the tag regularly after every update? #2696

alimd opened this issue Nov 24, 2023 · 19 comments

Comments

@alimd
Copy link

alimd commented Nov 24, 2023

I made a Docker image of this project and update it regularly, but I don't notify about new updates!
I can't build regularly in my CI/CD and unfortunately we are still using version v1.8.0!
Every once in a while, I checked this project and saw that there was still no new version (from the last tag) and I thought that this project was abandoned by Telegram and will not continue anymore! Until today I randomly saw 21 new updates since the last tag that I didn't see and I was shocked!
https://github.com/Alwatr/containers/tree/next/tdlib

Could you please make the tag regularly after every update?

@levlam
Copy link
Contributor

levlam commented Nov 24, 2023

If you want the tags to identify "the versions that are recommended to be used", then you just need to use master branch with the latest TDLib version as you would do for any other Telegram app, which are automatically updated. If you want to build the image regularly, but don't want to build it for every push to the master branch, then you can do this periodically, for example, once in a few weeks. See #1790 (comment) and #1627 (comment) for more details, why even some commits would be tagged master branch should be used instead anyway.

@alimd
Copy link
Author

alimd commented Nov 25, 2023

@levlam The answer was very strange and unprofessional and had nothing to do with my request!
Is there a specific reason why you don't update tags?

@alimd
Copy link
Author

alimd commented Nov 25, 2023

If you add me to the project, I will be honored to register and update the tags for you at the right time and even get a GitHub release to notify all those who started the project and make it more beautiful.

@levlam
Copy link
Contributor

levlam commented Nov 25, 2023

It is explained in the links that there is no "right time" for tags. Tag is just an alias for commit with some special meaning. If you need nothing special from the tag, then you can also use HEAD commit from the master branch always.

@alimd
Copy link
Author

alimd commented Nov 25, 2023

@levlam
I am very sorry to see this.
I think you are not familiar with usual GitHub release process and git flow release and even versioning at all!
I really did not expect this behavior from a professional project like tdlib!
I apologize for taking up your time.
Please, if possible, at least delete all existing tags so that others don't make a mistake like me.
To do this, just run these commands in the command prompt

git push origin --delete v1.8.0
git push origin --delete v1.7.0
...

@levlam
Copy link
Contributor

levlam commented Nov 25, 2023

No, the tags are made on purpose. But as you should not use Telegram 2.5 (and you can't even download old app versions from any official distribution source), you should not use any old TDLib version and use the latest public version instead. If you want to run some Github action, then you need to run it on every public TDLib commit.

@njfamirm
Copy link

I'm create tag and release in this repository: https://github.com/njfamirm/td

@njfamirm
Copy link

you can use it, Also I'm interested to do this in current repo

@alimd
Copy link
Author

alimd commented Nov 25, 2023

You should not use any old TDLib version and use the latest public version instead..

These words are completely true and I am successful with you, but believe me, regular release has its uses and is very beautiful and practical.
At least it makes everyone aware of the changes.
I think it is useless to continue this conversation.
I apologize again for taking up your time.

@alimd
Copy link
Author

alimd commented Nov 25, 2023

@njfamirm it's nice, thank you very much.

@levlam
Copy link
Contributor

levlam commented Nov 26, 2023

At least it makes everyone aware of the changes.

Any new commit makes everyone aware of the changes made to the project.

regular release has its uses

You provided no use cases for tags.

@daviwil
Copy link

daviwil commented Apr 4, 2024

@levlam The use case for tags is that some Linux distributions (like Void Linux) will only package software that has associated release tags so that there is a direct download link for the tarball containing the source files (they don't use Git to clone repositories).

By not adding release tags for your patch releases in the 1.8 series, users of apps that leverage tdlib on Void Linux will never have the most up to date version of the library. This is blocking my use of telega.el specifically because it expects a version of tdlib greater than 1.8.20, but I'm sure it will cause problems for many others.

Since it's not costly from a time or effort perspective to create a tag for each version bump and there are some out there who do need it, could you please reconsider?

@levlam
Copy link
Contributor

levlam commented Apr 4, 2024

users of apps that leverage tdlib on Void Linux will never have the most up to date version of the library.

Each app version requires specific TDLib version and is incompatible with all other TDLib versions. See #1718 (comment) for more details.

telega.el specifically because it expects a version of tdlib greater than 1.8.20

Specific version of telega.el requires specific version of TDLib to be able to use its API. It is theoretically possible to support multiple TDLib versions by an app such as telega.el, but this would require enormous additional amount of work by the author of telega.el. Therefore, currently the distribution must provide dozens TDLib packages simultaneously, one for each TDLib version, from which only a few will be used by other packages. Is it an option for Void Linux package manager? Instead, apps usually bundle TDLib as it is done in https://zevlg.github.io/telega.el/#running-telega-server-in-docker.

Providing shared libraries as packages improves many things, for example, allows sharing of the same library between different apps, improving memory usage and performance, allows fast adoption of security patches by distro maintainers for libraries with stable API. Unfortunately, none of this can be applied to TDLib. If you want an opinion on the matter from a person you know, I can point you to https://lore.kernel.org/lkml/CAHk-=whs8QZf3YnifdLv57+FhBi5_WeNTG1B-suOES=RcUSmQg@mail.gmail.com/.

@daviwil
Copy link

daviwil commented Apr 4, 2024

I see, thanks for taking the time to explain this. I'm not sure if packaging multiple versions within a minor version range would be acceptable to Void (I'm not a maintainer, just a user) but my guess is that they'd prefer not to do it.

I'll use an alternate approach to getting tdlib working for telega.el. Thanks for linking the Docker image support, I was not aware of that!

@chuxubank
Copy link

chuxubank commented Apr 26, 2024

What I want to mention is that an end user is unlikely to use multiple telegram clients in one computer at one same time.
So when using clients like telega.el, user may prefer to install the tdlib manually.
There's two reasons why using docker version is a bad solution:

  1. It takes more computer resources just for one chat client.
  2. For Apple Silicon chips, it need more steps Docker for M1 out of date? zevlg/telega.el#404 and may need Rosetta to work, which is not efficient.

If we have git tag, we may then build and install using https://docs.brew.sh/Versions to install the version we need like

brew install [email protected]

Or make our own tap to build the latest version to keep align with the client's supported version.

@stokito
Copy link

stokito commented Aug 16, 2024

Why to waste so much your and contributors time for a one second job?

The tags are easier to read and compare. Additionally with semantic versioning they allows to understand criticality of change. We always know that it should be safe to upgrade to the latest patch version.

For example, in the TG plugin for a Pidgin now used a commit hash instead of a tag and this makes it harder to understand.

The GitHub provides a nice feature to see list of commits from the last release or compare between tags. I wanted to see it but I couldn't.

@ghost
Copy link

ghost commented Aug 16, 2024

  • [ ]

@levlam
Copy link
Contributor

levlam commented Aug 16, 2024

@stokito All TDLib versions are binary compatible when used with JSON interface, but you can never just replace TDLib with a different version without adjusting source code of the app using it. TDLib has 1-3 feature releases monthly and it is never safe to update it without examining changes in https://github.com/tdlib/td/blob/master/td/generate/scheme/td_api.tl. See all my comments above for explanation, why tags are useless with TDLib for most their usual use cases.

The GitHub provides a nice feature to see list of commits from the last release or compare between tags. I wanted to see it but I couldn't.

On Github, as in git, you can easily compare any 2 commits. For example, see https://github.com/tdlib/td/compare/072cba1..8d08b34e.

@emin63
Copy link

emin63 commented Aug 28, 2024

Telegram provides a lot of nice tools and I am grateful for both the platform and the APIs/tools. I understand that this is a lot to maintain and appreciate the effort. I can understand how yet another request which seems not so important can be annoying.

If there is a strong reason not to add tags to the GitHub repo, maybe another compromise would be to have a way to add version numbers to the automated build instructions (which are really nice, by the way). If that was OK, I'm confident that I or one of the other people on this thread would be happy to add a PR to support that.

Since telega.el requires a specific version of tdlib, I did the following as a manual work around: I searched for 1.8.28 and found commit af69dd4 as a hit. I then did a git checkout af69dd4397b6dc1bf23ba0fd0bf429fcba6454f6 after cloning the repo and then followed the remainder of the automated build instructions.

I would still prefer to have tags for each release version, but if that is not feasible I think the above would be helpful for other users that need to build with a different version. Thanks.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

7 participants