LCOV - code coverage report
Current view: top level - libs/proxy/tokio-postgres2/src - codec.rs (source / functions) Coverage Total Hit
Test: 915229b2d22dd355ad718d9afbb773e7f2fba970.info Lines: 12.1 % 33 4
Test Date: 2025-07-24 10:33:41 Functions: 25.0 % 4 1

            Line data    Source code
       1              : use std::io;
       2              : 
       3              : use bytes::{Bytes, BytesMut};
       4              : use fallible_iterator::FallibleIterator;
       5              : use postgres_protocol2::message::backend;
       6              : use tokio::sync::mpsc::UnboundedSender;
       7              : use tokio_util::codec::{Decoder, Encoder};
       8              : 
       9              : pub enum FrontendMessage {
      10              :     Raw(Bytes),
      11              :     RecordNotices(RecordNotices),
      12              : }
      13              : 
      14              : pub struct RecordNotices {
      15              :     pub sender: UnboundedSender<Box<str>>,
      16              :     pub limit: usize,
      17              : }
      18              : 
      19              : pub enum BackendMessage {
      20              :     Normal { messages: BackendMessages },
      21              :     Async(backend::Message),
      22              : }
      23              : 
      24              : pub struct BackendMessages(BytesMut);
      25              : 
      26              : impl BackendMessages {
      27            0 :     pub fn empty() -> BackendMessages {
      28            0 :         BackendMessages(BytesMut::new())
      29            0 :     }
      30              : }
      31              : 
      32              : impl FallibleIterator for BackendMessages {
      33              :     type Item = backend::Message;
      34              :     type Error = io::Error;
      35              : 
      36            0 :     fn next(&mut self) -> io::Result<Option<backend::Message>> {
      37            0 :         backend::Message::parse(&mut self.0)
      38            0 :     }
      39              : }
      40              : 
      41              : pub struct PostgresCodec;
      42              : 
      43              : impl Encoder<Bytes> for PostgresCodec {
      44              :     type Error = io::Error;
      45              : 
      46           36 :     fn encode(&mut self, item: Bytes, dst: &mut BytesMut) -> io::Result<()> {
      47           36 :         dst.extend_from_slice(&item);
      48           36 :         Ok(())
      49           36 :     }
      50              : }
      51              : 
      52              : impl Decoder for PostgresCodec {
      53              :     type Item = BackendMessage;
      54              :     type Error = io::Error;
      55              : 
      56            0 :     fn decode(&mut self, src: &mut BytesMut) -> Result<Option<BackendMessage>, io::Error> {
      57            0 :         let mut idx = 0;
      58              : 
      59            0 :         while let Some(header) = backend::Header::parse(&src[idx..])? {
      60            0 :             let len = header.len() as usize + 1;
      61            0 :             if src[idx..].len() < len {
      62            0 :                 break;
      63            0 :             }
      64              : 
      65            0 :             match header.tag() {
      66              :                 backend::NOTICE_RESPONSE_TAG
      67              :                 | backend::NOTIFICATION_RESPONSE_TAG
      68              :                 | backend::PARAMETER_STATUS_TAG => {
      69            0 :                     if idx == 0 {
      70            0 :                         let message = backend::Message::parse(src)?.unwrap();
      71            0 :                         return Ok(Some(BackendMessage::Async(message)));
      72              :                     } else {
      73            0 :                         break;
      74              :                     }
      75              :                 }
      76            0 :                 _ => {}
      77              :             }
      78              : 
      79            0 :             idx += len;
      80              : 
      81            0 :             if header.tag() == backend::READY_FOR_QUERY_TAG {
      82            0 :                 break;
      83            0 :             }
      84              :         }
      85              : 
      86            0 :         if idx == 0 {
      87            0 :             Ok(None)
      88              :         } else {
      89            0 :             Ok(Some(BackendMessage::Normal {
      90            0 :                 messages: BackendMessages(src.split_to(idx)),
      91            0 :             }))
      92              :         }
      93            0 :     }
      94              : }
        

Generated by: LCOV version 2.1-beta