mirror of
https://codeberg.org/la-chouette/minishell.git
synced 2025-12-06 07:28:09 +01:00
quote removal: handle non-nested quotes
This commit is contained in:
parent
7b76c1a71f
commit
a3d2143b8b
2 changed files with 43 additions and 6 deletions
|
|
@ -6,12 +6,14 @@
|
||||||
/* By: khais <marvin@42.fr> +#+ +:+ +#+ */
|
/* By: khais <marvin@42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2025/02/28 13:52:02 by khais #+# #+# */
|
/* Created: 2025/02/28 13:52:02 by khais #+# #+# */
|
||||||
/* Updated: 2025/03/07 11:09:30 by khais ### ########.fr */
|
/* Updated: 2025/03/07 11:13:49 by khais ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
#include "remove_quotes.h"
|
#include "remove_quotes.h"
|
||||||
#include "libft.h"
|
#include "../../buffer/buffer.h"
|
||||||
|
#include "../matchers/quote.h"
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** use the marker in the given worddesc to create a new worddesc by removing
|
** use the marker in the given worddesc to create a new worddesc by removing
|
||||||
|
|
@ -20,15 +22,28 @@
|
||||||
** The new worddesc will have the marker set to NULL.
|
** The new worddesc will have the marker set to NULL.
|
||||||
**
|
**
|
||||||
** If word is null return null.
|
** If word is null return null.
|
||||||
|
**
|
||||||
|
** In case of allocation failure, return null
|
||||||
*/
|
*/
|
||||||
t_worddesc *remove_quotes(t_worddesc *word)
|
t_worddesc *remove_quotes(t_worddesc *word)
|
||||||
{
|
{
|
||||||
t_worddesc *output;
|
t_worddesc *output;
|
||||||
|
t_buffer *buf;
|
||||||
|
size_t i;
|
||||||
|
|
||||||
if (word == NULL)
|
if (word == NULL)
|
||||||
return (NULL);
|
return (NULL);
|
||||||
output = worddesc_create(ft_strdup(word->word), word->flags, NULL);
|
buf = ft_buffer_new();
|
||||||
if (output->word == NULL)
|
i = 0;
|
||||||
return (worddesc_destroy(output), NULL);
|
while (word->word[i] != '\0')
|
||||||
|
{
|
||||||
|
if (!is_quote(word->word[i]))
|
||||||
|
buf = ft_buffer_pushchar(buf, word->word[i]);
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
if (buf == NULL)
|
||||||
|
return (NULL);
|
||||||
|
output = worddesc_create(buf->buffer, word->flags, NULL);
|
||||||
|
free(buf);
|
||||||
return (output);
|
return (output);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -6,7 +6,7 @@
|
||||||
/* By: khais <marvin@42.fr> +#+ +:+ +#+ */
|
/* By: khais <marvin@42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2025/02/28 13:46:56 by khais #+# #+# */
|
/* Created: 2025/02/28 13:46:56 by khais #+# #+# */
|
||||||
/* Updated: 2025/03/07 11:07:59 by khais ### ########.fr */
|
/* Updated: 2025/03/07 11:14:48 by khais ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
|
@ -42,8 +42,30 @@ static void test_quote_removal_null(void)
|
||||||
assert(got_word == NULL);
|
assert(got_word == NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void test_quote_removal_single_quotes(void)
|
||||||
|
{
|
||||||
|
t_worddesc *word = create_single_word("'word'");
|
||||||
|
t_worddesc *got_word = remove_quotes(word);
|
||||||
|
assert_strequal("word", got_word->word);
|
||||||
|
assert(got_word->marker == NULL);
|
||||||
|
worddesc_destroy(word);
|
||||||
|
worddesc_destroy(got_word);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void test_quote_removal_double_quotes(void)
|
||||||
|
{
|
||||||
|
t_worddesc *word = create_single_word("\"word\"");
|
||||||
|
t_worddesc *got_word = remove_quotes(word);
|
||||||
|
assert_strequal("word", got_word->word);
|
||||||
|
assert(got_word->marker == NULL);
|
||||||
|
worddesc_destroy(word);
|
||||||
|
worddesc_destroy(got_word);
|
||||||
|
}
|
||||||
|
|
||||||
int main(void) {
|
int main(void) {
|
||||||
test_quote_removal_no_quotes_single_word();
|
test_quote_removal_no_quotes_single_word();
|
||||||
test_quote_removal_null();
|
test_quote_removal_null();
|
||||||
|
test_quote_removal_single_quotes();
|
||||||
|
test_quote_removal_double_quotes();
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue