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

[lwlog] Added new library #43047

Merged
merged 25 commits into from
Jan 14, 2025
Merged

[lwlog] Added new library #43047

merged 25 commits into from
Jan 14, 2025

Conversation

ChristianPanov
Copy link
Contributor

@ChristianPanov ChristianPanov commented Jan 1, 2025

  • Changes comply with the maintainer guide.
  • The name of the port matches an existing name for this component on https://repology.org/ if possible, and/or is strongly associated with that component on search engines.
  • Optional dependencies are resolved in exactly one way. For example, if the component is built with CMake, all find_package calls are REQUIRED, are satisfied by vcpkg.json's declared dependencies, or disabled with CMAKE_DISABLE_FIND_PACKAGE_Xxx.
  • The versioning scheme in vcpkg.json matches what upstream says.
  • The license declaration in vcpkg.json matches what upstream says.
  • The installed as the "copyright" file matches what upstream says.
  • The source code of the component installed comes from an authoritative source.
  • The generated "usage text" is accurate. See adding-usage for context.
  • The version database is fixed by rerunning ./vcpkg x-add-version --all and committing the result.
  • Only one version is in the new port's versions file.
  • Only one version is added to each modified port's versions file.

@ChristianPanov
Copy link
Contributor Author

@microsoft-github-policy-service agree

@Cheney-W Cheney-W added the category:new-port The issue is requesting a new library to be added; consider making a PR! label Jan 2, 2025
@Cheney-W Cheney-W changed the title Added lwlog library [lwlog] Added new library Jan 2, 2025
ports/lwlog/portfile.cmake Outdated Show resolved Hide resolved
ports/lwlog/portfile.cmake Outdated Show resolved Hide resolved
ports/lwlog/portfile.cmake Outdated Show resolved Hide resolved
ports/lwlog/portfile.cmake Outdated Show resolved Hide resolved
ports/lwlog/portfile.cmake Show resolved Hide resolved
@Cheney-W
Copy link
Contributor

Cheney-W commented Jan 2, 2025

I have two more questions:

  1. Does the built lwlog_sandbox.exe need to be provided to users?
  2. The current storage structure of the header files causes them to be included in the form <src/xxx.h>. Is this the expected behavior?

@Cheney-W Cheney-W marked this pull request as draft January 2, 2025 07:33
@ChristianPanov
Copy link
Contributor Author

@Cheney-W Regarding your first question, actually no, maybe I should make some changes to the cmake, but sandbox shouldn't neccessarily come with the library.
And yes, this file structure is intentional, to have all headers and compilation units in the same place

ports/lwlog/portfile.cmake Outdated Show resolved Hide resolved
@dg0yt
Copy link
Contributor

dg0yt commented Jan 4, 2025

AFAICT this must not be in this port, given its binary artifacts.

set(VCPKG_BUILD_TYPE release)
set(VCPKG_POLICY_MISMATCHED_NUMBER_OF_BINARIES enabled)

@dg0yt
Copy link
Contributor

dg0yt commented Jan 4, 2025

2. The current storage structure of the header files causes them to be included in the form <src/xxx.h>. Is this the expected behavior?

And yes, this file structure is intentional, to have all headers and compilation units in the same place

It is fine to organize everything in src/ in the source directory. But what looks questionable is the use of include/src/ in the installed tree. It doesn't give any hint that src is "owned" by lwlog, and it would clash with other packages making the same choice for directory and file names. In that regard, it is not much better then putting everything directly into include/.
With the CMake config available, where is the problem with installing header e.g. to include/lwlog/? Do you need help with that?

@ChristianPanov
Copy link
Contributor Author

  1. The current storage structure of the header files causes them to be included in the form <src/xxx.h>. Is this the expected behavior?

And yes, this file structure is intentional, to have all headers and compilation units in the same place

It is fine to organize everything in src/ in the source directory. But what looks questionable is the use of include/src/ in the installed tree. It doesn't give any hint that src is "owned" by lwlog, and it would clash with other packages making the same choice for directory and file names. In that regard, it is not much better then putting everything directly into include/. With the CMake config available, where is the problem with installing header e.g. to include/lwlog/? Do you need help with that?

I fully agree. Just pushed the changes

@Cheney-W
Copy link
Contributor

Cheney-W commented Jan 6, 2025

error: checked-in files for lwlog have changed but the version was not updated
version: 1.3.0
old SHA: 03bafbae9158d058b2c5d7cd5eb13ca28b8f30da
new SHA: 52f20d71e449b8edb6223e8c4316ea06c5ce6015
Did you remember to update the version or port version?
Use --overwrite-version to bypass this check

See https://learn.microsoft.com/vcpkg/commands/add-version?WT.mc_id=vcpkg_inproduct_cli#--overwrite-version for more information.

@ChristianPanov
Copy link
Contributor Author

error: checked-in files for lwlog have changed but the version was not updated
version: 1.3.0
old SHA: 03bafbae9158d058b2c5d7cd5eb13ca28b8f30da
new SHA: 52f20d71e449b8edb6223e8c4316ea06c5ce6015
Did you remember to update the version or port version?
Use --overwrite-version to bypass this check

See https://learn.microsoft.com/vcpkg/commands/add-version?WT.mc_id=vcpkg_inproduct_cli#--overwrite-version for more information.

Yes, I'm pretty sure I ran that command

@Cheney-W
Copy link
Contributor

Cheney-W commented Jan 6, 2025

This command is not a one-time execution, it needs to be run each time you submit a new commit.

@ChristianPanov ChristianPanov marked this pull request as ready for review January 6, 2025 10:18
@ChristianPanov
Copy link
Contributor Author

Is it possible to force the latest release instead of a certain version?

@Cheney-W
Copy link
Contributor

Cheney-W commented Jan 7, 2025

I didn't quite understand what you meant. Do you want the version in vcpkg.json to be set to 1.3.1, or are you asking vcpkg to automatically use the latest version of lwlog each time this port is installed?
If it's the former, you only need to directly modify the version value in vcpkg.json in this PR.
If it's the latter, vcpkg currently doesn't support this, and it would also be detrimental to version control.

@dg0yt
Copy link
Contributor

dg0yt commented Jan 7, 2025

AFAICT this must not be in this port, given its binary artifacts.

set(VCPKG_BUILD_TYPE release)
set(VCPKG_POLICY_MISMATCHED_NUMBER_OF_BINARIES enabled)

Reminder: this port must install debug binaries.

@ChristianPanov
Copy link
Contributor Author

I didn't quite understand what you meant. Do you want the version in vcpkg.json to be set to 1.3.1, or are you asking vcpkg to automatically use the latest version of lwlog each time this port is installed? If it's the former, you only need to directly modify the version value in vcpkg.json in this PR. If it's the latter, vcpkg currently doesn't support this, and it would also be detrimental to version control.

I see what you mean, okay, we will keep it the way it is

@ChristianPanov
Copy link
Contributor Author

AFAICT this must not be in this port, given its binary artifacts.

set(VCPKG_BUILD_TYPE release)
set(VCPKG_POLICY_MISMATCHED_NUMBER_OF_BINARIES enabled)

Reminder: this port must install debug binaries.

I remember that without it there were some problems, not sure if it will break again with the current changes

ports/lwlog/portfile.cmake Outdated Show resolved Hide resolved
ports/lwlog/portfile.cmake Show resolved Hide resolved
@Cheney-W
Copy link
Contributor

error: checked-in files for lwlog have changed but the version was not updated
version: 1.3.0
old SHA: 52f20d71e449b8edb6223e8c4316ea06c5ce6015
new SHA: 397eb522ff5cab01e993bde4d0f3b3d3aa86feaf
Did you remember to update the version or port version?
Use --overwrite-version to bypass this check

@Cheney-W Cheney-W marked this pull request as draft January 10, 2025 08:47
@ChristianPanov
Copy link
Contributor Author

Is there anything required from my side?

@Cheney-W
Copy link
Contributor

You need to execute:

.\vcpkg x-add-version lwlog --overwrite-version
git add .
git commit --amend --no-edit

Every time you submit a new commit, you need to run this command once.

@ChristianPanov
Copy link
Contributor Author

ChristianPanov commented Jan 13, 2025

Seems like the checks are successful now, only needs to be approved I think. Thank you for the extensive support. @Cheney-W @dg0yt

@Cheney-W Cheney-W marked this pull request as ready for review January 13, 2025 09:58
@Cheney-W Cheney-W added the info:reviewed Pull Request changes follow basic guidelines label Jan 13, 2025
@vicroms vicroms merged commit adc4d3d into microsoft:master Jan 14, 2025
17 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
category:new-port The issue is requesting a new library to be added; consider making a PR! info:reviewed Pull Request changes follow basic guidelines
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants