Skip to content

Commit a41dad4

Browse files
committed
Merge branch 'ml/userdiff-rust'
The pattern "git diff/grep" use to extract funcname and words boundary for Rust has been added. * ml/userdiff-rust: userdiff: two simplifications of patterns for rust userdiff: add built-in pattern for rust
2 parents a6a95cd + 33be7b3 commit a41dad4

File tree

7 files changed

+29
-0
lines changed

7 files changed

+29
-0
lines changed

Documentation/gitattributes.txt

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -833,6 +833,8 @@ patterns are available:
833833

834834
- `ruby` suitable for source code in the Ruby language.
835835

836+
- `rust` suitable for source code in the Rust language.
837+
836838
- `tex` suitable for source code for LaTeX documents.
837839

838840

t/t4018-diff-funcname.sh

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -43,6 +43,7 @@ diffpatterns="
4343
php
4444
python
4545
ruby
46+
rust
4647
tex
4748
custom1
4849
custom2

t/t4018/rust-fn

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
pub(self) fn RIGHT<T>(x: &[T]) where T: Debug {
2+
let _ = x;
3+
// a comment
4+
let a = ChangeMe;
5+
}

t/t4018/rust-impl

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
impl<'a, T: AsRef<[u8]>> std::RIGHT for Git<'a> {
2+
3+
pub fn ChangeMe(&self) -> () {
4+
}
5+
}

t/t4018/rust-struct

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
#[derive(Debug)]
2+
pub(super) struct RIGHT<'a> {
3+
name: &'a str,
4+
age: ChangeMe,
5+
}

t/t4018/rust-trait

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
unsafe trait RIGHT<T> {
2+
fn len(&self) -> u32;
3+
fn ChangeMe(&self, n: u32) -> T;
4+
fn iter<F>(&self, f: F) where F: Fn(T);
5+
}

userdiff.c

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -135,6 +135,12 @@ PATTERNS("ruby", "^[ \t]*((class|module|def)[ \t].*)$",
135135
"(@|@@|\\$)?[a-zA-Z_][a-zA-Z0-9_]*"
136136
"|[-+0-9.e]+|0[xXbB]?[0-9a-fA-F]+|\\?(\\\\C-)?(\\\\M-)?."
137137
"|//=?|[-+*/<>%&^|=!]=|<<=?|>>=?|===|\\.{1,3}|::|[!=]~"),
138+
PATTERNS("rust",
139+
"^[\t ]*((pub(\\([^\\)]+\\))?[\t ]+)?((async|const|unsafe|extern([\t ]+\"[^\"]+\"))[\t ]+)?(struct|enum|union|mod|trait|fn|impl)[< \t]+[^;]*)$",
140+
/* -- */
141+
"[a-zA-Z_][a-zA-Z0-9_]*"
142+
"|[0-9][0-9_a-fA-Fiosuxz]*(\\.([0-9]*[eE][+-]?)?[0-9_fF]*)?"
143+
"|[-+*\\/<>%&^|=!:]=|<<=?|>>=?|&&|\\|\\||->|=>|\\.{2}=|\\.{3}|::"),
138144
PATTERNS("bibtex", "(@[a-zA-Z]{1,}[ \t]*\\{{0,1}[ \t]*[^ \t\"@',\\#}{~%]*).*$",
139145
"[={}\"]|[^={}\" \t]+"),
140146
PATTERNS("tex", "^(\\\\((sub)*section|chapter|part)\\*{0,1}\\{.*)$",

0 commit comments

Comments
 (0)