Regex Too Complicated - replaceAll - large strings preprocessed before deserialize
Given
- A JSON string with Apex reserved words (like
"currency":"USD"
and otherwise undeserializable-into-Date type (like"someDate":"0001-01-01T00:00:00Z"
)
An apex method that uses
String s = s.replaceAll('"currency":','"currencyX":')
.replaceAll('"0001\-01\-01T00:00:00Z"','null');
before deserializing into a custom Apex type with property String currencyX
and Date someDate
When
The incoming Apex string is very large (> 1MB)
Then
Uncatchable error: Regex Too Complicated
What to do?
apex
add a comment |
Given
- A JSON string with Apex reserved words (like
"currency":"USD"
and otherwise undeserializable-into-Date type (like"someDate":"0001-01-01T00:00:00Z"
)
An apex method that uses
String s = s.replaceAll('"currency":','"currencyX":')
.replaceAll('"0001\-01\-01T00:00:00Z"','null');
before deserializing into a custom Apex type with property String currencyX
and Date someDate
When
The incoming Apex string is very large (> 1MB)
Then
Uncatchable error: Regex Too Complicated
What to do?
apex
add a comment |
Given
- A JSON string with Apex reserved words (like
"currency":"USD"
and otherwise undeserializable-into-Date type (like"someDate":"0001-01-01T00:00:00Z"
)
An apex method that uses
String s = s.replaceAll('"currency":','"currencyX":')
.replaceAll('"0001\-01\-01T00:00:00Z"','null');
before deserializing into a custom Apex type with property String currencyX
and Date someDate
When
The incoming Apex string is very large (> 1MB)
Then
Uncatchable error: Regex Too Complicated
What to do?
apex
Given
- A JSON string with Apex reserved words (like
"currency":"USD"
and otherwise undeserializable-into-Date type (like"someDate":"0001-01-01T00:00:00Z"
)
An apex method that uses
String s = s.replaceAll('"currency":','"currencyX":')
.replaceAll('"0001\-01\-01T00:00:00Z"','null');
before deserializing into a custom Apex type with property String currencyX
and Date someDate
When
The incoming Apex string is very large (> 1MB)
Then
Uncatchable error: Regex Too Complicated
What to do?
apex
apex
asked 11 hours ago
cropredycropredy
36k441123
36k441123
add a comment |
add a comment |
1 Answer
1
active
oldest
votes
This is basically teaching an old dog (me) new tricks
A cursory reading of the Apex String class documentation shows two methods
replace(target,replacement)
replaceAll(regExp,replacement)
The naive developer (me) assumes that the first method, replace
, only replaces a SINGLE instance of the target string and since the use case assumes you need to replace ALL occurrences of some pattern, you should use the more powerful replaceAll(..)
But epistemic arrogance crept in and I did not realize replace(target,replacement)
replaces ALL occurrences of target
with replacement
Replaces each substring of a string that matches the literal target sequence target with the specified literal replacement sequence replacement.
So, if you have large strings and you are just doing simple text substitution, avoid replaceAll
String s = s.replace('"currency":','"currencyX":')
.replace('"0001-01-01T00:00:00Z"','null');
add a comment |
Your Answer
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "459"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fsalesforce.stackexchange.com%2fquestions%2f252997%2fregex-too-complicated-replaceall-large-strings-preprocessed-before-deseriali%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
This is basically teaching an old dog (me) new tricks
A cursory reading of the Apex String class documentation shows two methods
replace(target,replacement)
replaceAll(regExp,replacement)
The naive developer (me) assumes that the first method, replace
, only replaces a SINGLE instance of the target string and since the use case assumes you need to replace ALL occurrences of some pattern, you should use the more powerful replaceAll(..)
But epistemic arrogance crept in and I did not realize replace(target,replacement)
replaces ALL occurrences of target
with replacement
Replaces each substring of a string that matches the literal target sequence target with the specified literal replacement sequence replacement.
So, if you have large strings and you are just doing simple text substitution, avoid replaceAll
String s = s.replace('"currency":','"currencyX":')
.replace('"0001-01-01T00:00:00Z"','null');
add a comment |
This is basically teaching an old dog (me) new tricks
A cursory reading of the Apex String class documentation shows two methods
replace(target,replacement)
replaceAll(regExp,replacement)
The naive developer (me) assumes that the first method, replace
, only replaces a SINGLE instance of the target string and since the use case assumes you need to replace ALL occurrences of some pattern, you should use the more powerful replaceAll(..)
But epistemic arrogance crept in and I did not realize replace(target,replacement)
replaces ALL occurrences of target
with replacement
Replaces each substring of a string that matches the literal target sequence target with the specified literal replacement sequence replacement.
So, if you have large strings and you are just doing simple text substitution, avoid replaceAll
String s = s.replace('"currency":','"currencyX":')
.replace('"0001-01-01T00:00:00Z"','null');
add a comment |
This is basically teaching an old dog (me) new tricks
A cursory reading of the Apex String class documentation shows two methods
replace(target,replacement)
replaceAll(regExp,replacement)
The naive developer (me) assumes that the first method, replace
, only replaces a SINGLE instance of the target string and since the use case assumes you need to replace ALL occurrences of some pattern, you should use the more powerful replaceAll(..)
But epistemic arrogance crept in and I did not realize replace(target,replacement)
replaces ALL occurrences of target
with replacement
Replaces each substring of a string that matches the literal target sequence target with the specified literal replacement sequence replacement.
So, if you have large strings and you are just doing simple text substitution, avoid replaceAll
String s = s.replace('"currency":','"currencyX":')
.replace('"0001-01-01T00:00:00Z"','null');
This is basically teaching an old dog (me) new tricks
A cursory reading of the Apex String class documentation shows two methods
replace(target,replacement)
replaceAll(regExp,replacement)
The naive developer (me) assumes that the first method, replace
, only replaces a SINGLE instance of the target string and since the use case assumes you need to replace ALL occurrences of some pattern, you should use the more powerful replaceAll(..)
But epistemic arrogance crept in and I did not realize replace(target,replacement)
replaces ALL occurrences of target
with replacement
Replaces each substring of a string that matches the literal target sequence target with the specified literal replacement sequence replacement.
So, if you have large strings and you are just doing simple text substitution, avoid replaceAll
String s = s.replace('"currency":','"currencyX":')
.replace('"0001-01-01T00:00:00Z"','null');
answered 11 hours ago
cropredycropredy
36k441123
36k441123
add a comment |
add a comment |
Thanks for contributing an answer to Salesforce Stack Exchange!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fsalesforce.stackexchange.com%2fquestions%2f252997%2fregex-too-complicated-replaceall-large-strings-preprocessed-before-deseriali%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown