mirror of
https://github.com/OpenDiablo2/OpenDiablo2
synced 2024-11-18 02:16:23 -05:00
d6c9748fef
* refactored logging in d2config, d2record, and d2asset * asset manager, record manager, and file loader now utilitize d2util.Logger * added colored logging to d2util.Logger (excluding windows platforms) * removed mpq file verification from d2config; d2loader handles this * record loaders now use the record manager's logger for printing info * added command line argument for setting log level (`--loglevel 4`, `-l4`, or `-l 4` * added `LogLevel` parameter to config file * default log level will show errors, warnings, and info log messages * specifying log level as an argument overrides setting from config file * fixed log level tests
46 lines
1007 B
Go
46 lines
1007 B
Go
package d2records
|
|
|
|
import (
|
|
"github.com/OpenDiablo2/OpenDiablo2/d2common/d2fileformats/d2txt"
|
|
)
|
|
|
|
func autoMapLoader(r *RecordManager, d *d2txt.DataDictionary) error {
|
|
records := make(AutoMaps, 0)
|
|
|
|
var frameFields = []string{"Cel1", "Cel2", "Cel3", "Cel4"}
|
|
|
|
for d.Next() {
|
|
record := &AutoMapRecord{
|
|
LevelName: d.String("LevelName"),
|
|
TileName: d.String("TileName"),
|
|
|
|
Style: d.Number("Style"),
|
|
StartSequence: d.Number("StartSequence"),
|
|
EndSequence: d.Number("EndSequence"),
|
|
|
|
// Note: aren't useful see the AutoMapRecord struct.
|
|
//Type1: d.String("Type1"),
|
|
//Type2: d.String("Type2"),
|
|
//Type3: d.String("Type3"),
|
|
//Type4: d.String("Type4"),
|
|
}
|
|
record.Frames = make([]int, len(frameFields))
|
|
|
|
for i := range frameFields {
|
|
record.Frames[i] = d.Number(frameFields[i])
|
|
}
|
|
|
|
records = append(records, record)
|
|
}
|
|
|
|
if d.Err != nil {
|
|
return d.Err
|
|
}
|
|
|
|
r.Logger.Infof("Loaded %d AutoMapRecord records", len(records))
|
|
|
|
r.Level.AutoMaps = records
|
|
|
|
return nil
|
|
}
|