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


TypeScript fs.symlinkSync函數代碼示例

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


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

示例1: setupBazelTo

export function setupBazelTo(tmpDirPath: string) {
  const nodeModulesPath = path.join(tmpDirPath, 'node_modules');
  const angularDirectory = path.join(nodeModulesPath, '@angular');

  fs.mkdirSync(nodeModulesPath);
  fs.mkdirSync(angularDirectory);

  getAngularPackagesFromRunfiles().forEach(({pkgPath, name}) => {
    fs.symlinkSync(pkgPath, path.join(angularDirectory, name), 'dir');

    // todo: check why we always need an index.d.ts
    if (!fs.existsSync(path.join(angularDirectory, name, 'index.d.ts'))) {
      fs.symlinkSync(
          path.join(pkgPath, `${name}.d.ts`), path.join(angularDirectory, name, 'index.d.ts'));
    }
  });

  // Link typescript
  const typeScriptSource = resolveNpmTreeArtifact('npm/node_modules/typescript');
  const typescriptDest = path.join(nodeModulesPath, 'typescript');
  fs.symlinkSync(typeScriptSource, typescriptDest, 'dir');

  // Link "rxjs" if it has been set up as a runfile. "rxjs" is linked optionally because
  // not all compiler-cli tests need "rxjs" set up.
  try {
    const rxjsSource = resolveNpmTreeArtifact('rxjs', 'index.js');
    const rxjsDest = path.join(nodeModulesPath, 'rxjs');
    fs.symlinkSync(rxjsSource, rxjsDest, 'dir');
  } catch (e) {
    if (e.code !== 'MODULE_NOT_FOUND') throw e;
  }
}
開發者ID:zackarychapple,項目名稱:angular,代碼行數:32,代碼來源:test_support.ts

示例2: setupBazelTo

export function setupBazelTo(basePath: string) {
  const sources = process.env.TEST_SRCDIR;
  const packages = path.join(sources, 'angular/packages');
  const nodeModulesPath = path.join(basePath, 'node_modules');
  const angularDirectory = path.join(nodeModulesPath, '@angular');
  fs.mkdirSync(nodeModulesPath);

  // Link the built angular packages
  fs.mkdirSync(angularDirectory);
  const packageNames = fs.readdirSync(packages).filter(
      name => fs.statSync(path.join(packages, name)).isDirectory() &&
          fs.existsSync(path.join(packages, name, 'npm_package')));
  for (const pkg of packageNames) {
    fs.symlinkSync(path.join(packages, `${pkg}/npm_package`), path.join(angularDirectory, pkg));
  }

  // Link rxjs
  const rxjsSource = path.join(sources, 'rxjs');
  const rxjsDest = path.join(nodeModulesPath, 'rxjs');
  if (fs.existsSync(rxjsSource)) {
    fs.symlinkSync(rxjsSource, rxjsDest);
  }

  // Link typescript
  const typescriptSource =
      path.join(sources, 'angular/external/angular_deps/node_modules/typescript');
  const typescriptDest = path.join(nodeModulesPath, 'typescript');
  if (fs.existsSync(typescriptSource)) {
    fs.symlinkSync(typescriptSource, typescriptDest);
  }
}
開發者ID:hulkike,項目名稱:angular,代碼行數:31,代碼來源:test_support.ts

示例3: beforeEach

 beforeEach(() => {
   errorSpy = jasmine.createSpy('consoleError');
   basePath = makeTempDir();
   write = (fileName: string, content: string) => {
     const dir = path.dirname(fileName);
     if (dir != '.') {
       const newDir = path.join(basePath, dir);
       if (!fs.existsSync(newDir)) fs.mkdirSync(newDir);
     }
     fs.writeFileSync(path.join(basePath, fileName), content, {encoding: 'utf-8'});
   };
   write('tsconfig-base.json', `{
     "compilerOptions": {
       "experimentalDecorators": true,
       "skipLibCheck": true,
       "types": [],
       "outDir": "built",
       "declaration": true,
       "module": "es2015",
       "moduleResolution": "node",
       "lib": ["es6", "dom"]
     }
   }`);
   outDir = path.resolve(basePath, 'built');
   const ngRootDir = getNgRootDir();
   const nodeModulesPath = path.resolve(basePath, 'node_modules');
   fs.mkdirSync(nodeModulesPath);
   fs.symlinkSync(
       path.resolve(ngRootDir, 'dist', 'all', '@angular'),
       path.resolve(nodeModulesPath, '@angular'));
   fs.symlinkSync(
       path.resolve(ngRootDir, 'node_modules', 'rxjs'), path.resolve(nodeModulesPath, 'rxjs'));
 });
開發者ID:DanielKucal,項目名稱:angular,代碼行數:33,代碼來源:ngc_spec.ts

示例4: beforeEach

 beforeEach(() => {
   basePath = makeTempDir();
   write = (fileName: string, content: string) => {
     fs.writeFileSync(path.join(basePath, fileName), content, {encoding: 'utf-8'});
   };
   write('tsconfig-base.json', `{
     "compilerOptions": {
       "experimentalDecorators": true,
       "types": [],
       "outDir": "built",
       "declaration": true,
       "module": "es2015",
       "moduleResolution": "node",
       "lib": ["es6", "dom"]
     }
   }`);
   outDir = path.resolve(basePath, 'built');
   const ngRootDir = getNgRootDir();
   const nodeModulesPath = path.resolve(basePath, 'node_modules');
   fs.mkdirSync(nodeModulesPath);
   fs.symlinkSync(
       path.resolve(ngRootDir, 'dist', 'all', '@angular'),
       path.resolve(nodeModulesPath, '@angular'));
   fs.symlinkSync(
       path.resolve(ngRootDir, 'node_modules', 'rxjs'), path.resolve(nodeModulesPath, 'rxjs'));
 });
開發者ID:rjamet,項目名稱:angular,代碼行數:26,代碼來源:main_spec.ts

示例5: getAngularPackagesFromRunfiles

  getAngularPackagesFromRunfiles().forEach(({pkgPath, name}) => {
    fs.symlinkSync(pkgPath, path.join(angularDirectory, name), 'dir');

    // todo: check why we always need an index.d.ts
    if (!fs.existsSync(path.join(angularDirectory, name, 'index.d.ts'))) {
      fs.symlinkSync(
          path.join(pkgPath, `${name}.d.ts`), path.join(angularDirectory, name, 'index.d.ts'));
    }
  });
開發者ID:zackarychapple,項目名稱:angular,代碼行數:9,代碼來源:test_support.ts

示例6: makeProperTestDir

export async function makeProperTestDir(dirname: string) {
  const startingDir = path.join(baseDir, dirname);
  const tempDir = path.join(baseDir, 'temp');
  if (await exists(tempDir)) {
    await new Promise((resolve, reject) => {
      rimraf(tempDir, (err) => err ? reject(err) : resolve());
    });
  }
  fs.mkdirSync(tempDir);

  // copy dir
  const pathToTestDir = await copyDir(startingDir, tempDir);
  const bowerDir = bowerConfig.read(pathToTestDir).directory;

  fs.mkdirSync(path.join(pathToTestDir, 'node_modules'));
  fs.mkdirSync(
      path.join(pathToTestDir, 'node_modules', 'web-component-tester'));

  // set up symlinks into component dirs for browser.js, data/, and wct's
  // dependencies (like mocha, sinon, etc)
  const componentsDirs = new Set([bowerDir]);
  for (const baseFile of fs.readdirSync(startingDir)) {
    if (new RegExp(`${bowerDir}(-|$)`).test(baseFile)) {
      componentsDirs.add(baseFile);
    }
  }

  for (const baseComponentsDir of componentsDirs) {
    const componentsDir = path.join(pathToTestDir, baseComponentsDir);
    if (!await exists(componentsDir)) {
      fs.mkdirSync(componentsDir);
    }
    // all of wct's bower deps should be present in the project under tests'
    // components dir
    const bowerDeps =
        fs.readdirSync(path.join(__dirname, '../../bower_components'));
    for (const baseFile of bowerDeps) {
      fs.symlinkSync(
          path.join('../../../../../../bower_components', baseFile),
          path.join(componentsDir, baseFile));
    }
    // Also set up a web-component-tester dir with symlinks into our own
    // client-side files.
    const wctDir = path.join(componentsDir, 'web-component-tester');
    fs.mkdirSync(wctDir);
    fs.symlinkSync(
        '../../../../../../../browser.js', path.join(wctDir, 'browser.js'),
        'file');
    fs.symlinkSync(
        '../../../../../../../package.json', path.join(wctDir, 'package.json'),
        'file');
    fs.symlinkSync(
        '../../../../../../../data', path.join(wctDir, 'data'), 'dir');
  }

  return pathToTestDir;
}
開發者ID:Polymer,項目名稱:web-component-tester,代碼行數:57,代碼來源:setup_test_dir.ts

示例7: it

		it("should read real path of existing file", async () => {
			const source = await createTmpFile();
			const destination = tmpFile();
			nativeFs.symlinkSync(source, destination);
			await expect(util.promisify(fs.realpath)(destination))
				.resolves.toBe(source);
		});
開發者ID:AhmadAlyTanany,項目名稱:code-server,代碼行數:7,代碼來源:fs.test.ts

示例8: dir_symlink

function dir_symlink(source: string, target: string) {
    try {
        __fs.symlinkSync(source, target, 'junction');
    } catch (error) {
        logger.error('symlink: bold<%s>', error);
    }
}
開發者ID:atmajs,項目名稱:atma-io,代碼行數:7,代碼來源:fs_dir.ts

示例9: useRubyVersion

export async function useRubyVersion(parameters: TaskParameters, platform: Platform): Promise<void> {
    const toolName: string = 'Ruby';
    const installDir: string | null = tool.findLocalTool(toolName, parameters.versionSpec);
    if (!installDir) {
        // Fail and list available versions
        throw new Error([
            task.loc('VersionNotFound', parameters.versionSpec),
            task.loc('ListAvailableVersions'),
            tool.findLocalToolVersions('Ruby')
        ].join(os.EOL));
    }

    const toolPath: string = path.join(installDir, 'bin');
    if (platform !== Platform.Windows) {
        // replace the default
        const dest: string = '/usr/bin/ruby';
        if (fs.existsSync(dest)) {
            task.debug('removing ' + dest);
            fs.unlinkSync(dest);
        }
        fs.symlinkSync(path.join(toolPath, 'ruby'), dest);
    }

    task.setVariable('rubyLocation', toolPath);
    if (parameters.addToPath) {
        tool.prependPath(toolPath);
    }
}
開發者ID:bleissem,項目名稱:vsts-tasks,代碼行數:28,代碼來源:userubyversion.ts

示例10: function

        action: function (packageDescriptor: PackageDescriptor, packagePath: string, callback: (error?: Error) => void): void {
            let packageTypingsFilePath = path.join(packagePath, "typings.json");
            let packageTypingsPath = path.join(packagePath, targetPath);

            if (!fs.existsSync(packageTypingsPath)) {
                fs.mkdirSync(packageTypingsPath);
            }
            else {
                rimraf.sync(packageTypingsPath + "/**/*");
            }

            Logger.verbose(`Linking typings for workspace package '${util.colors.cyan(packageDescriptor.name)}'`);

            let typingFilePaths = getTypingFileReferences(require(packageTypingsFilePath));

            for (let typingFilePathEntry in typingFilePaths) {
                let typingFilePath = path.resolve(packagePath, typingFilePaths[typingFilePathEntry]);
                let targetTypingFilePath = path.join(packageTypingsPath, typingFilePathEntry);

                fs.mkdirSync(targetTypingFilePath);

                fs.symlinkSync(typingFilePath, path.join(targetTypingFilePath, `${typingFilePathEntry}.d.ts`));

                Logger.verbose(`Linked typing '${util.colors.cyan(typingFilePathEntry)}' (-> '${util.colors.blue(typingFilePath)}')`);
            }

            callback();
        }
開發者ID:i-e-b,項目名稱:gulp-npmworkspace,代碼行數:28,代碼來源:PostInstallTypings.ts


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