Sophie

Sophie

distrib > Mageia > 7 > armv7hl > media > core-updates > by-pkgid > 0448c66ab6afa2f787658c5e6488e2d9 > files > 3215

libstdc++-docs-8.3.1-0.20191101.1.mga7.noarch.rpm

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
<meta name="generator" content="Doxygen 1.8.15"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>libstdc++: std::ctype&lt; char &gt; Class Template Reference</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="dynsections.js"></script>
<link href="navtree.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="resize.js"></script>
<script type="text/javascript" src="navtreedata.js"></script>
<script type="text/javascript" src="navtree.js"></script>
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&amp;dn=gpl-2.0.txt GPL-v2 */
  $(document).ready(initResizable);
/* @license-end */</script>
<link href="doxygen.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
 <tbody>
 <tr style="height: 56px;">
  <td id="projectalign" style="padding-left: 0.5em;">
   <div id="projectname">libstdc++
   </div>
  </td>
 </tr>
 </tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.15 -->
</div><!-- top -->
<div id="side-nav" class="ui-resizable side-nav-resizable">
  <div id="nav-tree">
    <div id="nav-tree-contents">
      <div id="nav-sync" class="sync"></div>
    </div>
  </div>
  <div id="splitbar" style="-moz-user-select:none;" 
       class="ui-resizable-handle">
  </div>
</div>
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&amp;dn=gpl-2.0.txt GPL-v2 */
$(document).ready(function(){initNavTree('a05860.html','');});
/* @license-end */
</script>
<div id="doc-content">
<div class="header">
  <div class="summary">
<a href="#pub-types">Public Types</a> &#124;
<a href="#pub-methods">Public Member Functions</a> &#124;
<a href="#pub-static-methods">Static Public Member Functions</a> &#124;
<a href="#pub-static-attribs">Static Public Attributes</a> &#124;
<a href="#pro-methods">Protected Member Functions</a> &#124;
<a href="#pro-static-methods">Static Protected Member Functions</a> &#124;
<a href="#pro-attribs">Protected Attributes</a> &#124;
<a href="a05857.html">List of all members</a>  </div>
  <div class="headertitle">
<div class="title">std::ctype&lt; char &gt; Class Template Reference<div class="ingroups"><a class="el" href="a01489.html">Locales</a></div></div>  </div>
</div><!--header-->
<div class="contents">
<div class="dynheader">
Inheritance diagram for std::ctype&lt; char &gt;:</div>
<div class="dyncontent">
<div class="center"><iframe scrolling="no" frameborder="0" src="a05859.svg" width="251" height="196"><p><b>This browser is not able to show SVG: try Firefox, Chrome, Safari, or Opera instead.</b></p></iframe>
</div>
<center><span class="legend">[<a target="top" href="graph_legend.html">legend</a>]</span></center></div>
<table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-types"></a>
Public Types</h2></td></tr>
<tr class="memitem:a5f48720a9ce7a65c85c3eadb6be509f9"><td class="memItemLeft" align="right" valign="top"><a id="a5f48720a9ce7a65c85c3eadb6be509f9"></a>
typedef const int *&#160;</td><td class="memItemRight" valign="bottom"><b>__to_type</b></td></tr>
<tr class="separator:a5f48720a9ce7a65c85c3eadb6be509f9"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a28f3c847c9453a72212fdf3c2d186e4a"><td class="memItemLeft" align="right" valign="top">typedef char&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a></td></tr>
<tr class="separator:a28f3c847c9453a72212fdf3c2d186e4a"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a3b4ec6a3bdbe8e685eb129460ace4f79"><td class="memItemLeft" align="right" valign="top"><a id="a3b4ec6a3bdbe8e685eb129460ace4f79"></a>
typedef unsigned short&#160;</td><td class="memItemRight" valign="bottom"><b>mask</b></td></tr>
<tr class="separator:a3b4ec6a3bdbe8e685eb129460ace4f79"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-methods"></a>
Public Member Functions</h2></td></tr>
<tr class="memitem:acf81454de90c003b463e19f8703c1cbb"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#acf81454de90c003b463e19f8703c1cbb">ctype</a> (const mask *__table=0, bool __del=false, size_t __refs=0)</td></tr>
<tr class="separator:acf81454de90c003b463e19f8703c1cbb"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a00afd225d281cd0a8cd3f35611dd91f9"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#a00afd225d281cd0a8cd3f35611dd91f9">ctype</a> (__c_locale __cloc, const mask *__table=0, bool __del=false, size_t __refs=0)</td></tr>
<tr class="separator:a00afd225d281cd0a8cd3f35611dd91f9"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a966c54a29d5fb4424486f74ceacaed4a"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#a966c54a29d5fb4424486f74ceacaed4a">is</a> (mask __m, char __c) const</td></tr>
<tr class="separator:a966c54a29d5fb4424486f74ceacaed4a"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a3f98c7b3851c877d90a1c55102506b30"><td class="memItemLeft" align="right" valign="top">const char *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#a3f98c7b3851c877d90a1c55102506b30">is</a> (const char *__lo, const char *__hi, mask *__vec) const</td></tr>
<tr class="separator:a3f98c7b3851c877d90a1c55102506b30"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a9ea185aec61cbd0161c6530aa8ee16f1"><td class="memItemLeft" align="right" valign="top">char&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#a9ea185aec61cbd0161c6530aa8ee16f1">narrow</a> (<a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> __c, char __dfault) const</td></tr>
<tr class="separator:a9ea185aec61cbd0161c6530aa8ee16f1"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a8b760284fa34ce8010089a74e1ead79e"><td class="memItemLeft" align="right" valign="top">const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#a8b760284fa34ce8010089a74e1ead79e">narrow</a> (const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *__lo, const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *__hi, char __dfault, char *__to) const</td></tr>
<tr class="separator:a8b760284fa34ce8010089a74e1ead79e"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:afb41b267fdd60faf7e4083606cb52a37"><td class="memItemLeft" align="right" valign="top">const char *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#afb41b267fdd60faf7e4083606cb52a37">scan_is</a> (mask __m, const char *__lo, const char *__hi) const</td></tr>
<tr class="separator:afb41b267fdd60faf7e4083606cb52a37"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a8dface426b4233def1221b870319be44"><td class="memItemLeft" align="right" valign="top">const char *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#a8dface426b4233def1221b870319be44">scan_not</a> (mask __m, const char *__lo, const char *__hi) const</td></tr>
<tr class="separator:a8dface426b4233def1221b870319be44"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a3007d55c6427b410606f499795e1f66c"><td class="memItemLeft" align="right" valign="top">const mask *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#a3007d55c6427b410606f499795e1f66c">table</a> () const  throw ()</td></tr>
<tr class="separator:a3007d55c6427b410606f499795e1f66c"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a613ce83b223f740721454f283d168ceb"><td class="memItemLeft" align="right" valign="top"><a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#a613ce83b223f740721454f283d168ceb">tolower</a> (<a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> __c) const</td></tr>
<tr class="separator:a613ce83b223f740721454f283d168ceb"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aae3c348679b28ff02f655b1ac59d37d9"><td class="memItemLeft" align="right" valign="top">const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#aae3c348679b28ff02f655b1ac59d37d9">tolower</a> (<a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *__lo, const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *__hi) const</td></tr>
<tr class="separator:aae3c348679b28ff02f655b1ac59d37d9"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a40a825cf22f673eafcd52ec226982604"><td class="memItemLeft" align="right" valign="top"><a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#a40a825cf22f673eafcd52ec226982604">toupper</a> (<a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> __c) const</td></tr>
<tr class="separator:a40a825cf22f673eafcd52ec226982604"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a45aa4603a4e2181084e6f634d83502fc"><td class="memItemLeft" align="right" valign="top">const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#a45aa4603a4e2181084e6f634d83502fc">toupper</a> (<a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *__lo, const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *__hi) const</td></tr>
<tr class="separator:a45aa4603a4e2181084e6f634d83502fc"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:adb03af528f35f54abb0e5145e82d6f98"><td class="memItemLeft" align="right" valign="top"><a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#adb03af528f35f54abb0e5145e82d6f98">widen</a> (char __c) const</td></tr>
<tr class="separator:adb03af528f35f54abb0e5145e82d6f98"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a536369ec0cf9590af6c627ff27a407bc"><td class="memItemLeft" align="right" valign="top">const char *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#a536369ec0cf9590af6c627ff27a407bc">widen</a> (const char *__lo, const char *__hi, <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *__to) const</td></tr>
<tr class="separator:a536369ec0cf9590af6c627ff27a407bc"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-static-methods"></a>
Static Public Member Functions</h2></td></tr>
<tr class="memitem:a747e7392c1a15e23869442fea9685aaf"><td class="memItemLeft" align="right" valign="top">static const mask *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#a747e7392c1a15e23869442fea9685aaf">classic_table</a> ()  throw ()</td></tr>
<tr class="separator:a747e7392c1a15e23869442fea9685aaf"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-static-attribs"></a>
Static Public Attributes</h2></td></tr>
<tr class="memitem:a647042ef0953afac8db2505a083d554d"><td class="memItemLeft" align="right" valign="top"><a id="a647042ef0953afac8db2505a083d554d"></a>
static const mask&#160;</td><td class="memItemRight" valign="bottom"><b>alnum</b></td></tr>
<tr class="separator:a647042ef0953afac8db2505a083d554d"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a3ae00fba70505be303107f4429fd00c5"><td class="memItemLeft" align="right" valign="top"><a id="a3ae00fba70505be303107f4429fd00c5"></a>
static const mask&#160;</td><td class="memItemRight" valign="bottom"><b>alpha</b></td></tr>
<tr class="separator:a3ae00fba70505be303107f4429fd00c5"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a54ce902d2dba4e907c39248dd74c7790"><td class="memItemLeft" align="right" valign="top"><a id="a54ce902d2dba4e907c39248dd74c7790"></a>
static const mask&#160;</td><td class="memItemRight" valign="bottom"><b>blank</b></td></tr>
<tr class="separator:a54ce902d2dba4e907c39248dd74c7790"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:afabc36a91999cdcd9a42ac110581bf9a"><td class="memItemLeft" align="right" valign="top"><a id="afabc36a91999cdcd9a42ac110581bf9a"></a>
static const mask&#160;</td><td class="memItemRight" valign="bottom"><b>cntrl</b></td></tr>
<tr class="separator:afabc36a91999cdcd9a42ac110581bf9a"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a55c6c04c7389ab91689789a041aa4bbf"><td class="memItemLeft" align="right" valign="top"><a id="a55c6c04c7389ab91689789a041aa4bbf"></a>
static const mask&#160;</td><td class="memItemRight" valign="bottom"><b>digit</b></td></tr>
<tr class="separator:a55c6c04c7389ab91689789a041aa4bbf"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:adfa3632ccd39b727567e9f1c843210a4"><td class="memItemLeft" align="right" valign="top"><a id="adfa3632ccd39b727567e9f1c843210a4"></a>
static const mask&#160;</td><td class="memItemRight" valign="bottom"><b>graph</b></td></tr>
<tr class="separator:adfa3632ccd39b727567e9f1c843210a4"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aaa75fca18dac7d25648746904feca918"><td class="memItemLeft" align="right" valign="top">static <a class="el" href="a05824.html">locale::id</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#aaa75fca18dac7d25648746904feca918">id</a></td></tr>
<tr class="separator:aaa75fca18dac7d25648746904feca918"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a608769609a66c382dc1013e025413bf9"><td class="memItemLeft" align="right" valign="top"><a id="a608769609a66c382dc1013e025413bf9"></a>
static const mask&#160;</td><td class="memItemRight" valign="bottom"><b>lower</b></td></tr>
<tr class="separator:a608769609a66c382dc1013e025413bf9"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a97a370592d1edb537f570ce544384fbf"><td class="memItemLeft" align="right" valign="top"><a id="a97a370592d1edb537f570ce544384fbf"></a>
static const mask&#160;</td><td class="memItemRight" valign="bottom"><b>print</b></td></tr>
<tr class="separator:a97a370592d1edb537f570ce544384fbf"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a40290f8665839843e3adf805ef4dac63"><td class="memItemLeft" align="right" valign="top"><a id="a40290f8665839843e3adf805ef4dac63"></a>
static const mask&#160;</td><td class="memItemRight" valign="bottom"><b>punct</b></td></tr>
<tr class="separator:a40290f8665839843e3adf805ef4dac63"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a6cc2b9b6be486b744fbbb701cf20f030"><td class="memItemLeft" align="right" valign="top"><a id="a6cc2b9b6be486b744fbbb701cf20f030"></a>
static const mask&#160;</td><td class="memItemRight" valign="bottom"><b>space</b></td></tr>
<tr class="separator:a6cc2b9b6be486b744fbbb701cf20f030"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a8e1ecbf03326b7f71563e2c3f9a40b03"><td class="memItemLeft" align="right" valign="top">static const size_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#a8e1ecbf03326b7f71563e2c3f9a40b03">table_size</a></td></tr>
<tr class="separator:a8e1ecbf03326b7f71563e2c3f9a40b03"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ab9b5673283d3f0bf05c78dd61d2996eb"><td class="memItemLeft" align="right" valign="top"><a id="ab9b5673283d3f0bf05c78dd61d2996eb"></a>
static const mask&#160;</td><td class="memItemRight" valign="bottom"><b>upper</b></td></tr>
<tr class="separator:ab9b5673283d3f0bf05c78dd61d2996eb"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a4adf373a7b38c7e7eafc1e2e8b193abc"><td class="memItemLeft" align="right" valign="top"><a id="a4adf373a7b38c7e7eafc1e2e8b193abc"></a>
static const mask&#160;</td><td class="memItemRight" valign="bottom"><b>xdigit</b></td></tr>
<tr class="separator:a4adf373a7b38c7e7eafc1e2e8b193abc"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pro-methods"></a>
Protected Member Functions</h2></td></tr>
<tr class="memitem:a245192d563ebc4ba5d52cfd4a114e598"><td class="memItemLeft" align="right" valign="top">virtual&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#a245192d563ebc4ba5d52cfd4a114e598">~ctype</a> ()</td></tr>
<tr class="separator:a245192d563ebc4ba5d52cfd4a114e598"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a136c4d09f8241b6d30657175f3361f4a"><td class="memItemLeft" align="right" valign="top">virtual char&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#a136c4d09f8241b6d30657175f3361f4a">do_narrow</a> (<a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> __c, char __dfault __attribute__((__unused__))) const</td></tr>
<tr class="separator:a136c4d09f8241b6d30657175f3361f4a"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a41ccb4858b9456fcfc9bd5946314ef49"><td class="memItemLeft" align="right" valign="top">virtual const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#a41ccb4858b9456fcfc9bd5946314ef49">do_narrow</a> (const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *__lo, const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *__hi, char __dfault __attribute__((__unused__)), char *__to) const</td></tr>
<tr class="separator:a41ccb4858b9456fcfc9bd5946314ef49"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac019737df7ce6bff299aa60d7d6b18b0"><td class="memItemLeft" align="right" valign="top">virtual <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#ac019737df7ce6bff299aa60d7d6b18b0">do_tolower</a> (<a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> __c) const</td></tr>
<tr class="separator:ac019737df7ce6bff299aa60d7d6b18b0"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:afe122310bbeed79c8451587e257ca463"><td class="memItemLeft" align="right" valign="top">virtual const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#afe122310bbeed79c8451587e257ca463">do_tolower</a> (<a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *__lo, const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *__hi) const</td></tr>
<tr class="separator:afe122310bbeed79c8451587e257ca463"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a0baaa8202343a9c588635910b4fa4d7d"><td class="memItemLeft" align="right" valign="top">virtual <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#a0baaa8202343a9c588635910b4fa4d7d">do_toupper</a> (<a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> __c) const</td></tr>
<tr class="separator:a0baaa8202343a9c588635910b4fa4d7d"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aaa8745e5d3c653ba8252ec926519bb60"><td class="memItemLeft" align="right" valign="top">virtual const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#aaa8745e5d3c653ba8252ec926519bb60">do_toupper</a> (<a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *__lo, const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *__hi) const</td></tr>
<tr class="separator:aaa8745e5d3c653ba8252ec926519bb60"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a37bae5847ddd2a3e9dda66b2bb663f38"><td class="memItemLeft" align="right" valign="top">virtual <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#a37bae5847ddd2a3e9dda66b2bb663f38">do_widen</a> (char __c) const</td></tr>
<tr class="separator:a37bae5847ddd2a3e9dda66b2bb663f38"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ad1c0a38350b682ac361a85ca1ac6ddc5"><td class="memItemLeft" align="right" valign="top">virtual const char *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a05860.html#ad1c0a38350b682ac361a85ca1ac6ddc5">do_widen</a> (const char *__lo, const char *__hi, <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *__to) const</td></tr>
<tr class="separator:ad1c0a38350b682ac361a85ca1ac6ddc5"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pro-static-methods"></a>
Static Protected Member Functions</h2></td></tr>
<tr class="memitem:aaaa39cc3ae39c5283101ce8c9c630902"><td class="memItemLeft" align="right" valign="top"><a id="aaaa39cc3ae39c5283101ce8c9c630902"></a>
static __c_locale&#160;</td><td class="memItemRight" valign="bottom"><b>_S_clone_c_locale</b> (__c_locale &amp;__cloc)  throw ()</td></tr>
<tr class="separator:aaaa39cc3ae39c5283101ce8c9c630902"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a60fbe742b113ff90f63e01c0ac658826"><td class="memItemLeft" align="right" valign="top"><a id="a60fbe742b113ff90f63e01c0ac658826"></a>
static void&#160;</td><td class="memItemRight" valign="bottom"><b>_S_create_c_locale</b> (__c_locale &amp;__cloc, const char *__s, __c_locale __old=0)</td></tr>
<tr class="separator:a60fbe742b113ff90f63e01c0ac658826"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a0a8c1c763d0d99421ab859f9c11668af"><td class="memItemLeft" align="right" valign="top"><a id="a0a8c1c763d0d99421ab859f9c11668af"></a>
static void&#160;</td><td class="memItemRight" valign="bottom"><b>_S_destroy_c_locale</b> (__c_locale &amp;__cloc)</td></tr>
<tr class="separator:a0a8c1c763d0d99421ab859f9c11668af"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a2e71ffc16033618e86c8c9d14ae4b022"><td class="memItemLeft" align="right" valign="top"><a id="a2e71ffc16033618e86c8c9d14ae4b022"></a>
static __c_locale&#160;</td><td class="memItemRight" valign="bottom"><b>_S_get_c_locale</b> ()</td></tr>
<tr class="separator:a2e71ffc16033618e86c8c9d14ae4b022"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:acda690006956a82c0cc436f5509c4f26"><td class="memItemLeft" align="right" valign="top"><a id="acda690006956a82c0cc436f5509c4f26"></a>
static const char *&#160;</td><td class="memItemRight" valign="bottom"><b>_S_get_c_name</b> ()  throw ()</td></tr>
<tr class="separator:acda690006956a82c0cc436f5509c4f26"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a426725452f3ac010eb3c090e83a6e574"><td class="memItemLeft" align="right" valign="top"><a id="a426725452f3ac010eb3c090e83a6e574"></a>
static __c_locale&#160;</td><td class="memItemRight" valign="bottom"><b>_S_lc_ctype_c_locale</b> (__c_locale __cloc, const char *__s)</td></tr>
<tr class="separator:a426725452f3ac010eb3c090e83a6e574"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pro-attribs"></a>
Protected Attributes</h2></td></tr>
<tr class="memitem:a2bbdaab6e5f9b58870bbc83dc0f5967a"><td class="memItemLeft" align="right" valign="top"><a id="a2bbdaab6e5f9b58870bbc83dc0f5967a"></a>
__c_locale&#160;</td><td class="memItemRight" valign="bottom"><b>_M_c_locale_ctype</b></td></tr>
<tr class="separator:a2bbdaab6e5f9b58870bbc83dc0f5967a"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a03c15b53d4cf869d62874f367ea59f69"><td class="memItemLeft" align="right" valign="top"><a id="a03c15b53d4cf869d62874f367ea59f69"></a>
bool&#160;</td><td class="memItemRight" valign="bottom"><b>_M_del</b></td></tr>
<tr class="separator:a03c15b53d4cf869d62874f367ea59f69"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a01e35a5cc56e804bb543ac674553775f"><td class="memItemLeft" align="right" valign="top"><a id="a01e35a5cc56e804bb543ac674553775f"></a>
char&#160;</td><td class="memItemRight" valign="bottom"><b>_M_narrow</b> [1+static_cast&lt; unsigned char &gt;(-1)]</td></tr>
<tr class="separator:a01e35a5cc56e804bb543ac674553775f"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a1cdc269c1678986e62a18b9613d2fd01"><td class="memItemLeft" align="right" valign="top"><a id="a1cdc269c1678986e62a18b9613d2fd01"></a>
char&#160;</td><td class="memItemRight" valign="bottom"><b>_M_narrow_ok</b></td></tr>
<tr class="separator:a1cdc269c1678986e62a18b9613d2fd01"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a5e655743a782562f9ab2a8149b8a2a91"><td class="memItemLeft" align="right" valign="top"><a id="a5e655743a782562f9ab2a8149b8a2a91"></a>
const mask *&#160;</td><td class="memItemRight" valign="bottom"><b>_M_table</b></td></tr>
<tr class="separator:a5e655743a782562f9ab2a8149b8a2a91"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a71799a2e964eef8a18509e966d5e59ce"><td class="memItemLeft" align="right" valign="top"><a id="a71799a2e964eef8a18509e966d5e59ce"></a>
__to_type&#160;</td><td class="memItemRight" valign="bottom"><b>_M_tolower</b></td></tr>
<tr class="separator:a71799a2e964eef8a18509e966d5e59ce"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:adbfaf27e1493fed08656f1b321d69409"><td class="memItemLeft" align="right" valign="top"><a id="adbfaf27e1493fed08656f1b321d69409"></a>
__to_type&#160;</td><td class="memItemRight" valign="bottom"><b>_M_toupper</b></td></tr>
<tr class="separator:adbfaf27e1493fed08656f1b321d69409"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a70a01ac4a3e71bd37077c700484ea1c2"><td class="memItemLeft" align="right" valign="top"><a id="a70a01ac4a3e71bd37077c700484ea1c2"></a>
char&#160;</td><td class="memItemRight" valign="bottom"><b>_M_widen</b> [1+static_cast&lt; unsigned char &gt;(-1)]</td></tr>
<tr class="separator:a70a01ac4a3e71bd37077c700484ea1c2"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a80b040c4e891a53064eb0ccdff446d6b"><td class="memItemLeft" align="right" valign="top"><a id="a80b040c4e891a53064eb0ccdff446d6b"></a>
char&#160;</td><td class="memItemRight" valign="bottom"><b>_M_widen_ok</b></td></tr>
<tr class="separator:a80b040c4e891a53064eb0ccdff446d6b"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table>
<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
<div class="textblock"><h3>template&lt;&gt;<br />
class std::ctype&lt; char &gt;</h3>

<p>The ctype&lt;char&gt; specialization.</p>
<p>This class defines classification and conversion functions for the char type. It gets used by char streams for many I/O operations. The char specialization provides a number of optimizations as well. </p>

<p class="definition">Definition at line <a class="el" href="a00401_source.html#l00681">681</a> of file <a class="el" href="a00401_source.html">locale_facets.h</a>.</p>
</div><h2 class="groupheader">Member Typedef Documentation</h2>
<a id="a28f3c847c9453a72212fdf3c2d186e4a"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a28f3c847c9453a72212fdf3c2d186e4a">&#9670;&nbsp;</a></span>char_type</h2>

<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">typedef char <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::<a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Typedef for the template parameter char. </p>

<p class="definition">Definition at line <a class="el" href="a00401_source.html#l00686">686</a> of file <a class="el" href="a00401_source.html">locale_facets.h</a>.</p>

</div>
</div>
<h2 class="groupheader">Constructor &amp; Destructor Documentation</h2>
<a id="acf81454de90c003b463e19f8703c1cbb"></a>
<h2 class="memtitle"><span class="permalink"><a href="#acf81454de90c003b463e19f8703c1cbb">&#9670;&nbsp;</a></span>ctype() <span class="overload">[1/2]</span></h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::<a class="el" href="a05856.html">ctype</a> </td>
          <td>(</td>
          <td class="paramtype">const mask *&#160;</td>
          <td class="paramname"><em>__table</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">bool&#160;</td>
          <td class="paramname"><em>__del</em> = <code>false</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">size_t&#160;</td>
          <td class="paramname"><em>__refs</em> = <code>0</code>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">explicit</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Constructor performs initialization. </p>
<p>This is the constructor provided by the standard.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">__table</td><td>If non-zero, table is used as the per-char mask. Else classic_table() is used. </td></tr>
    <tr><td class="paramname">__del</td><td>If true, passes ownership of table to this facet. </td></tr>
    <tr><td class="paramname">__refs</td><td>Passed to the base facet class. </td></tr>
  </table>
  </dd>
</dl>

</div>
</div>
<a id="a00afd225d281cd0a8cd3f35611dd91f9"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a00afd225d281cd0a8cd3f35611dd91f9">&#9670;&nbsp;</a></span>ctype() <span class="overload">[2/2]</span></h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::<a class="el" href="a05856.html">ctype</a> </td>
          <td>(</td>
          <td class="paramtype">__c_locale&#160;</td>
          <td class="paramname"><em>__cloc</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const mask *&#160;</td>
          <td class="paramname"><em>__table</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">bool&#160;</td>
          <td class="paramname"><em>__del</em> = <code>false</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">size_t&#160;</td>
          <td class="paramname"><em>__refs</em> = <code>0</code>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">explicit</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Constructor performs static initialization. </p>
<p>This constructor is used to construct the initial C locale facet.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">__cloc</td><td>Handle to C locale data. </td></tr>
    <tr><td class="paramname">__table</td><td>If non-zero, table is used as the per-char mask. </td></tr>
    <tr><td class="paramname">__del</td><td>If true, passes ownership of table to this facet. </td></tr>
    <tr><td class="paramname">__refs</td><td>Passed to the base facet class. </td></tr>
  </table>
  </dd>
</dl>

</div>
</div>
<a id="a245192d563ebc4ba5d52cfd4a114e598"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a245192d563ebc4ba5d52cfd4a114e598">&#9670;&nbsp;</a></span>~ctype()</h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">virtual <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::~<a class="el" href="a05856.html">ctype</a> </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td></td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">protected</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Destructor. </p>
<p>This function deletes table() if <em>del</em> was true in the constructor. </p>

</div>
</div>
<h2 class="groupheader">Member Function Documentation</h2>
<a id="a747e7392c1a15e23869442fea9685aaf"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a747e7392c1a15e23869442fea9685aaf">&#9670;&nbsp;</a></span>classic_table()</h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">static const mask* <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::classic_table </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td></td>
        </tr>
        <tr>
          <td align="right">throw </td><td>(</td><td colspan="2"></td>
        </tr>
        <tr>
          <td align="right"></td><td>)</td><td></td><td></td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">static</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Returns a pointer to the C locale mask table. </p>

</div>
</div>
<a id="a136c4d09f8241b6d30657175f3361f4a"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a136c4d09f8241b6d30657175f3361f4a">&#9670;&nbsp;</a></span>do_narrow() <span class="overload">[1/2]</span></h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">virtual char <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::do_narrow </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a>&#160;</td>
          <td class="paramname"><em>__c</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">char __dfault &#160;</td>
          <td class="paramname"><em>__attribute__</em>(__unused__)&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">protected</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Narrow char. </p>
<p>This virtual function converts the char to char using the simplest reasonable transformation. If the conversion fails, dfault is returned instead. For an underived ctype&lt;char&gt; facet, <em>c</em> will be returned unchanged.</p>
<p>do_narrow() is a hook for a derived facet to change the behavior of narrowing. do_narrow() must always return the same result for the same input.</p>
<p>Note: this is not what you want for codepage conversions. See codecvt for that.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">__c</td><td>The char to convert. </td></tr>
    <tr><td class="paramname">__dfault</td><td>Char to return if conversion fails. </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The converted char. </dd></dl>

<p class="definition">Definition at line <a class="el" href="a00401_source.html#l01134">1134</a> of file <a class="el" href="a00401_source.html">locale_facets.h</a>.</p>

</div>
</div>
<a id="a41ccb4858b9456fcfc9bd5946314ef49"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a41ccb4858b9456fcfc9bd5946314ef49">&#9670;&nbsp;</a></span>do_narrow() <span class="overload">[2/2]</span></h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">virtual const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a>* <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::do_narrow </td>
          <td>(</td>
          <td class="paramtype">const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *&#160;</td>
          <td class="paramname"><em>__lo</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *&#160;</td>
          <td class="paramname"><em>__hi</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">char __dfault &#160;</td>
          <td class="paramname"><em>__attribute__</em>(__unused__), </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">char *&#160;</td>
          <td class="paramname"><em>__to</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">protected</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Narrow char array to char array. </p>
<p>This virtual function converts each char in the range [lo,hi) to char using the simplest reasonable transformation and writes the results to the destination array. For any char in the input that cannot be converted, <em>dfault</em> is used instead. For an underived ctype&lt;char&gt; facet, the argument will be copied unchanged.</p>
<p>do_narrow() is a hook for a derived facet to change the behavior of narrowing. do_narrow() must always return the same result for the same input.</p>
<p>Note: this is not what you want for codepage conversions. See codecvt for that.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">__lo</td><td>Pointer to start of range. </td></tr>
    <tr><td class="paramname">__hi</td><td>Pointer to end of range. </td></tr>
    <tr><td class="paramname">__dfault</td><td>Char to use if conversion fails. </td></tr>
    <tr><td class="paramname">__to</td><td>Pointer to the destination array. </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><em>__hi</em>. </dd></dl>

<p class="definition">Definition at line <a class="el" href="a00401_source.html#l01160">1160</a> of file <a class="el" href="a00401_source.html">locale_facets.h</a>.</p>

</div>
</div>
<a id="ac019737df7ce6bff299aa60d7d6b18b0"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ac019737df7ce6bff299aa60d7d6b18b0">&#9670;&nbsp;</a></span>do_tolower() <span class="overload">[1/2]</span></h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">virtual <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::do_tolower </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a>&#160;</td>
          <td class="paramname"><em>__c</em></td><td>)</td>
          <td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">protected</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Convert to lowercase. </p>
<p>This virtual function converts the char argument to lowercase if possible. If not possible (for example, '2'), returns the argument.</p>
<p>do_tolower() is a hook for a derived facet to change the behavior of lowercasing. do_tolower() must always return the same result for the same input.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">__c</td><td>The char to convert. </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The lowercase char if convertible, else <em>__c</em>. </dd></dl>

</div>
</div>
<a id="afe122310bbeed79c8451587e257ca463"></a>
<h2 class="memtitle"><span class="permalink"><a href="#afe122310bbeed79c8451587e257ca463">&#9670;&nbsp;</a></span>do_tolower() <span class="overload">[2/2]</span></h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">virtual const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a>* <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::do_tolower </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *&#160;</td>
          <td class="paramname"><em>__lo</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *&#160;</td>
          <td class="paramname"><em>__hi</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">protected</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Convert array to lowercase. </p>
<p>This virtual function converts each char in the range [lo,hi) to lowercase if possible. Other chars remain untouched.</p>
<p>do_tolower() is a hook for a derived facet to change the behavior of lowercasing. do_tolower() must always return the same result for the same input.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">__lo</td><td>Pointer to first char in range. </td></tr>
    <tr><td class="paramname">__hi</td><td>Pointer to end of range. </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><em>__hi</em>. </dd></dl>

</div>
</div>
<a id="a0baaa8202343a9c588635910b4fa4d7d"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a0baaa8202343a9c588635910b4fa4d7d">&#9670;&nbsp;</a></span>do_toupper() <span class="overload">[1/2]</span></h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">virtual <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::do_toupper </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a>&#160;</td>
          <td class="paramname"><em>__c</em></td><td>)</td>
          <td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">protected</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Convert to uppercase. </p>
<p>This virtual function converts the char argument to uppercase if possible. If not possible (for example, '2'), returns the argument.</p>
<p>do_toupper() is a hook for a derived facet to change the behavior of uppercasing. do_toupper() must always return the same result for the same input.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">__c</td><td>The char to convert. </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The uppercase char if convertible, else <em>__c</em>. </dd></dl>

</div>
</div>
<a id="aaa8745e5d3c653ba8252ec926519bb60"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aaa8745e5d3c653ba8252ec926519bb60">&#9670;&nbsp;</a></span>do_toupper() <span class="overload">[2/2]</span></h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">virtual const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a>* <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::do_toupper </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *&#160;</td>
          <td class="paramname"><em>__lo</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *&#160;</td>
          <td class="paramname"><em>__hi</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">protected</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Convert array to uppercase. </p>
<p>This virtual function converts each char in the range [lo,hi) to uppercase if possible. Other chars remain untouched.</p>
<p>do_toupper() is a hook for a derived facet to change the behavior of uppercasing. do_toupper() must always return the same result for the same input.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">__lo</td><td>Pointer to start of range. </td></tr>
    <tr><td class="paramname">__hi</td><td>Pointer to end of range. </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><em>__hi</em>. </dd></dl>

</div>
</div>
<a id="a37bae5847ddd2a3e9dda66b2bb663f38"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a37bae5847ddd2a3e9dda66b2bb663f38">&#9670;&nbsp;</a></span>do_widen() <span class="overload">[1/2]</span></h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">virtual <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::do_widen </td>
          <td>(</td>
          <td class="paramtype">char&#160;</td>
          <td class="paramname"><em>__c</em></td><td>)</td>
          <td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">protected</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Widen char. </p>
<p>This virtual function converts the char to char using the simplest reasonable transformation. For an underived ctype&lt;char&gt; facet, the argument will be returned unchanged.</p>
<p>do_widen() is a hook for a derived facet to change the behavior of widening. do_widen() must always return the same result for the same input.</p>
<p>Note: this is not what you want for codepage conversions. See codecvt for that.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">__c</td><td>The char to convert. </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The converted character. </dd></dl>

<p class="definition">Definition at line <a class="el" href="a00401_source.html#l01084">1084</a> of file <a class="el" href="a00401_source.html">locale_facets.h</a>.</p>

</div>
</div>
<a id="ad1c0a38350b682ac361a85ca1ac6ddc5"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ad1c0a38350b682ac361a85ca1ac6ddc5">&#9670;&nbsp;</a></span>do_widen() <span class="overload">[2/2]</span></h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">virtual const char* <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::do_widen </td>
          <td>(</td>
          <td class="paramtype">const char *&#160;</td>
          <td class="paramname"><em>__lo</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const char *&#160;</td>
          <td class="paramname"><em>__hi</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *&#160;</td>
          <td class="paramname"><em>__to</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">protected</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Widen char array. </p>
<p>This function converts each char in the range [lo,hi) to char using the simplest reasonable transformation. For an underived ctype&lt;char&gt; facet, the argument will be copied unchanged.</p>
<p>do_widen() is a hook for a derived facet to change the behavior of widening. do_widen() must always return the same result for the same input.</p>
<p>Note: this is not what you want for codepage conversions. See codecvt for that.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">__lo</td><td>Pointer to start of range. </td></tr>
    <tr><td class="paramname">__hi</td><td>Pointer to end of range. </td></tr>
    <tr><td class="paramname">__to</td><td>Pointer to the destination array. </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><em>__hi</em>. </dd></dl>

<p class="definition">Definition at line <a class="el" href="a00401_source.html#l01107">1107</a> of file <a class="el" href="a00401_source.html">locale_facets.h</a>.</p>

</div>
</div>
<a id="a966c54a29d5fb4424486f74ceacaed4a"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a966c54a29d5fb4424486f74ceacaed4a">&#9670;&nbsp;</a></span>is() <span class="overload">[1/2]</span></h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">bool <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::is </td>
          <td>(</td>
          <td class="paramtype">mask&#160;</td>
          <td class="paramname"><em>__m</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">char&#160;</td>
          <td class="paramname"><em>__c</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Test char classification. </p>
<p>This function compares the mask table[c] to <em>__m</em>.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">__c</td><td>The char to compare the mask of. </td></tr>
    <tr><td class="paramname">__m</td><td>The mask to compare against. </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>True if __m &amp; table[__c] is true, false otherwise. </dd></dl>

<p class="definition">Definition at line <a class="el" href="a00677_source.html#l00043">43</a> of file <a class="el" href="a00677_source.html">ctype_inline.h</a>.</p>

</div>
</div>
<a id="a3f98c7b3851c877d90a1c55102506b30"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a3f98c7b3851c877d90a1c55102506b30">&#9670;&nbsp;</a></span>is() <span class="overload">[2/2]</span></h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">const char * <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::is </td>
          <td>(</td>
          <td class="paramtype">const char *&#160;</td>
          <td class="paramname"><em>__lo</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const char *&#160;</td>
          <td class="paramname"><em>__hi</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">mask *&#160;</td>
          <td class="paramname"><em>__vec</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Return a mask array. </p>
<p>This function finds the mask for each char in the range [lo, hi) and successively writes it to vec. vec must have as many elements as the char array.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">__lo</td><td>Pointer to start of range. </td></tr>
    <tr><td class="paramname">__hi</td><td>Pointer to end of range. </td></tr>
    <tr><td class="paramname">__vec</td><td>Pointer to an array of mask storage. </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><em>__hi</em>. </dd></dl>

<p class="definition">Definition at line <a class="el" href="a00677_source.html#l00048">48</a> of file <a class="el" href="a00677_source.html">ctype_inline.h</a>.</p>

</div>
</div>
<a id="a9ea185aec61cbd0161c6530aa8ee16f1"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a9ea185aec61cbd0161c6530aa8ee16f1">&#9670;&nbsp;</a></span>narrow() <span class="overload">[1/2]</span></h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">char <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::narrow </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a>&#160;</td>
          <td class="paramname"><em>__c</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">char&#160;</td>
          <td class="paramname"><em>__dfault</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Narrow char. </p>
<p>This function converts the char to char using the simplest reasonable transformation. If the conversion fails, dfault is returned instead. For an underived ctype&lt;char&gt; facet, <em>c</em> will be returned unchanged.</p>
<p>This function works as if it returns ctype&lt;char&gt;::do_narrow(c). do_narrow() must always return the same result for the same input.</p>
<p>Note: this is not what you want for codepage conversions. See codecvt for that.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">__c</td><td>The char to convert. </td></tr>
    <tr><td class="paramname">__dfault</td><td>Char to return if conversion fails. </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The converted character. </dd></dl>

<p class="definition">Definition at line <a class="el" href="a00401_source.html#l00931">931</a> of file <a class="el" href="a00401_source.html">locale_facets.h</a>.</p>

<p class="reference">References <a class="el" href="a05856.html#a01a3c227801621bd3ca9b3568c44c3a0">std::ctype&lt; _CharT &gt;::do_narrow()</a>.</p>

</div>
</div>
<a id="a8b760284fa34ce8010089a74e1ead79e"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a8b760284fa34ce8010089a74e1ead79e">&#9670;&nbsp;</a></span>narrow() <span class="overload">[2/2]</span></h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a>* <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::narrow </td>
          <td>(</td>
          <td class="paramtype">const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *&#160;</td>
          <td class="paramname"><em>__lo</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *&#160;</td>
          <td class="paramname"><em>__hi</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">char&#160;</td>
          <td class="paramname"><em>__dfault</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">char *&#160;</td>
          <td class="paramname"><em>__to</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Narrow char array. </p>
<p>This function converts each char in the input to char using the simplest reasonable transformation and writes the results to the destination array. For any char in the input that cannot be converted, <em>dfault</em> is used instead. For an underived ctype&lt;char&gt; facet, the argument will be copied unchanged.</p>
<p>This function works as if it returns ctype&lt;char&gt;::do_narrow(lo, hi, dfault, to). do_narrow() must always return the same result for the same input.</p>
<p>Note: this is not what you want for codepage conversions. See codecvt for that.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">__lo</td><td>Pointer to start of range. </td></tr>
    <tr><td class="paramname">__hi</td><td>Pointer to end of range. </td></tr>
    <tr><td class="paramname">__dfault</td><td>Char to use if conversion fails. </td></tr>
    <tr><td class="paramname">__to</td><td>Pointer to the destination array. </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><em>__hi</em>. </dd></dl>

<p class="definition">Definition at line <a class="el" href="a00401_source.html#l00964">964</a> of file <a class="el" href="a00401_source.html">locale_facets.h</a>.</p>

<p class="reference">References <a class="el" href="a05856.html#a01a3c227801621bd3ca9b3568c44c3a0">std::ctype&lt; _CharT &gt;::do_narrow()</a>.</p>

</div>
</div>
<a id="afb41b267fdd60faf7e4083606cb52a37"></a>
<h2 class="memtitle"><span class="permalink"><a href="#afb41b267fdd60faf7e4083606cb52a37">&#9670;&nbsp;</a></span>scan_is()</h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">const char * <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::scan_is </td>
          <td>(</td>
          <td class="paramtype">mask&#160;</td>
          <td class="paramname"><em>__m</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const char *&#160;</td>
          <td class="paramname"><em>__lo</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const char *&#160;</td>
          <td class="paramname"><em>__hi</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Find char matching a mask. </p>
<p>This function searches for and returns the first char in [lo,hi) for which is(m,char) is true.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">__m</td><td>The mask to compare against. </td></tr>
    <tr><td class="paramname">__lo</td><td>Pointer to start of range. </td></tr>
    <tr><td class="paramname">__hi</td><td>Pointer to end of range. </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>Pointer to a matching char if found, else <em>__hi</em>. </dd></dl>

<p class="definition">Definition at line <a class="el" href="a00677_source.html#l00057">57</a> of file <a class="el" href="a00677_source.html">ctype_inline.h</a>.</p>

</div>
</div>
<a id="a8dface426b4233def1221b870319be44"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a8dface426b4233def1221b870319be44">&#9670;&nbsp;</a></span>scan_not()</h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">const char * <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::scan_not </td>
          <td>(</td>
          <td class="paramtype">mask&#160;</td>
          <td class="paramname"><em>__m</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const char *&#160;</td>
          <td class="paramname"><em>__lo</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const char *&#160;</td>
          <td class="paramname"><em>__hi</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Find char not matching a mask. </p>
<p>This function searches for and returns a pointer to the first char in [__lo,__hi) for which is(m,char) is false.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">__m</td><td>The mask to compare against. </td></tr>
    <tr><td class="paramname">__lo</td><td>Pointer to start of range. </td></tr>
    <tr><td class="paramname">__hi</td><td>Pointer to end of range. </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>Pointer to a non-matching char if found, else <em>__hi</em>. </dd></dl>

<p class="definition">Definition at line <a class="el" href="a00677_source.html#l00067">67</a> of file <a class="el" href="a00677_source.html">ctype_inline.h</a>.</p>

</div>
</div>
<a id="a3007d55c6427b410606f499795e1f66c"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a3007d55c6427b410606f499795e1f66c">&#9670;&nbsp;</a></span>table()</h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">const mask* <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::table </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td> const</td>
        </tr>
        <tr>
          <td align="right">throw </td><td>(</td><td colspan="2"></td>
        </tr>
        <tr>
          <td align="right"></td><td>)</td><td></td><td></td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Returns a pointer to the mask table provided to the constructor, or the default from classic_table() if none was provided. </p>

<p class="definition">Definition at line <a class="el" href="a00401_source.html#l00983">983</a> of file <a class="el" href="a00401_source.html">locale_facets.h</a>.</p>

</div>
</div>
<a id="a613ce83b223f740721454f283d168ceb"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a613ce83b223f740721454f283d168ceb">&#9670;&nbsp;</a></span>tolower() <span class="overload">[1/2]</span></h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::tolower </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a>&#160;</td>
          <td class="paramname"><em>__c</em></td><td>)</td>
          <td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Convert to lowercase. </p>
<p>This function converts the char argument to lowercase if possible. If not possible (for example, '2'), returns the argument.</p>
<p>tolower() acts as if it returns ctype&lt;char&gt;::do_tolower(__c). do_tolower() must always return the same result for the same input.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">__c</td><td>The char to convert. </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The lowercase char if convertible, else <em>__c</em>. </dd></dl>

<p class="definition">Definition at line <a class="el" href="a00401_source.html#l00835">835</a> of file <a class="el" href="a00401_source.html">locale_facets.h</a>.</p>

<p class="reference">References <a class="el" href="a05856.html#a59a0ada1cc334c6c407e43af870d291e">std::ctype&lt; _CharT &gt;::do_tolower()</a>.</p>

</div>
</div>
<a id="aae3c348679b28ff02f655b1ac59d37d9"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aae3c348679b28ff02f655b1ac59d37d9">&#9670;&nbsp;</a></span>tolower() <span class="overload">[2/2]</span></h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a>* <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::tolower </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *&#160;</td>
          <td class="paramname"><em>__lo</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *&#160;</td>
          <td class="paramname"><em>__hi</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Convert array to lowercase. </p>
<p>This function converts each char in the range [lo,hi) to lowercase if possible. Other chars remain untouched.</p>
<p>tolower() acts as if it returns ctype&lt;char&gt;:: do_tolower(__lo, __hi). do_tolower() must always return the same result for the same input.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">__lo</td><td>Pointer to first char in range. </td></tr>
    <tr><td class="paramname">__hi</td><td>Pointer to end of range. </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><em>__hi</em>. </dd></dl>

<p class="definition">Definition at line <a class="el" href="a00401_source.html#l00852">852</a> of file <a class="el" href="a00401_source.html">locale_facets.h</a>.</p>

<p class="reference">References <a class="el" href="a05856.html#a59a0ada1cc334c6c407e43af870d291e">std::ctype&lt; _CharT &gt;::do_tolower()</a>.</p>

</div>
</div>
<a id="a40a825cf22f673eafcd52ec226982604"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a40a825cf22f673eafcd52ec226982604">&#9670;&nbsp;</a></span>toupper() <span class="overload">[1/2]</span></h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::toupper </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a>&#160;</td>
          <td class="paramname"><em>__c</em></td><td>)</td>
          <td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Convert to uppercase. </p>
<p>This function converts the char argument to uppercase if possible. If not possible (for example, '2'), returns the argument.</p>
<p>toupper() acts as if it returns ctype&lt;char&gt;::do_toupper(c). do_toupper() must always return the same result for the same input.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">__c</td><td>The char to convert. </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The uppercase char if convertible, else <em>__c</em>. </dd></dl>

<p class="definition">Definition at line <a class="el" href="a00401_source.html#l00802">802</a> of file <a class="el" href="a00401_source.html">locale_facets.h</a>.</p>

<p class="reference">References <a class="el" href="a05856.html#a292e998fb0eeeef612c4e879ead72bc9">std::ctype&lt; _CharT &gt;::do_toupper()</a>.</p>

</div>
</div>
<a id="a45aa4603a4e2181084e6f634d83502fc"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a45aa4603a4e2181084e6f634d83502fc">&#9670;&nbsp;</a></span>toupper() <span class="overload">[2/2]</span></h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a>* <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::toupper </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *&#160;</td>
          <td class="paramname"><em>__lo</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *&#160;</td>
          <td class="paramname"><em>__hi</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Convert array to uppercase. </p>
<p>This function converts each char in the range [__lo,__hi) to uppercase if possible. Other chars remain untouched.</p>
<p>toupper() acts as if it returns ctype&lt;char&gt;:: do_toupper(__lo, __hi). do_toupper() must always return the same result for the same input.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">__lo</td><td>Pointer to first char in range. </td></tr>
    <tr><td class="paramname">__hi</td><td>Pointer to end of range. </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><em>__hi</em>. </dd></dl>

<p class="definition">Definition at line <a class="el" href="a00401_source.html#l00819">819</a> of file <a class="el" href="a00401_source.html">locale_facets.h</a>.</p>

<p class="reference">References <a class="el" href="a05856.html#a292e998fb0eeeef612c4e879ead72bc9">std::ctype&lt; _CharT &gt;::do_toupper()</a>.</p>

</div>
</div>
<a id="adb03af528f35f54abb0e5145e82d6f98"></a>
<h2 class="memtitle"><span class="permalink"><a href="#adb03af528f35f54abb0e5145e82d6f98">&#9670;&nbsp;</a></span>widen() <span class="overload">[1/2]</span></h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::widen </td>
          <td>(</td>
          <td class="paramtype">char&#160;</td>
          <td class="paramname"><em>__c</em></td><td>)</td>
          <td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Widen char. </p>
<p>This function converts the char to char_type using the simplest reasonable transformation. For an underived ctype&lt;char&gt; facet, the argument will be returned unchanged.</p>
<p>This function works as if it returns ctype&lt;char&gt;::do_widen(c). do_widen() must always return the same result for the same input.</p>
<p>Note: this is not what you want for codepage conversions. See codecvt for that.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">__c</td><td>The char to convert. </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>The converted character. </dd></dl>

<p class="definition">Definition at line <a class="el" href="a00401_source.html#l00872">872</a> of file <a class="el" href="a00401_source.html">locale_facets.h</a>.</p>

<p class="reference">References <a class="el" href="a05856.html#a7d464e73ba99ec097116cb63a9f99761">std::ctype&lt; _CharT &gt;::do_widen()</a>.</p>

</div>
</div>
<a id="a536369ec0cf9590af6c627ff27a407bc"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a536369ec0cf9590af6c627ff27a407bc">&#9670;&nbsp;</a></span>widen() <span class="overload">[2/2]</span></h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">const char* <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::widen </td>
          <td>(</td>
          <td class="paramtype">const char *&#160;</td>
          <td class="paramname"><em>__lo</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const char *&#160;</td>
          <td class="paramname"><em>__hi</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="a05860.html#a28f3c847c9453a72212fdf3c2d186e4a">char_type</a> *&#160;</td>
          <td class="paramname"><em>__to</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Widen char array. </p>
<p>This function converts each char in the input to char using the simplest reasonable transformation. For an underived ctype&lt;char&gt; facet, the argument will be copied unchanged.</p>
<p>This function works as if it returns ctype&lt;char&gt;::do_widen(c). do_widen() must always return the same result for the same input.</p>
<p>Note: this is not what you want for codepage conversions. See codecvt for that.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">__lo</td><td>Pointer to first char in range. </td></tr>
    <tr><td class="paramname">__hi</td><td>Pointer to end of range. </td></tr>
    <tr><td class="paramname">__to</td><td>Pointer to the destination array. </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><em>__hi</em>. </dd></dl>

<p class="definition">Definition at line <a class="el" href="a00401_source.html#l00899">899</a> of file <a class="el" href="a00401_source.html">locale_facets.h</a>.</p>

<p class="reference">References <a class="el" href="a05856.html#a7d464e73ba99ec097116cb63a9f99761">std::ctype&lt; _CharT &gt;::do_widen()</a>.</p>

</div>
</div>
<h2 class="groupheader">Member Data Documentation</h2>
<a id="aaa75fca18dac7d25648746904feca918"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aaa75fca18dac7d25648746904feca918">&#9670;&nbsp;</a></span>id</h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="a05824.html">locale::id</a> <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::id</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">static</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>The facet id for ctype&lt;char&gt; </p>

<p class="definition">Definition at line <a class="el" href="a00401_source.html#l00703">703</a> of file <a class="el" href="a00401_source.html">locale_facets.h</a>.</p>

</div>
</div>
<a id="a8e1ecbf03326b7f71563e2c3f9a40b03"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a8e1ecbf03326b7f71563e2c3f9a40b03">&#9670;&nbsp;</a></span>table_size</h2>

<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">const size_t <a class="el" href="a05856.html">std::ctype</a>&lt; char &gt;::table_size</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">static</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>The size of the mask table. It is SCHAR_MAX + 1. </p>

<p class="definition">Definition at line <a class="el" href="a00401_source.html#l00705">705</a> of file <a class="el" href="a00401_source.html">locale_facets.h</a>.</p>

</div>
</div>
<hr/>The documentation for this class was generated from the following files:<ul>
<li><a class="el" href="a00401_source.html">locale_facets.h</a></li>
<li><a class="el" href="a00677_source.html">ctype_inline.h</a></li>
</ul>
</div><!-- contents -->
</div><!-- doc-content -->
<!-- start footer part -->
<div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
  <ul>
    <li class="navelem"><a class="el" href="a01538.html">std</a></li><li class="navelem"><a class="el" href="a05860.html">ctype&lt; char &gt;</a></li>
    <li class="footer">Generated by
    <a href="http://www.doxygen.org/index.html">
    <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.15 </li>
  </ul>
</div>
</body>
</html>