- 
    Bug 
- 
    Resolution: Done
- 
    Major 
- 
    None
- 
    6.4.0.Final
- 
    None
- 
        NEW
- 
        NEW
Assuming you have a rule name "rule(hello)",
package com.sample
rule "rule(hello)"
    when
    then
end
Here, ' (' and ')' ... U+FF08 (FULLWIDTH LEFT PARENTHESIS) and U+FF09 (FULLWIDTH RIGHT PARENTHESIS) are not a Java identifier part. The rule fails to compile.
Rule Compilation error : [Rule name='rule(hello)'] com/sample/Rule_rule(hello)0.java (3:84) : Syntax error on tokens, delete these tokens com/sample/Rule_rule(hello)0.java (3:97) : The public type Rule_rule must be defined in its own file com/sample/Rule_rule(hello)0.java (3:115) : Syntax error, insert "}" to complete Block com/sample/Rule_rule(hello)0.java (4:121) : Syntax error on tokens, delete these tokens com/sample/Rule_rule(hello)0.java (6:187) : Syntax error on token "void", @ expected com/sample/Rule_rule(hello)0.java (6:211) : Syntax error on token(s), misplaced construct(s) com/sample/Rule_rule(hello)0.java (6:238) : Syntax error on token "throws", @ expected com/sample/Rule_rule(hello)0.java (6:255) : Syntax error, insert "enum Identifier" to complete EnumHeader com/sample/Rule_rule(hello)0.java (11:332) : Syntax error on token "}", delete this token
But such a non-java identifier part should be normalized by org.drools.compiler.rule.builder.dialect.DialectUtil.normalizeRuleName() during the build. The problem is that DialectUtil.normalizeRuleName() misses to process the name because of NON_ALPHA_REGEX check. NON_ALPHA_REGEX doesn't take account into Unicode characters.
- is incorporated by
- 
                    RHBRMS-2451 DialectUtil.normalizeRuleName() doesn't normalize multibyte rule names -         
- Verified
 
-         
- 
                    RHBRMS-2452 [GSS] (6.3.z) DialectUtil.normalizeRuleName() doesn't normalize multibyte rule names -         
- Verified
 
-