A macOS CLI tool for After Effects project scaffolding
Project description
Aeset — After Effects Project Scaffolding Tool
Every video editor or motion designer wastes 10–20 minutes at the start of every project doing the exact same thing: creating folders by hand, naming them consistently, opening After Effects, and setting up a new composition with the right resolution, framerate, and duration. It is not creative work. It is repetitive work. Multiply it by 50 projects a year and you have lost a full work week to folder creation and blank composition setup.
Aeset is a tool built to solve this for After Effects on macOS. It takes the "scaffolding" logic used by software developers and applies it to the motion design world.
1. What The Tool Does
The user opens their terminal, navigates to where they want the project to live, and runs:
aeset
The tool then asks a series of interactive questions:
- Project name (e.g., Nike_Ident_2026)
- Project type (Commercial, Personal, etc.)
- Resolution (Full HD, 4K, Vertical, etc.)
- Frame rate (24, 25, 30, 60 fps)
- Duration in seconds
- Color space (sRGB, Rec. 709, ACES)
After those answers, the tool:
- Creates a standardized folder tree inside a new project directory.
- Copies a blank .aep template file into the project folder.
- Generates a small ExtendScript .jsx file containing the user's specs.
- Opens After Effects with the project file via a macOS system call.
- Fires an AppleScript command that tells After Effects to run the .jsx, which creates the composition and internal project bins (folders) automatically.
2. Folder Structure Generated
Aeset generates a directory layout that follows conventions used by professional motion studios. The core principle is: never mix source files with outputs.
On Disk:
<ProjectName>/
├── project/
│ ├── <ProjectName>.aep (copy of blank .aep template)
│ └── setup.jsx (temporary setup script)
├── footage/
│ ├── video/ (raw video clips)
│ ├── audio/ (music, SFX, voiceover)
│ └── renders/ (outputs from C4D, Blender, etc.)
├── assets/
│ ├── images/ (static graphics, PNGs, PSDs, AI files)
│ ├── fonts/ (local fonts scoped to this project)
│ └── documents/ (briefs, scripts, reference PDFs)
├── exports/
│ ├── drafts/ (work-in-progress renders)
│ └── final/ (delivered, approved renders)
└── README.md (auto-generated project notes)
Inside After Effects:
The tool also creates corresponding bins in the Project Panel to keep your workspace clean:
- _COMPS (containing your main composition)
- _FOOTAGE
- _ASSETS
- _AUDIO
3. The Mechanism
The .aep file
An .aep file is a binary format that cannot be easily generated by code. Because of this, Aeset ships with a hand-crafted blank .aep template. Every time the tool runs, it copies this template and renames it.
The .jsx file
The tool generates a plain text ExtendScript file at runtime. This script has full programmatic access to After Effects. It uses the specs you provided in the terminal to build your composition and organize your project panel.
The AppleScript Trigger
The .jsx is triggered explicitly after After Effects opens using a macOS AppleScript command (DoScript). This bridges the gap between the Python-based CLI and the Adobe environment.
4. Installation and Requirements
Installation
Aeset can be installed via pip:
pip install aeset
Requirements
- macOS: AppleScript and the 'open' command are macOS-specific.
- Adobe After Effects 2025: The tool is currently configured to target the 2025 version.
- Python 3.11+
5. Constraints and Assumptions
- No Adobe credentials required: The tool uses only local scripting.
- After Effects must already be installed: The tool does not manage the AE installation itself.
- Local execution: All files are generated and stored locally on your machine.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file aeset-0.1.0.tar.gz.
File metadata
- Download URL: aeset-0.1.0.tar.gz
- Upload date:
- Size: 9.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a18c2408dbf3bb221a5e716858bec231637027cdada94bcb70f71744c040323d
|
|
| MD5 |
aa74ff193c86f333bb7ba0bce22cc8f9
|
|
| BLAKE2b-256 |
dac0ee37c2893bbbd9a8d3ecbe5ec9f8db4faaf81121de41d1df1b11ecfa8eba
|
Provenance
The following attestation bundles were made for aeset-0.1.0.tar.gz:
Publisher:
publish.yml on A7med7x7/Aeset
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
aeset-0.1.0.tar.gz -
Subject digest:
a18c2408dbf3bb221a5e716858bec231637027cdada94bcb70f71744c040323d - Sigstore transparency entry: 1185769779
- Sigstore integration time:
-
Permalink:
A7med7x7/Aeset@03ed9317b1dc6f90e8b4c13fdd0bf017e1796d99 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/A7med7x7
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@03ed9317b1dc6f90e8b4c13fdd0bf017e1796d99 -
Trigger Event:
push
-
Statement type:
File details
Details for the file aeset-0.1.0-py3-none-any.whl.
File metadata
- Download URL: aeset-0.1.0-py3-none-any.whl
- Upload date:
- Size: 8.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1850dc479a4247c1aa30302ebafa32739208b5d4b081e88abd5fddcb97dcf866
|
|
| MD5 |
f0d5ce5f7347c81264852a23bd2d25f9
|
|
| BLAKE2b-256 |
2e6bdb82682c19483ad69184123502929d36bb16392971d59a00cc7e5a2078a9
|
Provenance
The following attestation bundles were made for aeset-0.1.0-py3-none-any.whl:
Publisher:
publish.yml on A7med7x7/Aeset
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
aeset-0.1.0-py3-none-any.whl -
Subject digest:
1850dc479a4247c1aa30302ebafa32739208b5d4b081e88abd5fddcb97dcf866 - Sigstore transparency entry: 1185769790
- Sigstore integration time:
-
Permalink:
A7med7x7/Aeset@03ed9317b1dc6f90e8b4c13fdd0bf017e1796d99 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/A7med7x7
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@03ed9317b1dc6f90e8b4c13fdd0bf017e1796d99 -
Trigger Event:
push
-
Statement type: