-
Notifications
You must be signed in to change notification settings - Fork 9
Description
During my recent implementations and rewrites, I've introduced some "error reporting" to make it easier for the caller to figure if and what might have gone wrong. On error, several methods now return an array like
[success:0, message:"reason"]But not all of them – for example, most of the search/browse methods supposed to return a simple array of package names don't have this. There would be two options to reach (a sort of) consistency:
- returning
[success:0, message:reason]instead (and if so, includesuccess:1with a "good result) also for those methods that currently do not, moving the "real results" into a "sub-array" (which then, on error, could be empty or just not present at all) - simply returning an empty array, and have a
getLastError()method for obtaining the reason for all search/browse methods while keeping the current behavior for the others.
I'd prefer the first approach (so it's completely consistent) with the "empty real result". This combines the best of two worlds, e.g.
$apps = $google->parseWhatever();
if ( empty($apps['data']) ) { // this could simply mean nothing found matching the criteria
if ( $apps['success'] ) { log('nothing found'); }
else { log ('ERROR occured: '.$apps['message']); }
} else { // do something with the dataI'd even go as far as to always include the message key, just leaving its value empty on success. That would make things most consistent.
What's your stance? If you agree, I'd go over the entire class another time and make it consistent:
success:0only on errors – not generally on "no results" for a user-specified search (I vaguely remember I accidentally made it such in one case).messagethen holds the reason (e.g. the HTTP response, or parse error when an expected pattern didn't match, etc)success:1on success.messagethen is present but usually empty, but might eg hold a hint on why the result set is empty (like "no hits").
If we want to fix it, we want to do that as early as possible – before there are users whose code would otherwise break on some update.