bibliothecary 14.3.0 → 14.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 6707fc0443320dc26cce55e6adcd048042c13b1648efe3a134952c62e5288f1f
4
- data.tar.gz: 7e53ee490a0f3eb7ab97470d30332247176c8ea73fdf88182c82da152de50c56
3
+ metadata.gz: d1f7fd4aeb8298f9fcb9b5edc69b7936eed8f112f3a6dde000edda36d641cfca
4
+ data.tar.gz: 4d9b619aab4813b3ee77a36b0fbb1588b561a3dd42275feeb216f01d19f8ea05
5
5
  SHA512:
6
- metadata.gz: eea5b5ac599bbd4043a1caf1ff3f89d8356619f9f30a45715a8bb81628673934b58cec80b4234ff863bb41c5b1cfde33a9a00a8ceaa58ce256ec267d99cab292
7
- data.tar.gz: 7dc7d4532c3da16a34d60e70e10022c773a2b4c748ec15efec8dda0eb3f2718f71f0f1162da28cd886e8e01138f9f945ab16bf8bcf4f4f44ebcf2a292a4a6f54
6
+ metadata.gz: a9a904ac75104ea34f45bfea2900475c89fd29a5d15ac065923d4e9d4c715ec6380d92ecea6499025063abe8f0146d2a89d9661f59f98cd216a4dcc6ce44b054
7
+ data.tar.gz: a4234dc007565e41587fa92ca7f970e5fdffd479debd202658e8a04edcf01943624df11aa1d0785398b87d10f694f3b84fb68fb985251315fbff67799f24fa2f
data/CHANGELOG.md CHANGED
@@ -13,6 +13,12 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
13
13
 
14
14
  ### Removed
15
15
 
16
+ ## [14.4.0]
17
+
18
+ ### Added
19
+
20
+ - Add suppport for vcpkg parsing
21
+
16
22
  ## [14.3.0]
17
23
 
18
24
  ### Added
@@ -0,0 +1,111 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Bibliothecary
4
+ module Parsers
5
+ class Vcpkg
6
+ include Bibliothecary::Analyser
7
+
8
+ def self.mapping
9
+ {
10
+ match_filename("vcpkg.json") => {
11
+ kind: "manifest",
12
+ parser: :parse_vcpkg_json,
13
+ },
14
+ # _generated-vcpkg-list.json is the output of `vcpkg list --x-json`.
15
+ match_filename("_generated-vcpkg-list.json") => {
16
+ kind: "lockfile",
17
+ parser: :parse_vcpkg_list_json,
18
+ },
19
+ }
20
+ end
21
+
22
+ add_multi_parser(Bibliothecary::MultiParsers::CycloneDX)
23
+ add_multi_parser(Bibliothecary::MultiParsers::Spdx)
24
+ add_multi_parser(Bibliothecary::MultiParsers::DependenciesCSV)
25
+
26
+ def self.parse_vcpkg_json(file_contents, options: {})
27
+ dependencies = []
28
+ manifest = JSON.parse(file_contents)
29
+ deps = manifest["dependencies"]
30
+
31
+ if !deps || deps.empty?
32
+ return ParserResult.new(dependencies: dependencies)
33
+ end
34
+
35
+ overrides = {}
36
+ manifest["overrides"]&.each do |override|
37
+ if override.is_a?(Hash) && override["name"]
38
+ override_version = override["version"] || override["version-semver"] || override["version-date"] || override["version-string"]
39
+ overrides[override["name"]] = format_requirement(override_version, override["port-version"])
40
+ end
41
+ end
42
+
43
+ deps.each do |dep|
44
+ if dep.is_a?(String)
45
+ # Simple string format: "boost-system"
46
+ name = dep
47
+ requirement = nil
48
+ is_development = false
49
+ elsif dep.is_a?(Hash)
50
+ # Object format: { "name": "cpprestsdk", "version>=": "2.10.0", ... }
51
+ name = dep["name"]
52
+ requirement = if dep["version>="]
53
+ ">=#{dep['version>=']}"
54
+ end
55
+ is_development = dep["host"] == true
56
+ end
57
+
58
+ # Skip entries with no name
59
+ next if name.nil? || name.empty?
60
+
61
+ requirement = overrides[name] if overrides[name]
62
+
63
+ dependencies << Dependency.new(
64
+ platform: platform_name,
65
+ name: name,
66
+ requirement: requirement,
67
+ type: is_development ? "development" : "runtime",
68
+ source: options.fetch(:filename, nil)
69
+ )
70
+ end
71
+
72
+ ParserResult.new(dependencies: dependencies)
73
+ end
74
+
75
+ def self.parse_vcpkg_list_json(file_contents, options: {})
76
+ # parses the output of `vcpkg list --x-json`
77
+ dependencies = []
78
+ manifest = JSON.parse(file_contents)
79
+
80
+ manifest.each_value do |package_info|
81
+ name = package_info["package_name"]
82
+ version = package_info["version"]
83
+ port_version = package_info["port_version"]
84
+
85
+ # Skip entries with no name
86
+ next if name.nil? || name.empty?
87
+
88
+ dependencies << Dependency.new(
89
+ platform: platform_name,
90
+ name: name,
91
+ requirement: format_requirement(version, port_version),
92
+ type: "runtime",
93
+ source: options.fetch(:filename, nil)
94
+ )
95
+ end
96
+
97
+ ParserResult.new(dependencies: dependencies)
98
+ end
99
+
100
+ def self.format_requirement(version, port_version)
101
+ return "*" unless version
102
+
103
+ if port_version && port_version > 0
104
+ return "#{version}##{port_version}"
105
+ end
106
+
107
+ version
108
+ end
109
+ end
110
+ end
111
+ end
@@ -18,6 +18,7 @@ module Bibliothecary
18
18
  "gem" => :rubygems,
19
19
  "nuget" => :nuget,
20
20
  "pypi" => :pypi,
21
+ "vcpkg" => :vcpkg,
21
22
  }.freeze
22
23
 
23
24
  # @param purl [PackageURL]
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Bibliothecary
4
- VERSION = "14.3.0"
4
+ VERSION = "14.4.0"
5
5
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: bibliothecary
3
3
  version: !ruby/object:Gem::Version
4
- version: 14.3.0
4
+ version: 14.4.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Andrew Nesbitt
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2025-11-12 00:00:00.000000000 Z
11
+ date: 2025-11-24 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: commander
@@ -201,6 +201,7 @@ files:
201
201
  - lib/bibliothecary/parsers/pypi.rb
202
202
  - lib/bibliothecary/parsers/rubygems.rb
203
203
  - lib/bibliothecary/parsers/shard.rb
204
+ - lib/bibliothecary/parsers/vcpkg.rb
204
205
  - lib/bibliothecary/purl_util.rb
205
206
  - lib/bibliothecary/related_files_info.rb
206
207
  - lib/bibliothecary/runner.rb