2018-04-09 15:07:31 +00:00
# A3XX Electronic Centralised Aircraft Monitoring System
# Jonathan Redpath (legoboyvdlp)
##############################################
# Copyright (c) Joshua Davidson (it0uchpods) #
##############################################
# Colors:
# 1 - Red, 2 - Amber, 3 - Cyan 4 - Green 5 - White
# Priority: 1 - LEVEL 3 2 - LEVEL 2 3 - LEVEL 1 4 - LEVEL 0 5 - MEMO
# LEVEL 3 has priority over all other warnings
# LEVEL 2 has priority over 1 and 0
# LEVEL 1 has priority over 0
# LEVEL 3 Messages Priority:
# Red visual warning, repetitive chime or sound
# 1 Stall
# 2 Over speed
# 3 Engine dual failure
# 4 Engine fire
# 5 APU fire
# 6 Takeoff configuration
# 7 Sidestick fault
# 8 Excessive cabin altitude
# 9 Engine oil lo pressure
# 10 L + R Elevator fault
# 11 Landing gear
# 12 Autopilot disconnection
# 13 Auto land
# 14 Smoke
# 15 Emergency configuration
# 16 Dual hydraulic failure
# LEVEL 2 Messages:
# Amber warning, single chime
# LEVEL 1 Messages:
# Amber warning, no chime
# LEVEL 0 Messages:
# No visual warning or chime: ECAM blue, green, or white message
# TYPES: Independent, Primary and Secondary, Status, and MEMO
# Operation: FWC receives electrical boolean or numeric signals, from the systems, and outputs a message, audible warning, or visual alert
# Electrical Connection: FWC1 is controlled by AC ESS, FWC2 by AC BUS 2
# Sounds: reduce volume by 6DB is engines are off
# ARINC 429: 100kb/s (high speed)
# PHASE: /FMGC/status/phase
# DISPLAY: 1 - EWD 2 - MEMO 3 - STATUS
2018-06-05 20:12:28 +00:00
var ewd = props.globals.initNode("/instrumentation/ewd");
var ewd_msg_three = ewd.initNode("msg/priority_3"," ","STRING");
var ewd_msg_two = ewd.initNode("msg/priority_2"," ","STRING");
var ewd_msg_one = ewd.initNode("msg/priority_1"," ","STRING");
var ewd_msg_zero = ewd.initNode("msg/priority_0"," ","STRING");
var ewd_msg_memo = ewd.initNode("msg/memo"," ","STRING");
2018-06-06 20:46:41 +00:00
var msgs_priority_3 = std.Vector.new();
var msgs_priority_2 = std.Vector.new();
var msgs_priority_1 = std.Vector.new();
var msgs_priority_0 = std.Vector.new();
var msgs_memo = std.Vector.new();
var active_messages = std.Vector.new();
2018-06-05 20:12:28 +00:00
var num_lines = 6;
var msg = nil;
var spacer = nil;
var line = nil;
# messages logic and added to arrays
var messages_priority_3 = func {
if (getprop("/controls/flight/flap-pos") > 2 and getprop("/position/gear-agl-ft") < 750 and getprop("/gear/gear[1]/position-norm") != 1 and getprop("/FMGC/status/phase") == 5) {
2018-06-06 20:46:41 +00:00
msgs_priority_3.append("L/G GEAR NOT DOWN");
active_messages.append("L/G GEAR NOT DOWN");
2018-04-09 15:07:31 +00:00
}
2018-06-05 20:12:28 +00:00
}
var messages_priority_2 = func {}
var messages_priority_1 = func {}
var messages_priority_0 = func {}
var messages_memo = func {
if (getprop("controls/flight/speedbrake-arm") == 1) {
2018-06-06 20:46:41 +00:00
msgs_memo.append("GND SPLRS ARMED");
active_messages.append("GND SPLRS ARMED");
2018-06-05 20:12:28 +00:00
}
}
2018-04-09 15:07:31 +00:00
2018-06-06 20:46:41 +00:00
2018-06-05 20:12:28 +00:00
# Finally the controller
2018-04-09 15:07:31 +00:00
2018-06-05 20:12:28 +00:00
var ECAM_controller = {
loop: func() {
# cleans up arrays
2018-06-06 20:46:41 +00:00
msgs_priority_3.clear();
msgs_priority_2.clear();
msgs_priority_1.clear();
msgs_priority_0.clear();
msgs_memo.clear();
active_messages.clear();
2018-04-09 15:07:31 +00:00
2018-06-05 20:12:28 +00:00
# check active messages
# config_warnings();
messages_priority_3();
messages_priority_2();
messages_priority_1();
messages_priority_0();
messages_memo();
# write to ECAM
2018-06-06 20:46:41 +00:00
foreach(var ewd_messages; active_messages.vector) {
var i = 1;
2018-06-08 16:08:17 +00:00
var x = getprop("/ECAM/msg/line" ~ i);
2018-06-06 20:46:41 +00:00
print("Variable i is:" ~ i);
if (x == "") {
2018-06-08 16:08:17 +00:00
setprop("/ECAM/msg/line" ~ i, ewd_messages);
2018-06-06 20:46:41 +00:00
} else {
i = i + 1;
2018-06-08 16:08:17 +00:00
setprop("/ECAM/msg/line" ~ i, ewd_messages);
2018-06-06 20:46:41 +00:00
print("Variable i is:" ~ i);
}
2018-04-09 15:07:31 +00:00
}
2018-06-06 20:46:41 +00:00
# debug
foreach(var debug; active_messages.vector) {
print(debug);
}
2018-04-09 15:07:31 +00:00
},
};