當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript fs.fstatSync函數代碼示例

本文整理匯總了TypeScript中fs.fstatSync函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript fstatSync函數的具體用法?TypeScript fstatSync怎麽用?TypeScript fstatSync使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了fstatSync函數的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: it

 it('fs.write should work with util.promisify', (done: DoneFn) => {
   const promisifyWrite = util.promisify(write);
   const dest = __filename + 'write';
   const fd = openSync(dest, 'a');
   const stats = fstatSync(fd);
   const chunkSize = 512;
   const buffer = new Buffer(chunkSize);
   for (let i = 0; i < chunkSize; i++) {
     buffer[i] = 0;
   }
   // fd, buffer, offset, length, position, callback
   promisifyWrite(fd, buffer, 0, chunkSize, 0)
       .then(
           (value) => {
             expect(value.bytesWritten).toBe(chunkSize);
             closeSync(fd);
             unlinkSync(dest);
             done();
           },
           err => {
             closeSync(fd);
             unlinkSync(dest);
             fail(`should not be here with error: ${error}.`);
           });
 });
開發者ID:angular,項目名稱:zone.js,代碼行數:25,代碼來源:fs.spec.ts

示例2: open

 protected open(filename: string): number {
   let fd = fs.openSync(filename, "r");
   this.fileMap[fd] = {
     size: fs.fstatSync(fd).size,
     pos: 0,
     name: filename,
   };
   return fd;
 }
開發者ID:YuJianrong,項目名稱:nodejs-unrar,代碼行數:9,代碼來源:fileExtractor.ts

示例3: setTimeout

    fs.stat(LOG_FILE, (err, stat) => {
      if (err && !err.message.startsWith("ENOENT:")) throw err;

      if (!(stat && stat.dev === logStat.dev && stat.ino === logStat.ino)) {
        logStream.end();
        logStream = fs.createWriteStream(null, {
          fd: fs.openSync(LOG_FILE, "a")
        });
        logStat = fs.fstatSync(logStream.fd);
      }

      if (--counter === 0)
        setTimeout(reopen, REOPEN_EVERY - (Date.now() % REOPEN_EVERY)).unref();
    });
開發者ID:zaidka,項目名稱:genieacs,代碼行數:14,代碼來源:logger.ts

示例4: init

export function init(service, version): void {
  defaultMeta.hostname = os.hostname();
  defaultMeta.pid = process.pid;
  defaultMeta.name = `genieacs-${service}`;
  defaultMeta.version = version;

  LOG_FILE = config.get(`${service.toUpperCase()}_LOG_FILE`);
  ACCESS_LOG_FILE = config.get(`${service.toUpperCase()}_ACCESS_LOG_FILE`);

  if (LOG_FILE) {
    logStream = fs.createWriteStream(null, { fd: fs.openSync(LOG_FILE, "a") });
    logStat = fs.fstatSync(logStream.fd);
  }

  if (ACCESS_LOG_FILE) {
    accessLogStream = fs.createWriteStream(null, {
      fd: fs.openSync(ACCESS_LOG_FILE, "a")
    });
    accessLogStat = fs.fstatSync(accessLogStream.fd);
  }

  // Determine if logs are going to journald
  const JOURNAL_STREAM = process.env["JOURNAL_STREAM"];

  if (JOURNAL_STREAM) {
    const [dev, inode] = JOURNAL_STREAM.split(":").map(parseInt);

    LOG_SYSTEMD = logStat.dev === dev && logStat.ino === inode;
    ACCESS_LOG_SYSTEMD =
      accessLogStat.dev === dev && accessLogStat.ino === inode;
  }

  if (LOG_FILE || ACCESS_LOG_FILE)
    // Can't use setInterval as we need all workers to cehck at the same time
    setTimeout(reopen, REOPEN_EVERY - (Date.now() % REOPEN_EVERY)).unref();
}
開發者ID:zaidka,項目名稱:genieacs,代碼行數:36,代碼來源:logger.ts

示例5: openSync

import { openSync, readSync, fstatSync, Stats } from 'fs';

let fileDescriptor: number;
try {
  fileDescriptor = openSync('hello.txt', 'r');
} catch (err) {
  console.log(`Couldn't open: ${err.message}`);
  process.exit(1);
}

let stat: Stats;
try {
  stat = fstatSync(fileDescriptor);
} catch (err) {
  console.log(`Couldn't get stat: ${err.message}`);
  process.exit(1);
}

const buffer = Buffer.alloc(stat.size);

try {
  readSync(fileDescriptor, buffer, 0, stat.size, null);
} catch (err) {
  console.log(`Couldn't read: ${err.message}`);
  process.exit(1);
}

let data: string;
try {
  data = buffer.toString();
} catch (err) {
開發者ID:Mercateo,項目名稱:rust-for-node-developers,代碼行數:31,代碼來源:index.ts

示例6: reopen

  /* eslint-disable-next-line @typescript-eslint/no-namespace */
  namespace NodeJS {
    export interface WritableStream {
      fd?: number;
    }
  }
}

declare module "fs" {
  interface WriteStream {
    fd?: number;
  }
}

let logStream = fs.createWriteStream(null, { fd: process.stderr.fd });
let logStat = fs.fstatSync(logStream.fd);
let accessLogStream = fs.createWriteStream(null, { fd: process.stdout.fd });
let accessLogStat = fs.fstatSync(accessLogStream.fd);

// Reopen if original files have been moved (e.g. logrotate)
function reopen(): void {
  let counter = 1;

  if (LOG_FILE) {
    ++counter;
    fs.stat(LOG_FILE, (err, stat) => {
      if (err && !err.message.startsWith("ENOENT:")) throw err;

      if (!(stat && stat.dev === logStat.dev && stat.ino === logStat.ino)) {
        logStream.end();
        logStream = fs.createWriteStream(null, {
開發者ID:zaidka,項目名稱:genieacs,代碼行數:31,代碼來源:logger.ts

示例7: openSync

import { openSync, readSync, fstatSync } from 'fs';

let file;
try {
  file = openSync('hello.txt', 'r');
} catch (err) {
  console.log(`Couldn't open: ${err.message}`);
  process.exit(1);
}

let stat;
try {
  stat = fstatSync(file);
} catch (err) {
  console.log(`Couldn't get stat: ${err.message}`);
  process.exit(1);
}

const buffer = new Buffer(stat.size);

try {
  readSync(file, buffer, 0, stat.size, null);
} catch (err) {
  console.log(`Couldn't read: ${err.message}`);
  process.exit(1);
}

let data;
try {
  data = buffer.toString();
} catch (err) {
開發者ID:allyjweir,項目名稱:rust-for-node-developers,代碼行數:31,代碼來源:index.ts


注:本文中的fs.fstatSync函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。