summaryrefslogtreecommitdiffstats
path: root/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/src/align_oc_decl_colon.cpp
diff options
context:
space:
mode:
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.cpp90
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