|
I would imagine Christian would have a good idea which direction the compiler should try first. He seems to have researched this type of stuff. Interesting question.
Tim Smith
I'm going to patent thought. I have yet to see any prior art.
|
|
|
|
|
*grin* I actually answered and then read your answer, expecting you to have said the same, but leaping in anyhow, because Microsoft are correct. char to int is guarenteed in the standard. You can do this:
char a = 65;
and this
int a = 'a';
so it stands to reason that the compiler will attempt that conversion.
Christian
No offense, but I don't really want to encourage the creation of another VB developer.
- Larry Antram 22 Oct 2002
C# will attract all comers, where VB is for IT Journalists and managers - Michael
P Butler 05-12-2002
Again, you can screw up a C/C++ program just as easily as a VB program. OK, maybe not
as easily, but it's certainly doable. - Jamie Nordmeyer - 15-Nov-2002
|
|
|
|
|
Joe Woodbury wrote:
It will even pick int over wchar_t.
In standard C++, conversion between char and int is implicit.
Joe Woodbury wrote:
char should pick wchar_t before to int, or at least a switch should be available to force this behavior.
I disagree. char to int is embedded in the C++ standard.
Christian
No offense, but I don't really want to encourage the creation of another VB developer.
- Larry Antram 22 Oct 2002
C# will attract all comers, where VB is for IT Journalists and managers - Michael
P Butler 05-12-2002
Again, you can screw up a C/C++ program just as easily as a VB program. OK, maybe not
as easily, but it's certainly doable. - Jamie Nordmeyer - 15-Nov-2002
|
|
|
|
|
Christian Graus wrote:
In standard C++, conversion between char and int is implicit.
... char to int is embedded in the C++ standard.
Close.
After some research and reading I realized why the compiler is behaving the way it is. When trying to determine which overloaded function to use, if an exact match is not found, the compiler then checks promotions, then conversions.
char to int is a promotion.
char to wchar_t is a conversion. (char is is a numeric value that can represent an ASCII character (0-127) and by definition, the first 127 characters of UNICODE exactly match ASCII. Thus, if the char is in the range 0-127, it appears to be a promotion. However, since by defintion char is a numeric value and wchar_t is a character value, it still is a conversion.)
Anything "going to" a bool, except true or false (or an expression that resolves to true or false), is a conversion, thus the ambiguity I encountered. I still believe, however, that any conversion should take precedence over a conversion to bool.
(I still firmly believe conversions to bool should be optionally disallowed.)
|
|
|
|
|
What might be part of the problem here is that char is signed and wchar_t is unsigned. Thus char -> wchar_t is a degenerative conversion given that over half the range of char can not be properly mapped to wchar_t. However, char -> bool is a well defined conversion given that char fully maps into a bool.
Tim Smith
I'm going to patent thought. I have yet to see any prior art.
|
|
|
|
|
How icon run my program as any programs in computer,for example i programmed an organizer and i want to run it as any programms,how i can build it ,,any one help me?
|
|
|
|
|
BOOL CWnd::GetWindowPlacement(WINDOWPLACEMENT* lpwndpl) const
{
<code>ASSERT(::IsWindow(m_hWnd));</code>
lpwndpl->length = sizeof(WINDOWPLACEMENT);
return ::GetWindowPlacement(m_hWnd, lpwndpl);
}
Crash says its not a window. However in my code I am getting a nonNUll pointer:
for (int i = 0 ; i <imageDisplayVectorsize ; i++)
{
CImageDisplay* imageDisplay =ImageDisplayVector[i];
imageDisplay->GetWindowPlacement(&wp);
I've used my ImageDisplayVector elsewhere as
int vecSize = ImageDisplayVector.size();
for (int i = 0; i < vecSize; i++)
{
CImageDisplay * pImageTemp = ImageDisplayVector[i];
pImageTemp->ShowWindow(SW_SHOW);
}
and the windows show up (first I'd hidden them) with no problem. Which makes me think my pointer is fine.
SO why does the GetWindowPl think its not a window?
How shall I approach the debugging of this problem?
Appreciate your help,
ns
|
|
|
|
|
Hello Everybody:
This is the weirdest thing that I experienced with MFC. In a project that I'm working, there is a class that is derived from a CScrollView that displays images. When I run the program and the CScrollView is visible on the screen, sometimes it shows up as a text editor. It stays as an text editor and the images shows up. There are some occasions that the text editor just stays there. By any chance any of you guys experienced this before? Any place that you guys can suggest that I can start looking? It's been hard to spot because the code is written by someone else. I tried in the CScrollView's OnInitialUpdate and I don't find anything. This is happens in a Win2k and a WinXP machine. Any answer is more than welcome.
Best regards,
Luis E. Cuadrado
)
|
|
|
|
|
I spent a while debugging this.:
I had a loop:
for (int i = 0; i &< nSize; i++) ;
{
vec[i]->someMethod();
}
where I was storing pointers to a class in the STL vector.
Well, eventually I saw why my code was crashing......(the . What puzzles me is that the variable i was still holding its final value of nSize + 1 when it finished with the for(). Besides which my code should have complained that i was not declared.....since its within the for ....
Maybe i am wrong in my scope assumptions?
Appreciate your help,
ns
|
|
|
|
|
Declaring a variable inside the for() is the same as declaring it outside the for(). I'd certainly prefer this not to be the case. As an aside you should be using STL iterators.
Neville Franks, Author of ED for Windows. www.getsoft.com
Make money with our new Affilate program
|
|
|
|
|
I could...but thats the appeal of an STL vector for me instead of some other container- accessing by index ............ But it would save me from this sort of mishap
Thanks much. I was mistaken in my scoping assumption then.....
Appreciate your help,
ns
|
|
|
|
|
ns wrote:
I was mistaken in my scoping assumption
Actually, you're right. Microsoft is wrong in this case. Very annoying when you're trying to code for multiple platforms.
he he he. I like it in the kitchen! - Marc Clifton (on taking the heat when being flamed)
Awasu v0.4a[^]: A free RSS reader with support for Code Project.
|
|
|
|
|
Hasn't this change been introduced only recently to the standard?
And, although it solves a common nuisance, it can make existing code break silently (though admittedly badly written). A bad move, I'd say...
Those who not hear the music think the dancers are mad. [sighist] [Agile Programming]
|
|
|
|
|
peterchen wrote:
Hasn't this change been introduced only recently to the standard?
Depends if you work for Microsoft and/or consider half a decade to be "recent", or if you consider the ISO C++ standard to be a document Microsoft should follow.
|
|
|
|
|
As I understand it, this was in the proposed revisions, then taken out, then put back in.
If you want the standards behavior you can add extra braces:
{for (int i = 0; i < 10; i++)<br />
{<br />
...<br />
}}
Incidentally, you can turn this enforcement on in VC++.NET.
|
|
|
|
|
Joe Woodbury wrote:
Incidentally, you can turn this enforcement on in VC++.NET.
That might be what you believe, and what Micros~1 wants to fool you into believing - the truth is that you're only screwed from the side, and not directly from behind, with that "fix".
for (int i=...) {}<br />
for (short i=...) {<br />
}
|
|
|
|
|
Mike Nordell wrote:
for (int i=...) {}
for (short i=...) {
// guess type of 'i'
}
short
I just checked (and it does what it advertises.)
|
|
|
|
|
ns wrote:
What puzzles me is that the variable i was still holding its final value ...
This is a well known bug in Microsofts compilers, and even in their "latest and greatest" the bug persists, only in a much more evil form:
for (int i=...) {}<br />
for (short i= ...) {<br />
}
There is but one solution to this problem: To the top of every source file wanting to keep scope of for-loop-variables, add
#ifdef _MSC_VER<br />
#define for if(0) {} else for<br />
#endif
|
|
|
|
|
But his snippet has nothing to do with the "well known" bug?! Or am I missing something?
Those who not hear the music think the dancers are mad. [sighist] [Agile Programming]
|
|
|
|
|
peterchen wrote:
But his snippet has nothing to do with the "well known" bug?!
Yes it has.
Or am I missing something?
Yes you are. This is about scoping of for-loop-variables. Once the for-loop is ended (in the example the terminating semicolon), 'i' is no longer valid. Yet, inside the (artificial and superflous) scope; 'i', which is no more (if following international rules, which MS are not), is still accessible from the broken compiler(s).
|
|
|
|
|
Actually, there's a peculiar inconsistancy with the standard. The opening brace of a for loop is essentially considered superfluous and a hidden brace is implied as being before the declaration.
However, in a do loop, the closing brace is NOT considered to be after the while condition. (Frankly, I wish it were, but it isn't.)
Finally, in Visual Studio .NET, you can turn on enforcement of the standard for scopes of for loops (/Zc:forScope) You can also turn off Microsoft extensions.
|
|
|
|
|
Hi,
I'm trying to set up doxygen, and encountered two things I can't figure out:
1) Can I automatically put all sources of one folder (and below) into a documentaiton module? (i.e. without touching every file in the folder)
2) I'm can't figure out how to get the following handling of undocumented members:
- they should be listed in the class overview
- the detailed spec should not contain them
Any doxy wizards around here?
TIA
Peter
Those who not hear the music think the dancers are mad. [sighist] [Agile Programming]
|
|
|
|
|
peterchen wrote:
Can I automatically put all sources of one folder (and below) into a documentaiton module
There's a RECURSIVE flag in the config file that you can turn on. In conjunction with FILE_PATTERNS, you can control what gets processed.
Not quit sure what you mean by #2. If you mean they should appear in the list of public methods but not have a detailed description further down the page, isn't that what happens anyway. I either totally ignore undocumented methods or document them
he he he. I like it in the kitchen! - Marc Clifton (on taking the heat when being flamed)
Awasu v0.4a[^]: A free RSS reader with support for Code Project.
|
|
|
|
|
Thanks!
#1) When using the recursive flag, everything is documented at the same level. However, with the following structure:
FooLib\
BarDll\
Appl\
I'd like to have sth. like "Project FooLib", "Project BarLib" etc. as oder criteria. If I udnerstand correctly that's what I can somehow achieve with the \ingroup / \addtogroup / \defgroup identifiers, but I didn't get it working at all.
#2) for the class:
struct CBar
{
void Documented();
void Undocumented();
}
I get the following HTML (rougly):
struct CBar
public methods:
void Documented();
Documented Method
void Undocumented(); (1)
Details:
void Documented()
Documented Method.
This one has been documented
implemented in bar.cpp, line 22
void Undocumented() (2)
implemented in bar.cpp, line 77
I played around, I either have both (1) and (2), or none of them. What I'd like is (1), but not (2).
Part of the project is a large code base with very irregular comments (can't auto-convert into doxygen style). I'd like to progressively touch up the parts I'm working on anyway, but I have no chance to document everything on one run. Yet I'd like to see the member listing, but without the bulky information-free details section.
Those who not hear the music think the dancers are mad. [sighist] [Agile Programming]
|
|
|
|
|
peterchen wrote:
I'd like to have sth. like "Project FooLib", "Project BarLib" etc. as oder criteria.
Trying to do this with Doxygen would be pretty hairy I would create a separate project for each one which is a better solution anyway, IMO. I have a Python script that I run every night which walks our directory tree building MSVC and Doxygen projects. It then creates an index page that links to the output of every Doxygen project that it built.
For #2, there is a way to turn off the detailed entries if you don't explicitly provide any documentation. Look at ALWAYS_DETAILED_SEC although you might need a combination of switches. Otherwise, I suspect it probably can't be done. You could always sumbit a feature request. Or do it yourself
You might want to take a look at DocJet[^] as well. It's not free but it doesn't require tags and does a reasonable sort of a job figuring out what your comments mean.
he he he. I like it in the kitchen! - Marc Clifton (on taking the heat when being flamed)
Awasu v0.4a[^]: A free RSS reader with support for Code Project.
|
|
|
|