Browse Source

fix: remove unnecessary regex class-group replacer

pull/7268/head
Pranav C 11 months ago
parent
commit
13e3a86fba
  1. 34
      packages/nocodb/src/db/functionMappings/pg.ts

34
packages/nocodb/src/db/functionMappings/pg.ts

@ -1,28 +1,10 @@
import dayjs from 'dayjs'; import dayjs from 'dayjs';
import { FormulaDataTypes } from 'nocodb-sdk';
import commonFns from './commonFns'; import commonFns from './commonFns';
import type { MapFnArgs } from '../mapFunctionName'; import type { MapFnArgs } from '../mapFunctionName';
import { convertUnits } from '~/helpers/convertUnits'; import { convertUnits } from '~/helpers/convertUnits';
import { getWeekdayByText } from '~/helpers/formulaFnHelper'; import { getWeekdayByText } from '~/helpers/formulaFnHelper';
import {FormulaDataTypes} from "nocodb-sdk";
const replaceCharClassShorthandlers = (str: string) => {
return str.replace(/(.|^)\\([dDsSwW])/g, (fullMatch, prevChar, alias) => {
if (prevChar === '\\') return fullMatch;
switch (alias) {
case 'd':
return `${prevChar}[0-9]`;
case 'D':
return `${prevChar}[^0-9]`;
case 's':
return `${prevChar}[\f\n\r\t\v\u0020\u00a0\u1680\u2000-\u200a\u2028\u2029\u202f\u205f\u3000\ufeff]`;
case 'S':
return `${prevChar}[^\f\n\r\t\v\u0020\u00a0\u1680\u2000-\u200a\u2028\u2029\u202f\u205f\u3000\ufeff]`;
case 'w':
return `${prevChar}[A-Za-z0-9_]`;
case 'W':
return `${prevChar}[^A-Za-z0-9_]`;
}
});
};
const pg = { const pg = {
...commonFns, ...commonFns,
LEN: 'length', LEN: 'length',
@ -249,9 +231,7 @@ const pg = {
// replace shorthand character classes with their equivalent character sets // replace shorthand character classes with their equivalent character sets
if (pt.arguments[1].type === 'Literal') { if (pt.arguments[1].type === 'Literal') {
pt.arguments[1].value = replaceCharClassShorthandlers( pt.arguments[1].value = pt.arguments[1].value;
pt.arguments[1].value,
);
} }
const pattern = (await fn(pt.arguments[1])).builder; const pattern = (await fn(pt.arguments[1])).builder;
@ -266,9 +246,7 @@ const pg = {
// replace shorthand character classes with their equivalent character sets // replace shorthand character classes with their equivalent character sets
if (pt.arguments[1].type === 'Literal') { if (pt.arguments[1].type === 'Literal') {
pt.arguments[1].value = replaceCharClassShorthandlers( pt.arguments[1].value = pt.arguments[1].value;
pt.arguments[1].value,
);
} }
const pattern = (await fn(pt.arguments[1])).builder; const pattern = (await fn(pt.arguments[1])).builder;
@ -286,9 +264,7 @@ const pg = {
// replace shorthand character classes with their equivalent character sets // replace shorthand character classes with their equivalent character sets
if (pt.arguments[1].type === 'Literal') { if (pt.arguments[1].type === 'Literal') {
pt.arguments[1].value = replaceCharClassShorthandlers( pt.arguments[1].value = pt.arguments[1].value;
pt.arguments[1].value,
);
} }
const replacement = (await fn(pt.arguments[2])).builder; const replacement = (await fn(pt.arguments[2])).builder;

Loading…
Cancel
Save