/**
* Declaring globals for users with E_ALL set.
*/
-global $SQSPELL_APP_DEFAULT, $SQSPELL_APP, $attachment_dir, $color;
+global $SQSPELL_APP_DEFAULT, $SQSPELL_APP, $SQSPELL_SPELLCHECKER,
+ $SQSPELL_FORCE_POPEN, $attachment_dir, $color;
if (! sqgetGlobalVar('sqspell_text',$sqspell_text,SQ_POST)) {
$sqspell_text = '';
}
/**
- * Now we explode the lines for three reasons:
+ * Now we explode the lines for two reasons:
* 1) So we can ignore lines starting with ">" (reply's)
* 2) So we can stop processing when we get to "--" on a single line,
* which means that the signature is starting
- * 3) So we can add an extra space at the beginning of each line. This way
- * ispell/aspell don't treat these as command characters.
*/
$sqspell_raw_lines = explode("\n", $sqspell_text);
for ($i=0; $i<sizeof($sqspell_raw_lines); $i++){
* stuff.
*/
if(substr($sqspell_raw_lines[$i], 0, 1) != '>'){
- $sqspell_new_lines[$i] = ' ' . $sqspell_raw_lines[$i];
+ $sqspell_new_lines[$i] = $sqspell_raw_lines[$i];
} else {
- $sqspell_new_lines[$i] = ' ';
+ $sqspell_new_lines[$i] = '';
}
}
/**
*/
$sqspell_new_text=implode("\n", $sqspell_new_lines);
-/**
- * Define the command used to spellcheck the document.
- */
-$sqspell_command=$SQSPELL_APP[$sqspell_use_app];
-/**
- * If you have php >= 4.3.0, we can use proc_open and safe mode
- * and not mess w/ temp files. Otherwise we will do it the old
- * way, (minus the uneeded call to cat that messes up Wintel
- * boxen.)
- * Thanks Ray Ferguson for providing this patch.
- */
-if( check_php_version ( 4, 3 ) ) {
- $descriptorspec = array(
- 0 => array('pipe', 'r'), // stdin is a pipe that the child will read from
- 1 => array('pipe', 'w'), // stdout is a pipe that the child will write to
- 2 => array('pipe', 'w'), // stderr is a pipe that the child will write to
- );
- $spell_proc = @proc_open($sqspell_command, $descriptorspec, $pipes);
- if ( ! is_resource ( $spell_proc ) ) {
- // TODO: replace error_box() with sqspell_makeWindow()
- error_box ( sprintf(_("Could not run the spellchecker command (%s)."),
- htmlspecialchars($sqspell_command) ) );
- // display footer (closes html tags) and stop script execution
- $oTemplate->display('footer.tpl');
- exit();
- }
- if ( ! @fwrite($pipes[0], $sqspell_new_text) ) {
- // TODO: replace error_box() with sqspell_makeWindow()
- error_box ( _("Error while writing to pipe.") );
- // close all three $pipes here.
- for($i=0; $i<=2; $i++) {
- // disable all fclose error messages
- @fclose($pipes[$i]);
- }
- // close html tags and abort script.
- $oTemplate->display('footer.tpl');
- exit();
- }
- fclose($pipes[0]);
- $sqspell_output = array();
- for($i=1; $i<=2; $i++) {
- while(!feof($pipes[$i])) {
- array_push($sqspell_output, rtrim(fgetss($pipes[$i],999),"\r\n"));
- }
- fclose($pipes[$i]);
- }
- $sqspell_exitcode=proc_close($spell_proc);
-} else {
- // add slash to attachment directory, if it does not end with slash.
- if (substr($attachment_dir, -1) != '/')
- $attachment_dir = $attachment_dir . '/';
+include_once(SM_PATH . 'plugins/squirrelspell/class/common.php');
- // find unused file in attachment directory
- do {
- $floc = $attachment_dir . md5($sqspell_new_text . microtime());
- } while (file_exists($floc));
+$aParams = array();
+$aParams['words'] = sqspell_getLang($sqspell_use_app);
- $fp = @fopen($floc, 'w');
- if ( ! is_resource ($fp) ) {
- // TODO: replace error_box() with sqspell_makeWindow()
- error_box ( sprintf(_("Could not open temporary file '%s'."),
- htmlspecialchars($floc) ) );
- // failed to open temp file. abort script.
- $oTemplate->display('footer.tpl');
- exit();
- }
- if ( ! @fwrite($fp, $sqspell_new_text) ) {
- // TODO: replace error_box() with sqspell_makeWindow()
- error_box ( sprintf(_("Error while writing to temporary file '%s'."),
- htmlspecialchars($floc) ) );
- // close file descriptor
- fclose($fp);
- // failed writing to temp file. abort script.
- $oTemplate->display('footer.tpl');
- exit();
+if ($SQSPELL_SPELLCHECKER===1) {
+ include_once(SM_PATH . 'plugins/squirrelspell/class/php_pspell.php');
+ $aParams['dictionary'] = $SQSPELL_APP[$sqspell_use_app];
+ $aParams['charset'] = $default_charset;
+ $check = new php_pspell($aParams);
+} else {
+ include_once(SM_PATH . 'plugins/squirrelspell/class/cmd_spell.php');
+ $aParams['spell_command'] = $SQSPELL_APP[$sqspell_use_app];
+ if ($SQSPELL_FORCE_POPEN) {
+ $aParams['use_proc_open'] = false;
+ } else {
+ $aParams['use_proc_open'] = check_php_version(4,3);
}
- fclose($fp);
- exec("$sqspell_command < $floc 2>&1", $sqspell_output, $sqspell_exitcode);
- unlink($floc);
+ $aParams['temp_dir'] = $attachment_dir;
+ $aParams['debug'] = false;
+ $check = new cmd_spell($aParams);
}
/**
- * Check if the execution was successful. Bail out if it wasn't.
+ * Check for class constructor function errors
*/
-if ($sqspell_exitcode){
+if (!empty($check->error)) {
$msg= '<div style="text-align: center;">'
- . sprintf(_("I tried to execute '%s', but it returned:"),
- $sqspell_command) . "<pre>"
- . htmlspecialchars(join("\n", $sqspell_output)) . '</pre>'
+ . nl2br(htmlspecialchars($check->error))
. '<form onsubmit="return false">'
. '<input type="submit" value=" ' . _("Close")
. ' " onclick="self.close()" /></form></div>';
exit;
}
-/**
- * Load the user dictionary.
- */
-$words=sqspell_getLang($sqspell_use_app);
-/**
- * Define some variables to be used during the processing.
- */
-$current_line=0;
$missed_words=Array();
$misses = Array();
$locations = Array();
$errors=0;
+$results = $check->check_text($sqspell_new_text);
+
/**
- * Now we process the output of sqspell_command (ispell or aspell in
- * ispell compatibility mode, whichever). I'm going to be scarce on
- * comments here, since you can just look at the ispell/aspell output
- * and figure out what's going on. ;) The best way to describe this is
- * "Dark Magic".
+ * Check for execution errors
*/
-for ($i=0; $i<sizeof($sqspell_output); $i++){
- switch (substr($sqspell_output[$i], 0, 1)){
- /**
- * Line is empty.
- * Ispell adds empty lines when an end of line is reached
- */
- case '':
- $current_line++;
- break;
- /**
- * Line begins with "&".
- * This means there's a misspelled word and a few suggestions.
- */
- case '&':
- list($left, $right) = explode(": ", $sqspell_output[$i]);
- $tmparray = explode(" ", $left);
- $sqspell_word=$tmparray[1];
- /**
- * Check if the word is in user dictionary.
- */
- if (! in_array($sqspell_word,$words)){
- $sqspell_symb=intval($tmparray[3])-1;
- if (!isset($misses[$sqspell_word])) {
- $misses[$sqspell_word] = $right;
- $missed_words[$errors] = $sqspell_word;
- $errors++;
- }
- if (isset($locations[$sqspell_word])){
- $locations[$sqspell_word] .= ', ';
- } else {
- $locations[$sqspell_word] = '';
- }
- $locations[$sqspell_word] .= "$current_line:$sqspell_symb";
+if (!empty($check->error)) {
+ $msg= '<div style="text-align: center;">'
+ . nl2br(htmlspecialchars($check->error))
+ . '<form onsubmit="return false">'
+ . '<input type="submit" value=" ' . _("Close")
+ . ' " onclick="self.close()" /></form></div>';
+ sqspell_makeWindow(null, _("SquirrelSpell is misconfigured."), null, $msg);
+ exit;
+}
+
+if (is_array($results)) {
+ // convert variables to old style squirrelspell results
+ if (!empty($results)) {
+ foreach(array_keys($results) as $word) {
+ if (isset($results[$word]['locations'])) {
+ $missed_words[] = $word;
+ $locations[$word] = implode(', ',$results[$word]['locations']);
+ if (isset($results[$word]['suggestions'])) {
+ $misses[$word] = implode(', ',$results[$word]['suggestions']);
+ } else {
+ $misses[$word] = '_NONE';
+ }
+ } else {
+ // $word without 'locations'. ignore it
+ }
+ }
+ $errors = count($missed_words);
}
- break;
- /**
- * Line begins with "#".
- * This means a misspelled word and no suggestions.
- */
- case '#':
- $tmparray = explode(" ", $sqspell_output[$i]);
- $sqspell_word=$tmparray[1];
- /**
- *
- * Check if the word is in user dictionary.
- */
- if (!in_array($sqspell_word,$words)){
- $sqspell_symb=intval($tmparray[2])-1;
- if (!isset($misses[$sqspell_word])) {
- $misses[$sqspell_word] = '_NONE';
- $missed_words[$errors] = $sqspell_word;
- $errors++;
- }
- if (isset($locations[$sqspell_word])) {
- $locations[$sqspell_word] .= ', ';
- } else {
- $locations[$sqspell_word] = '';
- }
- $locations[$sqspell_word] .= "$current_line:$sqspell_symb";
+} else {
+ if (!empty($check->error)) {
+ $error_msg = nl2br(htmlspecialchars($check->error));
+ } else {
+ $error_msg = _("Unknown error");
}
- break;
- }
+ $msg= '<div style="text-align: center;">'
+ . $error_msg
+ . '<form onsubmit="return false">'
+ . '<input type="submit" value=" ' . _("Close")
+ . ' " onclick="self.close()" /></form></div>';
+ sqspell_makeWindow(null, _("SquirrelSpell error."), null, $msg);
+ exit;
}
if ($errors){