diff options
Diffstat (limited to 'debian/uncrustify-trinity/uncrustify-trinity-0.75.0/src/align_oc_decl_colon.cpp')
-rw-r--r-- | debian/uncrustify-trinity/uncrustify-trinity-0.75.0/src/align_oc_decl_colon.cpp | 90 |
1 files changed, 90 insertions, 0 deletions
diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/src/align_oc_decl_colon.cpp b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/src/align_oc_decl_colon.cpp new file mode 100644 index 00000000..8c0bc078 --- /dev/null +++ b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/src/align_oc_decl_colon.cpp @@ -0,0 +1,90 @@ +/** + * @file align_oc_decl_colon.cpp + * + * @author Guy Maurel + * split from align.cpp + * @author Ben Gardner + * @license GPL v2+ + */ + +#include "align_oc_decl_colon.h" + +#include "align_stack.h" +#include "chunk.h" + + +using namespace uncrustify; + + +void align_oc_decl_colon(void) +{ + LOG_FUNC_ENTRY(); + + bool did_line; + AlignStack cas; // for the colons + AlignStack nas; // for the parameter label + + cas.Start(4); + nas.Start(4); + nas.m_right_align = !options::align_on_tabstop(); + + Chunk *pc = Chunk::GetHead(); + + while (pc->IsNotNullChunk()) + { + if (chunk_is_not_token(pc, CT_OC_SCOPE)) + { + pc = pc->GetNext(); + continue; + } + nas.Reset(); + cas.Reset(); + + size_t level = pc->level; + pc = pc->GetNextNcNnl(E_Scope::PREPROC); + + did_line = false; + + while ( pc->IsNotNullChunk() + && pc->level >= level) + { + // The declaration ends with an open brace or semicolon + if ( chunk_is_token(pc, CT_BRACE_OPEN) + || chunk_is_semicolon(pc)) + { + break; + } + + if (chunk_is_newline(pc)) + { + nas.NewLines(pc->nl_count); + cas.NewLines(pc->nl_count); + did_line = false; + } + else if ( !did_line + && chunk_is_token(pc, CT_OC_COLON)) + { + cas.Add(pc); + + Chunk *tmp = pc->GetPrev(E_Scope::PREPROC); + Chunk *tmp2 = tmp->GetPrevNcNnl(E_Scope::PREPROC); + + // Check for an un-labeled parameter + if ( ( chunk_is_token(tmp, CT_WORD) + || chunk_is_token(tmp, CT_TYPE) + || chunk_is_token(tmp, CT_OC_MSG_DECL) + || chunk_is_token(tmp, CT_OC_MSG_SPEC)) + && ( chunk_is_token(tmp2, CT_WORD) + || chunk_is_token(tmp2, CT_TYPE) + || chunk_is_token(tmp2, CT_PAREN_CLOSE))) + { + nas.Add(tmp); + } + did_line = true; + } + pc = pc->GetNext(E_Scope::PREPROC); + } + nas.End(); + cas.End(); + } +} // align_oc_decl_colon |