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 619 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 380 of file libxr_rw.cpp.

381{
382#if LIBXR_PRINTF_BUFFER_SIZE > 0
383 if (!STDIO::write_ || !STDIO::write_->Writable())
384 {
385 return -1;
386 }
387
388 if (!write_mutex_)
389 {
391 }
392
394
395 va_list args;
396 va_start(args, fmt);
397 int len = vsnprintf(STDIO::printf_buff_, LIBXR_PRINTF_BUFFER_SIZE, fmt, args);
398 va_end(args);
399
400 // Check result and limit length
401 if (len < 0)
402 {
403 return -1;
404 }
405 if (static_cast<size_t>(len) >= LIBXR_PRINTF_BUFFER_SIZE)
406 {
407 len = LIBXR_PRINTF_BUFFER_SIZE - 1;
408 }
409
410 ConstRawData data = {reinterpret_cast<const uint8_t*>(STDIO::printf_buff_),
411 static_cast<size_t>(len)};
412
413 static WriteOperation op; // NOLINT
414 auto ans = ErrorCode::OK;
415 if (write_stream_ == nullptr)
416 {
417 ans = STDIO::write_->operator()(data, op);
418 }
419 else
420 {
421 (*write_stream_) << data;
422 ans = write_stream_->Commit();
423 }
424
425 if (ans == ErrorCode::OK)
426 {
427 return len;
428 }
429 else
430 {
431 return -1;
432 }
433
434#else
435 UNUSED(fmt);
436 return 0;
437#endif
438}
常量原始数据封装类。 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:625
static WritePort * write_
Write port instance. 写入端口。
Definition libxr_rw.hpp:624
ErrorCode Commit()
手动提交已写入的数据到队列,并尝试续锁。
Definition libxr_rw.cpp:353

Field Documentation

◆ read_

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

Read port instance. 读取端口。

Definition at line 623 of file libxr_rw.hpp.

◆ write_

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

Write port instance. 写入端口。

Definition at line 624 of file libxr_rw.hpp.

◆ write_mutex_

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

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

Definition at line 625 of file libxr_rw.hpp.

◆ write_stream_

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

Definition at line 627 of file libxr_rw.hpp.


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