xaizek / vifm (License: GPLv2+) (since 2018-12-07)
Vifm is a file manager with curses interface, which provides Vi[m]-like environment for managing objects within file systems, extended with some useful ideas from mutt.
<root> / tests / parsing / grouping.c (e971f0d2ff57be20c3f15c9ca15b27fd9da6b105) (1,195B) (mode 100644) [raw]
#include <stic.h>

#include "../../src/engine/parsing.h"
#include "../../src/engine/variables.h"
#include "../../src/engine/var.h"

#include "asserts.h"

TEST(wrong_paren_syntax)
{
	ASSERT_FAIL("(", PE_MISSING_PAREN);
	ASSERT_FAIL(")", PE_INVALID_EXPRESSION);
	ASSERT_FAIL("(0", PE_MISSING_PAREN);
	ASSERT_FAIL("0)", PE_INVALID_EXPRESSION);
	ASSERT_FAIL("()", PE_INVALID_EXPRESSION);
}

TEST(whitespace_in_parens)
{
	ASSERT_OK("(1)", "1");
	ASSERT_OK("( 1)", "1");
	ASSERT_OK("(1 )", "1");
	ASSERT_OK("( 1 )", "1");
	ASSERT_OK(" (1)", "1");
	ASSERT_OK("(1) ", "1");
	ASSERT_OK(" (1) ", "1");
}

TEST(nesting)
{
	ASSERT_OK("('a')", "a");
	ASSERT_OK("(('a'))", "a");
	ASSERT_OK("((('a')))", "a");
}

TEST(grouping_works)
{
	ASSERT_OK("(1 + 2 + 3)", "6");
	ASSERT_OK("(1 + 2) + 3", "6");
	ASSERT_OK("1 + (2 + 3)", "6");
	ASSERT_OK("1 + (2) + 3", "6");

	ASSERT_OK("(1 - 2 - 3)", "-4");
	ASSERT_OK("(1 - 2) - 3", "-4");
	ASSERT_OK("1 - (2 - 3)", "2");
	ASSERT_OK("1 - (2) - 3", "-4");

	ASSERT_OK("-(2)", "-2");
	ASSERT_OK("-(-2)", "2");

	ASSERT_OK("(1 + 2).'2'", "32");
}

/* vim: set tabstop=2 softtabstop=2 shiftwidth=2 noexpandtab cinoptions-=(0 : */
/* vim: set cinoptions+=t0 filetype=c : */
Hints

Before first commit, do not forget to setup your git environment:
git config --global user.name "your_name_here"
git config --global user.email "your@email_here"

Clone this repository using HTTP(S):
git clone https://code.reversed.top/user/xaizek/vifm

Clone this repository using ssh (do not forget to upload a key first):
git clone ssh://rocketgit@code.reversed.top/user/xaizek/vifm

You are allowed to anonymously push to this repository.
This means that your pushed commits will automatically be transformed into a pull request:
... clone the repository ...
... make some changes and some commits ...
git push origin master