Skip to content
This repository has been archived by the owner on Nov 15, 2023. It is now read-only.

Telemetry (Slog + WS) #217

Merged
merged 120 commits into from
Jun 20, 2018
Merged
Changes from 1 commit
Commits
Show all changes
120 commits
Select commit Hold shift + click to select a range
b20b807
Merge remote-tracking branch 'origin/master' into gav-xts-dont-panic
gavofyork May 29, 2018
b7ca4ae
Merge remote-tracking branch 'origin/master' into gav-xts-dont-panic
gavofyork May 29, 2018
b2a48c8
Update wasm.
gavofyork May 29, 2018
2d3a1ce
consensus, session and staking all panic-safe.
gavofyork May 29, 2018
881f6af
Democracy doesn't panic in apply.
gavofyork May 29, 2018
fee0f6f
Fix tests.
gavofyork May 29, 2018
8b9f50f
Extra helper macro, council depanicked.
gavofyork May 30, 2018
0e31a73
Fix one test.
gavofyork May 30, 2018
820ec13
Fix up all council tests. No panics!
gavofyork May 30, 2018
62ab840
Council voting depanicked.
gavofyork May 30, 2018
ff5da1a
Dispatch returns result.
gavofyork May 31, 2018
1123ff7
session & staking tests updated
gavofyork May 31, 2018
00ba4e0
Fix democracy tests.
gavofyork May 31, 2018
b6e54c1
Fix council tests.
gavofyork May 31, 2018
f3c1b9b
Fix up polkadot parachains in runtime
gavofyork May 31, 2018
3b8a4be
Merge branch 'master' into gav-result-dispatch
gavofyork May 31, 2018
d51a9bd
Merge remote-tracking branch 'origin/master' into gav-result-dispatch
gavofyork May 31, 2018
6c81a1e
Fix borked merge
gavofyork May 31, 2018
0141a68
More Slicable support
gavofyork Jun 1, 2018
34d0b75
Basic storage types.
gavofyork Jun 1, 2018
96a9b01
Existential deposit for contract creation
gavofyork Jun 1, 2018
ea2499f
Basic implemnetation along with removals
gavofyork Jun 1, 2018
193dde7
Fix tests.
gavofyork Jun 1, 2018
6f9636c
externalities builder fix.
gavofyork Jun 1, 2018
777f4dc
Tests.
gavofyork Jun 1, 2018
4027bd2
Fix up the runtime.
gavofyork Jun 1, 2018
de952ba
Fix tests.
gavofyork Jun 2, 2018
5e19a40
Add generic `Address` type.
gavofyork Jun 2, 2018
752f1a9
Merge branch 'master' into gav-enum-accounts
gavofyork Jun 2, 2018
014c13e
Initial function integration of Address into Extrinsic.
gavofyork Jun 3, 2018
8d34279
Fix build
gavofyork Jun 3, 2018
dd824ef
All tests compile.
gavofyork Jun 3, 2018
f2bebd2
Fix (some) tests.
gavofyork Jun 3, 2018
9ed26a5
Fix signing.
gavofyork Jun 3, 2018
f4ab2e5
Merge branch 'gav-enum-accounts' of github.com:paritytech/polkadot in…
gavofyork Jun 3, 2018
3a1835a
Push error.
gavofyork Jun 3, 2018
b3a5037
transfer can accept Address
gavofyork Jun 3, 2018
a0f0e05
Make Address generic over AccountIndex
gavofyork Jun 4, 2018
3e978c3
Fix test
gavofyork Jun 4, 2018
b04ff33
Make Council use Address for dispatch.
gavofyork Jun 4, 2018
95063be
Fix build
gavofyork Jun 4, 2018
0bd2d97
Bend over backwards to support braindead derive.
gavofyork Jun 4, 2018
e241ebd
Repot some files.
gavofyork Jun 4, 2018
67d1e74
Fix tests.
gavofyork Jun 4, 2018
d6439e8
Fix grumbles
gavofyork Jun 4, 2018
2a391c1
Remove Default bound
gavofyork Jun 4, 2018
2353b0b
Fix build for new nightly.
gavofyork Jun 4, 2018
1f5b7da
Merge remote-tracking branch 'origin/master' into gav-enum-accounts
gavofyork Jun 4, 2018
904c7cc
Make `apply_extrinsic` never panic, return useful Result.
gavofyork Jun 4, 2018
cef4d4e
Merge remote-tracking branch 'origin/master' into gav-enum-accounts
gavofyork Jun 5, 2018
5401577
Merge remote-tracking branch 'origin/master' into gav-enum-accounts
gavofyork Jun 7, 2018
48d1e9f
More merge hell
gavofyork Jun 7, 2018
b689e16
Doesn't build, but might do soon
gavofyork Jun 7, 2018
f9f875e
Serde woes
gavofyork Jun 7, 2018
d83316a
get substrate-runtime-staking compiling
rphmeier Jun 7, 2018
86de50a
Polkadot builds again!
gavofyork Jun 8, 2018
fcdfdce
Fix all build.
gavofyork Jun 8, 2018
9ad1272
Fix tests & binaries.
gavofyork Jun 8, 2018
6d27096
Merge remote-tracking branch 'origin/master' into gav-enum-accounts
gavofyork Jun 8, 2018
d3cb378
Reserve some extra initial byte values of address for future format c…
gavofyork Jun 8, 2018
c614f5d
Make semantic of `ReservedBalance` clear.
gavofyork Jun 8, 2018
684daf0
Fix panic handler.
gavofyork Jun 8, 2018
f5a8b74
Integrate other balance transformations into the new model
gavofyork Jun 8, 2018
6ba768d
Fix runtime tests.
gavofyork Jun 9, 2018
3534cc5
Fix panic build.
gavofyork Jun 10, 2018
267c360
Tests for demonstrating interaction between balance types.
gavofyork Jun 10, 2018
7abaa1d
Repot some runtime code
gavofyork Jun 10, 2018
2a39363
Fix checkedblock in non-std builds
gavofyork Jun 10, 2018
8b820ed
Get rid of `DoLookup` phantom.
gavofyork Jun 11, 2018
a6426db
Attempt to make transaction_pool work with lookups.
gavofyork Jun 11, 2018
fe6fee9
Remove vscode settings
gavofyork Jun 11, 2018
766e455
New attempt at making transaction pool work.
gavofyork Jun 12, 2018
2015e6d
It builds again!
gavofyork Jun 12, 2018
584d3e1
--all builds
gavofyork Jun 12, 2018
25bd52e
Fix tests.
gavofyork Jun 12, 2018
917455e
New build.
gavofyork Jun 12, 2018
abe5d64
Test account nonce reset.
gavofyork Jun 12, 2018
c4b2703
polkadot transaction pool tests/framework.
gavofyork Jun 13, 2018
97c0e02
Initial draft (working).
gavofyork Jun 14, 2018
8269eb3
Address grumbles.
gavofyork Jun 14, 2018
b54081a
Merge branch 'gav-enum-accounts' into gav-slogging
gavofyork Jun 14, 2018
1cea609
Revert bad `map_or`
gavofyork Jun 14, 2018
49b539e
Merge remote-tracking branch 'origin/dk-pwasm-alloc-fix' into gav-enu…
gavofyork Jun 15, 2018
8e30aad
Rebuild binaries, workaround.
gavofyork Jun 15, 2018
1d351d0
Merge branch 'gav-enum-accounts' into gav-slogging
gavofyork Jun 15, 2018
8c999d2
Avoid checking in vscode
gavofyork Jun 15, 2018
2dcd073
reconnecting, shared, slog
gavofyork Jun 15, 2018
0e2aa61
Merge
gavofyork Jun 15, 2018
678d027
Merge branch 'gav-enum-accounts' into gav-slogging
gavofyork Jun 15, 2018
4c2cb9c
CLI options for name and telemetry url
gavofyork Jun 15, 2018
9fe8144
ensure telemetry url imples enabled
gavofyork Jun 15, 2018
8065ad8
Avoid casting to usize early.
gavofyork Jun 15, 2018
5fa7866
Merge branch 'gav-enum-accounts' into gav-slogging
gavofyork Jun 15, 2018
f474509
Provide on-connect event for session message
gavofyork Jun 15, 2018
3747b9b
Better port
gavofyork Jun 15, 2018
94e15d0
heartbeat and some renaming
gavofyork Jun 15, 2018
e5cc4e3
transaction pool stuff
gavofyork Jun 15, 2018
e9fcff0
minor renaming.
gavofyork Jun 15, 2018
c1e89f5
report telemetry
gavofyork Jun 15, 2018
d924faf
cleanups.
gavofyork Jun 15, 2018
80aadf1
Fix for previous cleanup
gavofyork Jun 15, 2018
8e1041f
Initial draft (working).
gavofyork Jun 14, 2018
a96fa41
Avoid checking in vscode
gavofyork Jun 15, 2018
1846099
reconnecting, shared, slog
gavofyork Jun 15, 2018
a18fcdc
CLI options for name and telemetry url
gavofyork Jun 15, 2018
7537ec7
ensure telemetry url imples enabled
gavofyork Jun 15, 2018
b683b73
Provide on-connect event for session message
gavofyork Jun 15, 2018
9408973
Better port
gavofyork Jun 15, 2018
62e336f
heartbeat and some renaming
gavofyork Jun 15, 2018
b828986
transaction pool stuff
gavofyork Jun 15, 2018
96342fc
minor renaming.
gavofyork Jun 15, 2018
b4626c0
report telemetry
gavofyork Jun 15, 2018
2b0116e
cleanups.
gavofyork Jun 15, 2018
1e58c8e
Fix for previous cleanup
gavofyork Jun 15, 2018
f27740f
Merge branch 'gav-slogging' of github.com:paritytech/polkadot into ga…
gavofyork Jun 19, 2018
16daf46
Address grumble
gavofyork Jun 19, 2018
4d88d11
Final grumble and repot telemetry to substrate
gavofyork Jun 19, 2018
2f3ed06
Fix comment
gavofyork Jun 19, 2018
d734aec
Merge
gavofyork Jun 19, 2018
c593380
Please build, travis...
gavofyork Jun 19, 2018
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Avoid casting to usize early.
  • Loading branch information
gavofyork committed Jun 15, 2018
commit 8065ad84e8beeecfe4c6964e4690f91385aec037
46 changes: 23 additions & 23 deletions substrate/runtime/staking/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -494,54 +494,54 @@ impl<T: Trait> Module<T> {
);
}

fn enum_set_size() -> T::AccountIndex {
T::AccountIndex::sa(ENUM_SET_SIZE)
}

/// Lookup an T::AccountIndex to get an Id, if there's one there.
pub fn lookup_index(index: T::AccountIndex) -> Option<T::AccountId> {
let usize_index: usize = As::<usize>::as_(index);
let mut set = Self::enum_set(T::AccountIndex::sa(usize_index / ENUM_SET_SIZE));
let i = usize_index % ENUM_SET_SIZE;
if i < set.len() {
Some(set.swap_remove(i))
} else {
None
}
let enum_set_size = Self::enum_set_size();
let set = Self::enum_set(index / enum_set_size);
let i: usize = (index % enum_set_size).as_();
set.get(i).map(|x| x.clone())
}

/// `true` if the account `index` is ready for reclaim.
pub fn can_reclaim(index: T::AccountIndex) -> bool {
let try_index: usize = index.as_();
let try_set = Self::enum_set(T::AccountIndex::sa(try_index / ENUM_SET_SIZE));
let item_index = try_index % ENUM_SET_SIZE;
item_index < try_set.len() && Self::voting_balance(&try_set[item_index]).is_zero()
pub fn can_reclaim(try_index: T::AccountIndex) -> bool {
let enum_set_size = Self::enum_set_size();
let try_set = Self::enum_set(try_index / enum_set_size);
let i = (try_index % enum_set_size).as_();
i < try_set.len() && Self::voting_balance(&try_set[i]).is_zero()
}

/// Register a new account (with existential balance).
fn new_account(who: &T::AccountId, balance: T::Balance) -> NewAccountOutcome {
let enum_set_size = Self::enum_set_size();
let next_set_index = Self::next_enum_set();
let reclaim_index_magic = T::AccountIndex::sa(RECLAIM_INDEX_MAGIC);
let reclaim_index_modulus = T::AccountIndex::sa(256usize);
let quantization = T::AccountIndex::sa(256usize);

// A little easter-egg for reclaiming dead indexes..
let ret = {
let next_set_index: usize = next_set_index.as_();

// we quantise the number of accounts so it stays constant over a reasonable
// period of time.
const QUANTIZATION: usize = 256;
let quantized_account_count = (next_set_index * ENUM_SET_SIZE / QUANTIZATION + 1) * QUANTIZATION;
let quantized_account_count: T::AccountIndex = (next_set_index * enum_set_size / quantization + One::one()) * quantization;
// then modify the starting balance to be modulo this to allow it to potentially
// identify an account index for reuse.
let maybe_try_index = balance % T::Balance::sa(quantized_account_count * 256);
let maybe_try_index = balance % <T::Balance as As<T::AccountIndex>>::sa(quantized_account_count * reclaim_index_modulus);
let maybe_try_index = As::<T::AccountIndex>::as_(maybe_try_index);
let maybe_try_index = As::<usize>::as_(maybe_try_index);

// this identifier must end with magic byte 0x69 to trigger this check (a minor
// optimisation to ensure we don't check most unintended account creations).
if maybe_try_index % 256 == RECLAIM_INDEX_MAGIC {
if maybe_try_index % reclaim_index_modulus == reclaim_index_magic {
// reuse is probably intended. first, remove magic byte.
let try_index = maybe_try_index / 256;
let try_index = maybe_try_index / reclaim_index_modulus;

// then check to see if this balance identifies a dead account index.
let set_index = T::AccountIndex::sa(try_index / ENUM_SET_SIZE);
let set_index = try_index / enum_set_size;
let mut try_set = Self::enum_set(set_index);
let item_index = try_index % ENUM_SET_SIZE;
let item_index = (try_index % enum_set_size).as_();
if item_index < try_set.len() {
if Self::voting_balance(&try_set[item_index]).is_zero() {
// yup - this index refers to a dead account. can be reused.
Expand Down