-
Notifications
You must be signed in to change notification settings - Fork 0
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
Merge NetFixClient and NetFixServer repos #29
Comments
I think merging the repos and allowing for code sharing is the right call. For automated builds, ifs both the server and client projects are part of the same Visual Studio solution, appveyor should build them both, producing the server executable and the client DLL. Just like in op2ext when we have a main project, library code, and a unit test application that all get compiled. Which platform is the primary for the current server? I was assuming a Linux build, but wasn't sure. Once we have some shared code, building a static library or not depends a bit on unit tests. We could statically compile the shared project and then perform unit tests. Or we could try to unit test the shared code through the server and client projects. I'm fine either way. It may depend on if the client and server are actually suitable to unit test on their own without a static library. If only a small amount of code is being shared, maybe a full static library and project files are overkill and less flexible. Although, we could figure that out post merging the repositories as well. This might be a good time to rename the project too. Having a NetFix and NetHelper is confusing. Also, I think describing the fact that this project is really adding a lobby or hub to the game for multiplayer match discovery would be appropriate in the title. Also, major feature improvements to NetFix may require changes to both the server and client code. Merging the repositories would allow discussing those changes in one project instead of across 2 projects. |
Alright, sounds like we should merge then. I was originally thinking of just calling the repo |
Ehh, I don't have any good suggestions. In light of that, I'm happy if we just use NetFix and punt to the future as opposed to waiting for a good name to show up. Being an established name is a good point on it own. Do you have a merge timeline on when you want me to stop adding new branches and cleanup existing branches? |
No timeline. We can do this whenever things settle down, or when this becomes the blocking issue. |
Once the 2 branches I just pushed are adjudicated, it is probably a good time to go ahead with the move into the new repository. I would probably have either wandered into Packet.h next or stood up google test. Both those efforts are probably best waiting until post move though. |
Hmm, #46 is already merged. Did you mean #48? Actually, we might be better off trying to close off issues first, and then merge later. Things like GitHub Issues won't automatically be ported from one repository to the other. It should be easy enough to merge histories. We'll probably want to update the folder structure first though, so things stay separated in subfolders after the merge. I don't want to be trying to separate things after a merge. We'll probably want to update the project structure and Since NetFixClient uses submodules already, and has the updated |
That was a typo on part, you are correct that I meant 48. It looks like it is easy to transfer issues between repositories as long as the repository owner is the same. |
Ahh, thank you for that. All this time it's been right there, and I've just never noticed it. |
I hit a bit of a snag with this. The updated The NetFixServer currently has a MacOS build. If it uses an updated Not too sure how to proceed at present. |
What are the odds it will ever be installed on a Macintosh? Maybe we can just drop support? |
The slightly annoying thing about this, is the code would still build, it's just the It may be reasonable to just drop support. We could potentially also keep the old I suppose I kind of want to get the generic makefile portion working for Posix Make, since then it could be used for projects like NAS2D and OPHD, which do currently have a MacOS build. Though that might be something to defer on. Another option might be to update the MacOS environment to I think for the moment I kind of want to try closing out a few of the other issues first so I have a bit of time to think about this. In particular #31 and #32. It looks like #2 might be best to leave until after the merge. |
It sounds like you are taking a crack at #31. If you are not, let me know and I'll attempt the refactor. |
Nope, I haven't touched #31 at all. Have at it. |
I was thinking, there's some sharing of code between NetFixClient and NetFixServer due to the shared network packets they must both be able to interpret.
It might make sense to merge NetFixClient and NetFixServer into the same repository/solution, but kept as separate projects in separate folders. That might help facilitate working on the shared portions.
It may also make sense to split the shared portion into a static library project.
Of course, the server is designed to be cross platform, while the client is Windows only. Merging the repositories might not be the most sensible when it comes to CI builds that only update one of the projects.
The text was updated successfully, but these errors were encountered: