vault_coh 3.0.0 → 4.0.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: 763f4d0ebdbd58cd93d40ea506dc1f3d5ec176b152639127fa63dce0f144b50b
4
- data.tar.gz: 58a846515ed9a32da75e3bc0c7f29c1585207ed1635d11dffe1c16a0af6c5bf7
3
+ metadata.gz: efcd317fb3639ebb84a7fcb11f7d3b513422211d1c2b87f3e564ce4ddbf78f74
4
+ data.tar.gz: c52abcfeceab7cafcb94f15e93dad181afb600bc8bbbb29e0ebf8ea0ebe61c33
5
5
  SHA512:
6
- metadata.gz: 905aa7c2464b935e14fd7196af6012c1afefb52adad173602e7b0b77ccb43f0e62fe964509d99e743e924649909dd4f8b744ad179b32eecf3d407e976ea5f02c
7
- data.tar.gz: ca9bae0ee2fb8c2e16b01e09c2edf0a0aa444b6c536f9cb5bf3b0499c35d64ecec8938509aed78af95795ab4d4d71442c0fdc8b971547fdb623cc3f7f3d270c5
6
+ metadata.gz: 866f6b1d80b16c5a006d0f3878202225c26b08138e088c24b31990e71a698a137e5f04bc58992dd038826939dacc75f356409566c0b358a637315ebe3309e789
7
+ data.tar.gz: a5d2d75254cbeb6bdc05b23fb0adec01d9df3c379d8b862be8b4e8568f56d56eb349255b1cf4b49bd68ff76202366b7ccd22eb445abf65576cabacb2126a1a55
data/.ruby-version ADDED
@@ -0,0 +1 @@
1
+ 3.2.2
data/Cargo.lock CHANGED
@@ -362,9 +362,9 @@ checksum = "3354b9ac3fae1ff6755cb6db53683adb661634f67557942dea4facebec0fee4b"
362
362
 
363
363
  [[package]]
364
364
  name = "vault"
365
- version = "6.0.0"
365
+ version = "7.0.0"
366
366
  source = "registry+https://github.com/rust-lang/crates.io-index"
367
- checksum = "56d2f7e8331af1c81e0e894ae95960807789cfe849dcc95e828382f9f41b2959"
367
+ checksum = "c883ce2ee65509850bbf77b935dac0d6876392de077138650de1f5d109381bd8"
368
368
  dependencies = [
369
369
  "byteorder",
370
370
  "magnus",
data/Gemfile CHANGED
@@ -12,4 +12,4 @@ gem 'rb_sys'
12
12
 
13
13
  gem 'rspec', '~> 3.0'
14
14
 
15
- gem 'rubocop', '~> 1.57'
15
+ gem 'rubocop', '~> 1.59'
data/Gemfile.lock CHANGED
@@ -1,17 +1,17 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- vault_coh (3.0.0)
4
+ vault_coh (4.0.0)
5
5
 
6
6
  GEM
7
7
  remote: https://rubygems.org/
8
8
  specs:
9
9
  ast (2.4.2)
10
10
  diff-lcs (1.5.0)
11
- json (2.6.3)
11
+ json (2.7.1)
12
12
  language_server-protocol (3.17.0.3)
13
- parallel (1.23.0)
14
- parser (3.2.2.4)
13
+ parallel (1.24.0)
14
+ parser (3.3.0.3)
15
15
  ast (~> 2.4.1)
16
16
  racc
17
17
  racc (1.7.3)
@@ -19,8 +19,8 @@ GEM
19
19
  rake (13.1.0)
20
20
  rake-compiler (1.2.5)
21
21
  rake
22
- rb_sys (0.9.83)
23
- regexp_parser (2.8.2)
22
+ rb_sys (0.9.86)
23
+ regexp_parser (2.9.0)
24
24
  rexml (3.2.6)
25
25
  rspec (3.12.0)
26
26
  rspec-core (~> 3.12.0)
@@ -35,7 +35,7 @@ GEM
35
35
  diff-lcs (>= 1.2.0, < 2.0)
36
36
  rspec-support (~> 3.12.0)
37
37
  rspec-support (3.12.1)
38
- rubocop (1.57.2)
38
+ rubocop (1.59.0)
39
39
  json (~> 2.3)
40
40
  language_server-protocol (>= 3.17.0)
41
41
  parallel (~> 1.10)
@@ -43,7 +43,7 @@ GEM
43
43
  rainbow (>= 2.2.2, < 4.0)
44
44
  regexp_parser (>= 1.8, < 3.0)
45
45
  rexml (>= 3.2.5, < 4.0)
46
- rubocop-ast (>= 1.28.1, < 2.0)
46
+ rubocop-ast (>= 1.30.0, < 2.0)
47
47
  ruby-progressbar (~> 1.7)
48
48
  unicode-display_width (>= 2.4.0, < 3.0)
49
49
  rubocop-ast (1.30.0)
@@ -60,7 +60,7 @@ DEPENDENCIES
60
60
  rake-compiler
61
61
  rb_sys
62
62
  rspec (~> 3.0)
63
- rubocop (~> 1.57)
63
+ rubocop (~> 1.59)
64
64
  vault_coh!
65
65
 
66
66
  BUNDLED WITH
data/README.md CHANGED
@@ -1,6 +1,6 @@
1
1
  # Vault
2
2
 
3
- [![Gem Version](https://badge.fury.io/rb/vault_coh.svg)](https://badge.fury.io/rb/vault_coh) [![Documentation](https://img.shields.io/badge/View-Documentation-blue.svg)](https://rubydoc.info/github/ryantaylor/vault-rb/v3.0.0)
3
+ [![Gem Version](https://badge.fury.io/rb/vault_coh.svg)](https://badge.fury.io/rb/vault_coh) [![Documentation](https://img.shields.io/badge/View-Documentation-blue.svg)](https://rubydoc.info/github/ryantaylor/vault-rb/v4.0.0)
4
4
 
5
5
  A native Ruby client wrapper for the [vault](https://github.com/ryantaylor/vault) Company of Heroes replay parser, integrated via a Rust native extension.
6
6
 
@@ -24,7 +24,7 @@ bytes = File.read('/path/to/replay.rec').unpack('C*')
24
24
  replay = VaultCoh::Replay.from_bytes(bytes)
25
25
  puts replay.version
26
26
  ```
27
- All information available from parsing can be found in the [documentation](https://rubydoc.info/github/ryantaylor/vault-rb/v3.0.0).
27
+ All information available from parsing can be found in the [documentation](https://rubydoc.info/github/ryantaylor/vault-rb/v4.0.0).
28
28
 
29
29
  ## Contributing
30
30
 
@@ -12,4 +12,4 @@ crate-type = ["cdylib"]
12
12
  [dependencies]
13
13
  magnus = { version = "0.6" }
14
14
  serde_magnus = { version = "0.8" }
15
- vault = { version = "6", features = ["magnus", "serde"] }
15
+ vault = { version = "7", features = ["magnus", "serde"] }
@@ -42,6 +42,7 @@ fn init() -> Result<(), Error> {
42
42
 
43
43
  let player = module.define_class("Player", class::object())?;
44
44
  player.define_method("name", method!(Player::name, 0))?;
45
+ player.define_method("human?", method!(Player::human, 0))?;
45
46
  player.define_method("faction", method!(Player::faction, 0))?;
46
47
  player.define_method("team", method!(Player::team, 0))?;
47
48
  player.define_method("battlegroup", method!(Player::battlegroup, 0))?;
@@ -6,7 +6,8 @@ module VaultCoh
6
6
  # Data object that contains information specific to the
7
7
  # type of command it represents.
8
8
  #
9
- # @return [Commands::BuildSquad |
9
+ # @return [Commands::BuildGlobalUpgrade |
10
+ # Commands::BuildSquad |
10
11
  # Commands::SelectBattlegroup |
11
12
  # Commands::SelectBattlegroupAbility |
12
13
  # Commands::UseBattlegroupAbility |
@@ -0,0 +1,34 @@
1
+ # frozen_string_literal: true
2
+
3
+ module VaultCoh
4
+ module Commands
5
+ # Data object representing information parsed from an
6
+ # upgrade construction command.
7
+ class BuildGlobalUpgrade
8
+ # This value is the tick at which the command was
9
+ # found while parsing the replay, which represents
10
+ # the time in the replay at which it was executed.
11
+ # Because CoH3's engine runs at 8 ticks per second,
12
+ # you can divide this value by 8 to get the number
13
+ # of seconds since the replay began, which will tell
14
+ # you when this command was executed.
15
+ #
16
+ # @return [Integer] unsigned, 32 bits
17
+ def tick; end
18
+
19
+ # Internal ID that uniquely identifies the upgrade being
20
+ # built. This value can be matched to CoH3 attribute
21
+ # files in order to determine the upgrade being built.
22
+ # Note that, while rare, it is possible that this value
23
+ # may change between patches for the same upgrade.
24
+ #
25
+ # @return [Integer] unsigned, 32 bits
26
+ def pbgid; end
27
+
28
+ # Returns a hash representation of the object.
29
+ #
30
+ # @return [Hash]
31
+ def to_h; end
32
+ end
33
+ end
34
+ end
@@ -0,0 +1,9 @@
1
+ # frozen_string_literal: true
2
+
3
+ module VaultCoh
4
+ module Commands
5
+ # Wrapper for an upgrade construction command.
6
+ class BuildGlobalUpgradeCommand < Command
7
+ end
8
+ end
9
+ end
@@ -13,6 +13,11 @@ module VaultCoh
13
13
  # @return [String]
14
14
  def name; end
15
15
 
16
+ # Whether or not the player was a human or an AI/CPU player.
17
+ #
18
+ # @return [Boolean]
19
+ def human?; end
20
+
16
21
  # The faction selected by the player in this match.
17
22
  #
18
23
  # @return [Faction]
@@ -31,19 +36,19 @@ module VaultCoh
31
36
  # @return [Integer|NilClass]
32
37
  def battlegroup; end
33
38
 
34
- # The Steam ID of the player. This ID can be used to uniquely
35
- # identify a player between replays, and connect them to their
36
- # Steam profile.
39
+ # The Steam ID of the player, or +nil+ if the player is AI. This ID
40
+ # can be used to uniquely identify a player between replays, and
41
+ # connect them to their Steam profile.
37
42
  #
38
- # @return [Integer] unsigned, 64 bits
43
+ # @return [Integer|NilClass] unsigned, 64 bits
39
44
  def steam_id; end
40
45
 
41
- # The Relic profile ID of the player. This ID can be used to
42
- # uniquely identify a player between replays, and can be used to
43
- # query statistical information about the player from Relic’s
44
- # stats API.
46
+ # The Relic profile ID of the player, or +nil+ if the player is AI.
47
+ # This ID can be used to uniquely identify a player between replays,
48
+ # and can be used to query statistical information about the player
49
+ # from Relic’s stats API.
45
50
  #
46
- # @return [Integer] unsigned, 64 bits
51
+ # @return [Integer|NilClass] unsigned, 64 bits
47
52
  def profile_id; end
48
53
 
49
54
  # A list of all messages sent by the player in the match. Sorted
@@ -60,9 +65,9 @@ module VaultCoh
60
65
 
61
66
  # A list of only build-related commands executed by the player in
62
67
  # the match. A build command is any that enqueues the construction
63
- # of a new unit. Sorted chronologically from first to last.
68
+ # of a new unit or upgrade. Sorted chronologically from first to last.
64
69
  #
65
- # @return [Array<Commands::BuildSquad>]
70
+ # @return [Array<Command>]
66
71
  def build_commands; end
67
72
 
68
73
  # A list of only battlegroup-related commands executed by the player
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module VaultCoh
4
- VERSION = '3.0.0'
4
+ VERSION = '4.0.0'
5
5
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: vault_coh
3
3
  version: !ruby/object:Gem::Version
4
- version: 3.0.0
4
+ version: 4.0.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - ryantaylor
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2023-11-23 00:00:00.000000000 Z
11
+ date: 2024-01-21 00:00:00.000000000 Z
12
12
  dependencies: []
13
13
  description: Company of Heroes replay parsing in Ruby using the vault parsing library
14
14
  via a Rust native extension.
@@ -21,6 +21,7 @@ extra_rdoc_files: []
21
21
  files:
22
22
  - ".rspec"
23
23
  - ".rubocop.yml"
24
+ - ".ruby-version"
24
25
  - CHANGELOG.md
25
26
  - Cargo.lock
26
27
  - Cargo.toml
@@ -36,6 +37,8 @@ files:
36
37
  - lib/vault_coh.rb
37
38
  - lib/vault_coh/command.rb
38
39
  - lib/vault_coh/commands.rb
40
+ - lib/vault_coh/commands/build_global_upgrade.rb
41
+ - lib/vault_coh/commands/build_global_upgrade_command.rb
39
42
  - lib/vault_coh/commands/build_squad.rb
40
43
  - lib/vault_coh/commands/build_squad_command.rb
41
44
  - lib/vault_coh/commands/select_battlegroup.rb