前提
現在、ESP32C3用のプログラムを作成しています。
実現したいこと
SPIFFS領域へファイルを作成したり、読み込みためのプログラムを追加してビルドするとエラーが発生してしまいます。
プログラム作成では下記のサイトを参考にしました。
ESP32でSPIFFSにファイルを読み書きする方法 | 次世代情報技術研究所(仮)
何かインクルードするべきライブラリなどありますでしょうか?
解決方法をご教示の程よろしくお願い致します。
発生している問題・エラーメッセージ
[Starting] Analyzing sketch 'OnDemandAP.ino' [Warning] Output path is not specified. Unable to reuse previously compiled files. Build will be slower. See README. 構成をロード中… パッケージを初期化中… ボードを準備中… 検証中… OnDemandAP:11:14: error: variable or field 'listDir' declared void void listDir(fs::FS &fs, const char * dirname, uint8_t levels){ ^~ OnDemandAP:11:14: error: 'fs' has not been declared OnDemandAP:11:22: error: 'fs' was not declared in this scope void listDir(fs::FS &fs, const char * dirname, uint8_t levels){ ^~ d:\mywork\Arduino\CarDoorChecker\OnDemandAP.ino:11:22: note: suggested alternative: 'fls' void listDir(fs::FS &fs, const char * dirname, uint8_t levels){ ^~ fls OnDemandAP:11:26: error: expected primary-expression before 'const' void listDir(fs::FS &fs, const char * dirname, uint8_t levels){ ^~~~~ OnDemandAP:11:56: error: expected primary-expression before 'levels' void listDir(fs::FS &fs, const char * dirname, uint8_t levels){ ^~~~~~ OnDemandAP:42:15: error: variable or field 'readFile' declared void void readFile(fs::FS &fs, const char * path){ ^~ OnDemandAP:42:15: error: 'fs' has not been declared OnDemandAP:42:23: error: 'fs' was not declared in this scope void readFile(fs::FS &fs, const char * path){ ^~ d:\mywork\Arduino\CarDoorChecker\OnDemandAP.ino:42:23: note: suggested alternative: 'fls' void readFile(fs::FS &fs, const char * path){ ^~ fls OnDemandAP:42:27: error: expected primary-expression before 'const' void readFile(fs::FS &fs, const char * path){ ^~~~~ OnDemandAP:62:16: error: variable or field 'writeFile' declared void void writeFile(fs::FS &fs, const char * path, const char * message){ ^~ OnDemandAP:62:16: error: 'fs' has not been declared OnDemandAP:62:24: error: 'fs' was not declared in this scope void writeFile(fs::FS &fs, const char * path, const char * message){ ^~ d:\mywork\Arduino\CarDoorChecker\OnDemandAP.ino:62:24: note: suggested alternative: 'fls' void writeFile(fs::FS &fs, const char * path, const char * message){ ^~ fls OnDemandAP:62:28: error: expected primary-expression before 'const' void writeFile(fs::FS &fs, const char * path, const char * message){ ^~~~~ OnDemandAP:62:47: error: expected primary-expression before 'const' void writeFile(fs::FS &fs, const char * path, const char * message){ ^~~~~ OnDemandAP:79:17: error: variable or field 'appendFile' declared void void appendFile(fs::FS &fs, const char * path, const char * message){ ^~ OnDemandAP:79:17: error: 'fs' has not been declared OnDemandAP:79:25: error: 'fs' was not declared in this scope void appendFile(fs::FS &fs, const char * path, const char * message){ ^~ d:\mywork\Arduino\CarDoorChecker\OnDemandAP.ino:79:25: note: suggested alternative: 'fls' void appendFile(fs::FS &fs, const char * path, const char * message){ ^~ fls OnDemandAP:79:29: error: expected primary-expression before 'const' void appendFile(fs::FS &fs, const char * path, const char * message){ ^~~~~ OnDemandAP:79:48: error: expected primary-expression before 'const' void appendFile(fs::FS &fs, const char * path, const char * message){ ^~~~~ exit status 1 [Warning] Failed to generate IntelliSense configuration. [Error] Analyzing sketch 'OnDemandAP.ino': Exit with code=1
該当のソースコード
c
#include "FS.h"#include "SPIFFS.h" #define FORMAT_SPIFFS_IF_FAILED true String gSerialName; void listDir(fs::FS &fs, const char * dirname, uint8_t levels){ Serial.printf("Listing directory: %s\r\n", dirname); File root = fs.open(dirname); if(!root){ Serial.println("- failed to open directory"); return; } if(!root.isDirectory()){ Serial.println(" - not a directory"); return; } File file = root.openNextFile(); while(file){ if(file.isDirectory()){ Serial.print(" DIR : "); Serial.println(file.name()); if(levels){ listDir(fs, file.path(), levels -1); } } else { Serial.print(" FILE: "); Serial.print(file.name()); Serial.print("\tSIZE: "); Serial.println(file.size()); } file = root.openNextFile(); }} void readFile(fs::FS &fs, const char * path){ Serial.printf("Reading file: %s\r\n", path); File file = fs.open(path); if(!file || file.isDirectory()){ Serial.println("- failed to open file for reading"); return; } Serial.println("- read from file:"); while(file.available()){ Serial.write(file.read()); //Serial.println(file.read()); } file.close();} void writeFile(fs::FS &fs, const char * path, const char * message){ Serial.printf("Writing file: %s\r\n", path); File file = fs.open(path, FILE_WRITE); if(!file){ Serial.println("- failed to open file for writing"); return; } if(file.print(message)){ Serial.println("- file written"); } else { Serial.println("- write failed"); } file.close();} void appendFile(fs::FS &fs, const char * path, const char * message){ Serial.printf("Appending to file: %s\r\n", path); File file = fs.open(path, FILE_APPEND); if(!file){ Serial.println("- failed to open file for appending"); return; } if(file.print(message)){ Serial.println("- message appended"); } else { Serial.println("- append failed"); } file.close();} void setup() { if (!SPIFFS.begin(true)) { Serial.println("An Error has occurred while mounting SPIFFS"); return; } } void loop() { // put your main code here, to run repeatedly: }
試したこと
気になる点があるのですが、
今まで、マルチタスク機能やAWS機能を入れたコードを作成していましたが、正常に動作しない箇所があるため、一旦上記コードのようにほぼsetup,loopのシンプルなものにして再ビルドしていました。
そしてとりあえずファイル操作のプログラムを追加してみたところ、今回の不具合に遭遇しました。
上記のファイル操作に関するプログラムは別のファイル”spiffs.ino”というファイルにいままではまとめていました。
その時は、正常にビルド成功しており、プログラムも動作しておりました。その時のgitのリビジョンに戻れば、正常にビルドできます。
今回setup,loop関数のあるファイルにまとめる作業を行ってみたところ、現在の不具合現象が発生しております。
補足情報(FW/ツールのバージョンなど)
ここにより詳細な情報を記載してください。
0 コメント