55502f40dc8b7c769880b10874abc9d0

Since path.exists and fs.stat are asynchronous functions I had to create a tree like this. Any suggestions how I can do it with a for loop?

filesize_done = 0;
path.exists(filename + "." + 0, function(exists) {
  fs.stat(filename + "." + 0, function(err, stat) {
    filesize_done += stat.size;
    path.exists(filename + "." + 1, function(exists) {
      fs.stat(filename + "." + 1, function(err, stat) {
        filesize_done += stat.size;
        path.exists(filename + "." + 2, function(exists) {
          fs.stat(filename + "." + 2, function(err, stat) {
            filesize_done += stat.size;
            console.log(filesize_done);
          });
        });
      });
    });
  });
});

Refactorings

No refactoring yet !

C953ddd239707998340e1a6fbb3eeb46

Tim Caswell

August 26, 2010, August 26, 2010 00:04, permalink

1 rating. Login to rate!

Use Step and path.exists is redundant when you're doing a stat anyway.

// http://github.com/creationix/step
var Step = require('step'),
    fs = require('fs');

// Simple utility that doesn't error out when the file doesn't exist
// and returns the size    
function getSize(filename, callback) {
  fs.stat(filename, function (err, stat) {
    if (err) {
      if (err.errno === process.ENOENT) {
        return callback(null, 0);
      }
      return callback(err);
    }
    callback(null, stat.size);
  });
}

var getTotal = Step.fn(
  function startChecks(filename, num) {
    var group = this.group();
    for (var i = 0; i < num; i++) {
      getSize(filename + "." + i, this);)
    }
  },
  function combine(err, sizes) {
    if (err) throw err;
    var total = 0;
    sizes.forEach(function (size) {
      total += size;
    });
    return total;
  }
);

getTotal("Myfile", 3, function (err, total) {
  // You now have the total size
});
A6d98536d90d2987d40a6abe731805ca

Fabian Jakobs

August 27, 2010, August 27, 2010 07:06, permalink

No rating. Login to rate!

With async.js you can rewrite your code in this functional style.

// http://github.com/fjakobs/async.js

var async = require("async");

async.files([filename + "." + 0, filename + "." + 1, filename + "." + 2])
    .exists()
    .filter(function(file) {
        return file.exists;
    })
    .stat()
    .reduce(function(file, sum) {
        return sum + file.stat.size;
    }, 0)
    .end(function(err, sum) {
        console.log(sum)
    })
Feb4d45f386d1ec13bf305746a707f6e

Shimon Doodkin

September 30, 2010, September 30, 2010 13:31, permalink

No rating. Login to rate!

my new node-inflow library is really good it makes non-common staff more common.

http://github.com/shimondoodkin/node-inflow

//inflow.each( shared_object, array_or_object, foreach_function(value,key,array), done_function [, debug=true/false] );


var inflow = require('node-inflow');
var size=0;

inflow.each({},['file1.txt','file2.txt','file3.txt'],function (value,key,array){
 var next=this.next;
 var filename=value;
 path.exists(filename, function(exists)
 {
  fs.stat(filename, function(err, stat)
  {
   size += stat.size;
   next();
  });
 });
},function (){
 console.log('size:'+size);
});


or

var inflow = require('node-inflow');

inflow.each({size:0},['file1.txt','file2.txt','file3.txt'],function (filename){

 var next=this;
 var shared=this.shared;

 path.exists(filename, function(exists){
  fs.stat(filename, function(err, stat){
   shared.size += stat.size;
   next();
  });
 });

},function (){
 console.log('size:'+this.shared.size);
});
Ae86efdd6e5e5ad9eb7ff86a280ee3ea

mablePabure

May 3, 2011, May 03, 2011 15:02, permalink

No rating. Login to rate!

Medication Safety Quiz For Nurses http://www.champion-audi.com/ - prednisone medication It can also be used in the treatment of migraines, cluster headaches, leukemia, Hodgkin?s lymphoma, and hormone sensitive tumors. http://www.champion-audi.com/ - prednisone medication

A30e2ff91282edecc0e65368a80af5d1

encalryinsise

May 15, 2011, May 15, 2011 10:50, permalink

No rating. Login to rate!

Immortality Pills
http://www.pgntravelteam.com/ - librium sale
It is an important drug as it was the first benzodiazepine to be synthesized.
http://www.pgntravelteam.com/ - librium sale

1919bfc4fa95c7f6b231e583da677a17

jonn2

June 15, 2011, June 15, 2011 00:12, permalink

No rating. Login to rate!

comment2,

comment2,
1919bfc4fa95c7f6b231e583da677a17

jonn2

June 15, 2011, June 15, 2011 03:48, permalink

No rating. Login to rate!

comment2,

comment2,
515a7a123756b91e56705ab8a7c48c31

CafDahsmeashy

June 15, 2011, June 15, 2011 20:33, permalink

No rating. Login to rate!

$4 Prescription Drug List Kroger http://crueton.com/ - cialis comprar Si usted es afectado de anemia, leucemia o cA?ncer de hueso, podrA­a verse afectado por incomodas erecciones muy prolongadas, misma precauciA?n que deberA? tener si padece de problemas al hA­gado, riA±A?n, enfermedades al corazA?n y anormalidades fA­sicas en el pene, como curvatura muy pronunciada, cicatrices, etc. http://crueton.com/ - comprar cialis online

9b652d908baed35e148f8f4b67f2cae8

Elaravianna

July 18, 2011, July 18, 2011 01:36, permalink

No rating. Login to rate!

Tablets Voltarol http://www.dunedinhomesforsale.org/ - cheapest librium The discovery of Lubrium was an accident, however, many ill patients are glad that it was discovered. http://www.dunedinhomesforsale.org/ - librium sale

6f0bd3997a48da1755f0d7bfa1c71d9d

poophycle

August 13, 2011, August 13, 2011 14:11, permalink

No rating. Login to rate!

The Top Penis Enlargemnet Pills http://www.texashighschoolfootballonline.com/ - discount soma The first one among them is that soma drug is colorless. http://www.texashighschoolfootballonline.com/ - soma pills

B8bd34773402a3772a32766f1c80cb2d

Haraavaithser

August 27, 2011, August 27, 2011 02:04, permalink

No rating. Login to rate!

Vibrating Pills http://www.gptim.org/ - xanax without rx Today it is used to treat depression related anxiety as well as a broad variety of anxiety disorders. http://www.gptim.org/ - xanax price

3ae1bd0809b062e1af5da52fe005b96b

HerselsAborgo

August 18, 2011, August 18, 2011 14:50, permalink

No rating. Login to rate!

Hdl Raising Drugs
http://www.hobinator.com/ - generic lasix no prescription
Lasix is used to prevent bleeding during a race in race horses.
http://www.hobinator.com/ - furosemide without prescription

Ac19b36ee1f99f9257bfefbe9b97b677

occateNit

September 8, 2011, September 08, 2011 16:26, permalink

No rating. Login to rate!

Hello, http://www.c16mag.com/ - klonopin pills The United States Food and Drug Administration approved Klonopin and it has been on the market since 1997. http://www.c16mag.com/ - generic klonopin

B3faa5433e882f65cefe0c49a70eb30c

ingerfirm

September 15, 2011, September 15, 2011 11:56, permalink

No rating. Login to rate!

jeogrargy http://www.ryanfinnoceanracing.com/ - cheap klonopin no prescription Patients as well as medical professionals prefer Klonopin because it has a very low toxicity, a short half life, and it also begins to work quite quickly. http://www.ryanfinnoceanracing.com/ - klonopin without prescriptions

46d357e225d39a8b6ebb42de4550018a

NurnAeronse

October 9, 2011, October 09, 2011 10:17, permalink

No rating. Login to rate!

Canine Pain Pills http://pedalforwishes.org/ - accutane sale Accutane is a medication that was originally developed as a chemotherapy type medication for the treatment of brain and pancreatic cancer. http://pedalforwishes.org/ - buying accutane online

166920e465e5154c5ab95a8071f86bf3

Querdorie

October 7, 2011, October 07, 2011 12:17, permalink

No rating. Login to rate!

Hello, http://www.indiahouseraleigh.com/ - diazepam 5mg While some patients will experience some or all of these symptoms, others will not experience anything but a relief of symptoms. http://www.indiahouseraleigh.com/ - valium price

0042795431c223c3dbe4b8f7894537be

Dypeaccutty

October 16, 2011, October 16, 2011 07:52, permalink

No rating. Login to rate!

Dypeaccutty, http://www.elongsworld.com/ - discount zyprexa Other off label uses for the medication includes anorexia nervosa, Tourette syndrome, and stuttering. http://www.elongsworld.com/ - zyprexa for sale

7d2e1add7c90cc0067cd05b3c68b39ed

spoloNeew

October 20, 2011, October 20, 2011 22:37, permalink

No rating. Login to rate!

Hello, http://www.tamoxifenforsale.com/ - cheap tamoxifen So what can be done about пїЅmale breastsпїЅ? There are two options currently available; surgery and Nolvadex. http://www.tamoxifenforsale.com/ - purchase nolvadex

80a2d8009b1cff6ac26cb43a05b13e51

ENGILAEDGED

November 9, 2011, November 09, 2011 03:57, permalink

No rating. Login to rate!

ENGILAEDGED, http://www.tadalafilohnerezept.com/ - cialis kaufen Es wird nicht empfohlen, Cialis zu nehmen, wenn Sie Probleme mit Ihrem Blutdruck haben oder entsprechende Medikamente einnehmen. http://www.tadalafilohnerezept.com/ - cialis online kaufen

525385c41a26f86fec2552e983654c52

Inerencominib

December 4, 2011, December 04, 2011 07:11, permalink

No rating. Login to rate!

Inerencominib, http://www.microdynamic.org/ - clonazepam no prescription Hyperekplexia, restless legs syndrome, and parasomnia are also successfully treated with Klonopin. http://www.microdynamic.org/ - discount klonopin

535162ba40adb173200beeb0e642cba5

canadian pharmacies

January 20, 2012, January 20, 2012 03:44, permalink

No rating. Login to rate!

pharmacy one source american association of colleges of pharmacy osco pharmacy locator

Your refactoring





Format Copy from initial code

or Cancel