Compare commits
No commits in common. "7e00e238015660ad52fc768f842a7d71d8e8ec42" and "dbc5105b9b897f83fb4ced101f40b3cc95141ff4" have entirely different histories.
7e00e23801
...
dbc5105b9b
3
.gitignore
vendored
3
.gitignore
vendored
@ -10,4 +10,5 @@
|
|||||||
/*.sh~
|
/*.sh~
|
||||||
/*.img
|
/*.img
|
||||||
src/include/asuro.pas
|
src/include/asuro.pas
|
||||||
localenv.json
|
.vscode/launch.json
|
||||||
|
.vscode
|
||||||
|
13
.vscode/launch.json
vendored
13
.vscode/launch.json
vendored
@ -3,11 +3,18 @@
|
|||||||
{
|
{
|
||||||
"name":"Run",
|
"name":"Run",
|
||||||
"request": "launch",
|
"request": "launch",
|
||||||
"type": "PowerShell",
|
"type": "coreclr",
|
||||||
"preLaunchTask": "Build",
|
"preLaunchTask": "Build",
|
||||||
"script": "${workspaceFolder}/virtualbox-wrapper.ps1",
|
"program": "VBoxSDL",
|
||||||
"args": ["-Command", "up"],
|
"args": [
|
||||||
|
"--comment",
|
||||||
|
"Asuro",
|
||||||
|
"--startvm",
|
||||||
|
"7d395c96-891c-4139-b77d-9b6b144b0b93"
|
||||||
|
],
|
||||||
"cwd": "${workspaceFolder}",
|
"cwd": "${workspaceFolder}",
|
||||||
|
"console": "internalConsole",
|
||||||
|
"internalConsoleOptions": "neverOpen"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
26
.vscode/tasks.json
vendored
26
.vscode/tasks.json
vendored
@ -9,18 +9,14 @@
|
|||||||
"command": "docker-compose",
|
"command": "docker-compose",
|
||||||
"args": [
|
"args": [
|
||||||
"run",
|
"run",
|
||||||
"builder",
|
"builder"
|
||||||
],
|
],
|
||||||
"type": "shell",
|
"type": "shell",
|
||||||
"problemMatcher": [],
|
"problemMatcher": [],
|
||||||
"group": {
|
"group": {
|
||||||
"kind": "build",
|
"kind": "build",
|
||||||
"isDefault": true
|
"isDefault": true
|
||||||
},
|
}
|
||||||
"dependsOn": [
|
|
||||||
"Close VirtualBox",
|
|
||||||
"Clean"
|
|
||||||
]
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"label": "Build (Builder)",
|
"label": "Build (Builder)",
|
||||||
@ -30,24 +26,6 @@
|
|||||||
"builder"
|
"builder"
|
||||||
],
|
],
|
||||||
"type": "shell"
|
"type": "shell"
|
||||||
},
|
|
||||||
{
|
|
||||||
"label": "Clean",
|
|
||||||
"command": "docker-compose",
|
|
||||||
"args": [
|
|
||||||
"down",
|
|
||||||
"--remove-orphans"
|
|
||||||
],
|
|
||||||
"type": "shell"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"label": "Close VirtualBox",
|
|
||||||
"command": "./virtualbox-wrapper.ps1",
|
|
||||||
"args": [
|
|
||||||
"-Command",
|
|
||||||
"down"
|
|
||||||
],
|
|
||||||
"type": "shell"
|
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
@ -1,3 +1,4 @@
|
|||||||
|
version: "3.9"
|
||||||
services:
|
services:
|
||||||
builder:
|
builder:
|
||||||
build: .
|
build: .
|
||||||
|
41
readme.md
41
readme.md
@ -13,8 +13,8 @@ We welcome everyone to give building/breaking/fixing/shooting Asuro a go, feel f
|
|||||||
I don't think this needs an explaination.
|
I don't think this needs an explaination.
|
||||||
* [VSCode (Optional, but highly recommended)](https://code.visualstudio.com/)
|
* [VSCode (Optional, but highly recommended)](https://code.visualstudio.com/)
|
||||||
Visual Studio code is our IDE of choice, and we have a number of recommended plugins.
|
Visual Studio code is our IDE of choice, and we have a number of recommended plugins.
|
||||||
* [PowerShell Plugin by Microsoft](https://marketplace.visualstudio.com/items?itemName=ms-vscode.powershell)
|
* [C# Plugin by Microsoft](https://marketplace.visualstudio.com/items?itemName=ms-dotnettools.csharp)
|
||||||
This plugin gives you the ability to use the 'PowerShell' task type, allowing the automatic launching of virtualbox with the resulting image generated during compilation of Asuro.
|
This plugin gives you the ability to use the 'coreclr' task type, allowing the automatic launching of virtualbox with the resulting image generated during compilation of Asuro.
|
||||||
* [VirtualBox](https://www.virtualbox.org/)
|
* [VirtualBox](https://www.virtualbox.org/)
|
||||||
Virtualbox is our Virtualisation environment of choice, don't ask why, it just is.
|
Virtualbox is our Virtualisation environment of choice, don't ask why, it just is.
|
||||||
|
|
||||||
@ -27,7 +27,7 @@ We welcome everyone to give building/breaking/fixing/shooting Asuro a go, feel f
|
|||||||
3. Install Docker for Windows.
|
3. Install Docker for Windows.
|
||||||
4. Install Git for Windows.
|
4. Install Git for Windows.
|
||||||
5. Install VSCode & the listed plugins.
|
5. Install VSCode & the listed plugins.
|
||||||
6. Install VirtualBox (v7+).
|
6. Install VirtualBox.
|
||||||
7. Clone this repository.
|
7. Clone this repository.
|
||||||
8. Run the following command in the root of the repo to build the docker image:
|
8. Run the following command in the root of the repo to build the docker image:
|
||||||
```powershell
|
```powershell
|
||||||
@ -50,29 +50,32 @@ We welcome everyone to give building/breaking/fixing/shooting Asuro a go, feel f
|
|||||||
```xml
|
```xml
|
||||||
<Machine uuid="{7d395c96-891c-4139-b77d-9b6b144b0b93}" name="Asuro" OSType="Linux" snapshotFolder="Snapshots" lastStateChange="2021-06-20T20:33:07Z">
|
<Machine uuid="{7d395c96-891c-4139-b77d-9b6b144b0b93}" name="Asuro" OSType="Linux" snapshotFolder="Snapshots" lastStateChange="2021-06-20T20:33:07Z">
|
||||||
```
|
```
|
||||||
Copy the uuid, in our case `7d395c96-891c-4139-b77d-9b6b144b0b93` & create a `localenv.json` file in the project root with the following content:
|
Copy the uuid, in our case `7d395c96-891c-4139-b77d-9b6b144b0b93` and replace the uuid found in `.vscode\launch.json` under `args`, so that it looks something like this:
|
||||||
```json
|
```json
|
||||||
{
|
{
|
||||||
"VirtualBox":{
|
"configurations": [
|
||||||
"MachineName":"<YOUR_UUID_OR_MACHINE_NAME>"
|
{
|
||||||
|
"name":"Run",
|
||||||
|
"request": "launch",
|
||||||
|
"type": "coreclr",
|
||||||
|
"preLaunchTask": "Build",
|
||||||
|
"program": "VBoxSDL",
|
||||||
|
"args": [
|
||||||
|
"--comment",
|
||||||
|
"Asuro",
|
||||||
|
"--startvm",
|
||||||
|
"<YOUR UUID HERE>"
|
||||||
|
],
|
||||||
|
"cwd": "${workspaceFolder}",
|
||||||
|
"console": "internalConsole",
|
||||||
|
"internalConsoleOptions": "neverOpen"
|
||||||
}
|
}
|
||||||
|
]
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
This will allow VSCode to automatically launch VirtualBox once Asuro has been compiled.
|
This will allow VSCode to automatically launch VirtualBox once Asuro has been compiled.
|
||||||
|
|
||||||
You can also enable the serial adapter "COM1" in mode "Raw File", give it a path, and provide this path in the `localenv.json` as follows:
|
|
||||||
```json
|
|
||||||
{
|
|
||||||
"VirtualBox" : {
|
|
||||||
"MachineName": "<YOUR_UUID_OR_MACHINE_NAME>",
|
|
||||||
"LogLocation": "Fully\\Qualified\\Path\\To\\Your\\Log\\File"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||
This will allow you to see the console output from Asuro in your host terminal.
|
|
||||||
13. Open your project folder in VSCode, use CTRL+SHIFT+B to build & F5 to build + run in VBox.
|
13. Open your project folder in VSCode, use CTRL+SHIFT+B to build & F5 to build + run in VBox.
|
||||||
14. Congratulations! You can now play with Asuro!
|
14. Congratulations! You can now play with Asuro!
|
||||||
|
|
||||||
### Notes & Gotchas
|
### Gotchas
|
||||||
- The above process has been updated to be compatible with VirtualBox 7+, in which VBoxSDL was removed and vboxmanage should be used in its place. A small wrapper powershell script is used to achieve this.
|
|
||||||
- It was noted that Windows builds above `20H2` seem to have issues installing WSL2. We may have to wait for a patch from Microsoft to fix this. Our devs are currently using build `20H2`.
|
- It was noted that Windows builds above `20H2` seem to have issues installing WSL2. We may have to wait for a patch from Microsoft to fix this. Our devs are currently using build `20H2`.
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -1,58 +0,0 @@
|
|||||||
<#
|
|
||||||
You need a local git-ignored localenv.json file with the following content:
|
|
||||||
{
|
|
||||||
"virtualbox": {
|
|
||||||
"MachineName": "your-machine-name or guid"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#>
|
|
||||||
|
|
||||||
param (
|
|
||||||
[Parameter(Mandatory=$true)]
|
|
||||||
[ValidateSet('up', 'down')]
|
|
||||||
[String]$Command
|
|
||||||
)
|
|
||||||
|
|
||||||
$Config = Get-Content .\localenv.json | ConvertFrom-Json
|
|
||||||
$MachineName = $Config.virtualbox.MachineName
|
|
||||||
$LogLocation = $Config.virtualbox.LogLocation
|
|
||||||
$LogOutputEnabled = $LogLocation -ne $null
|
|
||||||
|
|
||||||
if ($Command -eq 'up') {
|
|
||||||
|
|
||||||
if($LogOutputEnabled) {
|
|
||||||
Clear-Content $LogLocation
|
|
||||||
}
|
|
||||||
|
|
||||||
$MonitorJob = Start-Job -ArgumentList $MachineName -ScriptBlock {
|
|
||||||
param($MachineName)
|
|
||||||
Write-Output "Starting $MachineName"
|
|
||||||
VBoxManage.exe startvm $MachineName
|
|
||||||
$running=$true
|
|
||||||
while($running) {
|
|
||||||
$status=(VBoxManage.exe list runningvms)
|
|
||||||
if($status) {
|
|
||||||
$running=$status.contains($MachineName)
|
|
||||||
} else {
|
|
||||||
$running=$false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if($LogOutputEnabled) {
|
|
||||||
$LogJob = Start-Job -ArgumentList $LogLocation -ScriptBlock {
|
|
||||||
param($LogLocation)
|
|
||||||
Get-Content -Path $LogLocation -Wait
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
while($MonitorJob.State -eq 'Running') {
|
|
||||||
if($LogOutputEnabled) {
|
|
||||||
Receive-Job $LogJob
|
|
||||||
}
|
|
||||||
Receive-Job $MonitorJob
|
|
||||||
}
|
|
||||||
} elseif ($Command -eq 'down') {
|
|
||||||
Write-Output "Stopping $MachineName"
|
|
||||||
VBoxManage.exe controlvm $MachineName poweroff
|
|
||||||
}
|
|
Loading…
x
Reference in New Issue
Block a user