/*
* Copyright 2018 faddenSoft
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
using System;
using System.Collections.Generic;
namespace SourceGen {
///
/// A collection of project properties.
///
/// The class is mutable, but may only be modified by DisasmProject.ApplyChanges or
/// the deserializer.
///
/// All fields are explicitly handled by the ProjectFile serializer.
///
public class ProjectProperties {
//
// NOTE:
// If you add or modify a member, make sure to update the copy constructor and
// add serialization code to ProjectFile.
//
///
/// Some parameters we feed to the analyzers.
///
public class AnalysisParameters {
public bool AnalyzeUncategorizedData { get; set; }
public int MinCharsForString { get; set; }
public bool SeekNearbyTargets { get; set; }
public AnalysisParameters() {
AnalyzeUncategorizedData = true;
MinCharsForString = DataAnalysis.DEFAULT_MIN_STRING_LENGTH;
SeekNearbyTargets = true;
}
public AnalysisParameters(AnalysisParameters src) {
AnalyzeUncategorizedData = src.AnalyzeUncategorizedData;
MinCharsForString = src.MinCharsForString;
SeekNearbyTargets = src.SeekNearbyTargets;
}
}
///
/// Configured CPU type.
///
public Asm65.CpuDef.CpuType CpuType { get; set; }
///
/// Should we include undocumented instructions?
///
public bool IncludeUndocumentedInstr { get; set; }
///
/// Initial status flags at entry points.
///
public Asm65.StatusFlags EntryFlags { get; set; }
///
/// Naming style for auto-generated labels.
///
public AutoLabel.Style AutoLabelStyle { get; set; }
///
/// Configurable parameters for the analyzers.
///
public AnalysisParameters AnalysisParams { get; set; }
///
/// The identifiers of the platform symbol files we want to load symbols from.
///
public List PlatformSymbolFileIdentifiers { get; private set; }
///
/// The identifiers of the extension scripts we want to load.
///
public List ExtensionScriptFileIdentifiers { get; private set; }
///
/// Symbols defined at the project level. These get merged with PlatformSyms.
/// The list key is the symbol's label.
///
public SortedList ProjectSyms { get; private set; }
///
/// Nullary constructor.
///
public ProjectProperties() {
AnalysisParams = new AnalysisParameters();
PlatformSymbolFileIdentifiers = new List();
ExtensionScriptFileIdentifiers = new List();
ProjectSyms = new SortedList();
}
///
/// Copy constructor.
///
/// Object to clone.
public ProjectProperties(ProjectProperties src) : this() {
CpuType = src.CpuType;
IncludeUndocumentedInstr = src.IncludeUndocumentedInstr;
EntryFlags = src.EntryFlags;
AutoLabelStyle = src.AutoLabelStyle;
AnalysisParams = new AnalysisParameters(src.AnalysisParams);
// Clone PlatformSymbolFileIdentifiers
foreach (string fileName in src.PlatformSymbolFileIdentifiers) {
PlatformSymbolFileIdentifiers.Add(fileName);
}
// Clone ExtensionScriptFileIdentifiers
foreach (string fileName in src.ExtensionScriptFileIdentifiers) {
ExtensionScriptFileIdentifiers.Add(fileName);
}
// Clone ProjectSyms
foreach (KeyValuePair kvp in src.ProjectSyms) {
ProjectSyms[kvp.Key] = kvp.Value;
}
}
}
}