Skip to content

Commit

Permalink
[9.x] Adds ability to symlink directory in from skeleton to package (#…
Browse files Browse the repository at this point in the history
…283)

* wip

Signed-off-by: Mior Muhammad Zaki <crynobone@gmail.com>

* wip

Signed-off-by: Mior Muhammad Zaki <crynobone@gmail.com>

* [7.x] Adds ability to symlink directory in from skeleton to package

solved orchestral/workbench#64

Signed-off-by: Mior Muhammad Zaki <crynobone@gmail.com>

* wip

Signed-off-by: Mior Muhammad Zaki <crynobone@gmail.com>

---------

Signed-off-by: Mior Muhammad Zaki <crynobone@gmail.com>
  • Loading branch information
crynobone authored Dec 17, 2024
1 parent c45db6a commit 297aa85
Show file tree
Hide file tree
Showing 5 changed files with 20 additions and 8 deletions.
4 changes: 2 additions & 2 deletions src/Foundation/Config.php
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@
* auth: bool,
* welcome: bool|null,
* health: bool|null,
* sync: array<int, array{from: string, to: string}>,
* sync: array<int, array{from: string, to: string, reverse?: bool}>,
* build: array<int|string, array<string, mixed>|string>,
* assets: array<int, string>,
* discovers: TWorkbenchDiscoversConfig
Expand All @@ -56,7 +56,7 @@
* auth?: bool,
* welcome?: bool|null,
* health?: bool|null,
* sync?: array<int, array{from: string, to: string}>,
* sync?: array<int, array{from: string, to: string, reverse?: bool}>,
* build?: array<int|string, array<string, mixed>|string>,
* assets?: array<int, string>,
* discovers?: TWorkbenchOptionalDiscoversConfig
Expand Down
9 changes: 6 additions & 3 deletions src/Workbench/Actions/AddAssetSymlinkFolders.php
Original file line number Diff line number Diff line change
Expand Up @@ -32,16 +32,19 @@ public function __construct(
*/
public function handle(): void
{
/** @var array<int, array{from: string, to: string}> $sync */
/** @var array<int, array{from: string, to: string, reverse?: bool}> $sync */
$sync = $this->config->getWorkbenchAttributes()['sync'] ?? [];

Collection::make($sync)
->map(function ($pair) {
/** @var bool $reverse */
$reverse = isset($pair['reverse']) && \is_bool($pair['reverse']) ? $pair['reverse'] : false;

/** @var string $from */
$from = package_path($pair['from']);
$from = $reverse === false ? package_path($pair['from']) : base_path($pair['from']);

/** @var string $to */
$to = base_path($pair['to']);
$to = $reverse === false ? base_path($pair['to']) : package_path($pair['to']);

return $this->files->isDirectory($from)
? ['from' => $from, 'to' => $to]
Expand Down
9 changes: 6 additions & 3 deletions src/Workbench/Actions/RemoveAssetSymlinkFolders.php
Original file line number Diff line number Diff line change
Expand Up @@ -31,16 +31,19 @@ public function __construct(
*/
public function handle(): void
{
/** @var array<int, array{from: string, to: string}> $sync */
/** @var array<int, array{from: string, to: string, reverse?: bool}> $sync */
$sync = $this->config->getWorkbenchAttributes()['sync'] ?? [];

Collection::make($sync)
->map(static function ($pair) {
/** @var bool $reverse */
$reverse = isset($pair['reverse']) && \is_bool($pair['reverse']) ? $pair['reverse'] : false;

/** @var string $from */
$from = package_path($pair['from']);
$from = $reverse === false ? package_path($pair['from']) : base_path($pair['from']);

/** @var string $to */
$to = base_path($pair['to']);
$to = $reverse === false ? base_path($pair['to']) : package_path($pair['to']);

if (windows_os() && is_dir($to) && readlink($to) !== $to) {
return [$to, static function ($to) {
Expand Down
4 changes: 4 additions & 0 deletions testbench.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,10 @@ workbench:
api: true
commands: true
views: true
sync:
- from: storage
to: workbench/storage
reverse: true

purge:
files:
Expand Down
2 changes: 2 additions & 0 deletions workbench/.gitignore
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
.env
.env.dist
.env.example

/storage

0 comments on commit 297aa85

Please sign in to comment.