-
Data: 2020-04-07 19:07:37
Temat: Re: problem z wyrażeniem regularnym w C++
Od: RM <r...@w...pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]Potrzebuję jeszcze pomocy przy przetumaczeniu kawałka kodu z PHP na C++,
bo dokumentacji do C++owego sub_match nie rozumiem. Problem jest dla
mnie za trudny.
W PHP mam:
preg_match_all($r, $line, $matches, PREG_OFFSET_CAPTURE))
...
$match = $matches[$indexes[$what][$k]];
$delta_str = 0;
foreach ($match as $m) {
if ($what == 'f' && $k == 1) { // 2nd regexp for functions
// check if a method call:
$before = substr($line, $m[1] - 2, 2);
if ($before == '->' || $before == '::') continue; // don't obfuscate now
}
if ($what == 'f') { // case insensitive
$n = array_search(strtoupper($m[0]), $from[$what]);
} elseif ($what == 'm') { // case insensitive
if (in_array(strtoupper($m[0]), $from['a'])) { // action
$n = FALSE;
} else {
$n = array_search(strtoupper($m[0]), $from[$what]);
}
} else {
$n = array_search($m[0], $from[$what]);
}
if ($n !== FALSE) {
$line = substr_replace($line, '_' . $to[$what][$n], $m[1] +
$delta_str, strlen($m[0]));
$delta_str += strlen($to[$what][$n]) - strlen($m[0]) + 1;
}
}
W C++ wyobrażam sobie tak:
short delta_str = 0;
sub_match match = matches[indexes[what][k]];
for (auto m = match.begin(); m < match.end(); m++) {
if (what == i_functions && k == 1) { // 2nd regexp for functions
// check if a method call:
string before = line.substr(m.position() - 2, 2);
if (before == "->" || before == "::") {
continue; // don't obfuscate now
}
}
if (what == i_functions) { // case insensitive
n = strvector_search(strtoupper(m.str()), from[what]);
} else if (what == i_methods) { // case insensitive
if (in_strvector(strtoupper(m.str()), from[i_actions])) { // action
n = -1;
} else {
n = strvector_search(strtoupper(m.str()), from[what]);
}
} else { // case sensitive
n = strvector_search(m.str(), from[what]);
}
if (n >= 0) {
line = substr_replace(line, string("_").append(to[what][n]),
m.position() + delta_str, strlen(m.str().c_str()));
delta_str += strlen(to[what][n].c_str()) - strlen(m.str().c_str()) + 1;
}
}
Ale sub_match nie zawiera metod begin() i end() więc mój kod się nie
kompiluje. Prosiłbym bardzo o poprawienie kodu.
Następne wpisy z tego wątku
- 08.04.20 15:49 RM
- 08.04.20 16:39 RM
- 09.04.20 21:44 Wojciech Muła
Najnowsze wątki z tej grupy
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
- CfC 28th Ada-Europe Int. Conf. Reliable Software Technologies
- Młodzi programiści i tajna policja
Najnowsze wątki
- 2024-12-14 światła znów wlączyli
- 2024-12-14 nie lekceważ termostatu
- 2024-12-14 numer 112
- 2024-12-14 Pendrive, ale dysk
- 2024-12-12 Autocom CAN CDP+ wysokie kody błędów
- 2024-12-13 termostat do lodowki
- 2024-12-13 Gdańsk => Inżynier bezpieczeństwa aplikacji <=
- 2024-12-13 Warszawa => Head of International Freight Forwarding Department <=
- 2024-12-13 Poznań => Employer Branding Specialist <=
- 2024-12-13 Kraków => Business Development Manager - Dział Sieci i Bezpieczeńst
- 2024-12-13 Kraków => Business Development Manager - Network and Network Security
- 2024-12-13 Katowice => Regionalny Kierownik Sprzedaży (OZE) <=
- 2024-12-13 Gdańsk => Programista Full Stack .Net <=
- 2024-12-13 Warszawa => Analityk Biznesowo-Systemowy <=
- 2024-12-13 Białystok => Architekt rozwiązań (doświadczenie w obszarze Java, A