break;
case SITE_PREFIX."index_wr.php":
$header_out = array();
- $addr = "";
- // $ret = socket_getpeername($new_socket, $addr);
- printf("RET: %s\n", $addr);
- // exit(123);
ob_start();
index_wr_main($room, $addr, $get, $post, $cookie);
$content = ob_get_contents();
ob_end_clean();
-
- // printf("OUT: [%s]\n", $G_content);
- fwrite($new_socket, headers_render($header_out).$content);
- fclose($new_socket);
+
+ $pgflush = new PageFlush($new_socket, $curtime, 20, $header_out, $content);
+
+ if ($pgflush->try_flush($curtime) == FALSE) {
+ // Add $pgflush to the pgflush array
+ array_push($pages_flush, $pgflush);
+ }
break;
case SITE_PREFIX."index_rd_ifra.php":
do {
$header_out = array();
if (!isset($cookie['sess'])
|| (($user = $room->get_user($cookie['sess'], $idx)) == FALSE)) {
- $body = index_rd_ifra_fini(TRUE);
- fwrite($new_socket, headers_render($header_out).$body);
- fflush($new_socket);
- fclose($new_socket);
+ $content = index_rd_ifra_fini(TRUE);
+
+ $pgflush = new PageFlush($new_socket, $curtime, 20, $header_out, $content);
+
+ if ($pgflush->try_flush($curtime) == FALSE) {
+ // Add $pgflush to the pgflush array
+ array_push($pages_flush, $pgflush);
+ }
break;
}
// close a previous opened index_read_ifra socket, if exists
$user->rd_socket_set(NULL);
}
- $body = "";
- index_rd_ifra_init($room, $user, $header_out, $body, $get, $post, $cookie);
- fwrite($new_socket, headers_render($header_out).$body);
+ $content = "";
+ index_rd_ifra_init($room, $user, $header_out, $content, $get, $post, $cookie);
+ $content_l = mb_strlen($content, "ASCII");
+
+ $wret = @fwrite($new_socket, headers_render($header_out).$content);
+ if ($wret < $content_l) {
+ printf("TROUBLES WITH FWRITE: %d\n", $ret);
+ $user->rd_cache_set(mb_substr($content, $ret, $content_l - $ret, "ASCII"));
+ }
+ else {
+ $user->rd_cache_set("");
+ }
fflush($new_socket);
$s2u[intval($new_socket)] = $idx;