Comments (4)
For the moment it is not clear for me how you are going to solve the problem.
But you see 20 years ago I kept functions call at min so the code would be faster.
BTW you non-capturing group patch does add some additional calls and loops (to get capturing group by Idx from full groups list) and I am afraid that already slow down TRegExpr a bit..
May be we need some performance tests as well so we could see clearly that we do not sacrifice performance by new patches?
from tregexpr.
I can do optimization of GetSubExprArrayIndex
- make it "inline" (will be no function call)
- add variable NonCaptureExists:bool, which is set when first non-capture group is found, flag is checked in function to work faster
from tregexpr.
You that sounds(!) good but with modern CPU - multi-levels cache, branch predictions and so on I do not believe this is possible to understand what is good for performance just theoretically.
If we had some performance tests - easy to run and to compare change. Even as CI - so if we drop performance significantly they will be red.
And only with such a tests we could understand if we really need that..
from tregexpr.
solved
from tregexpr.
Related Issues (20)
- zero-length match not found at the end of searched string HOT 9
- UnQuoteChar can't be called from TRegExpr.Substitute
- Substitute: Numbered group in template defaults to "$" HOT 5
- no longer compiles with pre-UNICODE Delphi HOT 49
- Compile error in Delphi XE HOT 1
- Recursive inclusion (?R) with backreferences produces wrong matches HOT 10
- Find-replace with subroutine calls: wrong value substituted HOT 2
- RegExp.ModifierS does not work properly HOT 11
- ErrorMsg() still misses reeModifierUnsupported HOT 3
- Code inconsistencies (char literals, datatype casing, String, else begin) HOT 2
- regexpr_unicodedata.pas has wrong CharUpperArray and CharLowerArray mappings HOT 2
- _UpperCase() and _LowerCase() miss compiler directives around "inline;" HOT 2
- Upgrade regular expression engine to support features of major flavours like PCRE2, ECMAScript etc. HOT 7
- TRegExpr compile: unknown meta-character: \R (pos 10) HOT 17
- 'TRegExpr compile: *+ operand could be empty HOT 7
- Impossible to use lookahead/lookbehind in combination with boolean "or" HOT 6
- typo in Github HOT 1
- Typo in docs HOT 3
- github pages are not build
- asm can not be used for android/ios targets HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from tregexpr.