mirror of
https://forge.sourceware.org/marek/gcc.git
synced 2026-02-22 03:47:02 -05:00
Signed-off-by: Jose E. Marchesi <jemarch@gnu.org> gcc/ChangeLog * algol68/a68-low-bits.cc: New file. * algol68/a68-low-bools.cc: Likewise. * algol68/a68-low-chars.cc: Likewise. * algol68/a68-low-complex.cc: Likewise. * algol68/a68-low-ints.cc: Likewise. * algol68/a68-low-procs.cc: Likewise. * algol68/a68-low-reals.cc: Likewise. * algol68/a68-low-refs.cc: Likewise. * algol68/a68-low-strings.cc: Likewise.
78 lines
1.9 KiB
C++
78 lines
1.9 KiB
C++
/* Lowering routines for all things related to BOOL values.
|
|
Copyright (C) 2025 Jose E. Marchesi.
|
|
|
|
Written by Jose E. Marchesi.
|
|
|
|
GCC is free software; you can redistribute it and/or modify it
|
|
under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 3, or (at your option)
|
|
any later version.
|
|
|
|
GCC is distributed in the hope that it will be useful, but WITHOUT
|
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
|
|
License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with GCC; see the file COPYING3. If not see
|
|
<http://www.gnu.org/licenses/>. */
|
|
|
|
#define INCLUDE_MEMORY
|
|
#include "config.h"
|
|
#include "system.h"
|
|
#include "coretypes.h"
|
|
|
|
#include "tree.h"
|
|
#include "fold-const.h"
|
|
#include "diagnostic.h"
|
|
#include "langhooks.h"
|
|
#include "tm.h"
|
|
#include "function.h"
|
|
#include "cgraph.h"
|
|
#include "toplev.h"
|
|
#include "varasm.h"
|
|
#include "predict.h"
|
|
#include "stor-layout.h"
|
|
#include "tree-iterator.h"
|
|
#include "stringpool.h"
|
|
#include "print-tree.h"
|
|
#include "gimplify.h"
|
|
#include "dumpfile.h"
|
|
#include "convert.h"
|
|
|
|
#include "a68.h"
|
|
|
|
/* Return a tree with the yielind of SKIP of a BOOL mode. */
|
|
|
|
tree
|
|
a68_get_bool_skip_tree (void)
|
|
{
|
|
return build_int_cst (a68_bool_type, 0);
|
|
}
|
|
|
|
/* The absolute value of a BOOL is a non-zero INT for TRUE and zero for
|
|
FALSE. */
|
|
|
|
tree
|
|
a68_bool_abs (tree val)
|
|
{
|
|
return fold_convert (a68_int_type, val);
|
|
}
|
|
|
|
/* Given two boolean values, build an expression that calculates whether A = B. */
|
|
|
|
tree
|
|
a68_bool_eq (tree a, tree b, location_t loc)
|
|
{
|
|
return fold_build2_loc (loc, EQ_EXPR, boolean_type_node, a, b);
|
|
}
|
|
|
|
/* Given two boolean values, build an expression that calculates whether A /=
|
|
B. */
|
|
|
|
tree
|
|
a68_bool_ne (tree a, tree b, location_t loc)
|
|
{
|
|
return fold_build2_loc (loc, NE_EXPR, boolean_type_node, a, b);
|
|
}
|