feat: Rebrand Polkadot/Substrate references to PezkuwiChain
This commit systematically rebrands various references from Parity Technologies' Polkadot/Substrate ecosystem to PezkuwiChain within the kurdistan-sdk. Key changes include: - Updated external repository URLs (zombienet-sdk, parity-db, parity-scale-codec, wasm-instrument) to point to pezkuwichain forks. - Modified internal documentation and code comments to reflect PezkuwiChain naming and structure. - Replaced direct references to with or specific paths within the for XCM, Pezkuwi, and other modules. - Cleaned up deprecated issue and PR references in various and files, particularly in and modules. - Adjusted image and logo URLs in documentation to point to PezkuwiChain assets. - Removed or rephrased comments related to external Polkadot/Substrate PRs and issues. This is a significant step towards fully customizing the SDK for the PezkuwiChain ecosystem.
This commit is contained in:
@@ -0,0 +1,62 @@
|
||||
// This file is part of Bizinikiwi.
|
||||
|
||||
// Copyright (C) Parity Technologies (UK) Ltd.
|
||||
// SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
use std::collections::HashSet;
|
||||
|
||||
use crate::{
|
||||
id_sequence::SeqID,
|
||||
pubsub::{Dispatch, Subscribe, Unsubscribe},
|
||||
};
|
||||
|
||||
/// The shared structure to keep track on subscribers.
|
||||
#[derive(Debug, Default)]
|
||||
pub(super) struct Registry {
|
||||
pub(super) subscribers: HashSet<SeqID>,
|
||||
}
|
||||
|
||||
impl Subscribe<()> for Registry {
|
||||
fn subscribe(&mut self, _subs_key: (), subs_id: SeqID) {
|
||||
self.subscribers.insert(subs_id);
|
||||
}
|
||||
}
|
||||
impl Unsubscribe for Registry {
|
||||
fn unsubscribe(&mut self, subs_id: SeqID) {
|
||||
self.subscribers.remove(&subs_id);
|
||||
}
|
||||
}
|
||||
|
||||
impl<MakePayload, Payload, Error> Dispatch<MakePayload> for Registry
|
||||
where
|
||||
MakePayload: FnOnce() -> Result<Payload, Error>,
|
||||
Payload: Clone,
|
||||
{
|
||||
type Item = Payload;
|
||||
type Ret = Result<(), Error>;
|
||||
|
||||
fn dispatch<F>(&mut self, make_payload: MakePayload, mut dispatch: F) -> Self::Ret
|
||||
where
|
||||
F: FnMut(&SeqID, Self::Item),
|
||||
{
|
||||
if !self.subscribers.is_empty() {
|
||||
let payload = make_payload()?;
|
||||
for subs_id in &self.subscribers {
|
||||
dispatch(subs_id, payload.clone());
|
||||
}
|
||||
}
|
||||
Ok(())
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,51 @@
|
||||
// This file is part of Bizinikiwi.
|
||||
|
||||
// Copyright (C) Parity Technologies (UK) Ltd.
|
||||
// SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
use super::*;
|
||||
use futures::StreamExt;
|
||||
|
||||
#[derive(Clone)]
|
||||
pub struct DummyTracingKey;
|
||||
impl TracingKeyStr for DummyTracingKey {
|
||||
const TRACING_KEY: &'static str = "test_notification_stream";
|
||||
}
|
||||
|
||||
type StringStream = NotificationStream<String, DummyTracingKey>;
|
||||
|
||||
#[test]
|
||||
fn notification_channel_simple() {
|
||||
let (sender, stream) = StringStream::channel();
|
||||
|
||||
let test_payload = String::from("test payload");
|
||||
let closure_payload = test_payload.clone();
|
||||
|
||||
// Create a future to receive a single notification
|
||||
// from the stream and verify its payload.
|
||||
let future = stream.subscribe(100_000).take(1).for_each(move |payload| {
|
||||
let test_payload = closure_payload.clone();
|
||||
async move {
|
||||
assert_eq!(payload, test_payload);
|
||||
}
|
||||
});
|
||||
|
||||
// Send notification.
|
||||
let r: std::result::Result<(), ()> = sender.notify(|| Ok(test_payload));
|
||||
r.unwrap();
|
||||
|
||||
// Run receiver future.
|
||||
tokio_test::block_on(future);
|
||||
}
|
||||
Reference in New Issue
Block a user