質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.77%

pugをコンパイル後、コンパイルされた全てのファイルを同じ階層にまとめたい

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 1,232
退会済みユーザー

退会済みユーザー

 前提・実現したいこと

pugをコンパイルして、出力先の一階層目に全ての出力したファイルをコピーしたい。

普通にpugをコンパイルすると、ディレクトリ構造を保ったまま出力されてしまいます。
コンパイル先の全てのファイルを一箇所にまとめたく、以下のタスクを書いたのですが思うように動きません。
最終的にはコピーした後に、コピーしたファイル以外は削除するつもりですが、コピーの部分で躓いてしまいました。。。

「コンパイル」と「コピー」を順番に行うために、run-sequenceを使い順番にタスクを実行しています。
ですが、watch中、コンパイルは行われるのですが、コピーが行われません。しかし、コンソール上にはコピーのタスクが実行されたとなっています。

コピーのタスクを単体で実行すると何故かコピーはされます。。。

なぜwatch中はコピーされないのでしょうか。

また、コピーのsrcでファイル名を指定しているのですが、これを**に変えるとコピーされませんでした。
この原因も分かる方いましたら併せてご教授お願い致します。

 該当のソースコード

var gulp    = require('gulp'),
    pug     = require('gulp-pug'),
    plumber = require('gulp-plumber'),
    notify  = require('gulp-notify'),
    rename  = require('gulp-rename'),
    runSequence = require('run-sequence');

var paths = {
    src: '_src/',
    dest: 'dest/'
}

gulp.task('pug', function () {
    gulp.src([
        paths.src + '**/*.pug',
        '!' + paths.src + '**/_*.pug'
    ])
        .pipe(plumber({
            errorHandler: notify.onError('<%= error.message %>')
        }))
        .pipe(pug({
            pretty: true,
            doctype: 'html'
        }))
        .pipe(rename({
            extname: '.php'
        }))
        .pipe(gulp.dest(paths.dest));
});

gulp.task('copy', function() {
    gulp.src(paths.dest + 'module/*.php')
        .pipe(gulp.dest(paths.dest));
});

gulp.task('run-sequence', function(callback) {
    return runSequence(
        'pug',
        'copy',
        callback
    );
});

gulp.task('watch', function () {
    gulp.watch(paths.src + '**/*.pug', ['run-sequence'])
});

 補足情報(FW/ツールのバージョンなど)

"gulp": "^3.9.1",
"gulp-notify": "^3.2.0",
"gulp-plumber": "^1.1.0",
"gulp-pug": "^3.3.0",
"gulp-rename": "^1.2.2",
"run-sequence": "^2.2.1"

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

0

そのものズバリな記事を見つけたので共有します。

gulp の run-sequence を使うときは return を忘れずに - Qiita

これを参考にpugとcopyタスクの1行目がreturn gulp...で始まるように変更して確かめてみてください。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/03/27 16:31

    リンク先の記事を元にreturnを付けたら動いてくれました。ありがとうございました。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.77%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る