Re: [PATCH] Updated C# userdiff patterns.

2014-04-27 Thread Marius Ungureanu

On 26 Apr 2014, at 21:50, Johannes Sixt j...@kdbg.org wrote:

 Am 26.04.2014 20:33, schrieb Marius Ungureanu:
 ... add as many unit tests I can.
 
 Great! Keep in mind that quantity is secondary. Quality counts.

Obviously. By ‘as many’, I meant to cover all the cases here.

 I’ll start a new thread with the new
 patch as soon as I’m done with it.
 
 If possible, do not start a new thread, but post your new patch as a
 reply in this thread.
 

Okay, understood.

 Thanks,
 -- Hannes
 

Thanks,
Marius

--
To unsubscribe from this list: send the line unsubscribe git in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH] Updated C# userdiff patterns.

2014-04-27 Thread Marius Ungureanu
Heya, so I’ll add the patches in the next 2 emails.

I’ve changed a bit the main body of the methods/constructors regex.

Basically, I’ve made the first item after the modifiers optional. That’s
the return type and it’s not used in any case by operator overloads
or constructors/destructors.

I also added lots of symbols to the name of the function. Those are
the symbols of the operators that the language allows you to overload.

Thanks in advance,
Marius.--
To unsubscribe from this list: send the line unsubscribe git in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH 1/2] update C# userdiff patterns

2014-04-27 Thread Marius Ungureanu
Remove all keywords since they don't cause conflicts.

Add method modifiers: abstract, async, explicit, extern, implicit,
partial, operator.

Add properties modifiers: abstract, readonly.

Add type modifiers: abstract.

Parse C# operator functions.

Fix constructor parsing.

Signed-off-by: Marius Ungureanu marius.ungure...@xamarin.com
---
 userdiff.c | 8 +++-
 1 file changed, 3 insertions(+), 5 deletions(-)

diff --git a/userdiff.c b/userdiff.c
index fad52d6..e7ba5e3 100644
--- a/userdiff.c
+++ b/userdiff.c
@@ -133,14 +133,12 @@ PATTERNS(cpp,
 |[-+0-9.e]+[fFlL]?|0[xXbB]?[0-9a-fA-F]+[lLuU]*
 |[-+*/%^|=!]=|--|\\+\\+|=?|=?||\\|\\||::|-\\*?|\\.\\*),
 PATTERNS(csharp,
-/* Keywords */
-!^[ 
\t]*(do|while|for|if|else|instanceof|new|return|switch|case|throw|catch|using)\n
 /* Methods and constructors */
-^[ 
\t]*(((static|public|internal|private|protected|new|virtual|sealed|override|unsafe)[
 \t]+)*[][@.~_[:alnum:]]+[ \t]+[@._[:alnum:]]+[ \t]*\\(.*\\))[ \t]*$\n
+^[ 
\t]*(((abstract|async|explicit|extern|implicit|internal|new|operator|override|partial|private|protected|public|sealed|static|unsafe|virtual)[
 \t]+)*[][@._[:alnum:]]*[ \t]*[-@.~=+!*%|^_[:alnum:]]+[ \t]*\\(.*\\))[ 
\t]*$\n
 /* Properties */
-^[ 
\t]*(((static|public|internal|private|protected|new|virtual|sealed|override|unsafe)[
 \t]+)*[][@.~_[:alnum:]]+[ \t]+[@._[:alnum:]]+)[ \t]*$\n
+^[ 
\t]*(((abstract|internal|new|override|private|protected|public|readonly|sealed|static|unsafe|virtual)[
 \t]+)*[][@.~_[:alnum:]]+[ \t]+[@._[:alnum:]]+)[ \t]*$\n
 /* Type definitions */
-^[ 
\t]*(((static|public|internal|private|protected|new|unsafe|sealed|abstract|partial)[
 \t]+)*(class|enum|interface|struct)[ \t]+.*)$\n
+^[ 
\t]*(((abstract|internal|new|override|partial|private|protected|public|sealed|static|unsafe)[
 \t]+)*(class|enum|interface|struct)[ \t]+.*)$\n
 /* Namespace */
 ^[ \t]*(namespace[ \t]+.*)$,
 /* -- */
-- 
1.8.4


--
To unsubscribe from this list: send the line unsubscribe git in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH 2/2] add csharp userdiff tests

2014-04-27 Thread Marius Ungureanu

---
 t/t4018/csharp-constructor | 4 
 t/t4018/csharp-destructor  | 4 
 t/t4018/csharp-function| 4 
 t/t4018/csharp-member  | 4 
 t/t4018/csharp-namespace   | 4 
 t/t4018/csharp-operator| 4 
 t/t4018/csharp-property| 4 
 t/t4018/csharp-skip-call   | 5 +
 8 files changed, 33 insertions(+)
 create mode 100644 t/t4018/csharp-constructor
 create mode 100644 t/t4018/csharp-destructor
 create mode 100644 t/t4018/csharp-function
 create mode 100644 t/t4018/csharp-member
 create mode 100644 t/t4018/csharp-namespace
 create mode 100644 t/t4018/csharp-operator
 create mode 100644 t/t4018/csharp-property
 create mode 100644 t/t4018/csharp-skip-call

diff --git a/t/t4018/csharp-constructor b/t/t4018/csharp-constructor
new file mode 100644
index 000..a39cffb
--- /dev/null
+++ b/t/t4018/csharp-constructor
@@ -0,0 +1,4 @@
+MyClass(RIGHT)
+{
+   ChangeMe;
+}
diff --git a/t/t4018/csharp-destructor b/t/t4018/csharp-destructor
new file mode 100644
index 000..55106d9
--- /dev/null
+++ b/t/t4018/csharp-destructor
@@ -0,0 +1,4 @@
+~MyClass(RIGHT)
+{
+   ChangeMe;
+}
diff --git a/t/t4018/csharp-function b/t/t4018/csharp-function
new file mode 100644
index 000..a5d59a3
--- /dev/null
+++ b/t/t4018/csharp-function
@@ -0,0 +1,4 @@
+virtual DoStuff(RIGHT)
+{
+   ChangeMe;
+}
diff --git a/t/t4018/csharp-member b/t/t4018/csharp-member
new file mode 100644
index 000..4939d53
--- /dev/null
+++ b/t/t4018/csharp-member
@@ -0,0 +1,4 @@
+unsafe class RIGHT
+{
+   int ChangeMe;
+}
diff --git a/t/t4018/csharp-namespace b/t/t4018/csharp-namespace
new file mode 100644
index 000..6749980
--- /dev/null
+++ b/t/t4018/csharp-namespace
@@ -0,0 +1,4 @@
+namespace RIGHT
+{
+   ChangeMe;
+}
diff --git a/t/t4018/csharp-operator b/t/t4018/csharp-operator
new file mode 100644
index 000..5b00263
--- /dev/null
+++ b/t/t4018/csharp-operator
@@ -0,0 +1,4 @@
+A operator+(RIGHT)
+{
+   ChangeMe;
+}
diff --git a/t/t4018/csharp-property b/t/t4018/csharp-property
new file mode 100644
index 000..82d67fc
--- /dev/null
+++ b/t/t4018/csharp-property
@@ -0,0 +1,4 @@
+public virtual int RIGHT
+{
+   get { ChangeMe; }
+}
diff --git a/t/t4018/csharp-skip-call b/t/t4018/csharp-skip-call
new file mode 100644
index 000..e89d083
--- /dev/null
+++ b/t/t4018/csharp-skip-call
@@ -0,0 +1,5 @@
+virtual void RIGHT()
+{
+   call();
+   ChangeMe;
+}
-- 
1.8.4


--
To unsubscribe from this list: send the line unsubscribe git in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH 2/2] add csharp userdiff tests

2014-04-27 Thread Marius Ungureanu
Ugh, there’s an empty line at the beginning of the 2nd patch that shouldn’t be 
there.

Thanks,
Marius--
To unsubscribe from this list: send the line unsubscribe git in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH 2/2] add csharp userdiff tests

2014-04-27 Thread Marius Ungureanu

On 27 Apr 2014, at 19:19, Johannes Sixt j...@kdbg.org wrote:

 Am 27.04.2014 15:47, schrieb Marius Ungureanu:
 
 ---
 
 Thanks. Please signed off your patch.
 

Ah, yes, forgot to do that.

 When you re-send, please place [PATCH v3 n/m] in the subject (and drop
 the Re:) and note what you changed compared to the previous (or all
 earlier) rounds. The place for this note is here, after the --- marker.
 
 Have a look at Documentation/SubmittingPatches.
 

Will do so.

 t/t4018/csharp-constructor | 4 
 t/t4018/csharp-destructor  | 4 
 t/t4018/csharp-function| 4 
 t/t4018/csharp-member  | 4 
 t/t4018/csharp-namespace   | 4 
 t/t4018/csharp-operator| 4 
 t/t4018/csharp-property| 4 
 t/t4018/csharp-skip-call   | 5 +
 8 files changed, 33 insertions(+)
 create mode 100644 t/t4018/csharp-constructor
 create mode 100644 t/t4018/csharp-destructor
 create mode 100644 t/t4018/csharp-function
 create mode 100644 t/t4018/csharp-member
 create mode 100644 t/t4018/csharp-namespace
 create mode 100644 t/t4018/csharp-operator
 create mode 100644 t/t4018/csharp-property
 create mode 100644 t/t4018/csharp-skip-call
 
 
 Unfortunately, I think you have reduced the test cases too far. One of
 the main properties of C# code is that usually member and property
 definitions are indented and there is a class definition around them:
 
  class Foo {
 Foo(X) {}
 virtual void DoStuff() {}
 public int X;
  };
 
 In your examples, you omitted the surrounding class definition and did
 not indent the member definitions. By doing so, the test cases do not
 demonstrate that the csharp userdiff patterns are significantly
 different from the default userdiff pattern: in the examples you
 present, the default pattern would have picked the same hunk headers as
 the csharp patterns!
 

Ah, I think I over judged minimal sample here. I’ll do so.

Is it okay though if I add a few tests to show what is broken?

I think this can’t be solved at a regex level.

 For a reviewer who is not (or only marginally) familiar with C# (like
 myself), it would have been very instructive to present patches with
 test cases that demonstrate weaknesses of the old patterns before
 patches that fix them. For example, you say that you fix the constructor
 pattern. But I am unable to judge what is wrong and how you fix it. The
 commit message is the right place to add text that helps reviewers.
 

Well, the previous pattern didn’t match constructors as they should be
at a logical level. That means, it considered the constructor name
as being the return type. It’s just a logical change that helped with
writing operator function parsing.

 You can mark a userdiff test case that demonstrates a breakage by
 including the work broken somewhere in the file. See
 http://www.repo.or.cz/w/alt-git.git/commitdiff/9cc444f0570b196f1c51664ce2de1d8e1dee6046
 
 diff --git a/t/t4018/csharp-constructor b/t/t4018/csharp-constructor
 new file mode 100644
 index 000..a39cffb
 --- /dev/null
 +++ b/t/t4018/csharp-constructor
 @@ -0,0 +1,4 @@
 +MyClass(RIGHT)
 +{
 +ChangeMe;
 +}
 diff --git a/t/t4018/csharp-destructor b/t/t4018/csharp-destructor
 new file mode 100644
 index 000..55106d9
 --- /dev/null
 +++ b/t/t4018/csharp-destructor
 @@ -0,0 +1,4 @@
 +~MyClass(RIGHT)
 +{
 +ChangeMe;
 +}
 diff --git a/t/t4018/csharp-function b/t/t4018/csharp-function
 new file mode 100644
 index 000..a5d59a3
 --- /dev/null
 +++ b/t/t4018/csharp-function
 @@ -0,0 +1,4 @@
 +virtual DoStuff(RIGHT)
 +{
 +ChangeMe;
 +}
 diff --git a/t/t4018/csharp-member b/t/t4018/csharp-member
 new file mode 100644
 index 000..4939d53
 --- /dev/null
 +++ b/t/t4018/csharp-member
 @@ -0,0 +1,4 @@
 +unsafe class RIGHT
 +{
 +int ChangeMe;
 +}
 diff --git a/t/t4018/csharp-namespace b/t/t4018/csharp-namespace
 new file mode 100644
 index 000..6749980
 --- /dev/null
 +++ b/t/t4018/csharp-namespace
 @@ -0,0 +1,4 @@
 +namespace RIGHT
 +{
 +ChangeMe;
 +}
 diff --git a/t/t4018/csharp-operator b/t/t4018/csharp-operator
 new file mode 100644
 index 000..5b00263
 --- /dev/null
 +++ b/t/t4018/csharp-operator
 
 csharp-user-defined-operator would more precisely describe the case. I
 wouldn't mind seening other file names being a bit more elaborate, but I
 find this one particularly ambiguous.
 

Okay, I’ll name them better. Also improve them.

 @@ -0,0 +1,4 @@
 +A operator+(RIGHT)
 +{
 +ChangeMe;
 +}
 diff --git a/t/t4018/csharp-property b/t/t4018/csharp-property
 new file mode 100644
 index 000..82d67fc
 --- /dev/null
 +++ b/t/t4018/csharp-property
 @@ -0,0 +1,4 @@
 +public virtual int RIGHT
 +{
 +get { ChangeMe; }
 +}
 diff --git a/t/t4018/csharp-skip-call b/t/t4018/csharp-skip-call
 new file mode 100644
 index 000..e89d083
 --- /dev/null
 +++ b/t/t4018/csharp-skip-call
 @@ -0,0 +1,5 @@
 +virtual void RIGHT()
 +{
 +call();
 +ChangeMe;
 +}
 
 In this last test case, you want to demonstrate that the line call

Re: [PATCH 2/2] add csharp userdiff tests

2014-04-27 Thread Marius Ungureanu

 You can mark a userdiff test case that demonstrates a breakage by
 including the work broken somewhere in the file. See
 http://www.repo.or.cz/w/alt-git.git/commitdiff/9cc444f0570b196f1c51664ce2de1d8e1dee6046
 -- Hannes

Would you like me to add tests first, then fix them? Or just like this?--
To unsubscribe from this list: send the line unsubscribe git in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH] Updated C# userdiff patterns.

2014-04-26 Thread Marius Ungureanu

On 26 Apr 2014, at 10:10, Johannes Sixt j...@kdbg.org wrote:

 Am 26.04.2014 01:25, schrieb Marius Ungureanu:
 New keywords: foreach, break, in, try, finally, as, is, typeof, var,
 default, fixed, checked, unchecked, this, lock, readonly, unsafe,
 ref, out, base, null, delegate, continue.
 
 Removed keywords: instanceof. It's only in Java.
 Moved keywords to happen before modifier parsing, as matching a keyword
 will stop modifiers from being matched.
 
 Added method modifiers: extern, abstract.
 
 Added properties modifiers: abstract.
 
 Added parsing of events and delegates, which are like properties, but
 take an extra keyword.
 
 The reasoning behind adding unsafe to keywords is being also a
 statement that can happen inline in code to mention blocks which are
 unsafe. Also, delegates are not necessarily declared in class bodies,
 but can also happen inline in other functions.
 
 Keywords are based on MSDN docs.
 
 Signed-off-by: Marius Ungureanu marius.ungure...@xamarin.com
 
 Thanks for your contribution.
 
 Please write the commit message in imperative mood, and use full
 sentences, not just fragments and avoid contractions (it's). Also,
 don't capitalize the subject line and drop the full-stop:
 
   update C# userdiff patterns
 
   Add new keywords: foreach, break, ...
 
   Remove keyword instanceof because it is only in Java. …
 

Hey!

I’ll fix the commit message and description.

 BTW, it is now dead easy to add test cases for userdiff patterns. Just
 drop files with content like this into t/t4018:
 
  t/t4018/csharp-ignore-statement-keywords -
 class Foo {
   public int RIGHT()
   {
   if (x)
   else
   try
   catch (y)
   ...
 
   ChangeMe;
   }
 }
 
 

Great, I’ll make another commit with adding unit tests. Thanks!

 (This I just invented, I don't do C#.) See the README file in that
 directory.
 
 ---
 userdiff.c | 12 ++--
 1 file changed, 6 insertions(+), 6 deletions(-)
 
 diff --git a/userdiff.c b/userdiff.c
 index fad52d6..7612c5d 100644
 --- a/userdiff.c
 +++ b/userdiff.c
 @@ -133,14 +133,14 @@ PATTERNS(cpp,
   |[-+0-9.e]+[fFlL]?|0[xXbB]?[0-9a-fA-F]+[lLuU]*
   |[-+*/%^|=!]=|--|\\+\\+|=?|=?||\\|\\||::|-\\*?|\\.\\*),
 PATTERNS(csharp,
 - /* Keywords */
 - !^[ 
 \t]*(do|while|for|if|else|instanceof|new|return|switch|case|throw|catch|using)\n
   /* Methods and constructors */
 - ^[ 
 \t]*(((static|public|internal|private|protected|new|virtual|sealed|override|unsafe)[
  \t]+)*[][@.~_[:alnum:]]+[ \t]+[@._[:alnum:]]+[ \t]*\\(.*\\))[ \t]*$\n
 - /* Properties */
 - ^[ 
 \t]*(((static|public|internal|private|protected|new|virtual|sealed|override|unsafe)[
  \t]+)*[][@.~_[:alnum:]]+[ \t]+[@._[:alnum:]]+)[ \t]*$\n
 + ^[ 
 \t]*(((abstract|extern|internal|new|override|private|protected|public|sealed|static|unsafe|virtual)[
  \t]+)*[][@.~_[:alnum:]]+[ \t]+[@._[:alnum:]]+[ \t]*\\(.*\\))[ \t]*$\n
 + /* Properties, events, delegates */
 + ^[ 
 \t]*(((abstract|internal|new|override|private|protected|public|sealed|static|unsafe|virtual)[
  \t]+)*((delegate|event)[ \t]+)*[][@.~_[:alnum:]]+[ \t]+[@._[:alnum:]]+)[ 
 \t]*$\n
   /* Type definitions */
 - ^[ 
 \t]*(((static|public|internal|private|protected|new|unsafe|sealed|abstract|partial)[
  \t]+)*(class|enum|interface|struct)[ \t]+.*)$\n
 + ^[ 
 \t]*(((abstract|internal|new|override|partial|private|protected|public|sealed|static|unsafe)[
  \t]+)*(class|enum|interface|struct)[ \t]+.*)$\n
 + /* Keywords */
 + !^[ 
 \t]*(as|base|break|case|catch|checked|continue|default|delegate|do|else|finally|fixed|for|foreach|if|in|is|lock|new|null|out|readonly|ref|return|switch|this|throw|try|typeof|unchecked|unsafe|using|var|while)\n
   /* Namespace */
   ^[ \t]*(namespace[ \t]+.*)$,
   /* -- */
 
 Here, you are moving keywords down, but in the commit message you say
 that you moved keywords to happen before modifier parsing. Aren't you
 moving keywords *after* something? (Where the modifiers are here is
 not obvious, but that can be attributed to that I don't do C#.)
 

It was a typo because I was sleepy. It was intentional to move them *after*.
Modifier parsing can contain keywords, so just to be sure, I moved the
keywords after modifier parsing, so it uses the keywords as a fallback.
If this is not what should happen, please tell.

Modifiers are prefixes to methods/properties. (the pipe separated lists)

 BTW, I appreciate that you re-arrange keywords alphabetically. Could you
 do that in the commit message, too?
 
 — Hannes

I’ll handle this too, no problem.

Thanks,
Marius

--
To unsubscribe from this list: send the line unsubscribe git in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH] Updated C# userdiff patterns.

2014-04-26 Thread Marius Ungureanu
On a side note, I noticed some of the keywords I added shouldn’t be there.

I just realised that simple statements have no reason to be there, but only
block definitions. I’ll reduce the size of this patch on the keywords part.

Thanks,
Marius--
To unsubscribe from this list: send the line unsubscribe git in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH] Updated C# userdiff patterns.

2014-04-26 Thread Marius Ungureanu
On 26 Apr 2014, at 20:49, Johannes Sixt j...@kdbg.org wrote:
 Am 26.04.2014 11:55, schrieb Marius Ungureanu:
 On 26 Apr 2014, at 10:10, Johannes Sixt j...@kdbg.org wrote:
 Am 26.04.2014 01:25, schrieb Marius Ungureanu:
 diff --git a/userdiff.c b/userdiff.c
 index fad52d6..7612c5d 100644
 --- a/userdiff.c
 +++ b/userdiff.c
 @@ -133,14 +133,14 @@ PATTERNS(cpp,
 |[-+0-9.e]+[fFlL]?|0[xXbB]?[0-9a-fA-F]+[lLuU]*
 |[-+*/%^|=!]=|--|\\+\\+|=?|=?||\\|\\||::|-\\*?|\\.\\*),
 PATTERNS(csharp,
 -   /* Keywords */
 -   !^[ 
 \t]*(do|while|for|if|else|instanceof|new|return|switch|case|throw|catch|using)\n
 /* Methods and constructors */
 -   ^[ 
 \t]*(((static|public|internal|private|protected|new|virtual|sealed|override|unsafe)[
  \t]+)*[][@.~_[:alnum:]]+[ \t]+[@._[:alnum:]]+[ \t]*\\(.*\\))[ \t]*$\n
 -   /* Properties */
 -   ^[ 
 \t]*(((static|public|internal|private|protected|new|virtual|sealed|override|unsafe)[
  \t]+)*[][@.~_[:alnum:]]+[ \t]+[@._[:alnum:]]+)[ \t]*$\n
 +   ^[ 
 \t]*(((abstract|extern|internal|new|override|private|protected|public|sealed|static|unsafe|virtual)[
  \t]+)*[][@.~_[:alnum:]]+[ \t]+[@._[:alnum:]]+[ \t]*\\(.*\\))[ \t]*$\n
 +   /* Properties, events, delegates */
 +   ^[ 
 \t]*(((abstract|internal|new|override|private|protected|public|sealed|static|unsafe|virtual)[
  \t]+)*((delegate|event)[ \t]+)*[][@.~_[:alnum:]]+[ 
 \t]+[@._[:alnum:]]+)[ \t]*$\n
 /* Type definitions */
 -   ^[ 
 \t]*(((static|public|internal|private|protected|new|unsafe|sealed|abstract|partial)[
  \t]+)*(class|enum|interface|struct)[ \t]+.*)$\n
 +   ^[ 
 \t]*(((abstract|internal|new|override|partial|private|protected|public|sealed|static|unsafe)[
  \t]+)*(class|enum|interface|struct)[ \t]+.*)$\n
 +   /* Keywords */
 +   !^[ 
 \t]*(as|base|break|case|catch|checked|continue|default|delegate|do|else|finally|fixed|for|foreach|if|in|is|lock|new|null|out|readonly|ref|return|switch|this|throw|try|typeof|unchecked|unsafe|using|var|while)\n
 /* Namespace */
 ^[ \t]*(namespace[ \t]+.*)$,
 /* -- */
 
 ...
 Modifier parsing can contain keywords, so just to be sure, I moved the
 keywords after modifier parsing, so it uses the keywords as a fallback.
 If this is not what should happen, please tell.
 
 For each line, patterns are are scanned in order, and the first match
 determines the outcome: If it is a negative pattern (i.e., it begins
 with an exclamation mark), the line is not a hunk header; if it is a
 positive pattern, the line is a hunk header. If no pattern matches, the
 line is not a hunk header, either; it is as if the list were terminated
 by a negative catch-all pattern.
 
 Due to these rules, negative patterns in the list are only necessary
 when you want to make an exception to a positive pattern in the list,
 and then the negative pattern must be listed before the positive pattern.
 
 In the csharp case, I do not see a pattern of which the keyword pattern
 would make an exception (neither the old version nor your new version).
 Therefore, you could drop the keyword pattern entirely.
 
 -- Hannes
 

Hey!

I’ll remove them and add as many unit tests I can. I’ve been side tracked
today and I couldn’t get to look at it. I’ll start a new thread with the new
patch as soon as I’m done with it.

Thanks for all the tips until now. You’ve been of great help.

Marius--
To unsubscribe from this list: send the line unsubscribe git in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[PATCH] Updated C# userdiff patterns.

2014-04-25 Thread Marius Ungureanu
New keywords: foreach, break, in, try, finally, as, is, typeof, var,
default, fixed, checked, unchecked, this, lock, readonly, unsafe,
ref, out, base, null, delegate, continue.

Removed keywords: instanceof. It's only in Java.
Moved keywords to happen before modifier parsing, as matching a keyword
will stop modifiers from being matched.

Added method modifiers: extern, abstract.

Added properties modifiers: abstract.

Added parsing of events and delegates, which are like properties, but
take an extra keyword.

The reasoning behind adding unsafe to keywords is being also a
statement that can happen inline in code to mention blocks which are
unsafe. Also, delegates are not necessarily declared in class bodies,
but can also happen inline in other functions.

Keywords are based on MSDN docs.

Signed-off-by: Marius Ungureanu marius.ungure...@xamarin.com
---
 userdiff.c | 12 ++--
 1 file changed, 6 insertions(+), 6 deletions(-)

diff --git a/userdiff.c b/userdiff.c
index fad52d6..7612c5d 100644
--- a/userdiff.c
+++ b/userdiff.c
@@ -133,14 +133,14 @@ PATTERNS(cpp,
 |[-+0-9.e]+[fFlL]?|0[xXbB]?[0-9a-fA-F]+[lLuU]*
 |[-+*/%^|=!]=|--|\\+\\+|=?|=?||\\|\\||::|-\\*?|\\.\\*),
 PATTERNS(csharp,
-/* Keywords */
-!^[ 
\t]*(do|while|for|if|else|instanceof|new|return|switch|case|throw|catch|using)\n
 /* Methods and constructors */
-^[ 
\t]*(((static|public|internal|private|protected|new|virtual|sealed|override|unsafe)[
 \t]+)*[][@.~_[:alnum:]]+[ \t]+[@._[:alnum:]]+[ \t]*\\(.*\\))[ \t]*$\n
-/* Properties */
-^[ 
\t]*(((static|public|internal|private|protected|new|virtual|sealed|override|unsafe)[
 \t]+)*[][@.~_[:alnum:]]+[ \t]+[@._[:alnum:]]+)[ \t]*$\n
+^[ 
\t]*(((abstract|extern|internal|new|override|private|protected|public|sealed|static|unsafe|virtual)[
 \t]+)*[][@.~_[:alnum:]]+[ \t]+[@._[:alnum:]]+[ \t]*\\(.*\\))[ \t]*$\n
+/* Properties, events, delegates */
+^[ 
\t]*(((abstract|internal|new|override|private|protected|public|sealed|static|unsafe|virtual)[
 \t]+)*((delegate|event)[ \t]+)*[][@.~_[:alnum:]]+[ \t]+[@._[:alnum:]]+)[ 
\t]*$\n
 /* Type definitions */
-^[ 
\t]*(((static|public|internal|private|protected|new|unsafe|sealed|abstract|partial)[
 \t]+)*(class|enum|interface|struct)[ \t]+.*)$\n
+^[ 
\t]*(((abstract|internal|new|override|partial|private|protected|public|sealed|static|unsafe)[
 \t]+)*(class|enum|interface|struct)[ \t]+.*)$\n
+/* Keywords */
+!^[ 
\t]*(as|base|break|case|catch|checked|continue|default|delegate|do|else|finally|fixed|for|foreach|if|in|is|lock|new|null|out|readonly|ref|return|switch|this|throw|try|typeof|unchecked|unsafe|using|var|while)\n
 /* Namespace */
 ^[ \t]*(namespace[ \t]+.*)$,
 /* -- */
-- 
1.8.4

--
To unsubscribe from this list: send the line unsubscribe git in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html