/// <summary> /// GAMEBASE読み込み。GAMEBASE.csvの存在は必須ではないので読み込み失敗したらなかったことにする。 /// </summary> /// <param name="basePath"></param> /// <returns>読み込み続行するなら真、エラー終了なら偽</returns> public bool LoadGameBaseCsv(string basePath) { if (!File.Exists(basePath)) { return(true); } ScriptPosition pos = null; EraStreamReader eReader = new EraStreamReader(false); if (!eReader.Open(basePath)) { //output.PrintLine(eReader.Filename + "のオープンに失敗しました"); return(true); } try { StringStream st = null; while ((st = eReader.ReadEnabledLine()) != null) { string[] tokens = st.Substring().Split(','); if (tokens.Length < 2) { continue; } string param = tokens[1].Trim(); pos = new ScriptPosition(eReader.Filename, eReader.LineNo, st.RowString); switch (tokens[0]) { case "コード": if (tryatoi(tokens[1], out ScriptUniqueCode)) { if (ScriptUniqueCode == 0L) { ParserMediator.Warn("コード:0のセーブデータはいかなるコードのスクリプトからも読めるデータとして扱われます", pos, 0); } } break; case "バージョン": ScriptVersionDefined = tryatoi(tokens[1], out ScriptVersion); break; case "バージョン違い認める": tryatoi(tokens[1], out ScriptCompatibleMinVersion); break; case "最初からいるキャラ": tryatoi(tokens[1], out DefaultCharacter); break; case "アイテムなし": tryatoi(tokens[1], out DefaultNoItem); break; case "タイトル": ScriptTitle = tokens[1]; break; case "作者": ScriptAutherName = tokens[1]; break; case "製作年": ScriptYear = tokens[1]; break; case "追加情報": ScriptDetail = tokens[1]; break; case "ウィンドウタイトル": ScriptWindowTitle = tokens[1]; break; case "動作に必要なEmueraのバージョン": Compatible_EmueraVer = tokens[1]; if (!Regex.IsMatch(Compatible_EmueraVer, @"^\d+\.\d+\.\d+\.\d+$")) { ParserMediator.Warn("バージョン指定を読み取れなかったので処理を省略します", pos, 0); break; } Version curerntVersion = new Version(GlobalStatic.MainWindow.InternalEmueraVer); Version targetVersoin = new Version(Compatible_EmueraVer); if (curerntVersion < targetVersoin) { ParserMediator.Warn("このバリアント動作させるにはVer. " + GlobalStatic.MainWindow.EmueraVerText + "以降のバージョンのEmueraが必要です", pos, 2); return(false); } break; } } } catch { ParserMediator.Warn("GAMEBASE.CSVの読み込み中にエラーが発生したため、読みこみを中断します", pos, 1); return(true); } finally { eReader.Close(); } if (ScriptWindowTitle == null) { if (string.IsNullOrEmpty(ScriptTitle)) { ScriptWindowTitle = "Emuera"; } else { ScriptWindowTitle = ScriptTitle + " " + ScriptVersionText; } } return(true); }
private bool loadHeaderFile(string filepath, string filename) { StringStream st = null; ScriptPosition position = null; //EraStreamReader eReader = new EraStreamReader(false); //1815修正 _rename.csvの適用 //eramakerEXの仕様的には.ERHに適用するのはおかしいけど、もうEmueraの仕様になっちゃってるのでしかたないか var eReader = new EraStreamReader(true); if (!eReader.Open(filepath, filename)) { throw new CodeEE(eReader.Filename + "のオープンに失敗しました"); } try { while ((st = eReader.ReadEnabledLine()) != null) { if (!noError) { return(false); } position = new ScriptPosition(filename, eReader.LineNo, st.RowString); LexicalAnalyzer.SkipWhiteSpace(st); if (st.Current != '#') { throw new CodeEE("ヘッダーの中に#で始まらない行があります", position); } st.ShiftNext(); var sharpID = LexicalAnalyzer.ReadSingleIdentifier(st); if (sharpID == null) { ParserMediator.Warn("解釈できない#行です", position, 1); return(false); } if (Config.ICFunction) { sharpID = sharpID.ToUpper(); } LexicalAnalyzer.SkipWhiteSpace(st); switch (sharpID) { case "DEFINE": analyzeSharpDefine(st, position); break; case "FUNCTION": case "FUNCTIONS": analyzeSharpFunction(st, position, sharpID == "FUNCTIONS"); break; case "DIM": case "DIMS": analyzeSharpDim(st, position, sharpID == "DIMS"); break; default: throw new CodeEE("#" + sharpID + "は解釈できないプリプロセッサです", position); } } } catch (CodeEE e) { if (e.Position != null) { position = e.Position; } ParserMediator.Warn(e.Message, position, 2); return(false); } finally { eReader.Close(); } return(true); }