简体   繁体   中英

Gulp-rename files only and not directories

function javascriptSites() {
  return gulp.src(PATHS.javascriptSites)
  .pipe($.sourcemaps.init())
  .pipe($.babel())
  .pipe($.if(PRODUCTION, $.uglify()
    .on('error', e => { console.log(e); })
  ))
  .pipe($.if(PRODUCTION, $.rename({
    suffix: '.min'  
  })))
  .pipe(gulp.dest('dist/assets/js'))
}

This is outputting the following tree:

dir/assets/js/

folder1
    site.min.js

folder1.min
    empty

folder2
    site.min.js

folder2.min
    empty

folder3
    site.min.js

folder3.min
    empty

I would like to ONLY rename files and not directories (and not have repeating folders) but I cannot figure how to filter out directories. Any help is appreciated!

Edited: config.yml file added for Fabio

  # Your project's server will run on localhost:xxxx at this port
  PORT: 8000

  # Autoprefixer will make sure your CSS works with these browsers
  COMPATIBILITY:
    - "last 2 versions"
    - "ie >= 9"

  # UnCSS will use these settings
  UNCSS_OPTIONS:
    html:
      - "src/**/*.html"
    ignore:
      - !!js/regexp .foundation-mq
      - !!js/regexp ^\.is-.*

  # Gulp will reference these paths when it copies files
  PATHS:
    # Paths to static assets that aren't images, CSS, or JavaScript
    assets:
      - "src/assets/**/*"
      - "!src/assets/{img,js,scss}/**/*"
    fonts:
      - "bower_components/font-awesome/fonts/**/*"

    # Paths to Sass libraries, which can then be loaded with @import
    sass:
      - "bower_components/foundation-sites/scss"
      - "bower_components/motion-ui/src"
      - "src/assets/scss"

    # Paths to JavaScript libraries, which are compined into one file
    javascript:
     # Libraries requried by Foundation
      - "bower_components/jquery/dist/jquery.js"
      - "bower_components/what-input/what-input.js"
     # Core Foundation files
      - "bower_components/foundation-sites/js/foundation.core.js"
      - "bower_components/foundation-sites/js/foundation.util.*.js"
     # Individual Foundation components
     # If you aren't using a component, just remove it from the list
      - "bower_components/foundation-sites/js/foundation.abide.js"
      - "bower_components/foundation-sites/js/foundation.accordion.js"
      - "bower_components/foundation-sites/js/foundation.accordionMenu.js"
      - "bower_components/foundation-sites/js/foundation.drilldown.js"
      - "bower_components/foundation-sites/js/foundation.dropdown.js"
      - "bower_components/foundation-sites/js/foundation.dropdownMenu.js"
      - "bower_components/foundation-sites/js/foundation.equalizer.js"
      - "bower_components/foundation-sites/js/foundation.interchange.js"
      - "bower_components/foundation-sites/js/foundation.magellan.js"
      - "bower_components/foundation-sites/js/foundation.offcanvas.js"
      - "bower_components/foundation-sites/js/foundation.orbit.js"
      - "bower_components/foundation-sites/js/foundation.responsiveMenu.js"
      - "bower_components/foundation-sites/js/foundation.responsiveToggle.js"
      - "bower_components/foundation-sites/js/foundation.reveal.js"
      - "bower_components/foundation-sites/js/foundation.slider.js"
      - "bower_components/foundation-sites/js/foundation.sticky.js"
      - "bower_components/foundation-sites/js/foundation.tabs.js"
      - "bower_components/foundation-sites/js/foundation.toggler.js"
      - "bower_components/foundation-sites/js/foundation.tooltip.js"
     # Paths to your own project code are here
      - "src/assets/js/!(app).js"
      - "src/assets/js/app.js"
      - "bower_components/owl.carousel/dist/owl.carousel.js"

     javascriptSites:
      - "src/assets/js/**/*"
      - "!src/assets/js/app.js"

The problem is in your .yml file. You specified this as your source:

javascriptSites:
      - "src/assets/js/**/*"
      - "!src/assets/js/app.js"

Now the reason why your folders are being renamed and changed is because you're passing everything that is inside of your src/assets/js/ to your gulp pipes, when clearly what you want is to pass only all the javascript files.

To do that you need to change your .yml file to this:

javascriptSites:
      - "src/assets/js/**/*.js"
      - "!src/assets/js/app.js"

Note that we added the .js to your first line, so gulp only sources javascript files and not folders.

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM