preprocessor and character literal ('#letter')

B

Boris Du¹ek

Hi,

I have trouble defining a macro - see the following code:

#define LETTER_STRAIGHT(let) let = L'#let'

enum Letter {
LETTER_STRAIGHT(A),
LETTER_STRAIGHT(B),
LETTER_STRAIGHT(C),
};

I want it to expand to this:

enum Letter {
A = L'A',
B = L'B',
C = L'C',
};

However looking at the preprocessing output, it expands to this:

enum Letter {
A = L'#let',
B = L'#let',
C = L'#let',
};

How do I achieve the expansion in the way I want?

Thanks, Boris
 
D

dascandy

#define LETTER_STRAIGHT(let) let = L'#let'
enum Letter {
    A = L'#let',
    B = L'#let',
    C = L'#let',

};

You could try

#define LETTER_STRAIGHT(let) let = L#let[0]

which should create
enum Letter {
A = L"A"[0],
B = L"B"[0],
C = L"C"[0],

};

which should be functionally equivalent. You can't create a single
char with preprocessor macros - it's always a string. You can then use
the first char of that string, iirc.
 
J

James Kanze

You could try
#define LETTER_STRAIGHT(let) let = L#let[0]
which should create
enum Letter {
    A = L"A"[0],
    B = L"B"[0],
    C = L"C"[0],
};
which should be functionally equivalent. You can't create a
single char with preprocessor macros - it's always a string.
You can then use the first char of that string, iirc.

You can, but the result of a dereferce operator is never a
constant expression, even if you're dereferencing a string
literal, so it can't be used as the initializer of an enum
constant (or an array dimension, or a template argument).

There are a number of different work-arounds possible, but
without knowing what problem he's trying to solve, it's
difficult to recommand any. Off hand, I don't see what the
problem is in writing:

enum Letter
{
A = L'A',
B = L'B',
C = L'C'
} ;

directly.
 
J

Juha Nieminen

James said:
Off hand, I don't see what the
problem is in writing:

enum Letter
{
A = L'A',
B = L'B',
C = L'C'
} ;

directly.

Maybe he is trying to abstract the precise character type (L) away?
 
B

Boris Du¹ek

#define LETTER_STRAIGHT(let) let = L#let[0]
which should create
enum Letter {
    A = L"A"[0],
    B = L"B"[0],
    C = L"C"[0],
};
which should be functionally equivalent. You can't create a
single char with preprocessor macros - it's always a string.
You can then use the first char of that string, iirc.

You can, but the result of a dereferce operator is never a
constant expression

Right, the compiler complains about that.
difficult to recommand any.  Off hand, I don't see what the
problem is in writing:

    enum Letter
    {
        A = L'A',
        B = L'B',
        C = L'C'
    } ;

directly.

I had to write something like 100 enum values, so having a macro that
saves typing (if you copy/paste the line 100 times and then just
change one letter) and that helps avoiding a mistake that would result
from forgetting to change the right-hand side when I changed the left-
hand side is a plus. But I used vim to easily change it to the
explicit form, now it of course works.

What I am doing is that I want to include Unicode codepoints for all
letters in Czech alphabet (i.e. asides from English alphabet, 15 more
like ì¹èø¾ýáíé) into the enum, and then define uppercasing,
lowercasing and asciifying (é -> e) tables using these enum values
rather than the codepoints directly. I want to avoid relying on cs_CZ
or Czech locale, since i.e. Mac OS X's support for locale is basically
non-existent (i.e. even std::locale("") throws std::runtime_error; the
same for std::locale("cs_CZ") or any other even if it is present in /
usr/share/locale). So I have to have my own conversion tables. And
btw., the goal of all of this is to write an app that tries its best
to deasciify an asciified text.

Thanks to both of you for your ideas,
Boris
 
J

James Kanze

#define LETTER_STRAIGHT(let) let = L#let[0]
which should create
enum Letter {
    A = L"A"[0],
    B = L"B"[0],
    C = L"C"[0],
};
which should be functionally equivalent. You can't create
a single char with preprocessor macros - it's always a
string. You can then use the first char of that string,
iirc.
You can, but the result of a dereferce operator is never a
constant expression
Right, the compiler complains about that.
I had to write something like 100 enum values, so having a
macro that saves typing (if you copy/paste the line 100 times
and then just change one letter) and that helps avoiding a
mistake that would result from forgetting to change the
right-hand side when I changed the left- hand side is a plus.
But I used vim to easily change it to the explicit form, now
it of course works.

Exactly. Any decent editor will be able to handle this.
What I am doing is that I want to include Unicode codepoints
for all letters in Czech alphabet (i.e. asides from English
alphabet, 15 more like ì¹èø¾ýáíé) into the enum, and then
define uppercasing, lowercasing and asciifying (é -> e) tables
using these enum values rather than the codepoints directly.

That actually sounds like a pretty reasonable thing to do. I'd
write a simple AWK script, however, to generate the whole thing
from a simple two column list: the wide character and its ascii
equivalent.
 
A

Alexey Stepanyan

Hi,

I have trouble defining a macro - see the following code:

#define LETTER_STRAIGHT(let) let = L'#let'

enum Letter {
    LETTER_STRAIGHT(A),
    LETTER_STRAIGHT(B),
    LETTER_STRAIGHT(C),

};

I want it to expand to this:

enum Letter {
    A = L'A',
    B = L'B',
    C = L'C',

};

However looking at the preprocessing output, it expands to this:

enum Letter {
    A = L'#let',
    B = L'#let',
    C = L'#let',

};

How do I achieve the expansion in the way I want?

Thanks, Boris

There is a Microsoft specific solution - charizing operator:
#define LETTER_STRAIGHT(let) let = L#@let

Thanks, Alexey.
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Members online

Forum statistics

Threads
474,169
Messages
2,570,918
Members
47,458
Latest member
Chris#

Latest Threads

Top