… | |
… | |
119 | REQ_STAT, REQ_LSTAT, REQ_FSTAT, |
119 | REQ_STAT, REQ_LSTAT, REQ_FSTAT, |
120 | REQ_TRUNCATE, REQ_FTRUNCATE, |
120 | REQ_TRUNCATE, REQ_FTRUNCATE, |
121 | REQ_UTIME, REQ_FUTIME, |
121 | REQ_UTIME, REQ_FUTIME, |
122 | REQ_CHMOD, REQ_FCHMOD, |
122 | REQ_CHMOD, REQ_FCHMOD, |
123 | REQ_CHOWN, REQ_FCHOWN, |
123 | REQ_CHOWN, REQ_FCHOWN, |
124 | REQ_FSYNC, REQ_FDATASYNC, |
124 | REQ_SYNC, REQ_FSYNC, REQ_FDATASYNC, |
125 | REQ_UNLINK, REQ_RMDIR, REQ_MKDIR, REQ_RENAME, |
125 | REQ_UNLINK, REQ_RMDIR, REQ_MKDIR, REQ_RENAME, |
126 | REQ_MKNOD, REQ_READDIR, |
126 | REQ_MKNOD, REQ_READDIR, |
127 | REQ_LINK, REQ_SYMLINK, REQ_READLINK, |
127 | REQ_LINK, REQ_SYMLINK, REQ_READLINK, |
128 | REQ_GROUP, REQ_NOP, |
128 | REQ_GROUP, REQ_NOP, |
129 | REQ_BUSY, |
129 | REQ_BUSY, |
… | |
… | |
1267 | case REQ_LINK: req->result = link (req->ptr2, req->ptr1); break; |
1267 | case REQ_LINK: req->result = link (req->ptr2, req->ptr1); break; |
1268 | case REQ_SYMLINK: req->result = symlink (req->ptr2, req->ptr1); break; |
1268 | case REQ_SYMLINK: req->result = symlink (req->ptr2, req->ptr1); break; |
1269 | case REQ_MKNOD: req->result = mknod (req->ptr2, req->mode, (dev_t)req->offs); break; |
1269 | case REQ_MKNOD: req->result = mknod (req->ptr2, req->mode, (dev_t)req->offs); break; |
1270 | case REQ_READLINK: req->result = readlink (req->ptr2, req->ptr1, NAME_MAX); break; |
1270 | case REQ_READLINK: req->result = readlink (req->ptr2, req->ptr1, NAME_MAX); break; |
1271 | |
1271 | |
|
|
1272 | case REQ_SYNC: req->result = 0; sync (); break; |
|
|
1273 | case REQ_FSYNC: req->result = fsync (req->int1); break; |
1272 | case REQ_FDATASYNC: req->result = fdatasync (req->int1); break; |
1274 | case REQ_FDATASYNC: req->result = fdatasync (req->int1); break; |
1273 | case REQ_FSYNC: req->result = fsync (req->int1); break; |
1275 | |
1274 | case REQ_READDIR: scandir_ (req, self); break; |
1276 | case REQ_READDIR: scandir_ (req, self); break; |
1275 | |
1277 | |
1276 | case REQ_BUSY: |
1278 | case REQ_BUSY: |
1277 | #ifdef _WIN32 |
1279 | #ifdef _WIN32 |
1278 | Sleep (req->nv1 * 1000.); |
1280 | Sleep (req->nv1 * 1000.); |
… | |
… | |
1887 | XPUSHs (req_sv (req, AIO_GRP_KLASS)); |
1889 | XPUSHs (req_sv (req, AIO_GRP_KLASS)); |
1888 | } |
1890 | } |
1889 | |
1891 | |
1890 | void |
1892 | void |
1891 | aio_nop (SV *callback=&PL_sv_undef) |
1893 | aio_nop (SV *callback=&PL_sv_undef) |
|
|
1894 | ALIAS: |
|
|
1895 | aio_nop = REQ_NOP |
|
|
1896 | aio_sync = REQ_SYNC |
1892 | PPCODE: |
1897 | PPCODE: |
1893 | { |
1898 | { |
1894 | dREQ; |
1899 | dREQ; |
1895 | |
1900 | |
1896 | req->type = REQ_NOP; |
1901 | req->type = ix; |
1897 | |
1902 | |
1898 | REQ_SEND; |
1903 | REQ_SEND; |
1899 | } |
1904 | } |
1900 | |
1905 | |
1901 | int |
1906 | int |