Skip to content

Release 5.2.1 #662

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

Closed
stakx opened this issue Sep 1, 2023 · 10 comments
Closed

Release 5.2.1 #662

stakx opened this issue Sep 1, 2023 · 10 comments
Milestone

Comments

@stakx
Copy link
Member

stakx commented Sep 1, 2023

I think we're almost ready for another release.


Things to do after this next release

I'd love if we could tackle those larger discussions about this library's (and DynamicProxy's) future, possibly resulting in a major version bump:

Depending on the outcome of those decisions, we may end up with a much slimmer library and a somewhat pared-down DynamicProxy implementation that's easier to manage, so I think it would be good to start there and get rid of as much "baggage" as soon as we can.

(If we decide to keep the logging abstractions, we could take a look at #418, which should be relatively straightforward.)

I'd also love to do some code exploration about whether we really need 5 different types of proxy; I suspect we have a lot of code duplication in DynamicProxy because of that. While working on #447, that suspicion has only increased, since one of the previously distinguishing characteristics of interfaces – that they may not contain any implementation bits – no longer holds true in modern C# and .NET. The distinction between class and interface proxies may no longer make sense. (Note that instead of CreateClassProxy<TClass>(), you can already do an practically equivalent (TClass)CreateInterfaceProxyWithoutTarget<IEmptyInterface>(new ProxyGenerationOptions { BaseTypeForInterfaceProxy = typeof(TClass) })). We could potentially cut the number of collectors / contributors / generators in half with only a few minor breaking changes, and simplify the public API of ProxyGenerator a lot.

@stakx stakx added this to the vNext milestone Sep 1, 2023
@stakx stakx pinned this issue Sep 1, 2023
@stakx
Copy link
Member Author

stakx commented Apr 6, 2024

I've been delayed with daytime (aka paid) work, but I think I'll find some time very soon to finally get DIM support published.

@stakx
Copy link
Member Author

stakx commented Aug 30, 2024

Apologies to everyone who's been awaiting this release for a long time. Version 5.2.0 is basically ready, as soon as we've dealt with an expired NuGet API key, we should be able to publish it to NuGet.

@stakx stakx unpinned this issue Aug 31, 2024
@stakx stakx pinned this issue Aug 31, 2024
@304NotModified
Copy link

304NotModified commented Feb 27, 2025

This is still open, isn't?

Could we help with this?

@stakx
Copy link
Member Author

stakx commented Mar 9, 2025

@304NotModified, sorry for the delay. I could release 5.2.0 (and I have wanted to for a long time), but there is #684. I am somewhat worried about breaking e.g. NSubstitute by releasing 5.2.0 as is. Currently very busy with work so I don't have much time to prepare a fix in advance.

P.S.: IIRC, NuGet has a slightly unusual approach to semver in that it conservatively defaults to the lowest version that matches the requested version (not the highest), so perhaps we can safely release 5.2.0 without breaking anything. NSubstitute would have to explicitly upgrade their Castle.Core dependency to notice a problem.

@stakx stakx changed the title Release 5.2.0 Release 5.2.1 Mar 9, 2025
@stakx
Copy link
Member Author

stakx commented Mar 9, 2025

I just tried to re-release this as 5.2.1 (I don't have sufficient permissions to simply re-trigger the build for 5.2.0 and perhaps it wouldn't even help because...) only for the CI build to fail immediately. We need to fix that first (related: #683).

@stakx stakx changed the title Release 5.2.1 Release 5.2.2 Mar 9, 2025
@304NotModified
Copy link

I see 5.2.1 now on nuget.org 🎉

@stakx stakx changed the title Release 5.2.2 Release 5.2.1 Mar 9, 2025
@stakx
Copy link
Member Author

stakx commented Mar 9, 2025

You're right. I got so many pipeline failure emails that I overlooked the one that mattered re: publication didn't fail. It's a bit of a mess but I'm glad 5.2.1 made it through the door. The CI builds will still need fixing but we can do that for the next release.

@stakx stakx closed this as completed Mar 9, 2025
@304NotModified
Copy link

304NotModified commented Mar 10, 2025

Thanks @stakx!

Can you update the release/tag on GitHub? That will prevent confusion in the future. --> https://github.com/castleproject/Core/releases

PS: there are some build errors with NSubstitute when upgrading from 5.1.1 to 5.2.1. I haven't checked that yet (no pc, on mobile), so I'm not sure if this a breaking change (on source level, regarding nullability) in Caste.Core. See nsubstitute/NSubstitute#871
(This isn't the same as #684 right?)

@stakx
Copy link
Member Author

stakx commented Mar 10, 2025

Can you update the release/tag on GitHub? That will prevent confusion in the future.

@304NotModified, thanks for the hint. I trashed the 5.2.0 release (which still carried the unmet August 2024 release date) and recreated a 5.2.1 one.

As you can perhaps tell, I've probably spent too much time away from this project, I feel a little disorganized right now. 🙈

@stakx
Copy link
Member Author

stakx commented Mar 10, 2025

Also @304NotModified:

there are some build errors with NSubstitute [...] This isn't the same as #684 right?

No, those build errors seem unrelated to #684. I'd say they're a direct result of #668.

@stakx stakx unpinned this issue Mar 10, 2025
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

2 participants