-/* Copyright (C) 1995,1996,1998 Free Software Foundation, Inc.
+/* Copyright (C) 1995,1996,1998, 2000, 2001 Free Software Foundation, Inc.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* If you write modifications of your own for GUILE, it is your choice
* whether to permit this exception to apply to your modifications.
* If you do not wish that, delete this exception notice. */
-\f
-#include <stdio.h>
-#include <ctype.h>
-#include "_scm.h"
-#include "chars.h"
\f
+#include <ctype.h>
+#include "libguile/_scm.h"
+#include "libguile/validate.h"
+#include "libguile/chars.h"
+\f
-SCM_PROC(s_char_p, "char?", 1, 0, 0, scm_char_p);
-
-SCM
-scm_char_p(x)
- SCM x;
+SCM_DEFINE (scm_char_p, "char?", 1, 0, 0,
+ (SCM x),
+ "Return @code{#t} iff @var{x} is a character, else @code{#f}.")
+#define FUNC_NAME s_scm_char_p
{
- return SCM_ICHRP(x) ? SCM_BOOL_T : SCM_BOOL_F;
+ return SCM_BOOL(SCM_CHARP(x));
}
+#undef FUNC_NAME
-SCM_PROC1 (s_char_eq_p, "char=?", scm_tc7_rpsubr, scm_char_eq_p);
-
-SCM
-scm_char_eq_p(x, y)
- SCM x;
- SCM y;
+SCM_DEFINE1 (scm_char_eq_p, "char=?", scm_tc7_rpsubr,
+ (SCM x, SCM y),
+ "Return @code{#t} iff @var{x} is the same character as @var{y}, else @code{#f}.")
+#define FUNC_NAME s_scm_char_eq_p
{
- SCM_ASSERT(SCM_ICHRP(x), x, SCM_ARG1, s_char_eq_p);
- SCM_ASSERT(SCM_ICHRP(y), y, SCM_ARG2, s_char_eq_p);
- return (SCM_ICHR(x) == SCM_ICHR(y)) ? SCM_BOOL_T : SCM_BOOL_F;
+ SCM_VALIDATE_CHAR (1, x);
+ SCM_VALIDATE_CHAR (2, y);
+ return SCM_BOOL (SCM_EQ_P (x, y));
}
+#undef FUNC_NAME
-SCM_PROC1 (s_char_less_p, "char<?", scm_tc7_rpsubr, scm_char_less_p);
-
-SCM
-scm_char_less_p(x, y)
- SCM x;
- SCM y;
+SCM_DEFINE1 (scm_char_less_p, "char<?", scm_tc7_rpsubr,
+ (SCM x, SCM y),
+ "Return @code{#t} iff @var{x} is less than @var{y} in the ASCII sequence,\n"
+ "else @code{#f}.")
+#define FUNC_NAME s_scm_char_less_p
{
- SCM_ASSERT(SCM_ICHRP(x), x, SCM_ARG1, s_char_less_p);
- SCM_ASSERT(SCM_ICHRP(y), y, SCM_ARG2, s_char_less_p);
- return (SCM_ICHR(x) < SCM_ICHR(y)) ? SCM_BOOL_T : SCM_BOOL_F;
+ SCM_VALIDATE_CHAR (1,x);
+ SCM_VALIDATE_CHAR (2,y);
+ return SCM_BOOL(SCM_CHAR(x) < SCM_CHAR(y));
}
+#undef FUNC_NAME
-SCM_PROC1 (s_char_leq_p, "char<=?", scm_tc7_rpsubr, scm_char_leq_p);
-
-SCM
-scm_char_leq_p(x, y)
- SCM x;
- SCM y;
+SCM_DEFINE1 (scm_char_leq_p, "char<=?", scm_tc7_rpsubr,
+ (SCM x, SCM y),
+ "Return @code{#t} iff @var{x} is less than or equal to @var{y} in the\n"
+ "ASCII sequence, else @code{#f}.")
+#define FUNC_NAME s_scm_char_leq_p
{
- SCM_ASSERT(SCM_ICHRP(x), x, SCM_ARG1, s_char_leq_p);
- SCM_ASSERT(SCM_ICHRP(y), y, SCM_ARG2, s_char_leq_p);
- return (SCM_ICHR(x) <= SCM_ICHR(y)) ? SCM_BOOL_T : SCM_BOOL_F;
+ SCM_VALIDATE_CHAR (1,x);
+ SCM_VALIDATE_CHAR (2,y);
+ return SCM_BOOL(SCM_CHAR(x) <= SCM_CHAR(y));
}
+#undef FUNC_NAME
-SCM_PROC1 (s_char_gr_p, "char>?", scm_tc7_rpsubr, scm_char_gr_p);
-
-SCM
-scm_char_gr_p(x, y)
- SCM x;
- SCM y;
+SCM_DEFINE1 (scm_char_gr_p, "char>?", scm_tc7_rpsubr,
+ (SCM x, SCM y),
+ "Return @code{#t} iff @var{x} is greater than @var{y} in the ASCII\n"
+ "sequence, else @code{#f}.")
+#define FUNC_NAME s_scm_char_gr_p
{
- SCM_ASSERT(SCM_ICHRP(x), x, SCM_ARG1, s_char_gr_p);
- SCM_ASSERT(SCM_ICHRP(y), y, SCM_ARG2, s_char_gr_p);
- return (SCM_ICHR(x) > SCM_ICHR(y)) ? SCM_BOOL_T : SCM_BOOL_F;
+ SCM_VALIDATE_CHAR (1,x);
+ SCM_VALIDATE_CHAR (2,y);
+ return SCM_BOOL(SCM_CHAR(x) > SCM_CHAR(y));
}
+#undef FUNC_NAME
-SCM_PROC1 (s_char_geq_p, "char>=?", scm_tc7_rpsubr, scm_char_geq_p);
-
-SCM
-scm_char_geq_p(x, y)
- SCM x;
- SCM y;
+SCM_DEFINE1 (scm_char_geq_p, "char>=?", scm_tc7_rpsubr,
+ (SCM x, SCM y),
+ "Return @code{#t} iff @var{x} is greater than or equal to @var{y} in the\n"
+ "ASCII sequence, else @code{#f}.")
+#define FUNC_NAME s_scm_char_geq_p
{
- SCM_ASSERT(SCM_ICHRP(x), x, SCM_ARG1, s_char_geq_p);
- SCM_ASSERT(SCM_ICHRP(y), y, SCM_ARG2, s_char_geq_p);
- return (SCM_ICHR(x) >= SCM_ICHR(y)) ? SCM_BOOL_T : SCM_BOOL_F;
+ SCM_VALIDATE_CHAR (1,x);
+ SCM_VALIDATE_CHAR (2,y);
+ return SCM_BOOL(SCM_CHAR(x) >= SCM_CHAR(y));
}
+#undef FUNC_NAME
-SCM_PROC1 (s_char_ci_eq_p, "char-ci=?", scm_tc7_rpsubr, scm_char_ci_eq_p);
-
-SCM
-scm_char_ci_eq_p(x, y)
- SCM x;
- SCM y;
+SCM_DEFINE1 (scm_char_ci_eq_p, "char-ci=?", scm_tc7_rpsubr,
+ (SCM x, SCM y),
+ "Return @code{#t} iff @var{x} is the same character as @var{y} ignoring\n"
+ "case, else @code{#f}.")
+#define FUNC_NAME s_scm_char_ci_eq_p
{
- SCM_ASSERT(SCM_ICHRP(x), x, SCM_ARG1, s_char_ci_eq_p);
- SCM_ASSERT(SCM_ICHRP(y), y, SCM_ARG2, s_char_ci_eq_p);
- return (scm_upcase(SCM_ICHR(x))==scm_upcase(SCM_ICHR(y))) ? SCM_BOOL_T : SCM_BOOL_F;
+ SCM_VALIDATE_CHAR (1,x);
+ SCM_VALIDATE_CHAR (2,y);
+ return SCM_BOOL(scm_upcase(SCM_CHAR(x))==scm_upcase(SCM_CHAR(y)));
}
+#undef FUNC_NAME
-SCM_PROC1 (s_char_ci_less_p, "char-ci<?", scm_tc7_rpsubr, scm_char_ci_less_p);
-
-SCM
-scm_char_ci_less_p(x, y)
- SCM x;
- SCM y;
+SCM_DEFINE1 (scm_char_ci_less_p, "char-ci<?", scm_tc7_rpsubr,
+ (SCM x, SCM y),
+ "Return @code{#t} iff @var{x} is less than @var{y} in the ASCII sequence\n"
+ "ignoring case, else @code{#f}.")
+#define FUNC_NAME s_scm_char_ci_less_p
{
- SCM_ASSERT(SCM_ICHRP(x), x, SCM_ARG1, s_char_ci_less_p);
- SCM_ASSERT(SCM_ICHRP(y), y, SCM_ARG2, s_char_ci_less_p);
- return (scm_upcase(SCM_ICHR(x)) < scm_upcase(SCM_ICHR(y))) ? SCM_BOOL_T : SCM_BOOL_F;
+ SCM_VALIDATE_CHAR (1,x);
+ SCM_VALIDATE_CHAR (2,y);
+ return SCM_BOOL((scm_upcase(SCM_CHAR(x))) < scm_upcase(SCM_CHAR(y)));
}
+#undef FUNC_NAME
-SCM_PROC1 (s_char_ci_leq_p, "char-ci<=?", scm_tc7_rpsubr, scm_char_ci_leq_p);
-
-SCM
-scm_char_ci_leq_p(x, y)
- SCM x;
- SCM y;
+SCM_DEFINE1 (scm_char_ci_leq_p, "char-ci<=?", scm_tc7_rpsubr,
+ (SCM x, SCM y),
+ "Return @code{#t} iff @var{x} is less than or equal to @var{y} in the\n"
+ "ASCII sequence ignoring case, else @code{#f}.")
+#define FUNC_NAME s_scm_char_ci_leq_p
{
- SCM_ASSERT(SCM_ICHRP(x), x, SCM_ARG1, s_char_ci_leq_p);
- SCM_ASSERT(SCM_ICHRP(y), y, SCM_ARG2, s_char_ci_leq_p);
- return (scm_upcase(SCM_ICHR(x)) <= scm_upcase(SCM_ICHR(y))) ? SCM_BOOL_T : SCM_BOOL_F;
+ SCM_VALIDATE_CHAR (1,x);
+ SCM_VALIDATE_CHAR (2,y);
+ return SCM_BOOL(scm_upcase(SCM_CHAR(x)) <= scm_upcase(SCM_CHAR(y)));
}
+#undef FUNC_NAME
-SCM_PROC1 (s_char_ci_gr_p, "char-ci>?", scm_tc7_rpsubr, scm_char_ci_gr_p);
-
-SCM
-scm_char_ci_gr_p(x, y)
- SCM x;
- SCM y;
+SCM_DEFINE1 (scm_char_ci_gr_p, "char-ci>?", scm_tc7_rpsubr,
+ (SCM x, SCM y),
+ "Return @code{#t} iff @var{x} is greater than @var{y} in the ASCII\n"
+ "sequence ignoring case, else @code{#f}.")
+#define FUNC_NAME s_scm_char_ci_gr_p
{
- SCM_ASSERT(SCM_ICHRP(x), x, SCM_ARG1, s_char_ci_gr_p);
- SCM_ASSERT(SCM_ICHRP(y), y, SCM_ARG2, s_char_ci_gr_p);
- return (scm_upcase(SCM_ICHR(x)) > scm_upcase(SCM_ICHR(y))) ? SCM_BOOL_T : SCM_BOOL_F;
+ SCM_VALIDATE_CHAR (1,x);
+ SCM_VALIDATE_CHAR (2,y);
+ return SCM_BOOL(scm_upcase(SCM_CHAR(x)) > scm_upcase(SCM_CHAR(y)));
}
+#undef FUNC_NAME
-SCM_PROC1 (s_char_ci_geq_p, "char-ci>=?", scm_tc7_rpsubr, scm_char_ci_geq_p);
-
-SCM
-scm_char_ci_geq_p(x, y)
- SCM x;
- SCM y;
+SCM_DEFINE1 (scm_char_ci_geq_p, "char-ci>=?", scm_tc7_rpsubr,
+ (SCM x, SCM y),
+ "Return @code{#t} iff @var{x} is greater than or equal to @var{y} in the\n"
+ "ASCII sequence ignoring case, else @code{#f}.")
+#define FUNC_NAME s_scm_char_ci_geq_p
{
- SCM_ASSERT(SCM_ICHRP(x), x, SCM_ARG1, s_char_ci_geq_p);
- SCM_ASSERT(SCM_ICHRP(y), y, SCM_ARG2, s_char_ci_geq_p);
- return (scm_upcase(SCM_ICHR(x)) >= scm_upcase(SCM_ICHR(y))) ? SCM_BOOL_T : SCM_BOOL_F;
+ SCM_VALIDATE_CHAR (1,x);
+ SCM_VALIDATE_CHAR (2,y);
+ return SCM_BOOL(scm_upcase(SCM_CHAR(x)) >= scm_upcase(SCM_CHAR(y)));
}
+#undef FUNC_NAME
-SCM_PROC(s_char_alphabetic_p, "char-alphabetic?", 1, 0, 0, scm_char_alphabetic_p);
-
-SCM
-scm_char_alphabetic_p(chr)
- SCM chr;
+SCM_DEFINE (scm_char_alphabetic_p, "char-alphabetic?", 1, 0, 0,
+ (SCM chr),
+ "Return @code{#t} iff @var{chr} is alphabetic, else @code{#f}.\n"
+ "Alphabetic means the same thing as the isalpha C library function.")
+#define FUNC_NAME s_scm_char_alphabetic_p
{
- SCM_ASSERT(SCM_ICHRP(chr), chr, SCM_ARG1, s_char_alphabetic_p);
- return (isascii(SCM_ICHR(chr)) && isalpha(SCM_ICHR(chr))) ? SCM_BOOL_T : SCM_BOOL_F;
+ SCM_VALIDATE_CHAR (1,chr);
+ return SCM_BOOL(isascii(SCM_CHAR(chr)) && isalpha(SCM_CHAR(chr)));
}
+#undef FUNC_NAME
-SCM_PROC(s_char_numeric_p, "char-numeric?", 1, 0, 0, scm_char_numeric_p);
-
-SCM
-scm_char_numeric_p(chr)
- SCM chr;
+SCM_DEFINE (scm_char_numeric_p, "char-numeric?", 1, 0, 0,
+ (SCM chr),
+ "Return @code{#t} iff @var{chr} is numeric, else @code{#f}.\n"
+ "Numeric means the same thing as the isdigit C library function.")
+#define FUNC_NAME s_scm_char_numeric_p
{
- SCM_ASSERT(SCM_ICHRP(chr), chr, SCM_ARG1, s_char_numeric_p);
- return (isascii(SCM_ICHR(chr)) && isdigit(SCM_ICHR(chr))) ? SCM_BOOL_T : SCM_BOOL_F;
+ SCM_VALIDATE_CHAR (1,chr);
+ return SCM_BOOL(isascii(SCM_CHAR(chr)) && isdigit(SCM_CHAR(chr)));
}
+#undef FUNC_NAME
-SCM_PROC(s_char_whitespace_p, "char-whitespace?", 1, 0, 0, scm_char_whitespace_p);
-
-SCM
-scm_char_whitespace_p(chr)
- SCM chr;
+SCM_DEFINE (scm_char_whitespace_p, "char-whitespace?", 1, 0, 0,
+ (SCM chr),
+ "Return @code{#t} iff @var{chr} is whitespace, else @code{#f}.\n"
+ "Whitespace means the same thing as the isspace C library function.")
+#define FUNC_NAME s_scm_char_whitespace_p
{
- SCM_ASSERT(SCM_ICHRP(chr), chr, SCM_ARG1, s_char_whitespace_p);
- return (isascii(SCM_ICHR(chr)) && isspace(SCM_ICHR(chr))) ? SCM_BOOL_T : SCM_BOOL_F;
+ SCM_VALIDATE_CHAR (1,chr);
+ return SCM_BOOL(isascii(SCM_CHAR(chr)) && isspace(SCM_CHAR(chr)));
}
+#undef FUNC_NAME
-SCM_PROC(s_char_upper_case_p, "char-upper-case?", 1, 0, 0, scm_char_upper_case_p);
-
-SCM
-scm_char_upper_case_p(chr)
- SCM chr;
+SCM_DEFINE (scm_char_upper_case_p, "char-upper-case?", 1, 0, 0,
+ (SCM chr),
+ "Return @code{#t} iff @var{chr} is uppercase, else @code{#f}.\n"
+ "Uppercase means the same thing as the isupper C library function.")
+#define FUNC_NAME s_scm_char_upper_case_p
{
- SCM_ASSERT(SCM_ICHRP(chr), chr, SCM_ARG1, s_char_upper_case_p);
- return (isascii(SCM_ICHR(chr)) && isupper(SCM_ICHR(chr))) ? SCM_BOOL_T : SCM_BOOL_F;
+ SCM_VALIDATE_CHAR (1,chr);
+ return SCM_BOOL(isascii(SCM_CHAR(chr)) && isupper(SCM_CHAR(chr)));
}
+#undef FUNC_NAME
-SCM_PROC(s_char_lower_case_p, "char-lower-case?", 1, 0, 0, scm_char_lower_case_p);
-
-SCM
-scm_char_lower_case_p(chr)
- SCM chr;
+SCM_DEFINE (scm_char_lower_case_p, "char-lower-case?", 1, 0, 0,
+ (SCM chr),
+ "Return @code{#t} iff @var{chr} is lowercase, else @code{#f}.\n"
+ "Lowercase means the same thing as the islower C library function.")
+#define FUNC_NAME s_scm_char_lower_case_p
{
- SCM_ASSERT(SCM_ICHRP(chr), chr, SCM_ARG1, s_char_lower_case_p);
- return (isascii(SCM_ICHR(chr)) && islower(SCM_ICHR(chr))) ? SCM_BOOL_T : SCM_BOOL_F;
+ SCM_VALIDATE_CHAR (1,chr);
+ return SCM_BOOL(isascii(SCM_CHAR(chr)) && islower(SCM_CHAR(chr)));
}
+#undef FUNC_NAME
-SCM_PROC (s_char_is_both_p, "char-is-both?", 1, 0, 0, scm_char_is_both_p);
-
-SCM
-scm_char_is_both_p (chr)
- SCM chr;
+SCM_DEFINE (scm_char_is_both_p, "char-is-both?", 1, 0, 0,
+ (SCM chr),
+ "Return @code{#t} iff @var{chr} is either uppercase or lowercase, else @code{#f}.\n"
+ "Uppercase and lowercase are as defined by the isupper and islower\n"
+ "C library functions.")
+#define FUNC_NAME s_scm_char_is_both_p
{
- SCM_ASSERT(SCM_ICHRP(chr), chr, SCM_ARG1, s_char_upper_case_p);
- return ((isascii(SCM_ICHR(chr)) && (isupper(SCM_ICHR(chr)) || islower(SCM_ICHR(chr))))
- ? SCM_BOOL_T
- : SCM_BOOL_F);
+ SCM_VALIDATE_CHAR (1,chr);
+ return SCM_BOOL(isascii(SCM_CHAR(chr)) && (isupper(SCM_CHAR(chr)) || islower(SCM_CHAR(chr))));
}
+#undef FUNC_NAME
-SCM_PROC(s_char_to_integer, "char->integer", 1, 0, 0, scm_char_to_integer);
-
-SCM
-scm_char_to_integer(chr)
- SCM chr;
+SCM_DEFINE (scm_char_to_integer, "char->integer", 1, 0, 0,
+ (SCM chr),
+ "Return the number corresponding to ordinal position of @var{chr} in the\n"
+ "ASCII sequence.")
+#define FUNC_NAME s_scm_char_to_integer
{
- SCM_ASSERT(SCM_ICHRP(chr), chr, SCM_ARG1, s_char_to_integer);
- return scm_ulong2num((unsigned long)SCM_ICHR(chr));
+ SCM_VALIDATE_CHAR (1,chr);
+ return scm_ulong2num((unsigned long)SCM_CHAR(chr));
}
+#undef FUNC_NAME
-SCM_PROC(s_integer_to_char, "integer->char", 1, 0, 0, scm_integer_to_char);
-
-SCM
-scm_integer_to_char(n)
- SCM n;
+SCM_DEFINE (scm_integer_to_char, "integer->char", 1, 0, 0,
+ (SCM n),
+ "Return the character at position @var{n} in the ASCII sequence.")
+#define FUNC_NAME s_scm_integer_to_char
{
- unsigned long ni;
-
- ni = 0xffff & scm_num2ulong (n, (char *)SCM_ARG1, s_integer_to_char);
- return SCM_MAKICHR(SCM_INUM(n));
+ SCM_VALIDATE_INUM_RANGE (1, n, 0, 256);
+ return SCM_MAKE_CHAR (SCM_INUM (n));
}
+#undef FUNC_NAME
-SCM_PROC(s_char_upcase, "char-upcase", 1, 0, 0, scm_char_upcase);
-
-SCM
-scm_char_upcase(chr)
- SCM chr;
+SCM_DEFINE (scm_char_upcase, "char-upcase", 1, 0, 0,
+ (SCM chr),
+ "Return the uppercase character version of @var{chr}.")
+#define FUNC_NAME s_scm_char_upcase
{
- SCM_ASSERT(SCM_ICHRP(chr), chr, SCM_ARG1, s_char_upcase);
- return SCM_MAKICHR(scm_upcase(SCM_ICHR(chr)));
+ SCM_VALIDATE_CHAR (1,chr);
+ return SCM_MAKE_CHAR(scm_upcase(SCM_CHAR(chr)));
}
+#undef FUNC_NAME
-SCM_PROC(s_char_downcase, "char-downcase", 1, 0, 0, scm_char_downcase);
-
-SCM
-scm_char_downcase(chr)
- SCM chr;
+SCM_DEFINE (scm_char_downcase, "char-downcase", 1, 0, 0,
+ (SCM chr),
+ "Return the lowercase character version of @var{chr}.")
+#define FUNC_NAME s_scm_char_downcase
{
- SCM_ASSERT(SCM_ICHRP(chr), chr, SCM_ARG1, s_char_downcase);
- return SCM_MAKICHR(scm_downcase(SCM_ICHR(chr)));
+ SCM_VALIDATE_CHAR (1,chr);
+ return SCM_MAKE_CHAR(scm_downcase(SCM_CHAR(chr)));
}
+#undef FUNC_NAME
\f
int
-scm_upcase (c)
- unsigned int c;
+scm_upcase (unsigned int c)
{
if (c < sizeof (scm_upcase_table))
return scm_upcase_table[c];
int
-scm_downcase (c)
- unsigned int c;
+scm_downcase (unsigned int c)
{
if (c < sizeof (scm_downcase_table))
return scm_downcase_table[c];
void
scm_init_chars ()
{
-#include "chars.x"
+#ifndef SCM_MAGIC_SNARFER
+#include "libguile/chars.x"
+#endif
}
+
+/*
+ Local Variables:
+ c-file-style: "gnu"
+ End:
+*/