From b9294c0ab1a0bc5a5566a8c43d79f16b4c08b4e7 Mon Sep 17 00:00:00 2001 From: Raincloud Date: Sun, 28 Dec 2025 11:13:15 -0700 Subject: [PATCH] init --- .config/GetStructDir.ps1 | 68 ++++++++++++++++++++ .config/config.json | 7 +++ .cursorindexingignore | 3 + .gitattributes | 116 +++++++++++++++++++++++++++++++++++ .gitignore | 126 ++++++++++++++++++++++++++++++++++++++ .specstory/.gitignore | 4 ++ Renders/UnzipSeqArchv.bat | 42 +++++++++++++ Renders/ZipSeqArchv.bat | 44 +++++++++++++ 8 files changed, 410 insertions(+) create mode 100644 .config/GetStructDir.ps1 create mode 100644 .config/config.json create mode 100644 .cursorindexingignore create mode 100644 .gitattributes create mode 100644 .gitignore create mode 100644 .specstory/.gitignore create mode 100644 Renders/UnzipSeqArchv.bat create mode 100644 Renders/ZipSeqArchv.bat diff --git a/.config/GetStructDir.ps1 b/.config/GetStructDir.ps1 new file mode 100644 index 0000000..08be8d6 --- /dev/null +++ b/.config/GetStructDir.ps1 @@ -0,0 +1,68 @@ +# Simple helper script to get structDir from project config.json +# Reads config.json from .config folder in project root + +param( + [string]$ProjectRoot +) + +Set-StrictMode -Version Latest +$ErrorActionPreference = 'Stop' + +if ([string]::IsNullOrWhiteSpace($ProjectRoot)) { + # Try to determine project root from script location + if ($PSScriptRoot) { + $ProjectRoot = Split-Path -Parent $PSScriptRoot + } + elseif ($MyInvocation.MyCommand.Path) { + $ProjectRoot = Split-Path -Parent (Split-Path -Parent $MyInvocation.MyCommand.Path) + } + else { + Write-Error "Unable to determine project root. Please provide -ProjectRoot parameter." + exit 1 + } +} + +$configPath = Join-Path -Path $ProjectRoot -ChildPath '.config\config.json' + +if (-not (Test-Path -LiteralPath $configPath -PathType Leaf)) { + Write-Error "config.json not found at: $configPath" + exit 1 +} + +try { + $config = Get-Content -LiteralPath $configPath -Raw -ErrorAction Stop | ConvertFrom-Json + + if ($config.PSObject.Properties.Name -contains 'structDir') { + $structDir = $config.structDir + if ($null -ne $structDir -and ($structDir -isnot [string] -or $structDir.Trim().Length -gt 0)) { + # If it's an absolute path, resolve it + if ([System.IO.Path]::IsPathRooted($structDir)) { + $resolved = Resolve-Path -LiteralPath $structDir -ErrorAction SilentlyContinue + if ($null -ne $resolved) { + Write-Output $resolved.Path + exit 0 + } + Write-Output $structDir + exit 0 + } + # Relative path - resolve relative to config location + $candidate = Join-Path -Path (Split-Path -Parent $configPath) -ChildPath $structDir + $resolvedCandidate = Resolve-Path -LiteralPath $candidate -ErrorAction SilentlyContinue + if ($null -ne $resolvedCandidate) { + Write-Output $resolvedCandidate.Path + exit 0 + } + Write-Output $candidate + exit 0 + } + } + + # Default: return the directory containing config.json (project root) + Write-Output $ProjectRoot + exit 0 +} +catch { + Write-Error "Failed to read or parse config.json: $($_.Exception.Message)" + exit 1 +} + diff --git a/.config/config.json b/.config/config.json new file mode 100644 index 0000000..88e37fd --- /dev/null +++ b/.config/config.json @@ -0,0 +1,7 @@ +{ + "dailyFormat": "YYYY-MM-DD", + "structDir": "R:\\Creative\\artsy\\maya\\0 ProjectStructure", + "zipper": "7z", + "compression": 0, + "Max7zInst": 0 +} \ No newline at end of file diff --git a/.cursorindexingignore b/.cursorindexingignore new file mode 100644 index 0000000..953908e --- /dev/null +++ b/.cursorindexingignore @@ -0,0 +1,3 @@ + +# Don't index SpecStory auto-save files, but allow explicit context inclusion via @ references +.specstory/** diff --git a/.gitattributes b/.gitattributes new file mode 100644 index 0000000..9862802 --- /dev/null +++ b/.gitattributes @@ -0,0 +1,116 @@ +# Git LFS attributes configuration +# All listed file types will be tracked by Git LFS + +# Video files +*.avi filter=lfs diff=lfs merge=lfs -text +*.mkv filter=lfs diff=lfs merge=lfs -text +*.mov filter=lfs diff=lfs merge=lfs -text +*.MOV filter=lfs diff=lfs merge=lfs -text +*.mp4 filter=lfs diff=lfs merge=lfs -text +*.webm filter=lfs diff=lfs merge=lfs -text + +# Image files +*.bmp filter=lfs diff=lfs merge=lfs -text +*.exr filter=lfs diff=lfs merge=lfs -text +*.gif filter=lfs diff=lfs merge=lfs -text +*.hdr filter=lfs diff=lfs merge=lfs -text +*.jpg filter=lfs diff=lfs merge=lfs -text +*.jpeg filter=lfs diff=lfs merge=lfs -text +*.png filter=lfs diff=lfs merge=lfs -text +*.tga filter=lfs diff=lfs merge=lfs -text +*.tif filter=lfs diff=lfs merge=lfs -text +*.tiff filter=lfs diff=lfs merge=lfs -text +*.webp filter=lfs diff=lfs merge=lfs -text + +# 3D/CG files +*.3ds filter=lfs diff=lfs merge=lfs -text +*.abc filter=lfs diff=lfs merge=lfs -text +*.blend filter=lfs diff=lfs merge=lfs -text +*.blend1 filter=lfs diff=lfs merge=lfs -text +*.blend2 filter=lfs diff=lfs merge=lfs -text +*.bvh filter=lfs diff=lfs merge=lfs -text +*.bvh.gz filter=lfs diff=lfs merge=lfs -text +*.c4d filter=lfs diff=lfs merge=lfs -text +*.dae filter=lfs diff=lfs merge=lfs -text +*.fbx filter=lfs diff=lfs merge=lfs -text +*.fbxkey filter=lfs diff=lfs merge=lfs -text +*.ma filter=lfs diff=lfs merge=lfs -text +*.max filter=lfs diff=lfs merge=lfs -text +*.mb filter=lfs diff=lfs merge=lfs -text +*.obj filter=lfs diff=lfs merge=lfs -text +*.usd filter=lfs diff=lfs merge=lfs -text +*.usdz filter=lfs diff=lfs merge=lfs -text +*.vdb filter=lfs diff=lfs merge=lfs -text +*.bphys filter=lfs diff=lfs merge=lfs -text +*.bobj filter=lfs diff=lfs merge=lfs -text +*.bvel filter=lfs diff=lfs merge=lfs -text +*.bpointcache filter=lfs diff=lfs merge=lfs -text +*.blob filter=lfs diff=lfs merge=lfs -text +*.unitypackage filter=lfs diff=lfs merge=lfs -text + +# Houdini files +*.hiplc filter=lfs diff=lfs merge=lfs -text +*.bgeo filter=lfs diff=lfs merge=lfs -text +*.bgeo.sc filter=lfs diff=lfs merge=lfs -text + +# Flip Fluids cache files +*.data filter=lfs diff=lfs merge=lfs -text +*.sqlite3 filter=lfs diff=lfs merge=lfs -text +*.ffp3 filter=lfs diff=lfs merge=lfs -text + +# Substance files +*.sbs filter=lfs diff=lfs merge=lfs -text +*.sbsar filter=lfs diff=lfs merge=lfs -text +*.spp filter=lfs diff=lfs merge=lfs -text + +# Audio files +*.mp3 filter=lfs diff=lfs merge=lfs -text +*.wav filter=lfs diff=lfs merge=lfs -text +*.m4a filter=lfs diff=lfs merge=lfs -text +*.aac filter=lfs diff=lfs merge=lfs -text +*.ogg filter=lfs diff=lfs merge=lfs -text +*.flac filter=lfs diff=lfs merge=lfs -text + +# Archive/Compression files +*.7z filter=lfs diff=lfs merge=lfs -text +*.bz2 filter=lfs diff=lfs merge=lfs -text +*.gz filter=lfs diff=lfs merge=lfs -text +*.rar filter=lfs diff=lfs merge=lfs -text +*.tar filter=lfs diff=lfs merge=lfs -text +*.zip filter=lfs diff=lfs merge=lfs -text + +# Documents +*.docx filter=lfs diff=lfs merge=lfs -text +*.xlsx filter=lfs diff=lfs merge=lfs -text +*.eps filter=lfs diff=lfs merge=lfs -text +*.pdf filter=lfs diff=lfs merge=lfs -text + +# Adobe files +*.aegraphic filter=lfs diff=lfs merge=lfs -text +*.aep filter=lfs diff=lfs merge=lfs -text +*.prel filter=lfs diff=lfs merge=lfs -text +*.prin filter=lfs diff=lfs merge=lfs -text +*.prmf filter=lfs diff=lfs merge=lfs -text +*.prproj filter=lfs diff=lfs merge=lfs -text +*.ai filter=lfs diff=lfs merge=lfs -text +*.psd filter=lfs diff=lfs merge=lfs -text + +# Davinci Resolve files +*.dpx filter=lfs diff=lfs merge=lfs -text +*.drp filter=lfs diff=lfs merge=lfs -text + +# Data files +*.h5 filter=lfs diff=lfs merge=lfs -text +*.hdf5 filter=lfs diff=lfs merge=lfs -text + +# Other +*.uni filter=lfs diff=lfs merge=lfs -text +*.pdn filter=lfs diff=lfs merge=lfs -text +*.pur filter=lfs diff=lfs merge=lfs -text + +# Python files +*.npz filter=lfs diff=lfs merge=lfs -text + +# Adobe Alternatives +*.xcf filter=lfs diff=lfs merge=lfs -text +*.af filter=lfs diff=lfs merge=lfs -text \ No newline at end of file diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..242ab6a --- /dev/null +++ b/.gitignore @@ -0,0 +1,126 @@ +# Blender Studio Git Management - .gitignore + +# Blender auto-save files +*.blend1 +*.blend2 +*.blend3 +*.blend4 +*.blend5 +*.blend6 +*.blend7 +*.blend8 +*.blend9 +*.blend10 +*.blend11 +*.blend12 +*.blend13 +*.blend14 +*.blend15 +*.blend16 +*.blend17 +*.blend18 +*.blend19 +*.blend20 +*.blend21 +*.blend22 +*.blend23 +*.blend24 +*.blend25 +*.blend26 +*.blend27 +*.blend28 +*.blend29 +*.blend30 +*.blend31 +*.blend32 + +# Blender cache and temporary files +*.swp +*.swo +*~ +*.tmp +*.temp + +# OS generated files +.DS_Store +.DS_Store? +._* +.Spotlight-V100 +.Trashes +ehthumbs.db +Thumbs.db +desktop.ini + +# Editor files +.vscode/ +.idea/ +*.swp +*.swo +*~ + +# Large media files (uncomment if you want to exclude rendered outputs) +# *.mp4 +# *.avi +# *.mov +# *.png +# *.jpg +# *.jpeg +# *.exr +# *.hdr +# *.tiff +# *.tga + +# Audio files (uncomment if excluding) +# *.wav +# *.mp3 +# *.aac +# *.ogg + +# Log files +*.log + +# Python cache +__pycache__/ +*.pyc +*.pyo +*.pyd +.Python + +# Node modules (if using any web tools) +node_modules/ + +# Environment files +.env +.env.local +.env.development.local +.env.test.local +.env.production.local + +# Backup files +*.bak +*.backup +*.old + +# Temporary files +temp/ +tmp/ +cache/ + +Renders/** +!Renders/_zipped/ +!Renders/_zipped/** +!Renders/**/ +!Renders/**/*.bat +!Renders/**/*.log +seq/ + +# Premiere +*.prlock +Adobe Premiere Pro Video Previews/ +Adobe Premiere Pro Audio Previews/ +Adobe Premiere Pro (Beta) Video Previews/ +Adobe Premiere Pro (Beta) Audio Previews/ +footage/ +plates/ + +Pr/RnR/ \ No newline at end of file diff --git a/.specstory/.gitignore b/.specstory/.gitignore new file mode 100644 index 0000000..c5b4129 --- /dev/null +++ b/.specstory/.gitignore @@ -0,0 +1,4 @@ +# SpecStory project identity file +/.project.json +# SpecStory explanation file +/.what-is-this.md diff --git a/Renders/UnzipSeqArchv.bat b/Renders/UnzipSeqArchv.bat new file mode 100644 index 0000000..acfcc33 --- /dev/null +++ b/Renders/UnzipSeqArchv.bat @@ -0,0 +1,42 @@ +@echo off +setlocal EnableExtensions EnableDelayedExpansion + +set "REN_DIR=%~dp0" +for %%I in ("%REN_DIR%..") do set "PROJ_ROOT=%%~fI" + +set "CONFIG_DIR=%PROJ_ROOT%\.config" +set "CONFIG_PATH=%CONFIG_DIR%\config.json" +set "GET_STRUCT_DIR=%CONFIG_DIR%\GetStructDir.ps1" + +if not exist "%CONFIG_PATH%" ( + echo [ERROR] config.json not found at %CONFIG_PATH% + echo Please run ConfigLoader.ps1 to deploy helper files. + exit /b 1 +) + +if not exist "%GET_STRUCT_DIR%" ( + echo [ERROR] GetStructDir.ps1 not found at %GET_STRUCT_DIR% + echo Please run ConfigLoader.ps1 to deploy helper files. + exit /b 1 +) + +for /f "usebackq delims=" %%I in (`powershell -NoProfile -ExecutionPolicy Bypass -Command ^ + "Set-StrictMode -Version Latest; $structDir = & '%GET_STRUCT_DIR%' -ProjectRoot '%PROJ_ROOT%'; if (-not $structDir) { throw \"Failed to get structDir from GetStructDir.ps1\" }; $pyPath = Join-Path $structDir 'zip_sequences.py'; if (-not (Test-Path -LiteralPath $pyPath)) { throw \"zip_sequences.py not found at $pyPath\" }; Write-Output $pyPath"`) do set "PY_SCRIPT=%%I" + +if not defined PY_SCRIPT ( + echo [ERROR] Unable to resolve zip_sequences.py path from config. + exit /b 1 +) + +pushd "%PROJ_ROOT%" >nul 2>&1 + +python "%PY_SCRIPT%" --mode expand --verbose %* +set "ERR=!ERRORLEVEL!" + +if not "!ERR!"=="0" ( + echo Failed to expand render sequence archives (exit code !ERR!). +) + +popd >nul 2>&1 +exit /b !ERR! + diff --git a/Renders/ZipSeqArchv.bat b/Renders/ZipSeqArchv.bat new file mode 100644 index 0000000..2fa85ec --- /dev/null +++ b/Renders/ZipSeqArchv.bat @@ -0,0 +1,44 @@ +@echo off +setlocal EnableExtensions EnableDelayedExpansion + +set "REN_DIR=%~dp0" +for %%I in ("%REN_DIR%..") do set "PROJ_ROOT=%%~fI" + +set "CONFIG_DIR=%PROJ_ROOT%\.config" +set "CONFIG_PATH=%CONFIG_DIR%\config.json" +set "GET_STRUCT_DIR=%CONFIG_DIR%\GetStructDir.ps1" + +if not exist "%CONFIG_PATH%" ( + echo [ERROR] config.json not found at %CONFIG_PATH% + echo Please run ConfigLoader.ps1 to deploy helper files. + exit /b 1 +) + +if not exist "%GET_STRUCT_DIR%" ( + echo [ERROR] GetStructDir.ps1 not found at %GET_STRUCT_DIR% + echo Please run ConfigLoader.ps1 to deploy helper files. + exit /b 1 +) + +for /f "usebackq delims=" %%I in (`powershell -NoProfile -ExecutionPolicy Bypass -Command ^ + "Set-StrictMode -Version Latest; $structDir = & '%GET_STRUCT_DIR%' -ProjectRoot '%PROJ_ROOT%'; if (-not $structDir) { throw \"Failed to get structDir from GetStructDir.ps1\" }; $pyPath = Join-Path $structDir 'zip_sequences.py'; if (-not (Test-Path -LiteralPath $pyPath)) { throw \"zip_sequences.py not found at $pyPath\" }; Write-Output $pyPath"`) do set "PY_SCRIPT=%%~I" + +if not defined PY_SCRIPT ( + echo [ERROR] Unable to resolve zip_sequences.py path from config. + exit /b 1 +) + +pushd "%PROJ_ROOT%" >nul 2>&1 + +python "%PY_SCRIPT%" --verbose %* +set "ERR=!ERRORLEVEL!" + +popd >nul 2>&1 + +if !ERR! NEQ 0 ( + echo Failed to update render sequence archives ^(exit code !ERR!^). + exit /b !ERR! +) + +exit /b 0 +