Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add language support for Simula #7025

Open
wants to merge 9 commits into
base: main
Choose a base branch
from
3 changes: 3 additions & 0 deletions .gitmodules
Original file line number Diff line number Diff line change
Expand Up @@ -1371,6 +1371,9 @@
[submodule "vendor/grammars/vscode-scala-syntax"]
path = vendor/grammars/vscode-scala-syntax
url = https://github.com/scala/vscode-scala-syntax
[submodule "vendor/grammars/vscode-simula"]
path = vendor/grammars/vscode-simula
url = https://github.com/eirslett/vscode-simula.git
[submodule "vendor/grammars/vscode-singularity"]
path = vendor/grammars/vscode-singularity
url = https://github.com/onnovalkering/vscode-singularity
Expand Down
2 changes: 2 additions & 0 deletions grammars.yml
Original file line number Diff line number Diff line change
Expand Up @@ -1234,6 +1234,8 @@ vendor/grammars/vscode-ron:
- source.ron
vendor/grammars/vscode-scala-syntax:
- source.scala
vendor/grammars/vscode-simula:
- source.sim
vendor/grammars/vscode-singularity:
- source.singularity
vendor/grammars/vscode-slice:
Expand Down
6 changes: 6 additions & 0 deletions lib/linguist/heuristics.yml
Original file line number Diff line number Diff line change
Expand Up @@ -697,6 +697,12 @@ disambiguations:
- language: Markdown
# Markdown syntax for scdoc
pattern: '^#+\s+(NAME|SYNOPSIS|DESCRIPTION)'
- extensions: ['.sim']
rules:
- language: Simula
pattern: '(?i)\bbegin\b.*?\bend\b'
- language: YAML
pattern: '^[\{\[]'
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We also need a test for this heuristic

- extensions: ['.sol']
rules:
- language: Solidity
Expand Down
15 changes: 15 additions & 0 deletions lib/linguist/languages.yml
Original file line number Diff line number Diff line change
Expand Up @@ -1635,6 +1635,7 @@ Dockerfile:
filenames:
- Containerfile
- Dockerfile
- Dockerfile.sim
ace_mode: dockerfile
codemirror_mode: dockerfile
codemirror_mime_type: text/x-dockerfile
Expand Down Expand Up @@ -4204,6 +4205,7 @@ Makefile:
- Makefile.frag
- Makefile.in
- Makefile.inc
- Makefile.sim
- Makefile.wat
- makefile
- makefile.sco
Expand Down Expand Up @@ -6821,6 +6823,18 @@ Simple File Verification:
codemirror_mode: properties
codemirror_mime_type: text/x-properties
language_id: 735623761
Simula:
type: programming
color: "#B22F2F"
extensions:
- ".sim"
aliases:
- sim
tm_scope: source.simula
eirslett marked this conversation as resolved.
Show resolved Hide resolved
ace_mode: simula
codemirror_mode: simula
codemirror_mime_type: text/x-simula
language_id: 582204041
Singularity:
type: programming
color: "#64E6AD"
Expand Down Expand Up @@ -8245,6 +8259,7 @@ YAML:
- ".mir"
- ".reek"
- ".rviz"
- ".sim"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We need a sample for this language if you're going to add this extension here.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We need a sample for this language if you're going to add this extension here.

I'm not 100 % what you meant - was this about the Simula language, or about the YAML fallback?

I made 2 updates to the pull request:

  1. Pushed 5 more Simula language code samples
  2. Added an example of an existing .sim file on GitHub which would make sense to code-highlight as YAML (it's JSON, but all JSON is valid YAML).

It would be nice if linguist supported a "noop fallback" configuration, where - if we can't positively identify a .sim file as valid Simula code - it would just be treated as unknown text format.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I was referring to the YAML entry. You added it but didn't add a sample.

I see you've now added samples but you've now also added samples that are too big. Please remove any that are suppressed in the diff and any that aren't real world uses.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ok, I removed the samples!

- ".sublime-syntax"
- ".syntax"
- ".yaml"
Expand Down
17 changes: 17 additions & 0 deletions samples/Simula/BottlesOfBeer.sim
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
! License: MIT;
begin
integer i;
for i := 99 step -1 until 1 do
begin
outint(i, 2);
outtext(" bottles of beer on the wall, ");
outint(i, 2);
outtext(" bottles of beer.");
outimage;
outtext("Take one down and pass it around, ");
outint(i - 1, 2);
outtext(" bottles of beer on the wall.");
outimage;
end;
outtext("No more bottles of beer on the wall, no more bottles of beer.");
end-let's-drink;
108 changes: 108 additions & 0 deletions samples/Simula/TicTacToe.sim
Original file line number Diff line number Diff line change
@@ -0,0 +1,108 @@
! A simple Tic-Tac-Toe game. License: MIT;
begin
ref(TicTacToe) game;
character player;

class TicTacToe;
begin
character array board(1:9);

procedure placeMark(mark, position);
value mark, position;
character mark; integer position;
begin
board(position) := mark;
end-of-place-mark;

boolean procedure checkWinner(player);
value player;
character player;
begin
integer position;
comment
There are 8 possible ways to win: 3 rows, 3 columns, and 2 diagonals.
For reasons of laziness, we just AI-generate them:
;
if board(1) = player and board(2) = player and board(3) = player then
checkWinner := true
else if board(4) = player and board(5) = player and board(6) = player then
checkWinner := true
else if board(7) = player and board(8) = player and board(9) = player then
checkWinner := true
else if board(1) = player and board(4) = player and board(7) = player then
checkWinner := true
else if board(2) = player and board(5) = player and board(8) = player then
checkWinner := true
else if board(3) = player and board(6) = player and board(9) = player then
checkWinner := true
else if board(1) = player and board(5) = player and board(9) = player then
checkWinner := true
else if board(3) = player and board(5) = player and board(7) = player then
checkWinner := true
else
checkWinner := false;
end-of-checkWinner;

character procedure winner;
begin
if checkWinner('X') then winner := 'X'
else if checkWinner('O') then winner := 'O'
else winner := ' ';
end-of-winner;

procedure DrawTopBottom; begin
OutText("+---+---+---+");
OutImage;
end;

procedure draw;
begin
integer row;
OutImage;
DrawTopBottom;
for row := 0 step 1 until 2 do begin
OutText("| " );
OutChar(board(row * 3 + 1));
OutText(" | " );
OutChar(board(row * 3 + 2));
OutText(" | " );
OutChar(board(row * 3 + 3));
OutText(" |");
OutImage;
DrawTopBottom;
end
end-of-draw;

!populate the board with number placeholders;
board(1) := '1';
board(2) := '2';
board(3) := '3';
board(4) := '4';
board(5) := '5';
board(6) := '6';
board(7) := '7';
board(8) := '8';
board(9) := '9';
end-of-TicTacToe;


game :- new TicTacToe;
player := 'X';

while game.winner <> 'X' and game.winner <> 'O' do
begin
game.draw;
OutText("Player ");
OutChar(player);
OutText(" enter position: ");
OutImage;
game.placeMark(player, InInt);
if player = 'X' then player := 'O' else player := 'X';
end;

game.draw;

OutText("The winner is: player ");
OutChar(game.winner);
OutImage;
end-of-program
Loading