Localize a LOT of the UI
This commit is contained in:
parent
0365b33993
commit
e3f9a6028b
12 changed files with 379 additions and 655 deletions
|
@ -35,7 +35,17 @@ namespace ShiftOS.WinForms.Applications
|
|||
|
||||
public override long Length => box.Text.Length;
|
||||
|
||||
public override long Position { get => Length; set => throw new NotImplementedException(); }
|
||||
public override long Position
|
||||
{
|
||||
get
|
||||
{
|
||||
return Length;
|
||||
}
|
||||
set
|
||||
{
|
||||
//nothing
|
||||
}
|
||||
}
|
||||
|
||||
public override void Flush()
|
||||
{
|
||||
|
|
78
ShiftOS.WinForms/Applications/Pong.Designer.cs
generated
78
ShiftOS.WinForms/Applications/Pong.Designer.cs
generated
|
@ -28,18 +28,17 @@
|
|||
/// </summary>
|
||||
private void InitializeComponent()
|
||||
{
|
||||
System.ComponentModel.ComponentResourceManager resources = new System.ComponentModel.ComponentResourceManager(typeof(Pong));
|
||||
this.pnlcanvas = new System.Windows.Forms.Panel();
|
||||
this.pnllevelwon = new System.Windows.Forms.Panel();
|
||||
this.lbltitle = new System.Windows.Forms.Label();
|
||||
this.label1 = new System.Windows.Forms.Label();
|
||||
this.panel1 = new System.Windows.Forms.Panel();
|
||||
this.btncashout = new System.Windows.Forms.Button();
|
||||
this.button1 = new System.Windows.Forms.Button();
|
||||
this.btncashout = new System.Windows.Forms.Button();
|
||||
this.lbltitle = new System.Windows.Forms.Label();
|
||||
this.pnlgamestart = new System.Windows.Forms.Panel();
|
||||
this.label2 = new System.Windows.Forms.Label();
|
||||
this.panel3 = new System.Windows.Forms.Panel();
|
||||
this.button2 = new System.Windows.Forms.Button();
|
||||
this.btnplay = new System.Windows.Forms.Button();
|
||||
this.label3 = new System.Windows.Forms.Label();
|
||||
this.pnllevelwon.SuspendLayout();
|
||||
this.panel1.SuspendLayout();
|
||||
|
@ -68,17 +67,6 @@
|
|||
this.pnllevelwon.TabIndex = 0;
|
||||
this.pnllevelwon.Visible = false;
|
||||
//
|
||||
// lbltitle
|
||||
//
|
||||
this.lbltitle.Dock = System.Windows.Forms.DockStyle.Top;
|
||||
this.lbltitle.Location = new System.Drawing.Point(0, 0);
|
||||
this.lbltitle.Name = "lbltitle";
|
||||
this.lbltitle.Size = new System.Drawing.Size(301, 13);
|
||||
this.lbltitle.TabIndex = 0;
|
||||
this.lbltitle.Tag = "header2";
|
||||
this.lbltitle.Text = "You\'ve reached level 2!";
|
||||
this.lbltitle.TextAlign = System.Drawing.ContentAlignment.TopCenter;
|
||||
//
|
||||
// label1
|
||||
//
|
||||
this.label1.Dock = System.Windows.Forms.DockStyle.Fill;
|
||||
|
@ -86,8 +74,7 @@
|
|||
this.label1.Name = "label1";
|
||||
this.label1.Size = new System.Drawing.Size(301, 139);
|
||||
this.label1.TabIndex = 1;
|
||||
this.label1.Text = "You have survived this level of Pong. You now have a chance to cash out your Code" +
|
||||
"points or play on for more.";
|
||||
this.label1.Text = "{PONG_BEATLEVELDESC}";
|
||||
this.label1.TextAlign = System.Drawing.ContentAlignment.MiddleCenter;
|
||||
//
|
||||
// panel1
|
||||
|
@ -100,26 +87,37 @@
|
|||
this.panel1.Size = new System.Drawing.Size(301, 32);
|
||||
this.panel1.TabIndex = 2;
|
||||
//
|
||||
// btncashout
|
||||
//
|
||||
this.btncashout.Location = new System.Drawing.Point(48, 6);
|
||||
this.btncashout.Name = "btncashout";
|
||||
this.btncashout.Size = new System.Drawing.Size(93, 23);
|
||||
this.btncashout.TabIndex = 0;
|
||||
this.btncashout.Text = "Cash out";
|
||||
this.btncashout.UseVisualStyleBackColor = true;
|
||||
this.btncashout.Click += new System.EventHandler(this.btncashout_Click);
|
||||
//
|
||||
// button1
|
||||
//
|
||||
this.button1.Location = new System.Drawing.Point(159, 6);
|
||||
this.button1.Name = "button1";
|
||||
this.button1.Size = new System.Drawing.Size(93, 23);
|
||||
this.button1.TabIndex = 1;
|
||||
this.button1.Text = "Play on";
|
||||
this.button1.Text = "{PONG_PLAYON}";
|
||||
this.button1.UseVisualStyleBackColor = true;
|
||||
this.button1.Click += new System.EventHandler(this.button1_Click);
|
||||
//
|
||||
// btncashout
|
||||
//
|
||||
this.btncashout.Location = new System.Drawing.Point(48, 6);
|
||||
this.btncashout.Name = "btncashout";
|
||||
this.btncashout.Size = new System.Drawing.Size(93, 23);
|
||||
this.btncashout.TabIndex = 0;
|
||||
this.btncashout.Text = "{PONG_CASHOUT}";
|
||||
this.btncashout.UseVisualStyleBackColor = true;
|
||||
this.btncashout.Click += new System.EventHandler(this.btncashout_Click);
|
||||
//
|
||||
// lbltitle
|
||||
//
|
||||
this.lbltitle.Dock = System.Windows.Forms.DockStyle.Top;
|
||||
this.lbltitle.Location = new System.Drawing.Point(0, 0);
|
||||
this.lbltitle.Name = "lbltitle";
|
||||
this.lbltitle.Size = new System.Drawing.Size(301, 13);
|
||||
this.lbltitle.TabIndex = 0;
|
||||
this.lbltitle.Tag = "header2";
|
||||
this.lbltitle.Text = "You\'ve reached level 2!";
|
||||
this.lbltitle.TextAlign = System.Drawing.ContentAlignment.TopCenter;
|
||||
//
|
||||
// pnlgamestart
|
||||
//
|
||||
this.pnlgamestart.Controls.Add(this.label2);
|
||||
|
@ -138,27 +136,27 @@
|
|||
this.label2.Name = "label2";
|
||||
this.label2.Size = new System.Drawing.Size(301, 206);
|
||||
this.label2.TabIndex = 1;
|
||||
this.label2.Text = resources.GetString("label2.Text");
|
||||
this.label2.Text = "{PONG_DESC}";
|
||||
this.label2.TextAlign = System.Drawing.ContentAlignment.MiddleCenter;
|
||||
//
|
||||
// panel3
|
||||
//
|
||||
this.panel3.Controls.Add(this.button2);
|
||||
this.panel3.Controls.Add(this.btnplay);
|
||||
this.panel3.Dock = System.Windows.Forms.DockStyle.Bottom;
|
||||
this.panel3.Location = new System.Drawing.Point(0, 248);
|
||||
this.panel3.Name = "panel3";
|
||||
this.panel3.Size = new System.Drawing.Size(301, 32);
|
||||
this.panel3.TabIndex = 2;
|
||||
//
|
||||
// button2
|
||||
// btnplay
|
||||
//
|
||||
this.button2.Location = new System.Drawing.Point(100, 6);
|
||||
this.button2.Name = "button2";
|
||||
this.button2.Size = new System.Drawing.Size(116, 23);
|
||||
this.button2.TabIndex = 1;
|
||||
this.button2.Text = "Play some Pong!";
|
||||
this.button2.UseVisualStyleBackColor = true;
|
||||
this.button2.Click += new System.EventHandler(this.button2_Click);
|
||||
this.btnplay.Location = new System.Drawing.Point(100, 6);
|
||||
this.btnplay.Name = "btnplay";
|
||||
this.btnplay.Size = new System.Drawing.Size(116, 23);
|
||||
this.btnplay.TabIndex = 1;
|
||||
this.btnplay.Text = "{PONG_PLAY}";
|
||||
this.btnplay.UseVisualStyleBackColor = true;
|
||||
this.btnplay.Click += new System.EventHandler(this.button2_Click);
|
||||
//
|
||||
// label3
|
||||
//
|
||||
|
@ -168,7 +166,7 @@
|
|||
this.label3.Size = new System.Drawing.Size(301, 42);
|
||||
this.label3.TabIndex = 0;
|
||||
this.label3.Tag = "header2";
|
||||
this.label3.Text = "Welcome to Pong.";
|
||||
this.label3.Text = "{PONG_WELCOME}";
|
||||
this.label3.TextAlign = System.Drawing.ContentAlignment.TopCenter;
|
||||
//
|
||||
// Pong
|
||||
|
@ -200,7 +198,7 @@
|
|||
private System.Windows.Forms.Panel pnlgamestart;
|
||||
private System.Windows.Forms.Label label2;
|
||||
private System.Windows.Forms.Panel panel3;
|
||||
private System.Windows.Forms.Button button2;
|
||||
private System.Windows.Forms.Button btnplay;
|
||||
private System.Windows.Forms.Label label3;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -223,7 +223,7 @@ namespace ShiftOS.WinForms.Applications
|
|||
pnlgamestart.Show();
|
||||
pnlgamestart.BringToFront();
|
||||
pnlgamestart.CenterParent();
|
||||
Infobox.Show("You lose.", "You lost the game! Guess you should've cashed out...");
|
||||
Infobox.Show("{TITLE_PONG_YOULOSE}", "{PROMPT_PONGLOST}");
|
||||
doAi = false;
|
||||
doBallCalc = false;
|
||||
}
|
||||
|
@ -237,7 +237,10 @@ namespace ShiftOS.WinForms.Applications
|
|||
pnllevelwon.CenterParent();
|
||||
pnllevelwon.Show();
|
||||
pnllevelwon.BringToFront();
|
||||
lbltitle.Text = "You've reached level " + level + "!";
|
||||
lbltitle.Text = Localization.Parse("{PONG_LEVELREACHED}", new Dictionary<string, string>
|
||||
{
|
||||
["%level"] = level.ToString()
|
||||
});
|
||||
lbltitle.Height = (int)CreateGraphics().MeasureString(lbltitle.Text, lbltitle.Font).Height;
|
||||
codepointsToEarn += CalculateAIBeatCP() * 2;
|
||||
speedFactor += speedFactor / level;
|
||||
|
@ -251,8 +254,12 @@ namespace ShiftOS.WinForms.Applications
|
|||
|
||||
public void Win()
|
||||
{
|
||||
header = "You beat the AI! " + CalculateAIBeatCP() + " Codepoints!.";
|
||||
header = Localization.Parse("{PONG_BEATAI}", new Dictionary<string, string>
|
||||
{
|
||||
["%amount"] = CalculateAIBeatCP().ToString()
|
||||
});
|
||||
InitializeCoordinates();
|
||||
counterTimer.Stop();
|
||||
new System.Threading.Thread(() =>
|
||||
{
|
||||
doBallCalc = false;
|
||||
|
@ -265,6 +272,10 @@ namespace ShiftOS.WinForms.Applications
|
|||
doBallCalc = true;
|
||||
header = "";
|
||||
counter = "";
|
||||
Desktop.InvokeOnWorkerThread(() =>
|
||||
{
|
||||
counterTimer.Start();
|
||||
});
|
||||
}).Start();
|
||||
}
|
||||
|
||||
|
@ -322,7 +333,10 @@ namespace ShiftOS.WinForms.Applications
|
|||
//draw opponent
|
||||
e.Graphics.FillRectangle(new SolidBrush(pnlcanvas.ForeColor), new RectangleF((float)(pnlcanvas.Width - (paddleWidth*2)), (float)(opponentYLocal - (float)(paddleHeight / 2)), (float)paddleWidth, (float)paddleHeight));
|
||||
|
||||
string cp_text = Localization.Parse("{CODEPOINTS}: " + codepointsToEarn);
|
||||
string cp_text = Localization.Parse("{PONG_STATUSCP}", new Dictionary<string, string>
|
||||
{
|
||||
["%cp"] = codepointsToEarn.ToString()
|
||||
});
|
||||
|
||||
var tSize = e.Graphics.MeasureString(cp_text, SkinEngine.LoadedSkin.Header3Font);
|
||||
|
||||
|
@ -346,7 +360,11 @@ namespace ShiftOS.WinForms.Applications
|
|||
);
|
||||
e.Graphics.DrawString(header, SkinEngine.LoadedSkin.Header2Font, new SolidBrush(pnlcanvas.ForeColor), tLoc);
|
||||
|
||||
string l = Localization.Parse("{LEVEL}: " + level + " - " + secondsleft + " {SECONDS_LEFT}");
|
||||
string l = Localization.Parse("{PONG_STATUSLEVEL}", new Dictionary<string, string>
|
||||
{
|
||||
["%level"] = level.ToString(),
|
||||
["%time"] = secondsleft.ToString()
|
||||
});
|
||||
tSize = e.Graphics.MeasureString(l, SkinEngine.LoadedSkin.Header3Font);
|
||||
|
||||
tLoc = new PointF((pnlcanvas.Width - (int)tSize.Width) / 2,
|
||||
|
@ -412,7 +430,11 @@ namespace ShiftOS.WinForms.Applications
|
|||
SaveSystem.CurrentSave.Codepoints += (ulong)codepointsToEarn;
|
||||
level = 1;
|
||||
speedFactor = 0.0125;
|
||||
Infobox.Show("Codepoints transferred.", "Pong has transferred " + codepointsToEarn + " Codepoints to your system.");
|
||||
Infobox.Show("{TITLE_CODEPOINTSTRANSFERRED}", Localization.Parse("{PROMPT_CODEPOINTSTRANSFERRED}", new Dictionary<string, string>
|
||||
{
|
||||
["%transferrer"] = "Pong",
|
||||
["%amount"] = codepointsToEarn.ToString()
|
||||
}));
|
||||
codepointsToEarn = 0;
|
||||
pnlgamestart.Show();
|
||||
pnlgamestart.BringToFront();
|
||||
|
|
|
@ -117,11 +117,4 @@
|
|||
<resheader name="writer">
|
||||
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||
</resheader>
|
||||
<data name="label2.Text" xml:space="preserve">
|
||||
<value>Pong is the modern-day recreation of the classic 70s game called, you guessed it, Pong.
|
||||
|
||||
In Pong, you must try your best to keep the fast-moving ball from going past your side of the screen using your mouse to move your paddle in the way of the ball, while getting the ball to go past the opponent's paddle.
|
||||
|
||||
Once you start Pong, you have 60 seconds to beat the opponent and survive as much as possible. The game will get faster as you play, and the more 60-second levels you play, the more Codepoints you'll earn. If you lose the level, you will start back at Level 1 with 0 Codepoints. At the end of the level, you may choose to cash out or play on.</value>
|
||||
</data>
|
||||
</root>
|
2
ShiftOS.WinForms/MainMenu/Loading.Designer.cs
generated
2
ShiftOS.WinForms/MainMenu/Loading.Designer.cs
generated
|
@ -40,7 +40,7 @@
|
|||
this.label.Name = "label";
|
||||
this.label.Size = new System.Drawing.Size(284, 262);
|
||||
this.label.TabIndex = 0;
|
||||
this.label.Text = "Loading...";
|
||||
this.label.Text = "{GEN_LOADING}";
|
||||
this.label.TextAlign = System.Drawing.ContentAlignment.MiddleCenter;
|
||||
//
|
||||
// Loading
|
||||
|
|
|
@ -16,6 +16,7 @@ namespace ShiftOS.WinForms.MainMenu
|
|||
public Loading()
|
||||
{
|
||||
InitializeComponent();
|
||||
label.Text = Localization.Parse(label.Text);
|
||||
}
|
||||
|
||||
private void Loading_FormShown(object sender, EventArgs e)
|
||||
|
|
62
ShiftOS.WinForms/MainMenu/MainMenu.Designer.cs
generated
62
ShiftOS.WinForms/MainMenu/MainMenu.Designer.cs
generated
|
@ -36,8 +36,6 @@
|
|||
this.button5 = new System.Windows.Forms.Button();
|
||||
this.lbticker = new System.Windows.Forms.Label();
|
||||
this.pnloptions = new System.Windows.Forms.Panel();
|
||||
this.txtubase = new System.Windows.Forms.TextBox();
|
||||
this.label3 = new System.Windows.Forms.Label();
|
||||
this.txtdsport = new System.Windows.Forms.TextBox();
|
||||
this.label2 = new System.Windows.Forms.Label();
|
||||
this.txtdsaddress = new System.Windows.Forms.TextBox();
|
||||
|
@ -81,7 +79,7 @@
|
|||
this.button1.Name = "button1";
|
||||
this.button1.Size = new System.Drawing.Size(181, 23);
|
||||
this.button1.TabIndex = 0;
|
||||
this.button1.Text = "Campaign";
|
||||
this.button1.Text = "{MAINMENU_CAMPAIGN}";
|
||||
this.button1.UseVisualStyleBackColor = true;
|
||||
this.button1.Click += new System.EventHandler(this.button1_Click);
|
||||
//
|
||||
|
@ -92,7 +90,7 @@
|
|||
this.button2.Name = "button2";
|
||||
this.button2.Size = new System.Drawing.Size(181, 23);
|
||||
this.button2.TabIndex = 1;
|
||||
this.button2.Text = "Sandbox";
|
||||
this.button2.Text = "{MAINMENU_SANDBOX}";
|
||||
this.button2.UseVisualStyleBackColor = true;
|
||||
this.button2.Click += new System.EventHandler(this.button2_Click);
|
||||
//
|
||||
|
@ -103,7 +101,7 @@
|
|||
this.button3.Name = "button3";
|
||||
this.button3.Size = new System.Drawing.Size(181, 23);
|
||||
this.button3.TabIndex = 2;
|
||||
this.button3.Text = "Settings";
|
||||
this.button3.Text = "{GEN_SETTINGS}";
|
||||
this.button3.UseVisualStyleBackColor = true;
|
||||
this.button3.Click += new System.EventHandler(this.button3_Click);
|
||||
//
|
||||
|
@ -114,7 +112,7 @@
|
|||
this.button4.Name = "button4";
|
||||
this.button4.Size = new System.Drawing.Size(181, 23);
|
||||
this.button4.TabIndex = 3;
|
||||
this.button4.Text = "About";
|
||||
this.button4.Text = "{GEN_ABOUT}";
|
||||
this.button4.UseVisualStyleBackColor = true;
|
||||
//
|
||||
// button5
|
||||
|
@ -124,7 +122,7 @@
|
|||
this.button5.Name = "button5";
|
||||
this.button5.Size = new System.Drawing.Size(181, 23);
|
||||
this.button5.TabIndex = 4;
|
||||
this.button5.Text = "Exit";
|
||||
this.button5.Text = "{GEN_EXIT}";
|
||||
this.button5.UseVisualStyleBackColor = true;
|
||||
this.button5.Click += new System.EventHandler(this.button5_Click);
|
||||
//
|
||||
|
@ -140,8 +138,6 @@
|
|||
//
|
||||
// pnloptions
|
||||
//
|
||||
this.pnloptions.Controls.Add(this.txtubase);
|
||||
this.pnloptions.Controls.Add(this.label3);
|
||||
this.pnloptions.Controls.Add(this.txtdsport);
|
||||
this.pnloptions.Controls.Add(this.label2);
|
||||
this.pnloptions.Controls.Add(this.txtdsaddress);
|
||||
|
@ -149,25 +145,9 @@
|
|||
this.pnloptions.Controls.Add(this.flowLayoutPanel1);
|
||||
this.pnloptions.Location = new System.Drawing.Point(49, 26);
|
||||
this.pnloptions.Name = "pnloptions";
|
||||
this.pnloptions.Size = new System.Drawing.Size(432, 290);
|
||||
this.pnloptions.Size = new System.Drawing.Size(432, 167);
|
||||
this.pnloptions.TabIndex = 2;
|
||||
//
|
||||
// txtubase
|
||||
//
|
||||
this.txtubase.Location = new System.Drawing.Point(146, 133);
|
||||
this.txtubase.Name = "txtubase";
|
||||
this.txtubase.Size = new System.Drawing.Size(225, 20);
|
||||
this.txtubase.TabIndex = 6;
|
||||
//
|
||||
// label3
|
||||
//
|
||||
this.label3.AutoSize = true;
|
||||
this.label3.Location = new System.Drawing.Point(22, 136);
|
||||
this.label3.Name = "label3";
|
||||
this.label3.Size = new System.Drawing.Size(106, 13);
|
||||
this.label3.TabIndex = 5;
|
||||
this.label3.Text = "Unite API base URL:";
|
||||
//
|
||||
// txtdsport
|
||||
//
|
||||
this.txtdsport.Location = new System.Drawing.Point(146, 85);
|
||||
|
@ -180,9 +160,9 @@
|
|||
this.label2.AutoSize = true;
|
||||
this.label2.Location = new System.Drawing.Point(22, 88);
|
||||
this.label2.Name = "label2";
|
||||
this.label2.Size = new System.Drawing.Size(99, 13);
|
||||
this.label2.Size = new System.Drawing.Size(125, 13);
|
||||
this.label2.TabIndex = 3;
|
||||
this.label2.Text = "Digital Society Port:";
|
||||
this.label2.Text = "{MAINMENU_DSPORT}";
|
||||
//
|
||||
// txtdsaddress
|
||||
//
|
||||
|
@ -196,9 +176,9 @@
|
|||
this.label1.AutoSize = true;
|
||||
this.label1.Location = new System.Drawing.Point(22, 57);
|
||||
this.label1.Name = "label1";
|
||||
this.label1.Size = new System.Drawing.Size(118, 13);
|
||||
this.label1.Size = new System.Drawing.Size(147, 13);
|
||||
this.label1.TabIndex = 1;
|
||||
this.label1.Text = "Digital Society Address:";
|
||||
this.label1.Text = "{MAINMENU_DSADDRESS}";
|
||||
//
|
||||
// flowLayoutPanel1
|
||||
//
|
||||
|
@ -208,7 +188,7 @@
|
|||
this.flowLayoutPanel1.Controls.Add(this.btnsave);
|
||||
this.flowLayoutPanel1.Dock = System.Windows.Forms.DockStyle.Bottom;
|
||||
this.flowLayoutPanel1.FlowDirection = System.Windows.Forms.FlowDirection.RightToLeft;
|
||||
this.flowLayoutPanel1.Location = new System.Drawing.Point(0, 259);
|
||||
this.flowLayoutPanel1.Location = new System.Drawing.Point(0, 136);
|
||||
this.flowLayoutPanel1.Name = "flowLayoutPanel1";
|
||||
this.flowLayoutPanel1.Size = new System.Drawing.Size(432, 31);
|
||||
this.flowLayoutPanel1.TabIndex = 0;
|
||||
|
@ -218,11 +198,11 @@
|
|||
this.opt_btncancel.AutoSize = true;
|
||||
this.opt_btncancel.AutoSizeMode = System.Windows.Forms.AutoSizeMode.GrowAndShrink;
|
||||
this.opt_btncancel.FlatStyle = System.Windows.Forms.FlatStyle.Flat;
|
||||
this.opt_btncancel.Location = new System.Drawing.Point(377, 3);
|
||||
this.opt_btncancel.Location = new System.Drawing.Point(331, 3);
|
||||
this.opt_btncancel.Name = "opt_btncancel";
|
||||
this.opt_btncancel.Size = new System.Drawing.Size(52, 25);
|
||||
this.opt_btncancel.Size = new System.Drawing.Size(98, 25);
|
||||
this.opt_btncancel.TabIndex = 0;
|
||||
this.opt_btncancel.Text = "Cancel";
|
||||
this.opt_btncancel.Text = "{GEN_CANCEL}";
|
||||
this.opt_btncancel.UseVisualStyleBackColor = true;
|
||||
this.opt_btncancel.Click += new System.EventHandler(this.opt_btncancel_Click);
|
||||
//
|
||||
|
@ -231,11 +211,11 @@
|
|||
this.btnsave.AutoSize = true;
|
||||
this.btnsave.AutoSizeMode = System.Windows.Forms.AutoSizeMode.GrowAndShrink;
|
||||
this.btnsave.FlatStyle = System.Windows.Forms.FlatStyle.Flat;
|
||||
this.btnsave.Location = new System.Drawing.Point(327, 3);
|
||||
this.btnsave.Location = new System.Drawing.Point(241, 3);
|
||||
this.btnsave.Name = "btnsave";
|
||||
this.btnsave.Size = new System.Drawing.Size(44, 25);
|
||||
this.btnsave.Size = new System.Drawing.Size(84, 25);
|
||||
this.btnsave.TabIndex = 1;
|
||||
this.btnsave.Text = "Save";
|
||||
this.btnsave.Text = "{GEN_SAVE}";
|
||||
this.btnsave.UseVisualStyleBackColor = true;
|
||||
this.btnsave.Click += new System.EventHandler(this.btnsave_Click);
|
||||
//
|
||||
|
@ -259,7 +239,7 @@
|
|||
this.btnnewgame.Name = "btnnewgame";
|
||||
this.btnnewgame.Size = new System.Drawing.Size(181, 23);
|
||||
this.btnnewgame.TabIndex = 0;
|
||||
this.btnnewgame.Text = "New Game";
|
||||
this.btnnewgame.Text = "{MAINMENU_NEWGAME}";
|
||||
this.btnnewgame.UseVisualStyleBackColor = true;
|
||||
this.btnnewgame.Click += new System.EventHandler(this.btnnewgame_Click);
|
||||
//
|
||||
|
@ -270,7 +250,7 @@
|
|||
this.btncontinue.Name = "btncontinue";
|
||||
this.btncontinue.Size = new System.Drawing.Size(181, 23);
|
||||
this.btncontinue.TabIndex = 1;
|
||||
this.btncontinue.Text = "Continue";
|
||||
this.btncontinue.Text = "{GEN_CONTINUE}";
|
||||
this.btncontinue.UseVisualStyleBackColor = true;
|
||||
this.btncontinue.Click += new System.EventHandler(this.btncontinue_Click);
|
||||
//
|
||||
|
@ -281,7 +261,7 @@
|
|||
this.button10.Name = "button10";
|
||||
this.button10.Size = new System.Drawing.Size(181, 23);
|
||||
this.button10.TabIndex = 4;
|
||||
this.button10.Text = "Back";
|
||||
this.button10.Text = "{GEN_BACK}";
|
||||
this.button10.UseVisualStyleBackColor = true;
|
||||
this.button10.Click += new System.EventHandler(this.button10_Click);
|
||||
//
|
||||
|
@ -357,8 +337,6 @@
|
|||
private System.Windows.Forms.FlowLayoutPanel flowLayoutPanel1;
|
||||
private System.Windows.Forms.Button opt_btncancel;
|
||||
private System.Windows.Forms.Button btnsave;
|
||||
private System.Windows.Forms.TextBox txtubase;
|
||||
private System.Windows.Forms.Label label3;
|
||||
private System.Windows.Forms.TextBox txtdsport;
|
||||
private System.Windows.Forms.Label label2;
|
||||
private System.Windows.Forms.TextBox txtdsaddress;
|
||||
|
|
|
@ -116,29 +116,7 @@ namespace ShiftOS.WinForms.MainMenu
|
|||
|
||||
private string GetTickerMessage()
|
||||
{
|
||||
switch (rnd.Next(0, 10))
|
||||
{
|
||||
case 0:
|
||||
return "Did you know that you can skin this very menu? Just goes to show how much you can shift it your way.";
|
||||
case 1:
|
||||
return "Want to pick up a few skins or mods from the community? Head on over to http://getshiftos.ml/Skins!";
|
||||
case 2:
|
||||
return "Sandbox mode is a special version of ShiftOS that allows you to use the operating system without having to deal with Codepoints, the Shiftorium or having to play through the storyline. Handy...";
|
||||
case 3:
|
||||
return "ArtPad not good enough? You can use an external image editor to create ShiftOS skin textures. Just save your files to the Shared Directory and they'll be imported into ShiftOS on the 1:/ drive.";
|
||||
case 4:
|
||||
return "Terminal too weird for ya? You can use the Format Editor to generate your own Terminal command parser. No coding knowledge needed!";
|
||||
case 5:
|
||||
return "Contests are a good way to earn heaps of Codepoints. Head on over to http://getshiftos.ml/Contests for info on current community contests.";
|
||||
case 6:
|
||||
return "There's no bugs in this game... But if you find some, please submit them to http://getshiftos.ml/Bugs.";
|
||||
case 7:
|
||||
return "SHIFTOS - PROPERTY OF MICHAEL VANOVERBEEK. FOR INTERNAL USE ONLY. Build number = sos_tr_133764 [Just kidding. ShiftOS is open-source. Find the code at http://github.com/shiftos-game/ShiftOS!]";
|
||||
case 8:
|
||||
return "Hold your Codepoints against the wall... when they take everything away. Hold your Codepoints against the wall...";
|
||||
default:
|
||||
return "Good God. We don't know what to put here.";
|
||||
}
|
||||
return Localization.Parse("{MAINMENU_TIPTEXT_" + rnd.Next(10) + "}");
|
||||
}
|
||||
|
||||
private void button1_Click(object sender, EventArgs e)
|
||||
|
@ -175,7 +153,6 @@ namespace ShiftOS.WinForms.MainMenu
|
|||
{
|
||||
var conf = ShiftOS.Objects.UserConfig.Get();
|
||||
|
||||
txtubase.Text = conf.UniteUrl;
|
||||
txtdsaddress.Text = conf.DigitalSocietyAddress;
|
||||
txtdsport.Text = conf.DigitalSocietyPort.ToString();
|
||||
|
||||
|
@ -201,32 +178,14 @@ namespace ShiftOS.WinForms.MainMenu
|
|||
|
||||
int p = 0;
|
||||
|
||||
if(int.TryParse(txtdsport.Text, out p) == false)
|
||||
if(int.TryParse(txtdsport.Text, out p) == false || p < 0 || p > 65535)
|
||||
{
|
||||
Infobox.Show("Invalid port number", "The Digital Society Port must be a valid whole number between 0 and 65535.");
|
||||
Infobox.Show("{TITLE_INVALIDPORT}", "{PROMPT_INVALIDPORT}");
|
||||
return;
|
||||
}
|
||||
else
|
||||
{
|
||||
if(p < 0 || p > 65535)
|
||||
{
|
||||
Infobox.Show("Invalid port number", "The Digital Society Port must be a valid whole number between 0 and 65535.");
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
conf.DigitalSocietyPort = p;
|
||||
|
||||
string unite = txtubase.Text;
|
||||
if (unite.EndsWith("/"))
|
||||
{
|
||||
int len = unite.Length;
|
||||
int index = len - 1;
|
||||
int end = 1;
|
||||
unite = unite.Remove(index, end);
|
||||
}
|
||||
conf.UniteUrl = unite;
|
||||
|
||||
System.IO.File.WriteAllText("servers.json", Newtonsoft.Json.JsonConvert.SerializeObject(conf, Newtonsoft.Json.Formatting.Indented));
|
||||
|
||||
HideOptions();
|
||||
|
|
|
@ -1,244 +1,134 @@
|
|||
/*
|
||||
* ShiftOS English Language Pack
|
||||
*
|
||||
* This is the default language pack distributed within the game.
|
||||
*/
|
||||
|
||||
{
|
||||
"{SUBMIT}":"Submit",
|
||||
//General strings
|
||||
//These strings can be used anywhere in the UI where language context isn't necessary.
|
||||
"{GEN_PROGRAMS}": "Programs",
|
||||
"{GEN_COMMANDS}": "Commands",
|
||||
"{GEN_OBJECTIVES}": "Objectives",
|
||||
"{GEN_CURRENTPROCESSES}": "Current processes",
|
||||
"{GEN_WELCOME}": "Welcome to ShiftOS.",
|
||||
"{GEN_SYSTEMNAME}": "System name",
|
||||
"{GEN_PASSWORD}": "Password",
|
||||
"{GEN_LPROMPT}": "%sysname login: ",
|
||||
"{GEN_SYSTEMSTATUS}": "System status",
|
||||
"{GEN_USERS}": "Users",
|
||||
"{GEN_CODEPOINTS}": "Codepoints",
|
||||
"{GEN_LOADING}": "Loading...",
|
||||
"{GEN_SAVE}": "Save",
|
||||
"{GEN_CANCEL}": "Cancel",
|
||||
"{GEN_CONTINUE}": "Continue",
|
||||
"{GEN_BACK}": "Back",
|
||||
"{GEN_YES}": "Yes",
|
||||
"{GEN_NO}": "No",
|
||||
"{GEN_OK}": "OK",
|
||||
"{GEN_SETTINGS}": "Settings",
|
||||
"{GEN_ABOUT}": "About",
|
||||
"{GEN_EXIT}": "Exit",
|
||||
|
||||
"{TERMINAL_TUTORIAL_1}":"Welcome to the ShiftOS terminal. This is where you will spend the bulk of your time within ShiftOS.
|
||||
|
||||
A brief rundown of how to use the terminal is as follows. You can use the 'sos.help' command to show a list of all commands. Simply type it in and strike <enter> to view all commands.
|
||||
|
||||
Commands can be sent arguments by specifying a key-value pair inside a {} block at the end of the command. For example:
|
||||
|
||||
some.command{print:\"hello\"}
|
||||
math.add{op1:1,op2:2}
|
||||
set.value{key:\"somekey\", value:true}
|
||||
|
||||
You have been given 50 Codepoints - use your knowledge to use them to buy the MUD Fundamentals Shiftorium Upgrade using the terminal.
|
||||
To buy MUD Fundamentals, type shiftorium.buy{upgrade:\"mud_fundamentals\"} This is also true for any other thing you want to buy from the shiftorium, just replace mud_fundementals with any other upgrade id.
|
||||
",
|
||||
//General errors
|
||||
//Syntax errors, command errors, you name it..
|
||||
"{ERR_BADBOOL}": "The value you entered must be either true or false.",
|
||||
"{ERR_BADPERCENT}": "The value you entered must be a value from 0 to 100.",
|
||||
"{ERR_NOLANG}": "The language you entered does not exist!",
|
||||
"{ERR_NOTENOUGHCODEPOINTS}": "You don't have enough Codepoints to do that.",
|
||||
"{ERR_NOUPGRADE}": "We couldn't find that upgrade.",
|
||||
"{ERR_GENERAL}": "An error has occurred performing this operation.",
|
||||
"{ERR_EMPTYCATEGORY}": "The category you specified either has no items in it, or was not found.",
|
||||
"{ERR_NOMOREUPGRADES}": "There are no more Shiftorium Upgrades to show!",
|
||||
"{ERR_BADWINID}": "You must specify a value between 0 and %max.",
|
||||
"{ERR_USERFOUND}": "That user already exists.",
|
||||
"{ERR_NOUSER}": "That user was not found.",
|
||||
"{ERR_REMOVEYOU}": "You can't remove your own user account.",
|
||||
"{ERR_BADACL}": "You must specify a value between 0 (guest) and 3 (root) for a user permission.",
|
||||
"{ERR_ACLHIGHERVALUE}": "You can't set a user's permissions to a value higher than your own.",
|
||||
"{ERR_HIGHERPERMS}": "That user has more rights than you!",
|
||||
"{ERR_PASSWD_MISMATCH}": "Passwords don't match!",
|
||||
|
||||
//Command results
|
||||
"{RES_ACLUPDATED}": "User permissions updated.",
|
||||
"{RES_LANGUAGE_CHANGED}": "System language changed successfully.",
|
||||
"{RES_NOOBJECTIVES}": "No objectives to display! Check back for more.",
|
||||
"{RES_UPGRADEINSTALLED}": "Upgrade installed!",
|
||||
"{RES_WINDOWCLOSED}": "The window was closed.",
|
||||
"{RES_CREATINGUSER}": "Creating new user with username %name.",
|
||||
"{RES_REMOVINGUSER}": "Removing user with username %name from your system.",
|
||||
"{RES_DENIED}": "Access denied.",
|
||||
"{RES_GRANTED}": "Access granted.",
|
||||
"{RES_PASSWD_SET}": "Password set successfully.",
|
||||
|
||||
"{TERMINAL_TUTORIAL_2}":"You successfully passed the test. ShiftOS will now start installing it's base functionality.",
|
||||
"{ABOUT}":"About",
|
||||
"{HIGH_SCORES}":"High scores",
|
||||
"{PONG_VIEW_HIGHSCORES}":"See the high scores",
|
||||
"{PONG_HIGHSCORE_EXP}":"Want to see what other users have gotten?",
|
||||
"{START_SYSTEM_SCAN}":"Start system-wide scan",
|
||||
"{SCAN_HOME}":"Scan 0:/home",
|
||||
"{SCAN_SYSTEM}":"Scan 0:/system",
|
||||
"{RESULTS}":"Results",
|
||||
"{VIRUSSCANNER_ABOUT}":"Welcome to the ShiftOS virus scanner.
|
||||
|
||||
The ShiftOS virus scanner is a utility that allows you to scan any file on your system and see if it is a virus. If a virus is detected, you have the option to delete it after the scan by clicking 'Remove'.
|
||||
//Shiftorium messages.
|
||||
"{SHFM_UPGRADE}": "%id - %cost Codepoints",
|
||||
"{SHFM_CATEGORY}": " - %name: %available upgrades left.",
|
||||
"{SHFM_QUERYERROR}": "Shiftorium Query Error",
|
||||
"{SHFM_NOUPGRADES}": "No upgrades!",
|
||||
|
||||
If a system file is deleted by the virus scanner, it will be replaced.",
|
||||
"{PLAY}":"Play",
|
||||
"{APPLICATIONS}":"Applications",
|
||||
"{TERMINAL}":"Terminal",
|
||||
"{PONG}":"Pong",
|
||||
"{CODEPOINTS}":"Codepoints",
|
||||
"{SHIFTORIUM}":"Shiftorium",
|
||||
"{HACK}":"Hack",
|
||||
"{SHIFTER}":"Shifter",
|
||||
"{MUD_SHORT}":"MUD",
|
||||
"{MUD}":"Multi-user domain",
|
||||
"{DESKTOP}":"Desktop",
|
||||
"{WINDOW}":"Window",
|
||||
"{WINDOW_MANAGER}":"Window manager",
|
||||
"{UPGRADE}":"Upgrade",
|
||||
"{UPGRADES}":"Upgrades",
|
||||
"{APPLICATION}":"Application",
|
||||
"{SCRIPT}":"Script",
|
||||
"{ERROR}":"Error",
|
||||
"{SCRIPTS}":"Scripts",
|
||||
"{NULL}":"null",
|
||||
"{ID}":"ID Num",
|
||||
"{SYSTEM_INITIATED}":"System initiated",
|
||||
"{PASSWORD}":"Password",
|
||||
"{CRACK}":"Crack",
|
||||
"{ARTPAD_UNDO_ERROR}":"Artpad - Undo error",
|
||||
"{ARTPAD_NEXT_STEP_WILL_KILL_CANVAS_JUST_FLIPPING_CLICK_NEW}":"You cannot undo the previous action as it would delete the canvas. If you'd like to clear the canvas, click New.",
|
||||
"{ARTPAD_REDO_ERROR}":"Artpad - Redo error",
|
||||
"{ARTPAD_NOTHING_TO_REDO}": "Artpad has nothing to redo! Remember that when you undo and then draw on the canvas, all redo history is wiped.",
|
||||
"{ARTPAD_MAGNIFIER_ERROR}": "Artpad - Magnifier error",
|
||||
"{ARTPAD_MAGNIFICATION_ERROR_EXP_2}": "Artpad cannot zoom out any further as the canvas would disappear!",
|
||||
"{ARTPAD_MAGNIFICATION_ERROR_EXP}": "Artpad cannot zoom any further into the canvas. Well, it can, it just doesn't want to.",
|
||||
"{SHUTDOWN}":"Shutdown",
|
||||
"{CONNECTING_TO_MUD}":"Connecting to the multi-user domain...",
|
||||
"{READING_FS}":"Reading filesystem...",
|
||||
"{INIT_KERNEL}":"Initiating kernel...",
|
||||
"{START_DESKTOP}":"Starting desktop session...",
|
||||
"{DONE}": "done",
|
||||
"{READING_CONFIG}":"Reading configuration...",
|
||||
"{ID_TAKEN}":"ID has been taken! Use chat.join to join this chat.",
|
||||
"{CHAT_NOT_FOUND_OR_TOO_MANY_MEMBERS}":"This chat either doesn't exist or has too many users in it.",
|
||||
"{CHAT_NOT_FOUND_OR_NOT_IN_CHAT}":"You are not currently in this chat.",
|
||||
"{CHAT_PLEASE_PROVIDE_VALID_CHANNEL_DATA}":"You did not specify valid chat metadata! Please do chat.create{id:\"your_id\", name:\"Your chat\", topic:\"Your chat's topic\"}.",
|
||||
"{UPGRADE_PROGRESS}":"Upgrade progress",
|
||||
"{WIN_PROVIDEID}":"Please provide a valid Window ID from win.list.",
|
||||
"{WIN_CANTCLOSETERMINAL}":"You cannot close this terminal.",
|
||||
"{WELCOME_TO_SHIFTORIUM}":"Welcome to the Shiftorium",
|
||||
"{SUCCESSFULLY_CREATED_CHAT}":"Successfully created chat. Use chat.join{id:\"chat_id_here\"} to join it.",
|
||||
"{CHAT_HAS_JOINED}":"has joined the chat.",
|
||||
"{HAS_LEFT_CHAT}":"has left the chat.",
|
||||
"{SHIFTORIUM_EXP}":"The Shiftorium is your one-stop-shop for ShiftOS system enhancements, upgrades and applications.
|
||||
|
||||
You can buy upgrades in the Shiftorium using a currency called Codepoints, which you can earn by doing various tasks within ShiftOS, such as playing Pong, stealing them from other users, and finding ways to make your own. It's up to you how you get your Codepoints.
|
||||
|
||||
You can then use them to buy new applications, features, enhancements and upgrades for ShiftOS that make the user experience a lot better. Be careful though, buying too many system enhancements without buying new ways of earning Codepoints first can leave you in the dust and unable to upgrade the system.
|
||||
|
||||
Anyways, feel free to browse from our wonderful selection! You can see a list of available upgrades on the left, as well as a progress bar showing how much you've upgraded the system compared to how much you still can.",
|
||||
"{PONG_WELCOME}":"Welcome to Pong.",
|
||||
"{PONG_DESC}":"Pong is an arcade game where your goal is to get the ball past the opponent paddle while keeping it from getting past yours.
|
||||
|
||||
In ShiftOS, Pong is modified - you only have one chance, the game is divided into 60 second levels, and you can earn Codepoints by surviving a level, and beating the opponent.",
|
||||
"{NO_APP_TO_OPEN}":"No app found for this file!",
|
||||
"{NO_APP_TO_OPEN_EXP}":"File Skimmer could not find an application that can open this file.",
|
||||
"{CLIENT_DIAGNOSTICS}":"Client diagnostics",
|
||||
"{GUID}":"GUID",
|
||||
"{CLIENT_DATA}":"Client data",
|
||||
"{CLOSE}":"Close",
|
||||
"{LOAD_DEFAULT}":"Load default",
|
||||
"{IMPORT}":"Import",
|
||||
"{EXPORT}":"Export",
|
||||
"{APPLY}":"Apply",
|
||||
"{TEMPLATE}":"Template",
|
||||
"{H_VEL}":"Horizontal velocity",
|
||||
"{V_VEL}":"Vertical velocity",
|
||||
"{LEVEL}":"Level",
|
||||
"{UPGRADE_DEVELOPMENT}":"Development Upgrade",
|
||||
"{UPGRADE_DEVELOPMENT_DESCRIPTION}":"Development Upgrade Don't Buy",
|
||||
"{SECONDS_LEFT}":"seconds left",
|
||||
"{CASH_OUT_WITH_CODEPOINTS}":"Cash out with your codepoints",
|
||||
"{PONG_PLAY_ON_FOR_MORE}":"Play on for more!",
|
||||
"{YOU_REACHED_LEVEL}":"You've reached level",
|
||||
"{PONG_BEAT_AI_REWARD}":"Reward for beating AI (CP)",
|
||||
"{PONG_BEAT_AI_REWARD_SECONDARY}":"Codepoints for beating AI:",
|
||||
"{CODEPOINTS_FOR_BEATING_LEVEL}":"Codepoints for beating level",
|
||||
"{YOU_WON}":"You won",
|
||||
"{YOU_LOSE}":"You lose",
|
||||
"{TRY_AGAIN}":"Try again",
|
||||
"{CODEPOINTS_SHORT}":"CP",
|
||||
"{TERMINAL_FORMATTING_DRIVE}":"Formatting drive... %percent %",
|
||||
"{INSTALLING_SHIFTOS}":"Installing ShiftOS on %domain.",
|
||||
"{YOU_MISSED_OUT_ON}":"You missed out on",
|
||||
"{BUT_YOU_GAINED}":"But you gained",
|
||||
"{PONG_PLAYON_DESC}":"Or do you want to try your luck on the next level to increase your reward?",
|
||||
"{PONG_CASHOUT_DESC}":"Would you like the end the game now and cash out with your reward?",
|
||||
"{INITIAL_H_VEL}":"Initial H Vel",
|
||||
"{INITIAL_V_VEL}":"Initial V Vel",
|
||||
"{INC_H_VEL}":"Increment H Vel",
|
||||
"{INC_V_VEL}":"Increment V Vel",
|
||||
"{MULTIPLAYER_ONLY}":"Program not compatible with single-user domain.",
|
||||
"{MULTIPLAYER_ONLY_EXP}":"This program cannot run within a single-user domain. You must be within a multi-user domain to use this program.",
|
||||
"{SHIFTER_SKIN_APPLIED}":"Shifter - Settings applied!",
|
||||
"{YOU_HAVE_EARNED}":"You have earned",
|
||||
"{CREATING_PATH}":"Creating directory: %path",
|
||||
"{CREATING_FILE}":"Creating file: %path",
|
||||
"{SHIFTORIUM_HELP_DESCRIPTION}": "Help Descriptions",
|
||||
"{CREATING_USER}":"Creating user %username",
|
||||
"{SEPERATOR}":" - ",
|
||||
"{NAMESPACE}":"Namespace ",
|
||||
"{COMMAND}": "| Command ",
|
||||
"{SHIFTOS_HAS_BEEN_INSTALLED}":"ShiftOS has been installed on %domain.",
|
||||
"{WARN}": "WARN: ",
|
||||
"{ERROR}": "!ERROR! ",
|
||||
"{OBSOLETE_CHEATS_FREECP}": "The %ns.%cmd command is obsolete and has been replaced with %newcommand",
|
||||
"{REBOOTING_SYSTEM}":"Rebooting system in %i seconds...",
|
||||
"{ERROR_ARGUMENT_REQUIRED}": "You must supply an %argument value",
|
||||
"{ERROR_ARGUMENT_REQUIRED_NO_USAGE}": "You are missing some arguments.",
|
||||
"{GENERATING_PATHS}":"Generating paths...",
|
||||
"{ERROR_COMMAND_WRONG}": "Check your syntax and try again",
|
||||
"{LOGIN_EXP}": "Login as the admin of the multi user domain.",
|
||||
|
||||
"{USAGE}": "Usage: ",
|
||||
|
||||
"{NAMESPACE_SOS_DESCRIPTION}":"The ShiftOS Namespace",
|
||||
"{COMMAND_HELP_USAGE}":"%ns.%cmd{[topic:]}",
|
||||
"{COMMAND_HELP_DESCRIPTION}":"Lists all commands",
|
||||
"{COMMAND_SOS_SHUTDOWN_USAGE}":"%ns.%cmd",
|
||||
"{COMMAND_SOS_SHUTDOWN_DESCRIPTION}":"Saves and shuts down ShiftOS",
|
||||
"{COMMAND_SOS_STATUS_USAGE}":"%ns.%cmd",
|
||||
"{COMMAND_SOS_STATUS_DESCRIPTION}":"Displays how many codepoints you have",
|
||||
"{COMMAND_SOS_LANG_USAGE}":"%ns.%cmd{language:\"deutsch\"}",
|
||||
"{COMMAND_SOS_LANG_DESCRIPTION}":"Change the language.",
|
||||
"{COMMAND_DEV_CRASH_USAGE}":"%ns.%cmd",
|
||||
"{COMMAND_DEV_CRASH_DESCRIPTION}":"Shuts down ShiftOS forcefully",
|
||||
"{COMMAND_DEV_UNLOCKEVERYTHING_USAGE}":"%ns.%cmd",
|
||||
"{COMMAND_DEV_UNLOCKEVERYTHING_DESCRIPTION}":"Unlocks all shiftorium upgrades",
|
||||
"{COMMAND_DEV_FREECP_USAGE}":"%ns.%cmd{amount:1000}",
|
||||
"{COMMAND_DEV_FREECP_DESCRIPTION}":"Gives [amount] codepoints",
|
||||
"{COMMAND_TRM_CLEAR_USAGE}":"%ns.%cmd",
|
||||
"{COMMAND_TRM_CLEAR_DESCRIPTION}":"Clears the terminal",
|
||||
"{COMMAND_SHIFTORIUM_BUY_USAGE}":"%ns.%cmd{upgrade:}",
|
||||
"{COMMAND_SHIFTORIUM_BUY_DESCRIPTION}":"Buys [upgrade]",
|
||||
"{COMMAND_SHIFTORIUM_LIST_USAGE}":"%ns.%cmd",
|
||||
"{COMMAND_SHIFTORIUM_LIST_DESCRIPTION}":"Lists the upgrades that you can get",
|
||||
"{COMMAND_SHIFTORIUM_INFO_USAGE}":"%ns.%cmd{upgrade:}",
|
||||
"{COMMAND_SHIFTORIUM_INFO_DESCRIPTION}":"Gives a description about an upgrade",
|
||||
"{COMMAND_DEV_MULTARG_USAGE}":"%ns.%cmd{id:,name:,type:}",
|
||||
"{COMMAND_DEV_MULTARG_DESCRIPTION}":"A command which requiers multiple arguments",
|
||||
//Command data strings
|
||||
"{COM_STATUS}": "ShiftOS build %version\r\n\r\nCodepoints: %cp \r\n Upgrades: %installed installed, %available available\r\n\r\n",
|
||||
"{COM_UPGRADEINFO}": "%category: %name - %cost Codepoints.\r\n\r\n%description\r\n\r\nUpgrade ID: %id",
|
||||
|
||||
"{ERR_COMMAND_NOT_FOUND}":"Command not found.",
|
||||
"{ERROR_EXCEPTION_THROWN_IN_METHOD}":"An error occurred within the command. Error details:",
|
||||
"{MUD_ERROR}":"MUD error",
|
||||
|
||||
"{PROLOGUE_NO_USER_DETECTED}":"No user detected. Please enter a username.",
|
||||
"{PROLOGUE_BADUSER}":"Invalid username detected.",
|
||||
"{PROLOGUE_NOSPACES}":"Usernames must not contain spaces.",
|
||||
"{PROLOGUE_PLEASE_ENTER_USERNAME}":"Please enter a valid username. Blank usernames are not permitted.",
|
||||
//Terminal Command Descriptions
|
||||
//These strings show up when running the "commands" command in your Terminal.
|
||||
"{DESC_CLEAR}": "Clears the screen of the current Terminal.",
|
||||
"{DESC_SETSFXENABLED}": "Sets whether or not system sounds are enabled.",
|
||||
"{DESC_SETMUSICENABLED}": "Sets whether or not music is enabled in ShiftOS.",
|
||||
"{DESC_SETVOLUME}": "Sets the volume of sounds and music if they're enabled.",
|
||||
"{DESC_SHUTDOWN}": "Safely shuts down your computer.",
|
||||
"{DESC_LANG}": "Change the system language of ShiftOS.",
|
||||
"{DESC_COMMANDS}": "Shows a list of Terminal commands inside ShiftOS.",
|
||||
"{DESC_HELP}": "Type this command to get general help with using ShiftOS.",
|
||||
"{DESC_SAVE}": "Saves the in-memory configuration of ShiftOS.",
|
||||
"{DESC_STATUS}": "Shows basic status information such as how many Codepoints you have and your current objective.",
|
||||
"{DESC_BUY}": "Buys the specified Shiftorium upgrade.",
|
||||
"{DESC_BULKBUY}": "Buys the specified Shiftorium upgrades in bulk.",
|
||||
"{DESC_UPGRADEINFO}": "Shows information about the specified Shiftorium upgrade.",
|
||||
"{DESC_UPGRADECATEGORIES}": "Shows all the available Shiftorium categories and how many upgrades are available in them.",
|
||||
"{DESC_UPGRADES}": "Shows a list of available Shiftorium upgrades.",
|
||||
"{DESC_PROCESSES}": "Shows a list of currently running app processes.",
|
||||
"{DESC_PROGRAMS}": "Shows a list of programs you can run.",
|
||||
"{DESC_CLOSE}": "Closes the specified application window.",
|
||||
"{DESC_ADDUSER}": "Add a user to your system.",
|
||||
"{DESC_REMOVEUSER}": "Remove a user from your computer.",
|
||||
"{DESC_SETUSERPERMISSIONS}": "Set the permissions of a user.",
|
||||
"{DESC_USERS}": "Lists all users on your computer.",
|
||||
"{DESC_SU}": "Change your identity to another user's.",
|
||||
"{DESC_PASSWD}": "Change your user account password.",
|
||||
|
||||
"{SHIFTORIUM_NOTENOUGHCP}":"Not enough codepoints: ",
|
||||
"{SHIFTORIUM_TRANSFERRED_FROM}":"Received Codepoints from",
|
||||
"{SHIFTORIUM_TRANSFERRED_TO}":"Transferred Codepoints to",
|
||||
//Window titles.
|
||||
"{TITLE_PONG_YOULOSE}": "You lose",
|
||||
"{TITLE_CODEPOINTSTRANSFERRED}": "Codepoints transferred.",
|
||||
"{TITLE_INVALIDPORT}": "Invalid port number.",
|
||||
|
||||
"{SE_SAVING}":"Saving game to disk",
|
||||
"{SE_TIPOFADVICE}":"Tip of advice: ShiftOS will always save your game after big events or when you shut down the operating system. You can also invoke a save yourself using 'sos.save'.",
|
||||
//Infobox prompt messages
|
||||
"{PROMPT_PONGLOST}": "You lost this game of Pong. Guess you should've cashed out...",
|
||||
"{PROMPT_CODEPOINTSTRANSFERRED}": "%transferrer has transferred %amount Codepoints to your system.",
|
||||
"{PROMPT_INVALIDPORT}": "The Digital Society Port must be a valid whole number between 0 and 65535.",
|
||||
|
||||
"{STORY_WELCOME}":"Welcome to ShiftOS",
|
||||
"{STORY_SENTIENCEUNKNOWN}":"Your sentience is currently unknown. Please strike the Enter key to prove you are alive.",
|
||||
//Pong
|
||||
"{PONG_LEVELREACHED}": "You've reached level %level!",
|
||||
"{PONG_BEATAI}": "You've beaten the opponent! %amount Codepoints!",
|
||||
"{PONG_STATUSCP}": "Codepoints: %cp",
|
||||
"{PONG_STATUSLEVEL}": "Level %level. %time seconds to go!",
|
||||
"{PONG_PLAY}": "Play some Pong!",
|
||||
"{PONG_DESC}": "Pong is the modern-day recreation of the classic 70s game called, you guessed it, Pong.\r\n\r\nIn Pong, you must try your best to keep the fast-moving ball from going past your side of the screen using your mouse to move your paddle in the way of the ball, while getting the ball to go past the opponent's paddle.\r\n\r\nOnce you start Pong, you have 60 seconds to beat the opponent and survive as much as possible. The game will get faster as you play, and the more 60-second levels you play, the more Codepoints you'll earn. If you lose the level, you will start back at Level 1 with 0 Codepoints. At the end of the level, you may choose to cash out or play on.",
|
||||
"{PONG_WELCOME}": "Welcome to Pong.",
|
||||
"{PONG_BEATLEVELDESC}": "You have survived this level of Pong. You now have a chance to cash out your Codepoints or play on for more.",
|
||||
"{PONG_PLAYON}": "Play on",
|
||||
"{PONG_CASHOUT}": "Cash out",
|
||||
|
||||
"{SENTIENCE_BASIC}":"Sentience: Basic - User can respond to basic instructions.",
|
||||
"{SENTIENCE_BASICPLUS}":"Sentience: Basic+ - User can invoke commands within the ecosystem.",
|
||||
"{SENTIENCE_POSSIBLEHUMAN}":"Sentience: Possible human - user can perform actions based on a choice.",
|
||||
"{SENTIENCE_POSSIBLEHUMANPLUS}":"Sentience: Possible human+ - user can infer, and can pass arguments.",
|
||||
"{SENTIENCE_HUMAN}":"Sentience: Human. Thanks for your patience.",
|
||||
"{SENTIENCE_INVALIDPASSWORD}":"The password you entered is invalid.",
|
||||
|
||||
"{ARGS_PASSWORD}":"password",
|
||||
//Main menu tip messages
|
||||
|
||||
"{SHIFTOS_PLUS_MOTTO}":"ShiftOS, Shift it YOUR way.",
|
||||
"{SHIFTOS_VERSION_INFO}":"ShiftOS Version: ",
|
||||
"{USER_NAME}":"Username",
|
||||
"{DISCOURSE_INTEGRATION}":"Discourse Integration",
|
||||
"{SYSTEM_NAME}":"System Name",
|
||||
"{USER_INFO}":"User Information",
|
||||
"{SELECT_LANG}":"Select language",
|
||||
"{WELCOME_TO_SHIFTOS}":"Welcome to ShiftOS Alpha!",
|
||||
"{CREATE}":"Create",
|
||||
"{INSTALL}":"Install",
|
||||
"{ALIAS}":"Alias:",
|
||||
"{OBSOLETE_SYS_SHUTDOWN}":"sys.shutdown is obsolete",
|
||||
"{PY_EXCEPTION}":"There was an error running python code.",
|
||||
"{LUA_ERROR}":"There was an error running lua code.",
|
||||
"{LANGUAGE_CHANGED}":"The language has been changed. Please restart ShiftOS for changes to take full effect.",
|
||||
//Main menu - Settings
|
||||
"{MAINMENU_DSADDRESS}": "Digital Society address: ",
|
||||
"{MAINMENU_DSPORT": "Digital Society port: ",
|
||||
|
||||
"{TERMINAL_NAME}":"Terminal",
|
||||
"{ARTPAD_NAME}":"Artpad",
|
||||
"{PONG_NAME}":"Pong",
|
||||
"{WAV_PLAYER_NAME}":"WAV Player",
|
||||
"{SHIFTORIUM_NAME}":"Shiftorium",
|
||||
"{TEXTPAD_NAME}":"TextPad",
|
||||
"{VIRUS_SCANNER_NAME}":"Virus Scanner",
|
||||
"{SKIN_LOADER_NAME}":"Skin Loader",
|
||||
"{SHIFTER_NAME}":"Shifter",
|
||||
"{NAME_CHANGER_NAME}":"Name Changer",
|
||||
"{MUD_PASSWORD_CRACKER_NAME}":"Multi-User Domain Password Cracker v1.0",
|
||||
"{MUD_CONTROL_CENTRE_NAME}":"MUD Control Centre",
|
||||
"{MUD_AUTHENTICATOR_NAME}":"Multi-User Domain Admin Panel",
|
||||
"{GRAPHIC_PICKER_NAME}":"Graphic Picker",
|
||||
"{FILE_SKIMMER_NAME}":"File Skimmer",
|
||||
"{FILE_DIALOG_NAME}":"File Dialog",
|
||||
"{DIALOG_NAME}":"Dialog",
|
||||
"{COLOR_PICKER_NAME}":"Color Picker",
|
||||
"{CHAT_NAME}":"Chat",
|
||||
"{NOTIFICATIONS}":"Notifications",
|
||||
}
|
||||
//Main Menu - General text
|
||||
"{MAINMENU_TITLE}": "Main menu",
|
||||
"{MAINMENU_CAMPAIGN}": "Campaign",
|
||||
"{MAINMENU_SANDBOX}": "Sandbox",
|
||||
"{MAINMENU_NEWGAME}": "New game",
|
||||
}
|
|
@ -38,118 +38,26 @@ using Newtonsoft.Json;
|
|||
using System.IO.Compression;
|
||||
|
||||
using ShiftOS.Objects;
|
||||
using Discoursistency.Base.Models.Authentication;
|
||||
using ShiftOS.Engine.Scripting;
|
||||
using ShiftOS.Objects.ShiftFS;
|
||||
|
||||
namespace ShiftOS.Engine
|
||||
{
|
||||
[RequiresUpgrade("desktop;wm_free_placement")]
|
||||
public static class InfoboxDebugCommands
|
||||
{
|
||||
|
||||
[RequiresArgument("title")]
|
||||
[RequiresArgument("msg")]
|
||||
[Command("show")]
|
||||
public static bool ShowInfo(Dictionary<string, object> args)
|
||||
{
|
||||
Desktop.InvokeOnWorkerThread(new Action(() =>
|
||||
{
|
||||
Infobox.Show(args["title"].ToString(), args["msg"].ToString());
|
||||
}));
|
||||
return true;
|
||||
}
|
||||
|
||||
[RequiresArgument("title")]
|
||||
[RequiresArgument("msg")]
|
||||
[Command("yesno")]
|
||||
public static bool ShowYesNo(Dictionary<string, object> args)
|
||||
{
|
||||
bool forwarding = TerminalBackend.IsForwardingConsoleWrites;
|
||||
var fGuid = TerminalBackend.ForwardGUID;
|
||||
Action<bool> callback = (result) =>
|
||||
{
|
||||
TerminalBackend.IsForwardingConsoleWrites = forwarding;
|
||||
TerminalBackend.ForwardGUID = (forwarding == true) ? fGuid : null;
|
||||
string resultFriendly = (result == true) ? "yes" : "no";
|
||||
Console.WriteLine($"{SaveSystem.CurrentUser.Username} says {resultFriendly}.");
|
||||
TerminalBackend.IsForwardingConsoleWrites = false;
|
||||
};
|
||||
Desktop.InvokeOnWorkerThread(new Action(() =>
|
||||
{
|
||||
Infobox.PromptYesNo(args["title"].ToString(), args["msg"].ToString(), callback);
|
||||
|
||||
}));
|
||||
return true;
|
||||
}
|
||||
|
||||
[RequiresArgument("title")]
|
||||
[RequiresArgument("msg")]
|
||||
[Command("text")]
|
||||
public static bool ShowText(Dictionary<string, object> args)
|
||||
{
|
||||
bool forwarding = TerminalBackend.IsForwardingConsoleWrites;
|
||||
var fGuid = TerminalBackend.ForwardGUID;
|
||||
Action<string> callback = (result) =>
|
||||
{
|
||||
TerminalBackend.IsForwardingConsoleWrites = forwarding;
|
||||
TerminalBackend.ForwardGUID = (forwarding == true) ? fGuid : null;
|
||||
Console.WriteLine($"{SaveSystem.CurrentUser.Username} says \"{result}\".");
|
||||
TerminalBackend.IsForwardingConsoleWrites = false;
|
||||
};
|
||||
Desktop.InvokeOnWorkerThread(new Action(() =>
|
||||
{
|
||||
Infobox.PromptText(args["title"].ToString(), args["msg"].ToString(), callback);
|
||||
}));
|
||||
return true;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public static class AudioCommands
|
||||
{
|
||||
[Command("setvol", description = "Set the volume of the system audio to anywhere between 0 and 100.")]
|
||||
[RequiresArgument("value")]
|
||||
[RequiresUpgrade("audio_volume")]
|
||||
public static bool SetVolume(Dictionary<string,object> args)
|
||||
{
|
||||
int val = Convert.ToInt32(args["value"].ToString());
|
||||
float volume = (val / 100F);
|
||||
AudioManager.SetVolume(volume);
|
||||
return true;
|
||||
}
|
||||
[RequiresUpgrade("audio_volume")]
|
||||
[Command("mute", description = "Sets the volume of the system audio to 0")]
|
||||
public static bool MuteAudio()
|
||||
{
|
||||
AudioManager.SetVolume(0);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
[TutorialLock]
|
||||
public static class TerminalCommands
|
||||
{
|
||||
[Command("clear")]
|
||||
[Command("clear", description = "{DESC_CLEAR}")]
|
||||
public static bool Clear()
|
||||
{
|
||||
AppearanceManager.ConsoleOut.Clear();
|
||||
return true;
|
||||
}
|
||||
|
||||
[Command("echo")]
|
||||
[RequiresArgument("text")]
|
||||
public static bool Echo(Dictionary<string, object> args)
|
||||
{
|
||||
Console.WriteLine(args["text"]);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
public static class ShiftOSCommands
|
||||
{
|
||||
|
||||
[Command("setsfxenabled", description = "Set whether or not sound effects are enabled in the system.")]
|
||||
[Command("setsfxenabled", description = "{DESC_SETSFXENABLED}")]
|
||||
[RequiresArgument("value")]
|
||||
public static bool SetSfxEnabled(Dictionary<string, object> args)
|
||||
{
|
||||
|
@ -161,14 +69,14 @@ namespace ShiftOS.Engine
|
|||
}
|
||||
catch
|
||||
{
|
||||
Console.WriteLine("Error: Value must be either true or false.");
|
||||
Console.WriteLine("{ERR_BADBOOL}");
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
|
||||
[Command("setmusicenabled", description = "Set whether or not music is enabled in the system.")]
|
||||
[Command("setmusicenabled", description = "{DESC_SETMUSICENABLED}")]
|
||||
[RequiresArgument("value")]
|
||||
public static bool SetMusicEnabled(Dictionary<string, object> args)
|
||||
{
|
||||
|
@ -180,14 +88,14 @@ namespace ShiftOS.Engine
|
|||
}
|
||||
catch
|
||||
{
|
||||
Console.WriteLine("Error: Value must be either true or false.");
|
||||
Console.WriteLine("{ERR_BADBOOL}");
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
|
||||
[Command("setsfxvolume", description ="Set the system sound volume to a value between 1 and 100.")]
|
||||
[Command("setvolume", description ="{DESC_SETVOLUME}")]
|
||||
[RequiresArgument("value")]
|
||||
public static bool SetSfxVolume(Dictionary<string, object> args)
|
||||
{
|
||||
|
@ -199,13 +107,13 @@ namespace ShiftOS.Engine
|
|||
}
|
||||
else
|
||||
{
|
||||
Console.WriteLine("Volume must be between 0 and 100!");
|
||||
Console.WriteLine("{ERR_BADPERCENT}");
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
[RemoteLock]
|
||||
[Command("shutdown")]
|
||||
[Command("shutdown", description = "{DESC_SHUTDOWN}")]
|
||||
public static bool Shutdown()
|
||||
{
|
||||
TerminalBackend.InvokeCommand("sos.save");
|
||||
|
@ -213,7 +121,7 @@ namespace ShiftOS.Engine
|
|||
return true;
|
||||
}
|
||||
|
||||
[Command("lang", "{COMMAND_SOS_LANG_USAGE}", "{COMMAND_SOS_LANG_DESCRIPTION}")]
|
||||
[Command("lang", description = "{DESC_LANG}")]
|
||||
[RequiresArgument("language")]
|
||||
public static bool SetLanguage(Dictionary<string, object> userArgs)
|
||||
{
|
||||
|
@ -221,20 +129,17 @@ namespace ShiftOS.Engine
|
|||
{
|
||||
string lang = "";
|
||||
|
||||
if (userArgs.ContainsKey("language"))
|
||||
lang = (string)userArgs["language"];
|
||||
else
|
||||
throw new Exception("You must specify a valid 'language' value.");
|
||||
|
||||
lang = (string)userArgs["language"];
|
||||
|
||||
if (Localization.GetAllLanguages().Contains(lang))
|
||||
{
|
||||
SaveSystem.CurrentSave.Language = lang;
|
||||
SaveSystem.SaveGame();
|
||||
Console.WriteLine("{LANGUAGE_CHANGED}");
|
||||
Console.WriteLine("{RES_LANGUAGE_CHANGED}");
|
||||
return true;
|
||||
}
|
||||
|
||||
throw new Exception($"Couldn't find language with ID: {lang}");
|
||||
throw new Exception("{ERR_NOLANG}");
|
||||
}
|
||||
catch
|
||||
{
|
||||
|
@ -242,11 +147,11 @@ namespace ShiftOS.Engine
|
|||
}
|
||||
}
|
||||
|
||||
[Command("commands", "", "{COMMAND_COMMANDS_DESCRIPTION}")]
|
||||
[Command("commands", "", "{DESC_COMMANDS}")]
|
||||
public static bool Commands()
|
||||
{
|
||||
var sb = new StringBuilder();
|
||||
sb.AppendLine("Commands");
|
||||
sb.AppendLine("{GEN_COMMANDS}");
|
||||
sb.AppendLine("=================");
|
||||
sb.AppendLine();
|
||||
//print all unique namespaces.
|
||||
|
@ -254,7 +159,7 @@ namespace ShiftOS.Engine
|
|||
{
|
||||
sb.Append(n.CommandInfo.name);
|
||||
if (!string.IsNullOrWhiteSpace(n.CommandInfo.description))
|
||||
if (Shiftorium.UpgradeInstalled("help_descriptions"))
|
||||
if (Shiftorium.UpgradeInstalled("help_description"))
|
||||
sb.Append(" - " + n.CommandInfo.description);
|
||||
sb.AppendLine();
|
||||
}
|
||||
|
@ -264,7 +169,7 @@ namespace ShiftOS.Engine
|
|||
return true;
|
||||
}
|
||||
|
||||
[Command("help", description = "Type this command to list all the things you can do in ShiftOS.")]
|
||||
[Command("help", description = "{DESC_HELP}")]
|
||||
public static bool Help()
|
||||
{
|
||||
Commands();
|
||||
|
@ -274,7 +179,7 @@ namespace ShiftOS.Engine
|
|||
|
||||
|
||||
[MultiplayerOnly]
|
||||
[Command("save")]
|
||||
[Command("save", description = "{DESC_SAVE}")]
|
||||
public static bool Save()
|
||||
{
|
||||
SaveSystem.SaveGame();
|
||||
|
@ -282,19 +187,23 @@ namespace ShiftOS.Engine
|
|||
}
|
||||
|
||||
[MultiplayerOnly]
|
||||
[Command("status")]
|
||||
[Command("status", description = "{DESC_STATUS}")]
|
||||
public static bool Status()
|
||||
{
|
||||
string status = $@"ShiftOS version {Assembly.GetExecutingAssembly().GetName().Version.ToString()}
|
||||
string version = Assembly.GetExecutingAssembly().GetName().Version.ToString();
|
||||
|
||||
Codepoints: {SaveSystem.CurrentSave.Codepoints}
|
||||
Upgrades: {SaveSystem.CurrentSave.CountUpgrades()} installed,
|
||||
{Shiftorium.GetAvailable().Length} available
|
||||
string cp = SaveSystem.CurrentSave.Codepoints.ToString();
|
||||
string installed = SaveSystem.CurrentSave.CountUpgrades().ToString();
|
||||
string available = Shiftorium.GetAvailable().Length.ToString();
|
||||
|
||||
";
|
||||
|
||||
Console.WriteLine(status);
|
||||
Console.WriteLine("Objectives:");
|
||||
Console.WriteLine(Localization.Parse("{COM_STATUS}", new Dictionary<string, string>
|
||||
{
|
||||
["%cp"] = cp,
|
||||
["%version"] = version,
|
||||
["%installed"] = installed,
|
||||
["%available"] = available
|
||||
}));
|
||||
Console.WriteLine("{GEN_OBJECTIVES}");
|
||||
try
|
||||
{
|
||||
if (Story.CurrentObjectives.Count > 0)
|
||||
|
@ -309,12 +218,12 @@ Upgrades: {SaveSystem.CurrentSave.CountUpgrades()} installed,
|
|||
}
|
||||
else
|
||||
{
|
||||
Console.WriteLine(" - No objectives are running. Check back later!");
|
||||
Console.WriteLine("{RES_NOOBJECTIVES}");
|
||||
}
|
||||
}
|
||||
catch
|
||||
{
|
||||
Console.WriteLine(" - No objectives are running. Check back later!");
|
||||
Console.WriteLine("{RES_NOOBJECTIVES}");
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
@ -323,7 +232,7 @@ Upgrades: {SaveSystem.CurrentSave.CountUpgrades()} installed,
|
|||
[MultiplayerOnly]
|
||||
public static class ShiftoriumCommands
|
||||
{
|
||||
[Command("buy")]
|
||||
[Command("buy", description = "{DESC_BUY}")]
|
||||
[RequiresArgument("upgrade")]
|
||||
public static bool BuyUpgrade(Dictionary<string, object> userArgs)
|
||||
{
|
||||
|
@ -331,30 +240,31 @@ Upgrades: {SaveSystem.CurrentSave.CountUpgrades()} installed,
|
|||
{
|
||||
string upgrade = "";
|
||||
|
||||
if (userArgs.ContainsKey("upgrade"))
|
||||
upgrade = (string)userArgs["upgrade"];
|
||||
else
|
||||
throw new Exception("You must specify a valid 'upgrade' value.");
|
||||
upgrade = (string)userArgs["upgrade"];
|
||||
|
||||
foreach (var upg in Shiftorium.GetAvailable())
|
||||
var upg = Shiftorium.GetAvailable().FirstOrDefault(x => x.ID == upgrade);
|
||||
if(upg != null)
|
||||
{
|
||||
if (upg.ID == upgrade)
|
||||
{
|
||||
Shiftorium.Buy(upgrade, upg.Cost);
|
||||
return true;
|
||||
}
|
||||
if (Shiftorium.Buy(upg.ID, upg.Cost) == true)
|
||||
Console.WriteLine("{RES_UPGRADEINSTALLED}");
|
||||
else
|
||||
Console.WriteLine("{ERR_NOTENOUGHCODEPOINTS}");
|
||||
}
|
||||
else
|
||||
{
|
||||
Console.WriteLine("{ERR_NOUPGRADE}");
|
||||
}
|
||||
|
||||
throw new Exception($"Couldn't find upgrade with ID: {upgrade}");
|
||||
}
|
||||
catch
|
||||
{
|
||||
return false;
|
||||
Console.WriteLine("{ERR_GENERAL}");
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
[RequiresUpgrade("shiftorium_bulk_buy")]
|
||||
[Command("bulkbuy")]
|
||||
[Command("bulkbuy", description = "{DESC_BULKBUY}")]
|
||||
[RequiresArgument("upgrades")]
|
||||
public static bool BuyBulk(Dictionary<string, object> args)
|
||||
{
|
||||
|
@ -368,15 +278,11 @@ Upgrades: {SaveSystem.CurrentSave.CountUpgrades()} installed,
|
|||
BuyUpgrade(dict);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
throw new Exception("Please specify a list of upgrades in the 'upgrades' argument. Each upgrade is separated by a comma.");
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
[Command("upgradeinfo", description ="Shows information about a specific upgrade.")]
|
||||
[Command("upgradeinfo", description ="{DESC_UPGRADEINFO}")]
|
||||
[RequiresArgument("upgrade")]
|
||||
public static bool ViewInfo(Dictionary<string, object> userArgs)
|
||||
{
|
||||
|
@ -384,29 +290,26 @@ Upgrades: {SaveSystem.CurrentSave.CountUpgrades()} installed,
|
|||
{
|
||||
string upgrade = "";
|
||||
|
||||
if (userArgs.ContainsKey("upgrade"))
|
||||
upgrade = (string)userArgs["upgrade"];
|
||||
else
|
||||
throw new Exception("You must specify a valid 'upgrade' value.");
|
||||
upgrade = (string)userArgs["upgrade"];
|
||||
|
||||
foreach (var upg in Shiftorium.GetDefaults())
|
||||
{
|
||||
if (upg.ID == upgrade)
|
||||
{
|
||||
Console.WriteLine($@"Information for {upgrade}:
|
||||
Console.WriteLine(Localization.Parse("{COM_UPGRADEINFO}", new Dictionary<string, string>
|
||||
{
|
||||
["%id"] = upg.ID,
|
||||
["%category"] = upg.Category,
|
||||
["%name"] = upg.Name,
|
||||
["%cost"] = upg.Cost.ToString(),
|
||||
["%description"] = upg.Description
|
||||
}));
|
||||
|
||||
{upg.Category}: {upg.Name} - {upg.Cost} Codepoints
|
||||
------------------------------------------------------
|
||||
|
||||
{upg.Description}
|
||||
|
||||
To buy this upgrade, run:
|
||||
shiftorium.buy{{upgrade:""{upg.ID}""}}");
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
throw new Exception($"Couldn't find upgrade with ID: {upgrade}");
|
||||
throw new Exception("{ERR_NOUPGRADE}");
|
||||
}
|
||||
catch
|
||||
{
|
||||
|
@ -414,17 +317,21 @@ shiftorium.buy{{upgrade:""{upg.ID}""}}");
|
|||
}
|
||||
}
|
||||
|
||||
[Command("upgradecategories", description = "Shows all available Shiftorium upgrade categories, and how many upgrades are available in them.")]
|
||||
[Command("upgradecategories", description = "{DESC_UPGRADECATEGORIES}")]
|
||||
public static bool ListCategories()
|
||||
{
|
||||
foreach(var cat in Shiftorium.GetCategories())
|
||||
{
|
||||
Console.WriteLine($"{cat} - {Shiftorium.GetAvailable().Where(x=>x.Category==cat).Count()} upgrades");
|
||||
Console.WriteLine(Localization.Parse("{SHFM_CATEGORY}", new Dictionary<string, string>
|
||||
{
|
||||
["%name"] = cat,
|
||||
["%available"] = Shiftorium.GetAvailable().Where(x=>x.Category==cat).Count().ToString()
|
||||
}));
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
[Command("upgrades", description ="Lists all available Shiftorium upgrades.")]
|
||||
[Command("upgrades", description ="{DESC_UPGRADES}")]
|
||||
public static bool ListAll(Dictionary<string, object> args)
|
||||
{
|
||||
try
|
||||
|
@ -449,11 +356,11 @@ shiftorium.buy{{upgrade:""{upg.ID}""}}");
|
|||
{
|
||||
ConsoleEx.Bold = true;
|
||||
ConsoleEx.ForegroundColor = ConsoleColor.Red;
|
||||
Console.WriteLine("Shiftorium Query Error");
|
||||
Console.WriteLine("{SHFM_QUERYERROR}");
|
||||
Console.WriteLine();
|
||||
ConsoleEx.Bold = false;
|
||||
ConsoleEx.ForegroundColor = ConsoleColor.Gray;
|
||||
Console.WriteLine("Either there are no upgrades in the category \"" + cat + "\" or the category was not found.");
|
||||
Console.WriteLine("{ERR_EMPTYCATEGORY}");
|
||||
return true;
|
||||
}
|
||||
upglist = Shiftorium.GetAvailable().Where(x => x.Category == cat);
|
||||
|
@ -464,11 +371,11 @@ shiftorium.buy{{upgrade:""{upg.ID}""}}");
|
|||
{
|
||||
ConsoleEx.Bold = true;
|
||||
ConsoleEx.ForegroundColor = ConsoleColor.Red;
|
||||
Console.WriteLine("No upgrades available!");
|
||||
Console.WriteLine("{SHFM_NOUPGRADES}");
|
||||
Console.WriteLine();
|
||||
ConsoleEx.Bold = false;
|
||||
ConsoleEx.ForegroundColor = ConsoleColor.Gray;
|
||||
Console.WriteLine("You have installed all available upgrades for your system. Please check back later for more.");
|
||||
Console.WriteLine("{ERR_NOMOREUPGRADES}");
|
||||
return true;
|
||||
|
||||
}
|
||||
|
@ -482,11 +389,13 @@ shiftorium.buy{{upgrade:""{upg.ID}""}}");
|
|||
upgrades.Add(upg.ID, upg.Cost);
|
||||
}
|
||||
|
||||
Console.WriteLine("ID".PadRight((maxLength + 5) - 2) + "Cost (Codepoints)");
|
||||
|
||||
foreach (var upg in upgrades)
|
||||
{
|
||||
Console.WriteLine(upg.Key.PadRight((maxLength + 5) - upg.Key.Length) + " " + upg.Value.ToString());
|
||||
Console.WriteLine(Localization.Parse("{SHFM_UPGRADE}", new Dictionary<string, string>
|
||||
{
|
||||
["%id"] = upg.Key,
|
||||
["%cost"] = upg.Value.ToString()
|
||||
}));
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
@ -500,14 +409,11 @@ shiftorium.buy{{upgrade:""{upg.ID}""}}");
|
|||
|
||||
public static class WindowCommands
|
||||
{
|
||||
|
||||
|
||||
|
||||
[RemoteLock]
|
||||
[Command("processes", description = "Shows all running applications.")]
|
||||
[Command("processes", description = "{DESC_PROCESSES}")]
|
||||
public static bool List()
|
||||
{
|
||||
Console.WriteLine("Window ID\tName");
|
||||
Console.WriteLine("{GEN_CURRENTPROCESSES}");
|
||||
foreach (var app in AppearanceManager.OpenForms)
|
||||
{
|
||||
//Windows are displayed the order in which they were opened.
|
||||
|
@ -516,17 +422,17 @@ shiftorium.buy{{upgrade:""{upg.ID}""}}");
|
|||
return true;
|
||||
}
|
||||
|
||||
[Command("programs", description = "Lists all the programs installed in ShiftOS.")]
|
||||
[Command("programs", description = "{DESC_PROGRAMS}")]
|
||||
public static bool Programs()
|
||||
{
|
||||
Console.WriteLine("Programs:");
|
||||
Console.WriteLine("{GEN_PROGRAMS}");
|
||||
Console.WriteLine("===============");
|
||||
Console.WriteLine();
|
||||
foreach(var cmd in TerminalBackend.Commands.Where(x=>x is TerminalBackend.WinOpenCommand && Shiftorium.UpgradeInstalled(x.Dependencies)).OrderBy(x => x.CommandInfo.name))
|
||||
{
|
||||
Console.Write(" - " + cmd.CommandInfo.name);
|
||||
if (!string.IsNullOrWhiteSpace(cmd.CommandInfo.description))
|
||||
if (Shiftorium.UpgradeInstalled("help_descriptions"))
|
||||
if (Shiftorium.UpgradeInstalled("help_description"))
|
||||
Console.Write(": " + cmd.CommandInfo.description);
|
||||
Console.WriteLine();
|
||||
}
|
||||
|
@ -534,7 +440,7 @@ shiftorium.buy{{upgrade:""{upg.ID}""}}");
|
|||
}
|
||||
|
||||
[RemoteLock]
|
||||
[Command("close", usage = "{win:integer32}", description ="Closes the specified window.")]
|
||||
[Command("close", usage = "{win:integer32}", description ="{DESC_CLOSE}")]
|
||||
[RequiresArgument("win")]
|
||||
[RequiresUpgrade("close_command")]
|
||||
public static bool CloseWindow(Dictionary<string, object> args)
|
||||
|
@ -545,11 +451,14 @@ shiftorium.buy{{upgrade:""{upg.ID}""}}");
|
|||
string err = null;
|
||||
|
||||
if (winNum < 0 || winNum >= AppearanceManager.OpenForms.Count)
|
||||
err = "The window number must be between 0 and " + (AppearanceManager.OpenForms.Count - 1).ToString() + ".";
|
||||
err = Localization.Parse("{ERR_BADWINID}", new Dictionary<string, string>
|
||||
{
|
||||
["%max"] = (AppearanceManager.OpenForms.Count - 1).ToString()
|
||||
});
|
||||
|
||||
if (string.IsNullOrEmpty(err))
|
||||
{
|
||||
Console.WriteLine($"Closing {AppearanceManager.OpenForms[winNum].Text}...");
|
||||
Console.WriteLine("{RES_WINDOWCLOSED}");
|
||||
AppearanceManager.Close(AppearanceManager.OpenForms[winNum].ParentWindow);
|
||||
}
|
||||
else
|
||||
|
|
|
@ -126,9 +126,9 @@ namespace ShiftOS.Engine
|
|||
}
|
||||
|
||||
Thread.Sleep(350);
|
||||
Console.WriteLine("ShiftKernel v0.4.2");
|
||||
Console.WriteLine("{MISC_KERNELVERSION}");
|
||||
Thread.Sleep(50);
|
||||
Console.WriteLine("(MIT) DevX 2017, Very Little Rights Reserved");
|
||||
Console.WriteLine("Copyright (c) 2018 DevX. Licensed under MIT.");
|
||||
Console.WriteLine("");
|
||||
Console.WriteLine("THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR");
|
||||
Console.WriteLine("IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,");
|
||||
|
@ -139,39 +139,20 @@ namespace ShiftOS.Engine
|
|||
Console.WriteLine("SOFTWARE.");
|
||||
Console.WriteLine("");
|
||||
Thread.Sleep(250);
|
||||
Console.WriteLine("[init] Kernel boot complete.");
|
||||
Console.WriteLine("[sfs] Loading SFS driver v3");
|
||||
Console.WriteLine("{MISC_KERNELBOOTED}");
|
||||
Console.WriteLine("{MISC_SHIFTFSDRV}");
|
||||
Thread.Sleep(350);
|
||||
Console.WriteLine("[sfs] 4096 blocks read.");
|
||||
if (loadingJoke1 == 0)
|
||||
Console.WriteLine("[sos] Getting good and ready...");
|
||||
if (loadingJoke1 == 1)
|
||||
Console.WriteLine("[sos] Shifting the OS...");
|
||||
if (loadingJoke1 == 2)
|
||||
Console.WriteLine("[sos] Placing things everywhere...");
|
||||
if (loadingJoke1 == 3)
|
||||
Console.WriteLine("[sos] Making an an errors...");
|
||||
if (loadingJoke1 == 4)
|
||||
Console.WriteLine("[sos] Testing to see if this OS is indeed on...");
|
||||
if (loadingJoke1 == 5)
|
||||
Console.WriteLine("[sos] Calming user...");
|
||||
if (loadingJoke1 == 6)
|
||||
Console.WriteLine("[sos] Cleaning room...");
|
||||
if (loadingJoke1 == 7)
|
||||
Console.WriteLine("[sos] Checking for piracy...");
|
||||
if (loadingJoke1 == 8)
|
||||
Console.WriteLine("[sos] Getting Jim that important office memo...");
|
||||
if (loadingJoke1 == 9)
|
||||
Console.WriteLine("[sos] Using imagination...");
|
||||
Console.WriteLine("{MISC_SHIFTFSBLOCKSREAD}");
|
||||
Console.WriteLine("{MISC_LOADINGMSG1_" + loadingJoke1 + "}");
|
||||
Thread.Sleep(500);
|
||||
Console.WriteLine("[simpl-conf] Reading configuration files (global-3.conf)");
|
||||
Console.WriteLine("{MISC_LOADINGCONFIG}");
|
||||
Thread.Sleep(30);
|
||||
Console.WriteLine("[termdb] Building command database from filesystem...");
|
||||
Console.WriteLine("{MISC_BUILDINGCMDS}");
|
||||
TerminalBackend.PopulateTerminalCommands();
|
||||
|
||||
if (IsSandbox == false)
|
||||
{
|
||||
Console.WriteLine("[inetd] Connecting to network...");
|
||||
Console.WriteLine("{MISC_CONNECTINGTONETWORK}");
|
||||
|
||||
Ready = false;
|
||||
|
||||
|
@ -192,28 +173,9 @@ namespace ShiftOS.Engine
|
|||
{
|
||||
//Connection successful! Stop waiting!
|
||||
guidReceived = true;
|
||||
Console.WriteLine("[inetd] Connection successful.");
|
||||
Console.WriteLine("{INIT_CONNECTIONSUCCESSFUL}");
|
||||
Thread.Sleep(100);
|
||||
if (loadingJoke2 == 0)
|
||||
Console.WriteLine("[sos] Running final checks (gotta be sure!)...");
|
||||
if (loadingJoke2 == 1)
|
||||
Console.WriteLine("[sos] Fixing the time because we think we got it wrong...");
|
||||
if (loadingJoke2 == 2)
|
||||
Console.WriteLine("[sos] Fun Fact: there is a 12% chance you will read this...");
|
||||
if (loadingJoke2 == 3)
|
||||
Console.WriteLine("[sos] Fixing sloppy code...");
|
||||
if (loadingJoke2 == 4)
|
||||
Console.WriteLine("[sos] Welcoming new users...");
|
||||
if (loadingJoke2 == 5)
|
||||
Console.WriteLine("[sos] Taking inspiration from GMod...");
|
||||
if (loadingJoke2 == 6)
|
||||
Console.WriteLine("[sos] Getting help...");
|
||||
if (loadingJoke2 == 7)
|
||||
Console.WriteLine("[sos] I'm very clevery guy...");
|
||||
if (loadingJoke2 == 8)
|
||||
Console.WriteLine("[sos] Waiting a bit...");
|
||||
if (loadingJoke2 == 9)
|
||||
Console.WriteLine("[sos] Do a digital dancing...");
|
||||
Console.WriteLine("{MISC_LOADINGMSG2_" + loadingJoke2 + "}");
|
||||
Thread.Sleep(500);
|
||||
};
|
||||
|
||||
|
@ -227,12 +189,12 @@ namespace ShiftOS.Engine
|
|||
{
|
||||
Thread.Sleep(10);
|
||||
}
|
||||
Console.WriteLine("[inetd] DHCP GUID recieved, finished setup");
|
||||
Console.WriteLine("{MISC_DHCPHANDSHAKEFINISHED}");
|
||||
FinishBootstrap();
|
||||
}
|
||||
else
|
||||
{
|
||||
Console.WriteLine("[inetd] No suitable network interface card found, skipping network connection.");
|
||||
Console.WriteLine("{MISC_NONETWORK}");
|
||||
FinishBootstrap();
|
||||
}
|
||||
}
|
||||
|
@ -259,7 +221,7 @@ namespace ShiftOS.Engine
|
|||
}
|
||||
else
|
||||
{
|
||||
Console.WriteLine("[inetd] Sandbox mode initiating...");
|
||||
Console.WriteLine("{MISC_SANDBOXMODE}");
|
||||
CurrentSave = new Save
|
||||
{
|
||||
IsSandbox = true,
|
||||
|
@ -328,8 +290,6 @@ namespace ShiftOS.Engine
|
|||
/// </summary>
|
||||
private static void FinishBootstrap()
|
||||
{
|
||||
KernelWatchdog.Log("mud_handshake", "handshake successful: kernel watchdog access code is \"" + ServerManager.thisGuid.ToString() + "\"");
|
||||
|
||||
ServerMessageReceived savehandshake = null;
|
||||
|
||||
savehandshake = (msg) =>
|
||||
|
@ -343,7 +303,7 @@ namespace ShiftOS.Engine
|
|||
}
|
||||
catch
|
||||
{
|
||||
Console.WriteLine("[system] [SEVERE] Cannot parse configuration file.");
|
||||
Console.WriteLine("{ENGINE_CANNOTLOADSAVE}");
|
||||
oobe.PromptForLogin();
|
||||
}
|
||||
}
|
||||
|
@ -373,7 +333,7 @@ namespace ShiftOS.Engine
|
|||
Thread.Sleep(75);
|
||||
|
||||
Thread.Sleep(50);
|
||||
Console.WriteLine("[usr-man] Accepting logins on local tty 1.");
|
||||
Console.WriteLine("{MISC_ACCEPTINGLOGINS}");
|
||||
|
||||
Sysname:
|
||||
bool waitingForNewSysName = false;
|
||||
|
@ -381,16 +341,16 @@ namespace ShiftOS.Engine
|
|||
|
||||
if (string.IsNullOrWhiteSpace(CurrentSave.SystemName))
|
||||
{
|
||||
Infobox.PromptText("Enter a system name", "Your system does not have a name. All systems within the digital society must have a name. Please enter one.", (name) =>
|
||||
Infobox.PromptText("{TITLE_ENTERSYSNAME}", "{PROMPT_ENTERSYSNAME}", (name) =>
|
||||
{
|
||||
if (string.IsNullOrWhiteSpace(name))
|
||||
Infobox.Show("Invalid name", "Please enter a valid name.", () =>
|
||||
Infobox.Show("{TITLE_INVALIDNAME}", "{PROMPT_INVALIDNAME}.", () =>
|
||||
{
|
||||
gobacktosysname = true;
|
||||
waitingForNewSysName = false;
|
||||
});
|
||||
else if (name.Length < 5)
|
||||
Infobox.Show("Value too small.", "Your system name must have at least 5 characters in it.", () =>
|
||||
Infobox.Show("{TITLE_VALUESMALL}", "{PROMPT_SMALLSYSNAME}", () =>
|
||||
{
|
||||
gobacktosysname = true;
|
||||
waitingForNewSysName = false;
|
||||
|
@ -398,11 +358,6 @@ namespace ShiftOS.Engine
|
|||
else
|
||||
{
|
||||
CurrentSave.SystemName = name;
|
||||
if (!string.IsNullOrWhiteSpace(CurrentSave.UniteAuthToken))
|
||||
{
|
||||
var unite = new Unite.UniteClient("http://getshiftos.ml", CurrentSave.UniteAuthToken);
|
||||
unite.SetSysName(name);
|
||||
}
|
||||
SaveSystem.SaveGame();
|
||||
gobacktosysname = false;
|
||||
waitingForNewSysName = false;
|
||||
|
@ -429,18 +384,18 @@ namespace ShiftOS.Engine
|
|||
`-:/++++::.`
|
||||
.+ydNMMMMMNNMMMMMNhs/.
|
||||
/yNMMmy+:-` `````.-/ohNMMms-
|
||||
`oNMMh/.`:oydmNMMMMNmhs+- .+dMMm+` Welcome to ShiftOS.
|
||||
`oNMMh/.`:oydmNMMMMNmhs+- .+dMMm+` {{GEN_WELCOME}}
|
||||
`oMMmo``+dMMMMMMMMMMMMMMMMMNh/`.sNMN+
|
||||
:NMN+ -yMMMMMMMNdhyssyyhdmNMMMMNs``sMMd. SYSTEM STATUS:
|
||||
:NMN+ -yMMMMMMMNdhyssyyhdmNMMMMNs``sMMd. {{GEN_SYSTEMSTATUS}}
|
||||
oMMd.`sMMMMMMd+. `/MMMMN+ -mMN: ----------------------
|
||||
oMMh .mMMMMMM/ `-::::-.` :MMMMMMh`.mMM:
|
||||
:MMd .NMMMMMMs .dMMMMMMMMMNddMMMMMMMd`.NMN. Codepoints: {SaveSystem.CurrentSave.Codepoints}
|
||||
mMM. dMMMMMMMo -mMMMMMMMMMMMMMMMMMMMMs /MMy Upgrades: {SaveSystem.CurrentSave.CountUpgrades()} installed
|
||||
:MMh :MMMMMMMMm` .+shmMMMMMMMMMMMMMMMN` NMN` {Shiftorium.GetAvailable().Count()} available
|
||||
oMM+ sMMMMMMMMMN+` `-/smMMMMMMMMMMM: hMM: Filesystems: {Utils.Mounts.Count} filesystems mounted in memory.
|
||||
:MMd .NMMMMMMs .dMMMMMMMMMNddMMMMMMMd`.NMN. {{GEN_CODEPOINTS}}: {SaveSystem.CurrentSave.Codepoints}
|
||||
mMM. dMMMMMMMo -mMMMMMMMMMMMMMMMMMMMMs /MMy
|
||||
:MMh :MMMMMMMMm` .+shmMMMMMMMMMMMMMMMN` NMN`
|
||||
oMM+ sMMMMMMMMMN+` `-/smMMMMMMMMMMM: hMM:
|
||||
sMM+ sMMMMMMMMMMMMds/-` .sMMMMMMMMM/ yMM/
|
||||
+MMs +MMMMMMMMMMMMMMMMMmhs:` +MMMMMMMM- dMM- System name: {CurrentSave.SystemName.ToUpper()}
|
||||
.MMm `NMMMMMMMMMMMMMMMMMMMMMo `NMMMMMMd .MMN Users: {Users.Count()} found.
|
||||
+MMs +MMMMMMMMMMMMMMMMMmhs:` +MMMMMMMM- dMM- {{GEN_SYSTEMNAME}}: {CurrentSave.SystemName.ToUpper()}
|
||||
.MMm `NMMMMMMMMMMMMMMMMMMMMMo `NMMMMMMd .MMN {{GEN_USERS}}: {Users.Count()}.
|
||||
hMM+ +MMMMMMmsdNMMMMMMMMMMN/ -MMMMMMN- yMM+
|
||||
`NMN- oMMMMMd `-/+osso+- .mMMMMMN: +MMd
|
||||
-NMN: /NMMMm` :yMMMMMMm- oMMd`
|
||||
|
@ -460,7 +415,7 @@ namespace ShiftOS.Engine
|
|||
Password = "",
|
||||
Permissions = UserPermissions.Root
|
||||
});
|
||||
Console.WriteLine("[usr-man] WARN: No users found. Creating new user with username \"root\", with no password.");
|
||||
Console.WriteLine("{MISC_NOUSERS}");
|
||||
}
|
||||
TerminalBackend.InStory = false;
|
||||
|
||||
|
@ -492,18 +447,21 @@ namespace ShiftOS.Engine
|
|||
int progress = 0;
|
||||
bool goback = false;
|
||||
TextSentEventHandler ev = null;
|
||||
string loginstr = Localization.Parse("{GEN_LPROMPT}", new Dictionary<string, string>
|
||||
{
|
||||
["%sysname"] = CurrentSave.SystemName
|
||||
});
|
||||
ev = (text) =>
|
||||
{
|
||||
if (progress == 0)
|
||||
{
|
||||
string loginstr = CurrentSave.SystemName + " login: ";
|
||||
string getuser = text.Remove(0, loginstr.Length);
|
||||
if (!string.IsNullOrWhiteSpace(getuser))
|
||||
{
|
||||
if (CurrentSave.Users.FirstOrDefault(x => x.Username == getuser) == null)
|
||||
{
|
||||
Console.WriteLine();
|
||||
Console.WriteLine("User not found.");
|
||||
Console.WriteLine("{ERR_NOUSER}");
|
||||
goback = true;
|
||||
progress++;
|
||||
TerminalBackend.TextSent -= ev;
|
||||
|
@ -515,7 +473,7 @@ namespace ShiftOS.Engine
|
|||
else
|
||||
{
|
||||
Console.WriteLine();
|
||||
Console.WriteLine("Username not provided.");
|
||||
Console.WriteLine("{ERR_NOUSER}");
|
||||
TerminalBackend.TextSent -= ev;
|
||||
goback = true;
|
||||
progress++;
|
||||
|
@ -523,20 +481,20 @@ namespace ShiftOS.Engine
|
|||
}
|
||||
else if (progress == 1)
|
||||
{
|
||||
string passwordstr = "password: ";
|
||||
string passwordstr = Localization.Parse("{GEN_PASSWORD}: ");
|
||||
string getpass = text.Remove(0, passwordstr.Length);
|
||||
var user = CurrentSave.Users.FirstOrDefault(x => x.Username == username);
|
||||
if (user.Password == getpass)
|
||||
{
|
||||
Console.WriteLine();
|
||||
Console.WriteLine("Welcome to ShiftOS.");
|
||||
Console.WriteLine("{GEN_WELCOME}");
|
||||
CurrentUser = user;
|
||||
progress++;
|
||||
}
|
||||
else
|
||||
{
|
||||
Console.WriteLine();
|
||||
Console.WriteLine("Access denied.");
|
||||
Console.WriteLine("{RES_DENIED}");
|
||||
goback = true;
|
||||
progress++;
|
||||
}
|
||||
|
@ -545,7 +503,7 @@ namespace ShiftOS.Engine
|
|||
};
|
||||
TerminalBackend.TextSent += ev;
|
||||
Console.WriteLine();
|
||||
Console.Write(CurrentSave.SystemName + " login: ");
|
||||
Console.Write(loginstr);
|
||||
ConsoleEx.Flush();
|
||||
while (progress == 0)
|
||||
{
|
||||
|
@ -554,7 +512,7 @@ namespace ShiftOS.Engine
|
|||
if (goback)
|
||||
goto Login;
|
||||
Console.WriteLine();
|
||||
Console.Write("password: ");
|
||||
Console.Write("{GEN_PASSWORD}: ");
|
||||
ConsoleEx.Flush();
|
||||
while (progress == 1)
|
||||
Thread.Sleep(10);
|
||||
|
|
|
@ -19,14 +19,14 @@ namespace ShiftOS.Engine
|
|||
/// </summary>
|
||||
/// <param name="args">Command arguments.</param>
|
||||
/// <returns>Command result.</returns>
|
||||
[Command("add", description = "Add a user to the system.", usage ="name:")]
|
||||
[Command("adduser", description = "{DESC_ADDUSER}")]
|
||||
[RequiresArgument("name")]
|
||||
public static bool AddUser(Dictionary<string, object> args)
|
||||
{
|
||||
string name = args["name"].ToString();
|
||||
if(SaveSystem.CurrentSave.Users.FirstOrDefault(x=>x.Username==name) != null)
|
||||
if (SaveSystem.CurrentSave.Users.FirstOrDefault(x => x.Username == name) != null)
|
||||
{
|
||||
Console.WriteLine("Error: User already exists.");
|
||||
Console.WriteLine("{ERR_USERFOUND}");
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -37,7 +37,10 @@ namespace ShiftOS.Engine
|
|||
Permissions = UserPermissions.User
|
||||
};
|
||||
SaveSystem.CurrentSave.Users.Add(user);
|
||||
Console.WriteLine($"Creating new user \"{name}\" with no password and User permissions.");
|
||||
Console.WriteLine(Localization.Parse("{RES_CREATINGUSER}", new Dictionary<string, string>
|
||||
{
|
||||
{ "%name", name }
|
||||
}));
|
||||
SaveSystem.SaveGame();
|
||||
return true;
|
||||
}
|
||||
|
@ -48,25 +51,28 @@ namespace ShiftOS.Engine
|
|||
/// <param name="args">Command arguments.</param>
|
||||
/// <returns>Command result.</returns>
|
||||
|
||||
[Command("remove", description = "Remove a user from the system.", usage = "name:")]
|
||||
[Command("removeuser", description = "{DESC_REMOVEUSER}")]
|
||||
[RequiresArgument("name")]
|
||||
public static bool RemoveUser(Dictionary<string, object> args)
|
||||
{
|
||||
string name = args["name"].ToString();
|
||||
if (SaveSystem.CurrentSave.Users.FirstOrDefault(x => x.Username == name) == null)
|
||||
{
|
||||
Console.WriteLine("Error: User doesn't exist.");
|
||||
Console.WriteLine("{ERR_NOUSER}");
|
||||
return true;
|
||||
}
|
||||
|
||||
var user = SaveSystem.CurrentSave.Users.FirstOrDefault(x => x.Username == name);
|
||||
if(user.Username != SaveSystem.CurrentUser.Username)
|
||||
if (user.Username != SaveSystem.CurrentUser.Username)
|
||||
{
|
||||
Console.WriteLine("Error: Cannot remove yourself.");
|
||||
Console.WriteLine("{ERR_REMOVEYOU}");
|
||||
return true;
|
||||
}
|
||||
SaveSystem.CurrentSave.Users.Remove(user);
|
||||
Console.WriteLine($"Removing user \"{name}\" from system...");
|
||||
Console.WriteLine(Localization.Parse("{RES_REMOVINGUSER}", new Dictionary<string, string>
|
||||
{
|
||||
["%name"] = name
|
||||
}));
|
||||
SaveSystem.SaveGame();
|
||||
return true;
|
||||
}
|
||||
|
@ -79,7 +85,7 @@ namespace ShiftOS.Engine
|
|||
/// <param name="args">Command arguments.</param>
|
||||
/// <returns>Command result.</returns>
|
||||
|
||||
[Command("set_acl")]
|
||||
[Command("setuserpermissions", description = "{DESC_SETUSERPERMISSIONS}")]
|
||||
[RequiresArgument("user")]
|
||||
[RequiresArgument("val")]
|
||||
public static bool SetUserPermission(Dictionary<string, object> args)
|
||||
|
@ -92,13 +98,13 @@ namespace ShiftOS.Engine
|
|||
}
|
||||
catch
|
||||
{
|
||||
Console.WriteLine("Error: Permission value must be an integer.");
|
||||
Console.WriteLine("{ERR_BADACL}");
|
||||
return true;
|
||||
}
|
||||
|
||||
if(SaveSystem.CurrentSave.Users.FirstOrDefault(x=>x.Username==username) == null)
|
||||
{
|
||||
Console.WriteLine("Error: User not found.");
|
||||
Console.WriteLine("{ERR_NOUSER}");
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -119,26 +125,26 @@ namespace ShiftOS.Engine
|
|||
uperm = UserPermissions.Root;
|
||||
break;
|
||||
default:
|
||||
Console.WriteLine("Permission value must be between 0 and 4.");
|
||||
Console.WriteLine("{ERR_BADACL}");
|
||||
return true;
|
||||
}
|
||||
|
||||
//Permissions are backwards... oops...
|
||||
if(uperm < SaveSystem.CurrentUser.Permissions)
|
||||
{
|
||||
Console.WriteLine("Error: Cannot set user permissions to values greater than your own!");
|
||||
Console.WriteLine("{ERR_ACLHIGHERVALUE}");
|
||||
return true;
|
||||
}
|
||||
|
||||
var oldperm = SaveSystem.Users.FirstOrDefault(x => x.Username == username).Permissions;
|
||||
if (SaveSystem.CurrentUser.Permissions > oldperm)
|
||||
{
|
||||
Console.WriteLine("Error: Can't set the permission of this user. They have more rights than you.");
|
||||
Console.WriteLine("{ERR_HIGHERPERMS}");
|
||||
return true;
|
||||
}
|
||||
|
||||
SaveSystem.CurrentSave.Users.FirstOrDefault(x => x.Username == username).Permissions = uperm;
|
||||
Console.WriteLine("User permissions updated.");
|
||||
Console.WriteLine("{RES_ACLUPDATED}");
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -148,7 +154,7 @@ namespace ShiftOS.Engine
|
|||
/// <param name="args">Command arguments.</param>
|
||||
/// <returns>Command result.</returns>
|
||||
|
||||
[Command("users", description = "Get a list of all users on the system.")]
|
||||
[Command("users", description = "{DESC_USERS}")]
|
||||
public static bool GetUsers()
|
||||
{
|
||||
foreach (var u in SaveSystem.CurrentSave.Users)
|
||||
|
@ -180,7 +186,7 @@ namespace ShiftOS.Engine
|
|||
/// </summary>
|
||||
/// <param name="args">Command arguments.</param>
|
||||
/// <returns>Command result.</returns>
|
||||
[Command("login", description = "Log in as another user.")]
|
||||
[Command("su", description = "{DESC_SU}")]
|
||||
[RequiresArgument("user")]
|
||||
[RequiresArgument("pass")]
|
||||
public static bool Login(Dictionary<string, object> args)
|
||||
|
@ -191,18 +197,18 @@ namespace ShiftOS.Engine
|
|||
var usr = SaveSystem.CurrentSave.Users.FirstOrDefault(x => x.Username == user);
|
||||
if(usr==null)
|
||||
{
|
||||
Console.WriteLine("Error: No such user.");
|
||||
Console.WriteLine("{ERR_NOUSER}");
|
||||
return true;
|
||||
}
|
||||
|
||||
if (usr.Password != pass)
|
||||
{
|
||||
Console.WriteLine("Access denied.");
|
||||
Console.WriteLine("{RES_DENIED}");
|
||||
return true;
|
||||
}
|
||||
|
||||
SaveSystem.CurrentUser = usr;
|
||||
Console.WriteLine("Access granted.");
|
||||
Console.WriteLine("{RES_GRANTED}");
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -211,7 +217,7 @@ namespace ShiftOS.Engine
|
|||
/// </summary>
|
||||
/// <param name="args">Command arguments.</param>
|
||||
/// <returns>Command result.</returns>
|
||||
[Command("setpass", description ="Allows you to set your password to a new value.", usage ="old:,new:")]
|
||||
[Command("passwd", description ="{DESC_PASSWD}", usage ="old:,new:")]
|
||||
[RequiresArgument("old")]
|
||||
[RequiresArgument("new")]
|
||||
public static bool SetPassword(Dictionary<string, object> args)
|
||||
|
@ -223,12 +229,12 @@ namespace ShiftOS.Engine
|
|||
{
|
||||
SaveSystem.CurrentUser.Password = newpass;
|
||||
SaveSystem.CurrentSave.Users.FirstOrDefault(x => x.Username == SaveSystem.CurrentUser.Username).Password = newpass;
|
||||
Console.WriteLine("Password set successfully.");
|
||||
Console.WriteLine("{RES_PASSWD_SET}");
|
||||
SaveSystem.SaveGame();
|
||||
}
|
||||
else
|
||||
{
|
||||
Console.WriteLine("Passwords do not match.");
|
||||
Console.WriteLine("{ERR_PASSWD_MISMATCH}");
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
|
Reference in a new issue