Page MenuHomePhabricator

Remove "HeraldRepetitionPolicyConfig" and hide storage details inside HeraldRule
ClosedPublic

Authored by epriestley on Jan 25 2018, 4:10 AM.
Tags
None
Referenced Files
Unknown Object (File)
Sun, Dec 29, 6:38 PM
Unknown Object (File)
Sat, Dec 21, 11:07 PM
Unknown Object (File)
Sat, Dec 21, 11:07 PM
Unknown Object (File)
Thu, Dec 19, 6:18 PM
Unknown Object (File)
Fri, Dec 13, 1:49 AM
Unknown Object (File)
Nov 29 2024, 11:55 AM
Unknown Object (File)
Nov 26 2024, 8:56 PM
Unknown Object (File)
Nov 22 2024, 12:06 AM
Subscribers
None

Details

Summary

Depends on D18925. Ref T13048. Currently, HeraldRule stores policies as integers (0 or 1) in the database.

The application tries to mostly use strings ("first", "every"), but doesn't do a good job of hiding the fact that the values are integers deeper in the stack. So we end up with a lot of code like this:

$stored_int_value = $rule->getRepetitionPolicy();
$equivalent_string = HeraldRepetitionPolicyConfig::getString($stored_int_value);
$is_first = ($equivalent_string === HeraldRepetitionPolicyConfig::FIRST);

This happens in several places and is generally awful. Replace it with:

$is_first = $rule->isRepeatFirst();

To do this, merge HeraldRepetitionPolicyConfig into HeraldRule and hide all the mess inside the methods.

(This may let us just get rid of the integers in a later change, although I'm not sure I want to commit to that.)

Test Plan
  • Grepped for HeraldRepetitionPolicyConfig, no more hits.
  • Grepped for setRepetitionPolicy(...) and getRepetitionPolicy(...). There are no remaining callers outside of HeraldRule.
  • Browed and edited several rules. I'll vet this more convincingly after adding the new repetition rule.

Diff Detail

Repository
rP Phabricator
Lint
Lint Not Applicable
Unit
Tests Not Applicable