public inbox for gcc-help@gcc.gnu.org
 help / color / mirror / Atom feed
From: Alex Vinokur <alexander.vinokur@telrad.co.il>
To: help-gcc@gnu.org
Subject: __PRETTY_FUNCTION__, functions and templates
Date: Sat, 01 Apr 2000 00:00:00 -0000	[thread overview]
Message-ID: <84st15$1uh$1@nnrp1.deja.com> (raw)
Message-ID: <20000401000000.AgAbT7aoIFLLHeF3Jx6X9hBiDUVoW_C4nr3LIWBdgh8@z> (raw)
In-Reply-To: <84pus001rnr@enews2.newsguy.com>

In article < 84pus001rnr@enews2.newsguy.com >,
  "Johnny Favorite (it means \"Writhing Tentacle of Death\")"
<allen@snakebite.com> wrote:
> Alex Vinokur wrote:
> > 3. __PRETTY_FUNCTION__
> >     --FUNCTION__
>
> Since your other two examples were pretty cool-sounding I have to ask
about
> this one.  What the heck does __PRETTY_FUNCTION__ do?
>
>


Here is an example.

        Alex

//#########################################################
//------------------- C++ code : BEGIN -------------------

#include <iostream>
#include <string>


//==========================================
//------------------------------------------
void foo1 ()
{
        cout << __PRETTY_FUNCTION__ << endl;
}

//------------------------------------------
int foo2 (const string& s1_1, char c1_i)
{
        cout << __PRETTY_FUNCTION__ << endl;
        return 0;
}


//------------------------------------------
template <typename S1, typename S2, typename S3>
void foo3 (const S1& a1_i, S2& a2_i, S3 a3_i)
{
        cout << __PRETTY_FUNCTION__ << endl;
}


//------------------------------------------
template <typename S1, typename S2, typename S3>
void foo4 ()
{
        cout << __PRETTY_FUNCTION__ << endl;
}


//------------------------------------------
template <typename S0, typename S1, typename S2, typename S3>
S0 foo5 (const S1& a1_i, S2& a2_i, S3 a3_i)
{
        cout << __PRETTY_FUNCTION__ << endl;
        return S0 ();
}


//==========================================
class AAA
{
        public :
                //--------------------------
                void fooAAA1_1 ()
                {
                        cout << __PRETTY_FUNCTION__ << endl;
                }
                //--------------------------
                void fooAAA1_2 () const
                {
                        cout << __PRETTY_FUNCTION__ << endl;
                }
                //--------------------------
                static void fooAAA1_3 ()
                {
                        cout << __PRETTY_FUNCTION__ << endl;
                }
                //--------------------------
                int fooAAA2 (const string& s1_1, char c1_i)
                {
                        cout << __PRETTY_FUNCTION__ << endl;
                        return 0;
                }
                //--------------------------
                template <typename S1, typename S2, typename S3>
                void fooAAA3 (const S1& a1_i, S2& a2_i, S3 a3_i)
                {
                        cout << __PRETTY_FUNCTION__ << endl;
                }
                //--------------------------
                template <typename S1, typename S2, typename S3>
                void fooAAA4 ()
                {
                        cout << __PRETTY_FUNCTION__ << endl;
                }
                //--------------------------
                template <typename S0, typename S1, typename S2,
typename S3>
                S0 fooAAA5 (const S1& a1_i, S2& a2_i, S3 a3_i)
                {
                        cout << __PRETTY_FUNCTION__ << endl;
                        return S0 ();
                }
};



//==========================================
template <typename T1, typename T2>
class BBB
{
        public :
                //--------------------------
                void fooBBB1_1 ()
                {
                        cout << __PRETTY_FUNCTION__ << endl;
                }
                //--------------------------
                void fooBBB1_2 () const
                {
                        cout << __PRETTY_FUNCTION__ << endl;
                }
                //--------------------------
                static void fooBBB1_3 ()
                {
                        cout << __PRETTY_FUNCTION__ << endl;
                }
                //--------------------------
                int fooBBB2 (const string& s1_1, char c1_i)
                {
                        cout << __PRETTY_FUNCTION__ << endl;
                        return 0;
                }
                //--------------------------
                template <typename S1, typename S2, typename S3>
                void fooBBB3 (const S1& a1_i, S2& a2_i, S3 a3_i)
                {
                        cout << __PRETTY_FUNCTION__ << endl;
                }
                //--------------------------
                template <typename S1, typename S2, typename S3>
                void fooBBB4 ()
                {
                        cout << __PRETTY_FUNCTION__ << endl;
                }
                //--------------------------
                template <typename S0, typename S1, typename S2,
typename S3>
                S0 fooBBB5 (const S1& a1_i, S2& a2_i, S3 a3_i)
                {
                        cout << __PRETTY_FUNCTION__ << endl;
                        return S0 ();
                }
};

//==========================================
class XXX {};
class YYY {};
class ZZZ {};

//==========================================

int main ()
{
char            char_value      = 'Z';
int             int_value       = 123;
string          string_value    = "ABCDE";
XXX             XXX_value;
YYY             YYY_value;

        //===============================
        cout << endl;
        foo1 ();

        foo2 (string_value, char_value);

        foo3 (string_value, char_value, XXX_value);
        foo3 (YYY_value, char_value, XXX_value);

        foo4<YYY, int, string> ();
        foo4<YYY, XXX, YYY> ();

        foo5<int> (string_value, char_value, XXX_value);
        foo5<YYY> (char_value, int_value, XXX_value);

        //===============================
        cout << endl;

AAA     aaa;
        aaa.fooAAA1_1 ();

        aaa.fooAAA1_2 ();

        aaa.fooAAA1_3 ();

        aaa.fooAAA2 (string_value, char_value);

        aaa.fooAAA3 (string_value, char_value, XXX_value);
        aaa.fooAAA3 (YYY_value, char_value, XXX_value);

        aaa.template fooAAA4<YYY, int, string> ();
        aaa.template fooAAA4<YYY, XXX, YYY> ();

        aaa.template fooAAA5<int> (string_value, char_value, XXX_value);
        aaa.template fooAAA5<YYY> (char_value, int_value, XXX_value);


        //===============================
        cout << endl;

BBB<int, char>  bbb1;

        bbb1.fooBBB1_1 ();

        bbb1.fooBBB1_2 ();

        bbb1.fooBBB1_3 ();

        bbb1.fooBBB2 (string_value, char_value);

        bbb1.fooBBB3 (string_value, char_value, XXX_value);
        bbb1.fooBBB3 (YYY_value, char_value, XXX_value);

        bbb1.template fooBBB4<YYY, int, string> ();
        bbb1.template fooBBB4<YYY, XXX, YYY> ();

        bbb1.template fooBBB5<int> (string_value, char_value,
XXX_value);
        bbb1.template fooBBB5<YYY> (char_value, int_value, XXX_value);


        //===============================
        cout << endl;

BBB<XXX, int>   bbb2;

        bbb2.fooBBB1_1 ();

        bbb2.fooBBB1_2 ();

        bbb2.fooBBB1_3 ();

        bbb2.fooBBB2 (string_value, char_value);

        bbb2.fooBBB3 (string_value, char_value, XXX_value);
        bbb2.fooBBB3 (YYY_value, char_value, XXX_value);

        bbb2.template fooBBB4<YYY, int, string> ();
        bbb2.template fooBBB4<YYY, XXX, YYY> ();

        bbb2.template fooBBB5<int> (string_value, char_value,
XXX_value);
        bbb2.template fooBBB5<YYY> (char_value, int_value, XXX_value);

        //===============================
        cout << endl;
        bbb2.template fooBBB5<ZZZ> (bbb1, aaa, bbb2);
        return 0;
}


//------------------- C++ code : END ----------------------





//#########################################################
//------------------- Running Results : BEGIN -------------

void foo1()
int foo2(const class string &, char)
void foo3<string, char, XXX>(const class string &, char &, class XXX)
void foo3<YYY, char, XXX>(const class YYY &, char &, class XXX)
void foo4<YYY, int, string>()
void foo4<YYY, XXX, YYY>()
int foo5<int, string, char, XXX>(const class string &, char &, class
XXX)
class YYY foo5<YYY, char, int, XXX>(const char &, int &, class XXX)

void AAA::fooAAA1_1()
void AAA::fooAAA1_2() const
static void AAA::fooAAA1_3()
int AAA::fooAAA2(const class string &, char)
void AAA::fooAAA3<string, char, XXX>(const class string &, char &, class
XXX)
void AAA::fooAAA3<YYY, char, XXX>(const class YYY &, char &, class XXX)
void AAA::fooAAA4<YYY, int, string>()
void AAA::fooAAA4<YYY, XXX, YYY>()
int AAA::fooAAA5<int, string, char, XXX>(const class string &, char &,
class XXX)
class YYY AAA::fooAAA5<YYY, char, int, XXX>(const char &, int &, class
XXX)

void BBB<int,char>::fooBBB1_1<int, char>()    ### Attention ###
void BBB<int,char>::fooBBB1_2<int, char>() const    ### Attention ###
static void BBB<int,char>::fooBBB1_3<int, char>()    ### Attention ###
int BBB<int,char>::fooBBB2<int, char>(const class string &, char)    ###
Attention ###
void BBB<int,char>::fooBBB3<string, char, XXX>(const class string &,
char &, class XXX)
void BBB<int,char>::fooBBB3<YYY, char, XXX>(const class YYY &, char &,
class XXX)
void BBB<int,char>::fooBBB4<YYY, int, string>()
void BBB<int,char>::fooBBB4<YYY, XXX, YYY>()
int BBB<int,char>::fooBBB5<int, string, char, XXX>(const class string &,
char &, class XXX)
class YYY BBB<int,char>::fooBBB5<YYY, char, int, XXX>(const char &, int
&, class XXX)

void BBB<XXX,int>::fooBBB1_1<XXX, int>()    ### Attention ###
void BBB<XXX,int>::fooBBB1_2<XXX, int>() const    ### Attention ###
static void BBB<XXX,int>::fooBBB1_3<XXX, int>()    ### Attention ###
int BBB<XXX,int>::fooBBB2<XXX, int>(const class string &, char)    ###
Attention ###
void BBB<XXX,int>::fooBBB3<string, char, XXX>(const class string &, char
&, class XXX)
void BBB<XXX,int>::fooBBB3<YYY, char, XXX>(const class YYY &, char &,
class XXX)
void BBB<XXX,int>::fooBBB4<YYY, int, string>()
void BBB<XXX,int>::fooBBB4<YYY, XXX, YYY>()
int BBB<XXX,int>::fooBBB5<int, string, char, XXX>(const class string &,
char &, class XXX)
class YYY BBB<XXX,int>::fooBBB5<YYY, char, int, XXX>(const char &, int
&, class XXX)

class ZZZ BBB<XXX,int>::fooBBB5<ZZZ, BBB<int,char>, AAA,
BBB<XXX,int>>(const class BBB<int,char> &, class AAA &, class
BBB<XXX,int>)

//------------------- Running Results : END ---------------



//#########################################################
//------------------- Environment -------------------------

g++ -v     : gcc version egcs-2.91.57 19980901
             (egcs-1.1 release)

uname -sr  : SunOS 5.6

//---------------------------------------------------------



//#########################################################



Sent via Deja.com http://www.deja.com/
Before you buy.

  parent reply	other threads:[~2000-04-01  0:00 UTC|newest]

Thread overview: 12+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <386da233.0@news.tm.net.my>
     [not found] ` <84n59m$daj$1@nnrp1.deja.com>
     [not found]   ` <386fac89@eeyore.callnetuk.com>
2000-01-02 21:35     ` how to declare dynamic 2-dimensional array in C++? Alex Vinokur
2000-01-03  3:55       ` Johnny Favorite (it means "Writhing Tentacle of Death")
2000-01-03 10:16         ` Martin Ambuhl
2000-01-03 11:04           ` Greg Comeau
2000-04-01  0:00             ` Greg Comeau
2000-01-04  4:24           ` Johnny Favorite (it means "Writhing Tentacle of Death")
2000-04-01  0:00             ` Johnny Favorite (it means "Writhing Tentacle of Death")
2000-04-01  0:00           ` Martin Ambuhl
2000-01-04  5:55         ` Alex Vinokur [this message]
2000-04-01  0:00           ` __PRETTY_FUNCTION__, functions and templates Alex Vinokur
2000-04-01  0:00         ` how to declare dynamic 2-dimensional array in C++? Johnny Favorite (it means "Writhing Tentacle of Death")
2000-04-01  0:00       ` Alex Vinokur

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to='84st15$1uh$1@nnrp1.deja.com' \
    --to=alexander.vinokur@telrad.co.il \
    --cc=help-gcc@gnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).