-
Notifications
You must be signed in to change notification settings - Fork 7.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Fix #2750 #2763
Fix #2750 #2763
Changes from 3 commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -14,26 +14,37 @@ | |
#ifndef _SPIFFS_H_ | ||
#define _SPIFFS_H_ | ||
|
||
#pragma once | ||
|
||
#include "FS.h" | ||
#include "FSImpl.h" | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. these two includes should not be in the header, but in the CPP file instead. Nothing in the header depends on them :) There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The header does depend on them, but they are also included via vfs_api.h, so at most they are redundant. For the same reason they don't need to be included in the .cpp file (because they are included via vfs_api.h which is included via SPIFFS.h). Whatever, I have removed them from SPIFFS.h, but I haven't added them to SPIFFS.cpp. |
||
#include "vfs_api.h" | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. FS should be included. vfs_api is a private header. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 18 hours ago, you asked me to remove FS.h and FSImpl.h, now you are asking me to add FS.h back in. If I remove vfs_api.h I will also have to add FSImpl.h back because SPIFFSImpl is declared in SPIFFS.h. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. No, I asked about There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This change requires an additional class, SPIFFFSImpl that inherits VFSImpl, which is declared in vfs_api.h, so something is going to need to include vfs_api.h. Currently this class is declared in SPIFFS.h, which is why SPIFFS.h includes vfs_api.h. How would you have me resolve this? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Does this class need to be public? What happens if the declaration goes into the CPP file? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It should be fine if I move it to the CPP file. |
||
|
||
namespace fs | ||
{ | ||
|
||
class SPIFFSImpl : public VFSImpl | ||
{ | ||
public: | ||
SPIFFSImpl(); | ||
virtual ~SPIFFSImpl() { } | ||
virtual bool exists(const char* path); | ||
}; | ||
|
||
class SPIFFSFS : public FS | ||
{ | ||
public: | ||
SPIFFSFS(FSImplPtr impl); | ||
SPIFFSFS(); | ||
bool begin(bool formatOnFail=false, const char * basePath="/spiffs", uint8_t maxOpenFiles=10); | ||
bool format(); | ||
size_t totalBytes(); | ||
size_t usedBytes(); | ||
void end(); | ||
bool exists(const char* path); | ||
bool exists(const String& path); | ||
}; | ||
|
||
} | ||
|
||
extern fs::SPIFFSFS SPIFFS; | ||
|
||
#endif /* _SPIFFS_H_ */ | ||
|
||
#endif |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this is redundant with the above. keep one or the other :)