<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, minimum-scale=1" />
<meta name="generator" content="pdoc 0.10.0" />
<title>utils.buffer API documentation</title>
<meta name="description" content="" />
<link rel="preload stylesheet" as="style" href="https://cdnjs.cloudflare.com/ajax/libs/10up-sanitize.css/11.0.1/sanitize.min.css" integrity="sha256-PK9q560IAAa6WVRRh76LtCaI8pjTJ2z11v0miyNNjrs=" crossorigin>
<link rel="preload stylesheet" as="style" href="https://cdnjs.cloudflare.com/ajax/libs/10up-sanitize.css/11.0.1/typography.min.css" integrity="sha256-7l/o7C8jubJiy74VsKTidCy1yBkRtiUGbVkYBylBqUg=" crossorigin>
<link rel="stylesheet preload" as="style" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.1.1/styles/github.min.css" crossorigin>
<style>:root{--highlight-color:#fe9}.flex{display:flex !important}body{line-height:1.5em}#content{padding:20px}#sidebar{padding:30px;overflow:hidden}#sidebar > *:last-child{margin-bottom:2cm}.http-server-breadcrumbs{font-size:130%;margin:0 0 15px 0}#footer{font-size:.75em;padding:5px 30px;border-top:1px solid #ddd;text-align:right}#footer p{margin:0 0 0 1em;display:inline-block}#footer p:last-child{margin-right:30px}h1,h2,h3,h4,h5{font-weight:300}h1{font-size:2.5em;line-height:1.1em}h2{font-size:1.75em;margin:1em 0 .50em 0}h3{font-size:1.4em;margin:25px 0 10px 0}h4{margin:0;font-size:105%}h1:target,h2:target,h3:target,h4:target,h5:target,h6:target{background:var(--highlight-color);padding:.2em 0}a{color:#058;text-decoration:none;transition:color .3s ease-in-out}a:hover{color:#e82}.title code{font-weight:bold}h2[id^="header-"]{margin-top:2em}.ident{color:#900}pre code{background:#f8f8f8;font-size:.8em;line-height:1.4em}code{background:#f2f2f1;padding:1px 4px;overflow-wrap:break-word}h1 code{background:transparent}pre{background:#f8f8f8;border:0;border-top:1px solid #ccc;border-bottom:1px solid #ccc;margin:1em 0;padding:1ex}#http-server-module-list{display:flex;flex-flow:column}#http-server-module-list div{display:flex}#http-server-module-list dt{min-width:10%}#http-server-module-list p{margin-top:0}.toc ul,#index{list-style-type:none;margin:0;padding:0}#index code{background:transparent}#index h3{border-bottom:1px solid #ddd}#index ul{padding:0}#index h4{margin-top:.6em;font-weight:bold}@media (min-width:200ex){#index .two-column{column-count:2}}@media (min-width:300ex){#index .two-column{column-count:3}}dl{margin-bottom:2em}dl dl:last-child{margin-bottom:4em}dd{margin:0 0 1em 3em}#header-classes + dl > dd{margin-bottom:3em}dd dd{margin-left:2em}dd p{margin:10px 0}.name{background:#eee;font-weight:bold;font-size:.85em;padding:5px 10px;display:inline-block;min-width:40%}.name:hover{background:#e0e0e0}dt:target .name{background:var(--highlight-color)}.name > span:first-child{white-space:nowrap}.name.class > span:nth-child(2){margin-left:.4em}.inherited{color:#999;border-left:5px solid #eee;padding-left:1em}.inheritance em{font-style:normal;font-weight:bold}.desc h2{font-weight:400;font-size:1.25em}.desc h3{font-size:1em}.desc dt code{background:inherit}.source summary,.git-link-div{color:#666;text-align:right;font-weight:400;font-size:.8em;text-transform:uppercase}.source summary > *{white-space:nowrap;cursor:pointer}.git-link{color:inherit;margin-left:1em}.source pre{max-height:500px;overflow:auto;margin:0}.source pre code{font-size:12px;overflow:visible}.hlist{list-style:none}.hlist li{display:inline}.hlist li:after{content:',\2002'}.hlist li:last-child:after{content:none}.hlist .hlist{display:inline;padding-left:1em}img{max-width:100%}td{padding:0 .5em}.admonition{padding:.1em .5em;margin-bottom:1em}.admonition-title{font-weight:bold}.admonition.note,.admonition.info,.admonition.important{background:#aef}.admonition.todo,.admonition.versionadded,.admonition.tip,.admonition.hint{background:#dfd}.admonition.warning,.admonition.versionchanged,.admonition.deprecated{background:#fd4}.admonition.error,.admonition.danger,.admonition.caution{background:lightpink}</style>
<style media="screen and (min-width: 700px)">@media screen and (min-width:700px){#sidebar{width:30%;height:100vh;overflow:auto;position:sticky;top:0}#content{width:70%;max-width:100ch;padding:3em 4em;border-left:1px solid #ddd}pre code{font-size:1em}.item .name{font-size:1em}main{display:flex;flex-direction:row-reverse;justify-content:flex-end}.toc ul ul,#index ul{padding-left:1.5em}.toc > ul > li{margin-top:.5em}}</style>
<style media="print">@media print{#sidebar h1{page-break-before:always}.source{display:none}}@media print{*{background:transparent !important;color:#000 !important;box-shadow:none !important;text-shadow:none !important}a[href]:after{content:" (" attr(href) ")";font-size:90%}a[href][title]:after{content:none}abbr[title]:after{content:" (" attr(title) ")"}.ir a:after,a[href^="javascript:"]:after,a[href^="#"]:after{content:""}pre,blockquote{border:1px solid #999;page-break-inside:avoid}thead{display:table-header-group}tr,img{page-break-inside:avoid}img{max-width:100% !important}@page{margin:0.5cm}p,h2,h3{orphans:3;widows:3}h1,h2,h3,h4,h5,h6{page-break-after:avoid}}</style>
<script async src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.7/latest.js?config=TeX-AMS_CHTML" integrity="sha256-kZafAc6mZvK3W3v1pHOcUix30OHQN6pU/NO2oFkqZVw=" crossorigin></script>
<script defer src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.1.1/highlight.min.js" integrity="sha256-Uv3H6lx7dJmRfRvH8TH6kJD1TSK1aFcwgx+mdg3epi8=" crossorigin></script>
<script>window.addEventListener('DOMContentLoaded', () => hljs.initHighlighting())</script>
</head>
<body>
<main>
<article id="content">
<header>
<h1 class="title">Module <code>utils.buffer</code></h1>
</header>
<section id="section-intro">
<details class="source">
<summary>
<span>Expand source code</span>
</summary>
<pre><code class="python">#!/usr/bin/env python3

import threading
import time


class Buffer:
    &#34;&#34;&#34;Thread safe ring - buffer of commands&#34;&#34;&#34;

    def __init__(self, max_capacity=100):
        self.max_capacity = max_capacity
        self.items = [None] * self.max_capacity  # List with reserved memory to eliminate problems with memory resizing
        self.front_index = 0  # Read position for popFront
        self.back_index = 0  # Write position for pushBack
        self.length = 0  # Length of buffer in elements
        self.lock = threading.Lock()  # Be default lock is not acquired
        self.item_is_ready = threading.Semaphore(value=0)  # Semaphore to signal when there are items in the buffer

    def __len__(self):
        &#34;&#34;&#34;Total number of items in the thread-safe container.&#34;&#34;&#34;
        self.lock.acquire()
        L = self.length
        self.lock.release()

        return L

    def isFull(self):
        &#34;&#34;&#34;Check that buffer is full&#34;&#34;&#34;
        return len(self) == self.max_capacity

    def isEmpty(self):
        &#34;&#34;&#34;Predict which allow to check is container empty.&#34;&#34;&#34;
        return len(self) == 0

    def pushBack(self, item):
        &#34;&#34;&#34;
      Push item into the back of a container, with blocking.

      Args:
          item (object): item which is inserted into container
      &#34;&#34;&#34;
        while True:
            self.lock.acquire()
            if self.length == self.max_capacity:
                self.lock.release()
                time.sleep(0.0001)
                continue

            else:
                self.items[self.back_index] = item
                self.back_index = (self.back_index + 1) % self.max_capacity
                self.length += 1
                self.lock.release()
                self.item_is_ready.release()
                break

        return self

    def waitForItem(self):
        &#34;&#34;&#34;Wait for item available for popping from container via popFront(), blocking.&#34;&#34;&#34;
        self.item_is_ready.acquire()
        return self

    def popFront(self):
        &#34;&#34;&#34;
          Get item from the front of a container, no blocking.

          Method does not perform checking is any element in the container is available.
          Please use waitForItem() or len() if you&#39;re not sure.

          Returns:
          object: item from a container
        &#34;&#34;&#34;
        self.lock.acquire()
        return_item = self.items[self.front_index]
        self.front_index = (self.front_index + 1) % self.max_capacity
        self.length -= 1
        self.lock.release()
        return return_item

    def front(self):
        &#34;&#34;&#34;Get item from the front of a container, not blocking.&#34;&#34;&#34;
        self.lock.acquire()
        return_item = self.items[self.front_index]
        self.lock.release()
        return return_item

    def get(self, index):
        &#34;&#34;&#34;
      Get item from the front of a container, not blocking

      Method does not perform checking is index within need range accessible range.

      Returns:
      object: item from a container
      &#34;&#34;&#34;
        self.lock.acquire()
        index = index + self.front_index
        index = index % self.max_capacity
        return_item = self.items[index]
        self.lock.release()
        return return_item

    def __getitem__(self, index):
        return self.get(index)


# ======================================================================================================================
# Unittests for launch please use: &#34;pytest -v buffer.py&#34; 
# https://docs.pytest.org/en/stable/getting-started.html

def test_cmd_buffer_push_pop():
    b = Buffer()
    b.pushBack(10).pushBack(20)
    assert len(b) == 2
    assert b.popFront() == 10
    assert b.popFront() == 20
    assert len(b) == 0
    assert b.isEmpty()


def test_cmd_buffer_waiting():
    b = Buffer()
    assert b.isEmpty()

    b.pushBack(10)
    b.pushBack(20)
    b.pushBack(30)
    assert not b.isEmpty()
    b.waitForItem()
    assert b.front() == 10
    assert b.front() == 10
    assert b.popFront() == 10
    assert b.front() == 20
    assert b.popFront() == 20


def test_cmd_buffer_indexing():
    b = Buffer()
    b.pushBack(10).pushBack(20).pushBack(30)
    assert b[0] == 10
    assert b[1] == 20
    assert b[2] == 30

    b = Buffer()
    b.pushBack(50).pushBack(10).pushBack(20).pushBack(30)
    assert len(b) == 4
    assert 50 == b.popFront()
    assert b[0] == 10
    assert b[1] == 20
    assert b[2] == 30

    c = Buffer(max_capacity=3)
    c.pushBack(50).pushBack(10).pushBack(20)
    c.popFront()
    c.popFront()
    c.pushBack(21).pushBack(22)

    assert c[0] == 20
    assert c[1] == 21
    assert c[2] == 22
    assert len(c) == 3


def test_buffer_waiting():
    class TestThread(threading.Thread):
        def __init__(self, buffer):
            threading.Thread.__init__(self)
            self.buffer = buffer

        def run(self):
            time.sleep(1.0)
            out.pushBack(&#34;Action-2&#34;)
            self.buffer.popFront()

    b = Buffer(3)
    out = Buffer(3)
    b.pushBack(1)
    b.pushBack(2)
    assert not b.isFull()
    b.pushBack(3)
    assert b.isFull()
    th = TestThread(b)
    th.start()
    out.pushBack(&#34;Action-1&#34;)
    b.pushBack(4)
    out.pushBack(&#34;Action-3&#34;)
    assert out[0] == &#34;Action-1&#34;
    assert out[1] == &#34;Action-2&#34;
    assert out[2] == &#34;Action-3&#34;
# ======================================================================================================================</code></pre>
</details>
</section>
<section>
</section>
<section>
</section>
<section>
<h2 class="section-title" id="header-functions">Functions</h2>
<dl>
<dt id="utils.buffer.test_buffer_waiting"><code class="name flex">
<span>def <span class="ident">test_buffer_waiting</span></span>(<span>)</span>
</code></dt>
<dd>
<div class="desc"></div>
<details class="source">
<summary>
<span>Expand source code</span>
</summary>
<pre><code class="python">def test_buffer_waiting():
    class TestThread(threading.Thread):
        def __init__(self, buffer):
            threading.Thread.__init__(self)
            self.buffer = buffer

        def run(self):
            time.sleep(1.0)
            out.pushBack(&#34;Action-2&#34;)
            self.buffer.popFront()

    b = Buffer(3)
    out = Buffer(3)
    b.pushBack(1)
    b.pushBack(2)
    assert not b.isFull()
    b.pushBack(3)
    assert b.isFull()
    th = TestThread(b)
    th.start()
    out.pushBack(&#34;Action-1&#34;)
    b.pushBack(4)
    out.pushBack(&#34;Action-3&#34;)
    assert out[0] == &#34;Action-1&#34;
    assert out[1] == &#34;Action-2&#34;
    assert out[2] == &#34;Action-3&#34;</code></pre>
</details>
</dd>
<dt id="utils.buffer.test_cmd_buffer_indexing"><code class="name flex">
<span>def <span class="ident">test_cmd_buffer_indexing</span></span>(<span>)</span>
</code></dt>
<dd>
<div class="desc"></div>
<details class="source">
<summary>
<span>Expand source code</span>
</summary>
<pre><code class="python">def test_cmd_buffer_indexing():
    b = Buffer()
    b.pushBack(10).pushBack(20).pushBack(30)
    assert b[0] == 10
    assert b[1] == 20
    assert b[2] == 30

    b = Buffer()
    b.pushBack(50).pushBack(10).pushBack(20).pushBack(30)
    assert len(b) == 4
    assert 50 == b.popFront()
    assert b[0] == 10
    assert b[1] == 20
    assert b[2] == 30

    c = Buffer(max_capacity=3)
    c.pushBack(50).pushBack(10).pushBack(20)
    c.popFront()
    c.popFront()
    c.pushBack(21).pushBack(22)

    assert c[0] == 20
    assert c[1] == 21
    assert c[2] == 22
    assert len(c) == 3</code></pre>
</details>
</dd>
<dt id="utils.buffer.test_cmd_buffer_push_pop"><code class="name flex">
<span>def <span class="ident">test_cmd_buffer_push_pop</span></span>(<span>)</span>
</code></dt>
<dd>
<div class="desc"></div>
<details class="source">
<summary>
<span>Expand source code</span>
</summary>
<pre><code class="python">def test_cmd_buffer_push_pop():
    b = Buffer()
    b.pushBack(10).pushBack(20)
    assert len(b) == 2
    assert b.popFront() == 10
    assert b.popFront() == 20
    assert len(b) == 0
    assert b.isEmpty()</code></pre>
</details>
</dd>
<dt id="utils.buffer.test_cmd_buffer_waiting"><code class="name flex">
<span>def <span class="ident">test_cmd_buffer_waiting</span></span>(<span>)</span>
</code></dt>
<dd>
<div class="desc"></div>
<details class="source">
<summary>
<span>Expand source code</span>
</summary>
<pre><code class="python">def test_cmd_buffer_waiting():
    b = Buffer()
    assert b.isEmpty()

    b.pushBack(10)
    b.pushBack(20)
    b.pushBack(30)
    assert not b.isEmpty()
    b.waitForItem()
    assert b.front() == 10
    assert b.front() == 10
    assert b.popFront() == 10
    assert b.front() == 20
    assert b.popFront() == 20</code></pre>
</details>
</dd>
</dl>
</section>
<section>
<h2 class="section-title" id="header-classes">Classes</h2>
<dl>
<dt id="utils.buffer.Buffer"><code class="flex name class">
<span>class <span class="ident">Buffer</span></span>
<span>(</span><span>max_capacity=100)</span>
</code></dt>
<dd>
<div class="desc"><p>Thread safe ring - buffer of commands</p></div>
<details class="source">
<summary>
<span>Expand source code</span>
</summary>
<pre><code class="python">class Buffer:
    &#34;&#34;&#34;Thread safe ring - buffer of commands&#34;&#34;&#34;

    def __init__(self, max_capacity=100):
        self.max_capacity = max_capacity
        self.items = [None] * self.max_capacity  # List with reserved memory to eliminate problems with memory resizing
        self.front_index = 0  # Read position for popFront
        self.back_index = 0  # Write position for pushBack
        self.length = 0  # Length of buffer in elements
        self.lock = threading.Lock()  # Be default lock is not acquired
        self.item_is_ready = threading.Semaphore(value=0)  # Semaphore to signal when there are items in the buffer

    def __len__(self):
        &#34;&#34;&#34;Total number of items in the thread-safe container.&#34;&#34;&#34;
        self.lock.acquire()
        L = self.length
        self.lock.release()

        return L

    def isFull(self):
        &#34;&#34;&#34;Check that buffer is full&#34;&#34;&#34;
        return len(self) == self.max_capacity

    def isEmpty(self):
        &#34;&#34;&#34;Predict which allow to check is container empty.&#34;&#34;&#34;
        return len(self) == 0

    def pushBack(self, item):
        &#34;&#34;&#34;
      Push item into the back of a container, with blocking.

      Args:
          item (object): item which is inserted into container
      &#34;&#34;&#34;
        while True:
            self.lock.acquire()
            if self.length == self.max_capacity:
                self.lock.release()
                time.sleep(0.0001)
                continue

            else:
                self.items[self.back_index] = item
                self.back_index = (self.back_index + 1) % self.max_capacity
                self.length += 1
                self.lock.release()
                self.item_is_ready.release()
                break

        return self

    def waitForItem(self):
        &#34;&#34;&#34;Wait for item available for popping from container via popFront(), blocking.&#34;&#34;&#34;
        self.item_is_ready.acquire()
        return self

    def popFront(self):
        &#34;&#34;&#34;
          Get item from the front of a container, no blocking.

          Method does not perform checking is any element in the container is available.
          Please use waitForItem() or len() if you&#39;re not sure.

          Returns:
          object: item from a container
        &#34;&#34;&#34;
        self.lock.acquire()
        return_item = self.items[self.front_index]
        self.front_index = (self.front_index + 1) % self.max_capacity
        self.length -= 1
        self.lock.release()
        return return_item

    def front(self):
        &#34;&#34;&#34;Get item from the front of a container, not blocking.&#34;&#34;&#34;
        self.lock.acquire()
        return_item = self.items[self.front_index]
        self.lock.release()
        return return_item

    def get(self, index):
        &#34;&#34;&#34;
      Get item from the front of a container, not blocking

      Method does not perform checking is index within need range accessible range.

      Returns:
      object: item from a container
      &#34;&#34;&#34;
        self.lock.acquire()
        index = index + self.front_index
        index = index % self.max_capacity
        return_item = self.items[index]
        self.lock.release()
        return return_item

    def __getitem__(self, index):
        return self.get(index)</code></pre>
</details>
<h3>Methods</h3>
<dl>
<dt id="utils.buffer.Buffer.front"><code class="name flex">
<span>def <span class="ident">front</span></span>(<span>self)</span>
</code></dt>
<dd>
<div class="desc"><p>Get item from the front of a container, not blocking.</p></div>
<details class="source">
<summary>
<span>Expand source code</span>
</summary>
<pre><code class="python">def front(self):
    &#34;&#34;&#34;Get item from the front of a container, not blocking.&#34;&#34;&#34;
    self.lock.acquire()
    return_item = self.items[self.front_index]
    self.lock.release()
    return return_item</code></pre>
</details>
</dd>
<dt id="utils.buffer.Buffer.get"><code class="name flex">
<span>def <span class="ident">get</span></span>(<span>self, index)</span>
</code></dt>
<dd>
<div class="desc"><p>Get item from the front of a container, not blocking</p>
<p>Method does not perform checking is index within need range accessible range.</p>
<p>Returns:
object: item from a container</p></div>
<details class="source">
<summary>
<span>Expand source code</span>
</summary>
<pre><code class="python">def get(self, index):
    &#34;&#34;&#34;
  Get item from the front of a container, not blocking

  Method does not perform checking is index within need range accessible range.

  Returns:
  object: item from a container
  &#34;&#34;&#34;
    self.lock.acquire()
    index = index + self.front_index
    index = index % self.max_capacity
    return_item = self.items[index]
    self.lock.release()
    return return_item</code></pre>
</details>
</dd>
<dt id="utils.buffer.Buffer.isEmpty"><code class="name flex">
<span>def <span class="ident">isEmpty</span></span>(<span>self)</span>
</code></dt>
<dd>
<div class="desc"><p>Predict which allow to check is container empty.</p></div>
<details class="source">
<summary>
<span>Expand source code</span>
</summary>
<pre><code class="python">def isEmpty(self):
    &#34;&#34;&#34;Predict which allow to check is container empty.&#34;&#34;&#34;
    return len(self) == 0</code></pre>
</details>
</dd>
<dt id="utils.buffer.Buffer.isFull"><code class="name flex">
<span>def <span class="ident">isFull</span></span>(<span>self)</span>
</code></dt>
<dd>
<div class="desc"><p>Check that buffer is full</p></div>
<details class="source">
<summary>
<span>Expand source code</span>
</summary>
<pre><code class="python">def isFull(self):
    &#34;&#34;&#34;Check that buffer is full&#34;&#34;&#34;
    return len(self) == self.max_capacity</code></pre>
</details>
</dd>
<dt id="utils.buffer.Buffer.popFront"><code class="name flex">
<span>def <span class="ident">popFront</span></span>(<span>self)</span>
</code></dt>
<dd>
<div class="desc"><p>Get item from the front of a container, no blocking.</p>
<p>Method does not perform checking is any element in the container is available.
Please use waitForItem() or len() if you're not sure.</p>
<p>Returns:
object: item from a container</p></div>
<details class="source">
<summary>
<span>Expand source code</span>
</summary>
<pre><code class="python">def popFront(self):
    &#34;&#34;&#34;
      Get item from the front of a container, no blocking.

      Method does not perform checking is any element in the container is available.
      Please use waitForItem() or len() if you&#39;re not sure.

      Returns:
      object: item from a container
    &#34;&#34;&#34;
    self.lock.acquire()
    return_item = self.items[self.front_index]
    self.front_index = (self.front_index + 1) % self.max_capacity
    self.length -= 1
    self.lock.release()
    return return_item</code></pre>
</details>
</dd>
<dt id="utils.buffer.Buffer.pushBack"><code class="name flex">
<span>def <span class="ident">pushBack</span></span>(<span>self, item)</span>
</code></dt>
<dd>
<div class="desc"><p>Push item into the back of a container, with blocking.</p>
<h2 id="args">Args</h2>
<dl>
<dt><strong><code>item</code></strong> :&ensp;<code>object</code></dt>
<dd>item which is inserted into container</dd>
</dl></div>
<details class="source">
<summary>
<span>Expand source code</span>
</summary>
<pre><code class="python">def pushBack(self, item):
    &#34;&#34;&#34;
  Push item into the back of a container, with blocking.

  Args:
      item (object): item which is inserted into container
  &#34;&#34;&#34;
    while True:
        self.lock.acquire()
        if self.length == self.max_capacity:
            self.lock.release()
            time.sleep(0.0001)
            continue

        else:
            self.items[self.back_index] = item
            self.back_index = (self.back_index + 1) % self.max_capacity
            self.length += 1
            self.lock.release()
            self.item_is_ready.release()
            break

    return self</code></pre>
</details>
</dd>
<dt id="utils.buffer.Buffer.waitForItem"><code class="name flex">
<span>def <span class="ident">waitForItem</span></span>(<span>self)</span>
</code></dt>
<dd>
<div class="desc"><p>Wait for item available for popping from container via popFront(), blocking.</p></div>
<details class="source">
<summary>
<span>Expand source code</span>
</summary>
<pre><code class="python">def waitForItem(self):
    &#34;&#34;&#34;Wait for item available for popping from container via popFront(), blocking.&#34;&#34;&#34;
    self.item_is_ready.acquire()
    return self</code></pre>
</details>
</dd>
</dl>
</dd>
</dl>
</section>
</article>
<nav id="sidebar">
<h1>Index</h1>
<div class="toc">
<ul></ul>
</div>
<ul id="index">
<li><h3><a href="#header-functions">Functions</a></h3>
<ul class="">
<li><code><a title="utils.buffer.test_buffer_waiting" href="#utils.buffer.test_buffer_waiting">test_buffer_waiting</a></code></li>
<li><code><a title="utils.buffer.test_cmd_buffer_indexing" href="#utils.buffer.test_cmd_buffer_indexing">test_cmd_buffer_indexing</a></code></li>
<li><code><a title="utils.buffer.test_cmd_buffer_push_pop" href="#utils.buffer.test_cmd_buffer_push_pop">test_cmd_buffer_push_pop</a></code></li>
<li><code><a title="utils.buffer.test_cmd_buffer_waiting" href="#utils.buffer.test_cmd_buffer_waiting">test_cmd_buffer_waiting</a></code></li>
</ul>
</li>
<li><h3><a href="#header-classes">Classes</a></h3>
<ul>
<li>
<h4><code><a title="utils.buffer.Buffer" href="#utils.buffer.Buffer">Buffer</a></code></h4>
<ul class="two-column">
<li><code><a title="utils.buffer.Buffer.front" href="#utils.buffer.Buffer.front">front</a></code></li>
<li><code><a title="utils.buffer.Buffer.get" href="#utils.buffer.Buffer.get">get</a></code></li>
<li><code><a title="utils.buffer.Buffer.isEmpty" href="#utils.buffer.Buffer.isEmpty">isEmpty</a></code></li>
<li><code><a title="utils.buffer.Buffer.isFull" href="#utils.buffer.Buffer.isFull">isFull</a></code></li>
<li><code><a title="utils.buffer.Buffer.popFront" href="#utils.buffer.Buffer.popFront">popFront</a></code></li>
<li><code><a title="utils.buffer.Buffer.pushBack" href="#utils.buffer.Buffer.pushBack">pushBack</a></code></li>
<li><code><a title="utils.buffer.Buffer.waitForItem" href="#utils.buffer.Buffer.waitForItem">waitForItem</a></code></li>
</ul>
</li>
</ul>
</li>
</ul>
</nav>
</main>
<footer id="footer">
FL_PyTorch. The document generated 06-March-2023 18:58:30.
<p>Generated by <a href="https://pdoc3.github.io/pdoc" title="pdoc: Python API documentation generator"><cite>pdoc</cite> 0.10.0</a>.</p>
</footer>
</body>
</html>