Source code for sttp.transport.bufferblock
# ******************************************************************************************************
# bufferblock.py - Gbtc
#
# Copyright © 2022, Grid Protection Alliance. All Rights Reserved.
#
# Licensed to the Grid Protection Alliance (GPA) under one or more contributor license agreements. See
# the NOTICE file distributed with this work for additional information regarding copyright ownership.
# The GPA licenses this file to you under the MIT License (MIT), the "License"; you may not use this
# file except in compliance with the License. You may obtain a copy of the License at =
#
# http =//opensource.org/licenses/MIT
#
# Unless agreed to in writing, the subject software distributed under the License is distributed on an
# "AS-IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. Refer to the
# License for the specific language governing permissions and limitations.
#
# Code Modification History =
# ----------------------------------------------------------------------------------------------------
# 08/15/2022 - J. Ritchie Carroll
# Generated original version of source code.
#
# ******************************************************************************************************
from gsf import Empty
from uuid import UUID
from typing import Optional
[docs]
class BufferBlock:
"""
BufferBlock defines an atomic unit of data, i.e., a binary buffer, for transport in STTP.
"""
DEFAULT_SIGNALID = Empty.GUID
DEFAULT_BUFFER: Optional[bytearray] = None
def __init__(self,
signalid: UUID = ...,
buffer: bytearray = ...
):
self.signalid = BufferBlock.DEFAULT_SIGNALID if signalid is ... else signalid
"""
Defines measurement's globally unique identifier.
"""
self._buffer = BufferBlock.DEFAULT_BUFFER if buffer is ... else buffer
@property
def buffer(self) -> Optional[bytearray]:
"""
Gets measurement buffer as an atomic unit of data, i.e., a binary buffer.
This buffer typically represents a partial image of a larger whole.
"""
return self._buffer