libxr  1.0
Want to be the best embedded framework
Loading...
Searching...
No Matches
LibXR::STDIO Class Reference

STDIO interface for read/write ports. More...

#include <libxr_rw.hpp>

Collaboration diagram for LibXR::STDIO:
[legend]

Static Public Member Functions

static int Printf (const char *fmt,...)
 Prints a formatted string to the write port (like printf).
 

Static Public Attributes

static ReadPortread_ = nullptr
 Read port instance. 读取端口。
 
static WritePortwrite_ = nullptr
 Write port instance. 写入端口。
 
static LibXR::Mutexwrite_mutex_
 Write port mutex. 写入端口互斥锁。
 
static LibXR::WritePort::Streamwrite_stream_ = nullptr
 

Detailed Description

STDIO interface for read/write ports.

提供静态全局的输入输出接口绑定与缓冲区管理。

Definition at line 594 of file libxr_rw.hpp.

Member Function Documentation

◆ Printf()

int STDIO::Printf ( const char * fmt,
... )
static

Prints a formatted string to the write port (like printf).

将格式化字符串发送至写入端口,类似 printf。

Parameters
fmtThe format string. 格式化字符串。
...Variable arguments to be formatted. 需要格式化的参数。
Returns
Number of characters written, or negative on error. 成功返回写入的字符数,失败返回负数。

Definition at line 429 of file libxr_rw.cpp.

430{
431#if LIBXR_PRINTF_BUFFER_SIZE > 0
432 if (!STDIO::write_ || !STDIO::write_->Writable())
433 {
434 return -1;
435 }
436
437 if (!write_mutex_)
438 {
440 }
441
443
444 va_list args;
445 va_start(args, fmt);
446 int len = vsnprintf(STDIO::printf_buff_, LIBXR_PRINTF_BUFFER_SIZE, fmt, args);
447 va_end(args);
448
449 // Check result and limit length
450 if (len < 0)
451 {
452 return -1;
453 }
454 if (static_cast<size_t>(len) >= LIBXR_PRINTF_BUFFER_SIZE)
455 {
456 len = LIBXR_PRINTF_BUFFER_SIZE - 1;
457 }
458
459 ConstRawData data = {reinterpret_cast<const uint8_t*>(STDIO::printf_buff_),
460 static_cast<size_t>(len)};
461
462 static WriteOperation op; // NOLINT
463 if (write_stream_ == nullptr)
464 {
465 return static_cast<int>(STDIO::write_->operator()(data, op));
466 }
467 else
468 {
469 (*write_stream_) << data;
470 return static_cast<int>(write_stream_->Commit());
471 }
472#else
473 UNUSED(fmt);
474 return 0;
475#endif
476}
常量原始数据封装类。 A class for encapsulating constant raw data.
互斥锁的 RAII 机制封装 (RAII-style mechanism for automatic mutex management).
Definition mutex.hpp:65
互斥锁类,提供线程同步机制 (Mutex class providing thread synchronization mechanisms).
Definition mutex.hpp:18
static LibXR::Mutex * write_mutex_
Write port mutex. 写入端口互斥锁。
Definition libxr_rw.hpp:600
static WritePort * write_
Write port instance. 写入端口。
Definition libxr_rw.hpp:599
ErrorCode Commit()
手动提交已写入的数据到队列,并尝试续锁。
Definition libxr_rw.cpp:402

Field Documentation

◆ read_

ReadPort* LibXR::STDIO::read_ = nullptr
inlinestatic

Read port instance. 读取端口。

Definition at line 598 of file libxr_rw.hpp.

◆ write_

WritePort* LibXR::STDIO::write_ = nullptr
inlinestatic

Write port instance. 写入端口。

Definition at line 599 of file libxr_rw.hpp.

◆ write_mutex_

LibXR::Mutex* LibXR::STDIO::write_mutex_
inlinestatic
Initial value:
=
nullptr

Write port mutex. 写入端口互斥锁。

Definition at line 600 of file libxr_rw.hpp.

◆ write_stream_

LibXR::WritePort::Stream* LibXR::STDIO::write_stream_ = nullptr
inlinestatic

Definition at line 602 of file libxr_rw.hpp.


The documentation for this class was generated from the following files: