Whole Tomato Software Forums
Whole Tomato Software Forums
Main Site | Profile | Register | Active Topics | Members | Search | FAQ
User name:
Password:
Save Password
Forgot your password?

 All Forums
 Visual Assist
 Feature Requests
 Default arguments (C++)
 New Topic  Reply to Topic
 Printer Friendly
Author Previous Topic Topic Next Topic  

tom_seddon
Tomato Guru

162 Posts

Posted - Oct 14 2009 :  09:57:00 AM  Show Profile  Reply with Quote
It would be useful if the parameter list suggestion that you get when typing a function definition didn't (or, at least, could optionally not) include the default arguments. This is mainly because they are added in using /*...*/, which is annoying as it makes it hard to reliably comment out large blocks of code using /*...*/. (I feel that tools should never introduce block comments, for this reason.)

I don't mind continuing to carefully remove them every time this happens, but it's a bit annoying.

khb
Tomato Guru

Germany
337 Posts

Posted - Oct 15 2009 :  10:11:23 AM  Show Profile  Reply with Quote
I like that behavior. So when it is going to be modified then please do it by option so that I can keep the current behavior.

Regards
Marcus
Go to Top of Page

feline
Whole Tomato Software

United Kingdom
19073 Posts

Posted - Oct 15 2009 :  12:45:34 PM  Show Profile  Reply with Quote
We are considering adding an option to control this:

case=3495


For now, take this simple C++ code:

void simpleWithDefaults(int nParam1 /* = 2 */, int nParam2 /* = 3 */)
{ }


Select these two lines and press * to tell VA to surround them with a block comment, and you get:

/*
void simpleWithDefaults(int nParam1 / * = 2 * /, int nParam2 / * = 3 * /)
{ }
*/


Note that the block comments for the parameters have been "fixed" so they do not break the wrapper block comment. If you later on select the comment block and press * to uncomment it VA will return the comments on the parameters to their correct form.

zen is the art of being at one with the two'ness
Go to Top of Page

Luke1410
Senior Member

32 Posts

Posted - Oct 19 2009 :  11:01:45 AM  Show Profile  Reply with Quote
We'd also like to be able to set VAX not to include default parameter comments at all when using the rafactoring methods as originally requested by Tom.
Even though the planned case 3495 would improve the situation, it doesn't really help with the case where we add manually /* and */ (which for us is a much more likely scenario, since we could already use VAX //-comment feature, if we wanted to use VAX to comment out code blocks).
Go to Top of Page

feline
Whole Tomato Software

United Kingdom
19073 Posts

Posted - Oct 19 2009 :  3:37:02 PM  Show Profile  Reply with Quote
The idea of case=3495 is that you can tell VA to never add the defaults to the implementations, even when using refactoring commands to generate the implementations.

Another option is to wrap the code to comment out in #if 0, #endif. I know this is another work around, but you might find the idea helpful.

zen is the art of being at one with the two'ness
Go to Top of Page

znakeeye
Tomato Guru

379 Posts

Posted - Oct 20 2009 :  03:53:01 AM  Show Profile  Reply with Quote
Personally, I find it annoying that a leading and trailing space is added to the comment.

foo(int x /* = 0 */){}

I don't like it. If I remove the comment there are two spaces there, which is bad styling.

Actually, the "misuse" of spaces is one of the reasons I don't use VAX refactoring.
Go to Top of Page

andre.horst
Tomato Guru

Germany
150 Posts

Posted - Oct 20 2009 :  05:24:45 AM  Show Profile  Reply with Quote
What about a snippet for this?
$SymbolType$ $SymbolContext$( $ParameterListWithOutcommentedArgs$ ) $MethodQualifier$
{
$end$$MethodBody$
}

And of course there could be two different out-commenting refactorings.

void foo( int i /* = 10 */ )
{}

or

void foo( int i1 // = 10
          int i2 // = 20
        )
{
}
{}
Go to Top of Page

feline
Whole Tomato Software

United Kingdom
19073 Posts

Posted - Oct 20 2009 :  12:08:07 PM  Show Profile  Reply with Quote
znakeeye details of white space formatting, some of this you can change by editing the VA refactoring snippets. Some of it... to provide "total" control would require a LARGE number of formatting options, and get us heavily into code formatting, which is not something we want to do right now.

Plus this is the implementation, removing the comment block leaves you with invalid code, the default parameter can only be specified on the declaration.

andre.horst this would probably be done as a VA option, and not via the refactoring snippet, since changing the snippet would not help the case where you type the function name manually, and accept the parameter portion via a tooltip.

Making the declaration multi line like this just invites extra problems with Change Signature and other refactoring commands, since multi-line declarations open up a whole pile of edge cases, and thats before you start looking at code formatting.

zen is the art of being at one with the two'ness
Go to Top of Page

znakeeye
Tomato Guru

379 Posts

Posted - Oct 21 2009 :  04:36:37 AM  Show Profile  Reply with Quote
It surprises me that you don't want to get into code-formatting. With an AST of the source code (which I assume you have), it's like two days of coding - INCLUDING a lot of styling-options.
Go to Top of Page

feline
Whole Tomato Software

United Kingdom
19073 Posts

Posted - Oct 21 2009 :  10:31:58 AM  Show Profile  Reply with Quote
This is very optimistic on your part. I once spent quite a lot of time looking into GC

http://sourceforge.net/projects/gcgreatcode/

trying to make it do exactly what I wanted. It has a LOT of options, so it would take a lot more than 2 days just to define how all of the different options would interact, and outline one test per combination of options. After all, the code does have to be tested before it is released.

Remember you also need to deal with Tabs vs Spaces, different tab indents, macro's, invalid code, etc. The more you think about code formatting the harder it gets.

zen is the art of being at one with the two'ness
Go to Top of Page

drac
Senior Member

Germany
49 Posts

Posted - Oct 21 2009 :  12:57:03 PM  Show Profile  Reply with Quote
quote:
Originally posted by feline

This is very optimistic on your part. I once spent quite a lot of time looking into GC

http://sourceforge.net/projects/gcgreatcode/

Remember you also need to deal with Tabs vs Spaces, different tab indents, macro's, invalid code, etc. The more you think about code formatting the harder it gets.



It would be a good idea to have that time invested and not spent. You already did the research, there is a starting point why not just continue?

Write down all the enumerated things to know the requirements and start hacking the code.

Because it's not easy that's why VA should have it!
Go to Top of Page

feline
Whole Tomato Software

United Kingdom
19073 Posts

Posted - Oct 22 2009 :  09:36:48 AM  Show Profile  Reply with Quote
My mistake, I was not as clear as I should have been. The time spent with GC was at my old job, when I was trying to make it format code according to the companies code standards, and even after quite a lot of time I did not manage to achieve the desired result. This was quite worrying, when you consider just how MANY options GC has for code formatting.

Code formatting is one of those things that people thing is simple, but everyone who wants it seems to want their code formatted differently, and normally with a very high degree of control over "minor" spacing and formatting. This is going to require a LOT of options, and a lot of code to do this, all of which has to work without getting in the way of or breaking anything else.

It may happen one day, but not right now. Our current focus is on getting support for VS2010 up and running properly, since this is something we need to address and cannot ignore.

zen is the art of being at one with the two'ness
Go to Top of Page

sean
Whole Tomato Software

USA
2817 Posts

Posted - Jun 26 2014 :  01:50:35 AM  Show Profile  Reply with Quote
case=3495 is implemented in build 2042 (see Refactoring page of VA Options dialog).
Go to Top of Page
  Previous Topic Topic Next Topic  
 New Topic  Reply to Topic
 Printer Friendly
Jump To:
© 2023 Whole Tomato Software, LLC Go To Top Of Page
Snitz Forums 2000