From 79f7f793efb637f95fa4a619e79792abd3caefa8 Mon Sep 17 00:00:00 2001 From: IsaacShelton Date: Thu, 17 Oct 2024 21:44:04 -0500 Subject: [PATCH] Fixed issue with strings from header files not being resolved to C-style strings --- src/c/parser/expr.rs | 1 + src/c/translation/expr/string.rs | 5 ++++- 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/src/c/parser/expr.rs b/src/c/parser/expr.rs index 56c49189..0ef79c67 100644 --- a/src/c/parser/expr.rs +++ b/src/c/parser/expr.rs @@ -240,6 +240,7 @@ impl<'a> Parser<'a> { if let CTokenKind::StringLiteral(encoding, string) = &self.input.peek().kind { let string = string.clone(); let encoding = encoding.clone(); + self.input.advance(); return Ok(ExprKind::StringLiteral(encoding, string).at(source)); } diff --git a/src/c/translation/expr/string.rs b/src/c/translation/expr/string.rs index 86b2834d..aa61c03a 100644 --- a/src/c/translation/expr/string.rs +++ b/src/c/translation/expr/string.rs @@ -3,6 +3,7 @@ use crate::{ c::{encoding::Encoding, parser::ParseError}, source_files::Source, }; +use std::ffi::CString; pub fn translate_expr_string( encoding: &Encoding, @@ -10,7 +11,9 @@ pub fn translate_expr_string( source: Source, ) -> Result { if let Encoding::Default = encoding { - return Ok(ast::ExprKind::String(content.into()).at(source)); + // TODO: Add proper error message? + let content = CString::new(content).expect("valid null-terminated string"); + return Ok(ast::ExprKind::NullTerminatedString(content).at(source)); } todo!("translate non-default encoding C string")