function vmn_sendThrottledItems($now, $emailsettings, $throttleinterval, $throttlesize)
{
    $database =& JFactory::getDBO();
    if ($throttleinterval < 1 || $throttlesize < 1) {
        return;
    }
    vmn_lockTable();
    $database->setQuery("SELECT throttletime FROM #__vemod_news_mailer_scantime LIMIT 1");
    $throttletime = $database->loadResult();
    if (strtotime($now) - strtotime($throttletime) < $throttleinterval) {
        vmn_unlockTable();
        return;
    }
    $database->setQuery("SELECT COUNT(*) FROM #__vemod_news_mailer_log WHERE status >= 10 OR status <= -10 ORDER BY sent LIMIT 1");
    $tcount = $database->loadResult();
    if ($tcount) {
        $database->setQuery("UPDATE #__vemod_news_mailer_scantime SET throttletime=" . $database->Quote($now) . " LIMIT 1");
        $database->query();
    }
    vmn_unlockTable();
    echo chr(0x0);
    $database->setQuery("SELECT * FROM #__vemod_news_mailer_log WHERE status >= 10 ORDER BY sent LIMIT 1");
    $throttleditem = NULL;
    $throttleditem = $database->loadObject();
    if ($throttleditem) {
        $database->setQuery("UPDATE  #__vemod_news_mailer_log SET sent=" . $database->quote($now) . ", status=status+1 WHERE id={$throttleditem->id}");
        $database->Query();
        $throttlecount = $throttleditem->status - 9;
        $codedmessage = vmn_codeMessage($throttleditem->message);
        $valid = vmn_getLoggedUsers($throttleditem->users, $throttlesize, $throttlecount);
        if (count($valid)) {
            $statuscount = 0;
            for ($i = 0; $i < count($valid['email']); $i++) {
                @set_time_limit(600);
                $status = JUtility::sendMail($emailsettings['mailfrom'], $emailsettings['fromname'], $valid['email'][$i], $throttleditem->subject, str_replace('[username]', $valid['name'][$i], $codedmessage), 1, NULL, NULL) === true;
                if ($i % 5 == 0) {
                    echo chr(0x0);
                }
                if ($status) {
                    $statuscount++;
                }
            }
            if ($throttleditem->status == 10) {
                if ($statuscount < count($valid['email']) * 0.9) {
                    $database->setQuery("UPDATE  #__vemod_news_mailer_log SET sent=" . $database->quote($now) . ", status=1 WHERE id={$throttleditem->id}");
                    $database->Query();
                    return;
                }
            }
            return;
        } else {
            $database->setQuery("UPDATE  #__vemod_news_mailer_log SET sent=" . $database->quote($now) . ", status=0 WHERE id={$throttleditem->id}");
            $database->Query();
        }
    }
    $database->setQuery("SELECT * FROM #__vemod_news_mailer_log WHERE status <= -10 ORDER BY sent LIMIT 1");
    $throttleditem = NULL;
    $throttleditem = $database->loadObject();
    if ($throttleditem) {
        $database->setQuery("UPDATE  #__vemod_news_mailer_log SET sent=" . $database->quote($now) . ", status=status-1 WHERE id={$throttleditem->id}");
        $database->Query();
        $throttlecount = abs($throttleditem->status) - 9;
        $message = $throttleditem->message;
        $smsprefix = '';
        if (strpos($message, '<sms></sms>') === 0) {
            $smsprefix = '<sms></sms>';
            $message = str_replace('<sms></sms>', '', $message);
        }
        $search = array('<pre>', '</pre>');
        $replace = array('', '');
        $message = str_replace($search, $replace, $message);
        $codedmessage = vmn_codeMessage($message);
        $valid = vmn_getLoggedUsers($throttleditem->users, $throttlesize, $throttlecount);
        if (count($valid)) {
            $statuscount = 0;
            for ($i = 0; $i < count($valid['email']); $i++) {
                @set_time_limit(600);
                if (strlen($smsprefix)) {
                    $status = JUtility::sendMail($emailsettings['smsmailfrom'], $emailsettings['smsfromname'], $valid['email'][$i], $throttleditem->subject, str_replace('[username]', $valid['name'][$i], $codedmessage), 0, NULL, NULL) === true;
                } else {
                    $status = JUtility::sendMail($emailsettings['mailfrom'], $emailsettings['fromname'], $valid['email'][$i], $throttleditem->subject, str_replace('[username]', $valid['name'][$i], $codedmessage), 0, NULL, NULL) === true;
                }
                if ($i % 5 == 0) {
                    echo chr(0x0);
                }
                if ($status) {
                    $statuscount++;
                }
            }
            if ($throttleditem->status == -10) {
                if ($statuscount < count($valid['email']) * 0.9) {
                    $database->setQuery("UPDATE  #__vemod_news_mailer_log SET sent=" . $database->quote($now) . ", status=2 WHERE id={$throttleditem->id}");
                    $database->Query();
                    return;
                }
            }
        } else {
            $database->setQuery("UPDATE  #__vemod_news_mailer_log SET sent=" . $database->quote($now) . ", status=0 WHERE id={$throttleditem->id}");
            $database->Query();
        }
    }
}
                 $subscribers = vmn_getSubscribers($newitems[$i]->catid, unserialize(stripslashes($customrecipients)));
                 if (count($subscribers)) {
                     $title = vmn_getCatTitle($newitems[$i]->catid);
                     vmn_sendNews($newitems[$i], TRUE, $HTMLmessage, $textmessage, $subject, $sentHTMLusers, $senttextusers, $subscribers, $now, $readmore, $sidebarmodules, $newsmailHTML, $newsmailText, $mailformat, $textusers, $emailsettings, $unsubscribealltext, $base_url, $title, @$throttleinterval, @$throttlesize, $newsmailsubject, @$stripmambots);
                     if (in_array($newitems[$i]->catid, $checkedsms)) {
                         $smssubscribers = vmn_getSMSSubscribers($newitems[$i]->catid);
                         vmn_sendSMS($newitems[$i], TRUE, $smsmessage, $subjectsms, $sentsmsusers, $smssubscribers, $now, @$smsText, $emailsettings, $title, @$throttleinterval, @$throttlesize, @$smssubject);
                     }
                 }
             }
         }
         if (isset($logsize)) {
             vmn_trimLog($logsize);
         }
     } else {
         vmn_unlockTable();
     }
     vmn_sendThrottledItems($now, $emailsettings, @$throttleinterval, @$throttlesize);
     break;
 case 5:
     //Kill log
     if ($fromtemplate) {
         break;
     }
     if (!vmn_userAccess($previewusers) && !vmn_userAccess($mailusers)) {
         vmn_doPageTop(JTEXT::_('VMN_LOGIN'));
         echo $registertext;
         break;
     }
     if ($killlogitems) {
         if (count(@$_POST['cid'])) {