-
Notifications
You must be signed in to change notification settings - Fork 296
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
Proposing: removing lines with more than one statements. #1114
Conversation
I agree this way is more readible for both us and the the software tools |
Another style question: void GridBase::addKernel( const KernelFunctions& kernel ) {
plumed_dbg_assert( kernel.ndim()==dimension_ );
std::vector<unsigned> nneighb=kernel.getSupport( dx_ );
std::vector<index_t> neighbors=getNeighbors( kernel.getCenter(), nneighb );
std::vector<double> xx( dimension_ );
std::vector<std::unique_ptr<Value>> vv( dimension_ );
std::string str_min, str_max;
for(unsigned i=0; i<dimension_; ++i) {
vv[i]=Tools::make_unique<Value>();
if( pbc_[i] ) {
Tools::convert(min_[i],str_min);
Tools::convert(max_[i],str_max);
vv[i]->setDomain( str_min, str_max );
} else {
vv[i]->setNotPeriodic();
}
}
// vv_ptr contains plain pointers obtained from vv.
// this is the simplest way to replace a unique_ptr here.
// perhaps the interface of kernel.evaluate() should be changed
// in order to accept a std::vector<std::unique_ptr<Value>>
auto vv_ptr=Tools::unique2raw(vv);
std::vector<double> der( dimension_ );
for(unsigned i=0; i<neighbors.size(); ++i) {
index_t ineigh=neighbors[i];
getPoint( ineigh, xx );
for(unsigned j=0; j<dimension_; ++j)
vv[j]->set(xx[j]);
double newval = kernel.evaluate( vv_ptr, der, usederiv_ );
if( usederiv_ )
addValueAndDerivatives( ineigh, newval, der );
else
addValue( ineigh, newval );
}
} where we have both a } else {
vv[i]->setNotPeriodic();
} an one-line statement with braces, and a for(unsigned j=0; j<dimension_; ++j)
vv[j]->set(xx[j]);
double newval = kernel.evaluate( vv_ptr, der, usederiv_ );
if( usederiv_ )
addValueAndDerivatives( ineigh, newval, der );
else
addValue( ineigh, newval ); a series of one-line statements without braces
I prefer having the braces both for clarity and things like faster "printf-debugging" (since you will need to add the braces in case you'd want to add something to the cycle/branch anyway), and in any case in case you forgot them astyle will put them for you. Having the braces, in my opinion, makes also nested for/if easier to understand for(unsigned j=0; j<dimension_; ++j) {
fd[j]=D[j];
for(unsigned i=0; i<dimension_; ++i)
if(i!=j)
fd[j]*=C[i];
} for(unsigned j=0; j<dimension_; ++j) {
fd[j]=D[j];
for(unsigned i=0; i<dimension_; ++i) {
if(i!=j) {
fd[j]*=C[i];
}
}
} The compiler will not care but the reader (and future you) surely will |
I agree. I see that sometime having no newline can make the code more compact. However:
So I agree in having a new line after an if or for statement. As long as we have a new line, I think braces should be there for clarity. With more and more people using python daily, we need to avoid ambiguous code such as:
|
The state is now far more strict than before: for(int i=0; i<2; i++) for(int j=0; j<2; j++) for(int k=0; k<2; k++) shifts[i][j][k].clear(); became this for(int i=0; i<2; i++)
for(int j=0; j<2; j++)
for(int k=0; k<2; k++) {
shifts[i][j][k].clear();
} but not this for(int i=0; i<2; i++) {
for(int j=0; j<2; j++) {
for(int k=0; k<2; k++) {
shifts[i][j][k].clear();
}
}
} I do not think that astyle enforces this passage (at least, I am convinced about this because I did not find the option in the manual), but both versions pass the style check, and changing code manually is a Still is clearer, and can be done atomically when someone edits that file and happens to remember that Apart from that this is fine and ready we'll need to open an issue or something like that for external contributors that are developing on older branches with the series of instructions like: git merge hash-2.9-before-format
git merge -s ours hash-2.9-after-format
make astyle
git merge v2.9 |
This sentence is not true anymore, to do that I would need to check more or less every file, merge hash-before-this-pr
merge -s ours hash-of-this-pr
# some other commands in the middle
git checkout hash-of-this-pr .astyle.options
make astyle
# finalize the commit All the comment editing will need to be redone by hand for each misplaced comment :/ |
shall we move on with this? |
I think so, And I think I need to rebase this to the current 2.9 before |
@carlocamilloni |
then let's start.. |
Description
Don't merge this right now.
I am starting from the v2.9 since v2.10 bumped from C++11 to C++17 and so I think that v2.9 will be maintained a little longer.
I am changing the astyle settings to have 1 line 1 operation, this should make the code more diff friendly and more readable.
This should also make the coverage by line more accurate
Another thing that this PR will help with is some comments like this:
that (I think) they are not as clear as they should be:
When everything is clear I will squash everything in a single commit and remove the "legacy option" from astyle
Target release
I would like my code to appear in release v2.9++
Type of contribution
Copyright
COPYRIGHT
file with the correct license information. Code should be released under an open source license. I also used the commandcd src && ./header.sh mymodulename
in order to make sure the headers of the module are correct.Tests