base44 0.0.17 → 0.0.18
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +58 -142
- package/bin/dev.js +12 -0
- package/bin/run.js +12 -0
- package/dist/{cli/index.js → index.js} +42 -8
- package/package.json +7 -8
- /package/dist/{cli/templates → templates}/backend-and-client/.nvmrc +0 -0
- /package/dist/{cli/templates → templates}/backend-and-client/README.md +0 -0
- /package/dist/{cli/templates → templates}/backend-and-client/base44/app.jsonc.ejs +0 -0
- /package/dist/{cli/templates → templates}/backend-and-client/base44/config.jsonc.ejs +0 -0
- /package/dist/{cli/templates → templates}/backend-and-client/base44/entities/task.jsonc +0 -0
- /package/dist/{cli/templates → templates}/backend-and-client/components.json +0 -0
- /package/dist/{cli/templates → templates}/backend-and-client/index.html +0 -0
- /package/dist/{cli/templates → templates}/backend-and-client/jsconfig.json +0 -0
- /package/dist/{cli/templates → templates}/backend-and-client/package.json +0 -0
- /package/dist/{cli/templates → templates}/backend-and-client/postcss.config.js +0 -0
- /package/dist/{cli/templates → templates}/backend-and-client/src/App.jsx +0 -0
- /package/dist/{cli/templates → templates}/backend-and-client/src/api/base44Client.js.ejs +0 -0
- /package/dist/{cli/templates → templates}/backend-and-client/src/components/Base44Logo.jsx +0 -0
- /package/dist/{cli/templates → templates}/backend-and-client/src/components/ui/button.jsx +0 -0
- /package/dist/{cli/templates → templates}/backend-and-client/src/components/ui/checkbox.jsx +0 -0
- /package/dist/{cli/templates → templates}/backend-and-client/src/components/ui/input.jsx +0 -0
- /package/dist/{cli/templates → templates}/backend-and-client/src/index.css +0 -0
- /package/dist/{cli/templates → templates}/backend-and-client/src/main.jsx +0 -0
- /package/dist/{cli/templates → templates}/backend-and-client/tailwind.config.js +0 -0
- /package/dist/{cli/templates → templates}/backend-and-client/vite.config.js +0 -0
- /package/dist/{cli/templates → templates}/backend-only/base44/app.jsonc.ejs +0 -0
- /package/dist/{cli/templates → templates}/backend-only/base44/config.jsonc.ejs +0 -0
- /package/dist/{cli/templates → templates}/templates.json +0 -0
package/README.md
CHANGED
|
@@ -1,193 +1,109 @@
|
|
|
1
1
|
# Base44 CLI
|
|
2
2
|
|
|
3
|
-
|
|
3
|
+
Command-line interface for building applications with [Base44's backend service](https://docs.base44.com/developers/backend/overview/introduction).
|
|
4
4
|
|
|
5
|
-
|
|
5
|
+
Base44's backend service provides a managed backend for your applications, including data storage with entities, serverless functions, authentication, and hosting. The CLI lets you:
|
|
6
|
+
|
|
7
|
+
- **Create projects** from templates.
|
|
8
|
+
- **Sync** resources defined in local code with your Base44 backend.
|
|
9
|
+
- **Deploy sites** to Base44's hosting platform.
|
|
10
|
+
|
|
11
|
+
To get started, see the full list of commands below or check out the [documentation](https://docs.base44.com/developers/references/cli/get-started/overview).
|
|
6
12
|
|
|
7
13
|
## Installation
|
|
8
14
|
|
|
9
15
|
```bash
|
|
10
|
-
# Using npm (globally)
|
|
11
16
|
npm install -g base44
|
|
12
|
-
|
|
13
|
-
# Or run directly with npx
|
|
14
|
-
npx base44 <command>
|
|
15
17
|
```
|
|
16
18
|
|
|
17
|
-
|
|
19
|
+
Or run commands directly with npx:
|
|
18
20
|
|
|
19
21
|
```bash
|
|
20
|
-
|
|
21
|
-
base44 login
|
|
22
|
-
|
|
23
|
-
# 2. Create a new project
|
|
24
|
-
base44 create
|
|
25
|
-
|
|
26
|
-
# 3. Deploy everything (entities, functions, and site)
|
|
27
|
-
npm run build
|
|
28
|
-
base44 deploy
|
|
22
|
+
npx base44 <command>
|
|
29
23
|
```
|
|
30
24
|
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
### Authentication
|
|
25
|
+
Requires Node.js 20.19.0 or higher.
|
|
34
26
|
|
|
35
|
-
|
|
36
|
-
|---------|-------------|
|
|
37
|
-
| `base44 login` | Authenticate with Base44 using device code flow |
|
|
38
|
-
| `base44 whoami` | Display current authenticated user |
|
|
39
|
-
| `base44 logout` | Logout from current device |
|
|
40
|
-
|
|
41
|
-
### Project Management
|
|
42
|
-
|
|
43
|
-
| Command | Description |
|
|
44
|
-
|---------|-------------|
|
|
45
|
-
| `base44 create` | Create a new Base44 project from a template |
|
|
46
|
-
| `base44 link` | Link a local project to Base44 (create new or link existing) |
|
|
47
|
-
| `base44 dashboard` | Open the app dashboard in your browser |
|
|
48
|
-
|
|
49
|
-
#### Link Command Options
|
|
50
|
-
|
|
51
|
-
The `link` command supports both creating new projects and linking to existing ones:
|
|
27
|
+
## Quick start
|
|
52
28
|
|
|
53
29
|
```bash
|
|
54
|
-
#
|
|
55
|
-
base44
|
|
56
|
-
|
|
57
|
-
# Create a new project (non-interactive)
|
|
58
|
-
base44 link --create --name "my-app" --description "My app description"
|
|
30
|
+
# Authenticate
|
|
31
|
+
base44 login
|
|
59
32
|
|
|
60
|
-
#
|
|
61
|
-
base44
|
|
33
|
+
# Create a project
|
|
34
|
+
base44 create
|
|
62
35
|
```
|
|
63
36
|
|
|
64
|
-
|
|
65
|
-
|--------|-------------|
|
|
66
|
-
| `-c, --create` | Create a new project (skip selection prompt) |
|
|
67
|
-
| `-n, --name <name>` | Project name (required with --create) |
|
|
68
|
-
| `-d, --description <desc>` | Project description (optional) |
|
|
69
|
-
| `-p, --projectId <id>` | Link to an existing project by ID (skips selection prompt) |
|
|
37
|
+
The CLI will guide you through project setup. For step-by-step tutorials, see the quickstart guides:
|
|
70
38
|
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
| Command | Description |
|
|
74
|
-
|---------|-------------|
|
|
75
|
-
| `base44 deploy` | Deploy all resources (entities, functions, and site) |
|
|
39
|
+
- [Backend only](https://docs.base44.com/developers/backend/quickstart/quickstart-backend-only) — for headless apps or custom frontends
|
|
40
|
+
- [React](https://docs.base44.com/developers/backend/quickstart/quickstart-with-react) — full-stack with Vite + React
|
|
76
41
|
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
| Command | Description |
|
|
80
|
-
|---------|-------------|
|
|
81
|
-
| `base44 entities push` | Push local entity schemas to Base44 |
|
|
82
|
-
|
|
83
|
-
### Functions
|
|
42
|
+
## Commands
|
|
84
43
|
|
|
85
44
|
| Command | Description |
|
|
86
|
-
|
|
87
|
-
| `base44
|
|
88
|
-
|
|
89
|
-
|
|
45
|
+
| ------- | ----------- |
|
|
46
|
+
| [`create`](https://docs.base44.com/developers/references/cli/commands/create) | Create a new Base44 project from a template |
|
|
47
|
+
| [`deploy`](https://docs.base44.com/developers/references/cli/commands/deploy) | Deploy resources and site to Base44 |
|
|
48
|
+
| [`link`](https://docs.base44.com/developers/references/cli/commands/link) | Link a local project to a project on Base44 |
|
|
49
|
+
| [`dashboard`](https://docs.base44.com/developers/references/cli/commands/dashboard) | Open the app dashboard in your browser |
|
|
50
|
+
| [`login`](https://docs.base44.com/developers/references/cli/commands/login) | Authenticate with Base44 |
|
|
51
|
+
| [`logout`](https://docs.base44.com/developers/references/cli/commands/logout) | Sign out and clear stored credentials |
|
|
52
|
+
| [`whoami`](https://docs.base44.com/developers/references/cli/commands/whoami) | Display the current authenticated user |
|
|
53
|
+
| [`entities push`](https://docs.base44.com/developers/references/cli/commands/entities-push) | Push local entity schemas to Base44 |
|
|
54
|
+
| [`functions deploy`](https://docs.base44.com/developers/references/cli/commands/functions-deploy) | Deploy local functions to Base44 |
|
|
55
|
+
| [`site deploy`](https://docs.base44.com/developers/references/cli/commands/site-deploy) | Deploy built site files to Base44 hosting |
|
|
90
56
|
|
|
91
|
-
| Command | Description |
|
|
92
|
-
|---------|-------------|
|
|
93
|
-
| `base44 site deploy` | Deploy built site files to Base44 hosting |
|
|
94
57
|
|
|
95
|
-
|
|
58
|
+
<!--| [`eject`](https://docs.base44.com/developers/references/cli/commands/eject) | Create a Base44 backend project from an existing Base44 app | -->
|
|
96
59
|
|
|
97
|
-
|
|
60
|
+
## AI Agent Skills
|
|
98
61
|
|
|
99
|
-
|
|
62
|
+
When creating a project, you'll be prompted to install AI agent skills for your preferred coding assistants:
|
|
100
63
|
|
|
101
|
-
```jsonc
|
|
102
|
-
// base44/config.jsonc
|
|
103
|
-
{
|
|
104
|
-
"name": "My Project",
|
|
105
|
-
"entitiesDir": "./entities", // Default: ./entities
|
|
106
|
-
"functionsDir": "./functions", // Default: ./functions
|
|
107
|
-
"site": {
|
|
108
|
-
"outputDirectory": "../dist" // Path to built site files
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
64
|
```
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
```jsonc
|
|
118
|
-
// base44/.app.jsonc
|
|
119
|
-
{
|
|
120
|
-
"id": "your-app-id"
|
|
121
|
-
}
|
|
65
|
+
◆ Add AI agent skills? (Select agents to configure)
|
|
66
|
+
│ ◼ Cursor
|
|
67
|
+
│ ◼ Claude Code
|
|
68
|
+
└
|
|
122
69
|
```
|
|
123
70
|
|
|
124
|
-
|
|
71
|
+
This installs [base44/skills](https://github.com/base44/skills) which helps AI agents understand how to work with Base44 projects.
|
|
125
72
|
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
```
|
|
129
|
-
my-project/
|
|
130
|
-
├── base44/
|
|
131
|
-
│ ├── config.jsonc # Project configuration
|
|
132
|
-
│ ├── .app.jsonc # App ID (git-ignored)
|
|
133
|
-
│ ├── entities/ # Entity schema files
|
|
134
|
-
│ │ ├── user.jsonc
|
|
135
|
-
│ │ └── product.jsonc
|
|
136
|
-
│ └── functions/ # Backend functions
|
|
137
|
-
│ └── my-function/
|
|
138
|
-
│ ├── config.jsonc
|
|
139
|
-
│ └── index.js
|
|
140
|
-
├── src/ # Your frontend code
|
|
141
|
-
├── dist/ # Built site files (for deployment)
|
|
142
|
-
└── package.json
|
|
143
|
-
```
|
|
144
|
-
|
|
145
|
-
## Development
|
|
146
|
-
|
|
147
|
-
### Prerequisites
|
|
148
|
-
|
|
149
|
-
- Node.js >= 20.19.0
|
|
150
|
-
- npm
|
|
151
|
-
|
|
152
|
-
### Setup
|
|
73
|
+
**Non-interactive mode:**
|
|
153
74
|
|
|
154
75
|
```bash
|
|
155
|
-
#
|
|
156
|
-
|
|
157
|
-
cd cli
|
|
76
|
+
# Install skills for all supported agents
|
|
77
|
+
base44 create --name my-app --path ./my-app --skills
|
|
158
78
|
|
|
159
|
-
#
|
|
160
|
-
|
|
79
|
+
# Skip skills installation
|
|
80
|
+
base44 create --name my-app --path ./my-app
|
|
81
|
+
```
|
|
161
82
|
|
|
162
|
-
|
|
163
|
-
npm run build
|
|
83
|
+
**Manual installation:**
|
|
164
84
|
|
|
165
|
-
|
|
166
|
-
|
|
85
|
+
```bash
|
|
86
|
+
npx add-skill base44/skills
|
|
167
87
|
```
|
|
168
88
|
|
|
169
|
-
|
|
89
|
+
## Help
|
|
170
90
|
|
|
171
91
|
```bash
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
npm run dev # Run in development mode with tsx
|
|
175
|
-
npm run lint # Lint with ESLint
|
|
176
|
-
npm test # Run tests with Vitest
|
|
92
|
+
base44 --help
|
|
93
|
+
base44 <command> --help
|
|
177
94
|
```
|
|
178
95
|
|
|
179
|
-
|
|
96
|
+
## Version
|
|
180
97
|
|
|
181
98
|
```bash
|
|
182
|
-
|
|
183
|
-
npm start -- <command>
|
|
184
|
-
|
|
185
|
-
# Or directly
|
|
186
|
-
./dist/cli/index.js <command>
|
|
99
|
+
base44 --version
|
|
187
100
|
```
|
|
188
|
-
## Contributing
|
|
189
101
|
|
|
190
|
-
|
|
102
|
+
## Alpha
|
|
103
|
+
|
|
104
|
+
The CLI and Base44 backend service are currently in alpha. We're actively improving them based on user feedback. Share your thoughts and feature requests on our [GitHub Discussions](https://github.com/orgs/base44/discussions).
|
|
105
|
+
|
|
106
|
+
Found a bug? [Open an issue](https://github.com/base44/cli/issues).
|
|
191
107
|
|
|
192
108
|
## License
|
|
193
109
|
|
package/bin/dev.js
ADDED
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
#!/usr/bin/env tsx
|
|
2
|
+
import { program, CLIExitError } from "../src/cli/index.ts";
|
|
3
|
+
|
|
4
|
+
try {
|
|
5
|
+
await program.parseAsync();
|
|
6
|
+
} catch (error) {
|
|
7
|
+
if (error instanceof CLIExitError) {
|
|
8
|
+
process.exit(error.code);
|
|
9
|
+
}
|
|
10
|
+
console.error(error);
|
|
11
|
+
process.exit(1);
|
|
12
|
+
}
|
package/bin/run.js
ADDED
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import { program, CLIExitError } from "../dist/index.js";
|
|
3
|
+
|
|
4
|
+
try {
|
|
5
|
+
await program.parseAsync();
|
|
6
|
+
} catch (error) {
|
|
7
|
+
if (error instanceof CLIExitError) {
|
|
8
|
+
process.exit(error.code);
|
|
9
|
+
}
|
|
10
|
+
console.error(error);
|
|
11
|
+
process.exit(1);
|
|
12
|
+
}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
1
|
import { createRequire } from "node:module";
|
|
3
2
|
import { EventEmitter, addAbortListener, on, once, setMaxListeners } from "node:events";
|
|
4
3
|
import childProcess, { ChildProcess, execFile, spawn, spawnSync } from "node:child_process";
|
|
@@ -30586,6 +30585,21 @@ async function getUserInfo(accessToken) {
|
|
|
30586
30585
|
return result.data;
|
|
30587
30586
|
}
|
|
30588
30587
|
|
|
30588
|
+
//#endregion
|
|
30589
|
+
//#region src/cli/errors.ts
|
|
30590
|
+
/**
|
|
30591
|
+
* Error thrown to signal a controlled CLI exit with a specific exit code.
|
|
30592
|
+
* This allows proper error propagation without calling process.exit() directly,
|
|
30593
|
+
* making the code more testable and maintaining a single exit point.
|
|
30594
|
+
*/
|
|
30595
|
+
var CLIExitError = class extends Error {
|
|
30596
|
+
constructor(code$1) {
|
|
30597
|
+
super(`CLI exited with code ${code$1}`);
|
|
30598
|
+
this.code = code$1;
|
|
30599
|
+
this.name = "CLIExitError";
|
|
30600
|
+
}
|
|
30601
|
+
};
|
|
30602
|
+
|
|
30589
30603
|
//#endregion
|
|
30590
30604
|
//#region node_modules/chalk/source/vendor/ansi-styles/index.js
|
|
30591
30605
|
const ANSI_BACKGROUND_OFFSET = 10;
|
|
@@ -31152,7 +31166,7 @@ async function runCommand(commandFn, options) {
|
|
|
31152
31166
|
} catch (e$1) {
|
|
31153
31167
|
if (e$1 instanceof Error) M.error(e$1.stack ?? e$1.message);
|
|
31154
31168
|
else M.error(String(e$1));
|
|
31155
|
-
|
|
31169
|
+
throw new CLIExitError(1);
|
|
31156
31170
|
}
|
|
31157
31171
|
}
|
|
31158
31172
|
|
|
@@ -38093,6 +38107,7 @@ async function createInteractive(options) {
|
|
|
38093
38107
|
description: result.description || void 0,
|
|
38094
38108
|
projectPath: result.projectPath,
|
|
38095
38109
|
deploy: options.deploy,
|
|
38110
|
+
skills: options.skills,
|
|
38096
38111
|
isInteractive: true
|
|
38097
38112
|
});
|
|
38098
38113
|
}
|
|
@@ -38103,10 +38118,11 @@ async function createNonInteractive(options) {
|
|
|
38103
38118
|
description: options.description,
|
|
38104
38119
|
projectPath: options.path,
|
|
38105
38120
|
deploy: options.deploy,
|
|
38121
|
+
skills: options.skills,
|
|
38106
38122
|
isInteractive: false
|
|
38107
38123
|
});
|
|
38108
38124
|
}
|
|
38109
|
-
async function executeCreate({ template, name: rawName, description, projectPath, deploy, isInteractive }) {
|
|
38125
|
+
async function executeCreate({ template, name: rawName, description, projectPath, deploy, skills, isInteractive }) {
|
|
38110
38126
|
const name$1 = rawName.trim();
|
|
38111
38127
|
const resolvedPath = resolve(projectPath);
|
|
38112
38128
|
const { projectId } = await runTask("Setting up your project...", async () => {
|
|
@@ -38166,12 +38182,31 @@ async function executeCreate({ template, name: rawName, description, projectPath
|
|
|
38166
38182
|
finalAppUrl = appUrl;
|
|
38167
38183
|
}
|
|
38168
38184
|
}
|
|
38185
|
+
let shouldAddSkills = false;
|
|
38186
|
+
if (isInteractive) {
|
|
38187
|
+
const result = await ye({ message: "Add AI agent skills?" });
|
|
38188
|
+
shouldAddSkills = !pD(result) && result;
|
|
38189
|
+
} else shouldAddSkills = !!skills;
|
|
38190
|
+
if (shouldAddSkills) await runTask("Installing AI agent skills...", async () => {
|
|
38191
|
+
await execa("npx", [
|
|
38192
|
+
"-y",
|
|
38193
|
+
"add-skill",
|
|
38194
|
+
"base44/skills",
|
|
38195
|
+
"-y"
|
|
38196
|
+
], {
|
|
38197
|
+
cwd: resolvedPath,
|
|
38198
|
+
stdio: "inherit"
|
|
38199
|
+
});
|
|
38200
|
+
}, {
|
|
38201
|
+
successMessage: theme.colors.base44Orange("AI agent skills added successfully"),
|
|
38202
|
+
errorMessage: "Failed to add AI agent skills - you can add them later with: npx add-skill base44/skills"
|
|
38203
|
+
});
|
|
38169
38204
|
M.message(`${theme.styles.header("Project")}: ${theme.colors.base44Orange(name$1)}`);
|
|
38170
38205
|
M.message(`${theme.styles.header("Dashboard")}: ${theme.colors.links(getDashboardUrl(projectId))}`);
|
|
38171
38206
|
if (finalAppUrl) M.message(`${theme.styles.header("Site")}: ${theme.colors.links(finalAppUrl)}`);
|
|
38172
38207
|
return { outroMessage: "Your project is set up and ready to use" };
|
|
38173
38208
|
}
|
|
38174
|
-
const createCommand = new Command("create").description("Create a new Base44 project").option("-n, --name <name>", "Project name").option("-d, --description <description>", "Project description").option("-p, --path <path>", "Path where to create the project").option("-t, --template <id>", "Template ID (e.g., backend-only, backend-and-client)").option("--deploy", "Build and deploy the site").hook("preAction", validateNonInteractiveFlags$1).action(async (options) => {
|
|
38209
|
+
const createCommand = new Command("create").description("Create a new Base44 project").option("-n, --name <name>", "Project name").option("-d, --description <description>", "Project description").option("-p, --path <path>", "Path where to create the project").option("-t, --template <id>", "Template ID (e.g., backend-only, backend-and-client)").option("--deploy", "Build and deploy the site").option("--skills", "Add AI agent skills").hook("preAction", validateNonInteractiveFlags$1).action(async (options) => {
|
|
38175
38210
|
await chooseCreate(options);
|
|
38176
38211
|
});
|
|
38177
38212
|
|
|
@@ -38897,10 +38932,10 @@ const siteDeployCommand = new Command("site").description("Manage site deploymen
|
|
|
38897
38932
|
|
|
38898
38933
|
//#endregion
|
|
38899
38934
|
//#region package.json
|
|
38900
|
-
var version = "0.0.
|
|
38935
|
+
var version = "0.0.18";
|
|
38901
38936
|
|
|
38902
38937
|
//#endregion
|
|
38903
|
-
//#region src/cli/
|
|
38938
|
+
//#region src/cli/program.ts
|
|
38904
38939
|
const program = new Command();
|
|
38905
38940
|
program.name("base44").description("Base44 CLI - Unified interface for managing Base44 applications").version(version);
|
|
38906
38941
|
program.configureHelp({ sortSubcommands: true });
|
|
@@ -38914,7 +38949,6 @@ program.addCommand(linkCommand);
|
|
|
38914
38949
|
program.addCommand(entitiesPushCommand);
|
|
38915
38950
|
program.addCommand(functionsDeployCommand);
|
|
38916
38951
|
program.addCommand(siteDeployCommand);
|
|
38917
|
-
program.parse();
|
|
38918
38952
|
|
|
38919
38953
|
//#endregion
|
|
38920
|
-
export {
|
|
38954
|
+
export { CLIExitError, program };
|
package/package.json
CHANGED
|
@@ -1,21 +1,20 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "base44",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.18",
|
|
4
4
|
"description": "Base44 CLI - Unified interface for managing Base44 applications",
|
|
5
5
|
"type": "module",
|
|
6
|
-
"
|
|
7
|
-
|
|
8
|
-
"exports": {
|
|
9
|
-
".": "./dist/cli/index.js"
|
|
6
|
+
"bin": {
|
|
7
|
+
"base44": "./bin/run.js"
|
|
10
8
|
},
|
|
11
9
|
"files": [
|
|
12
|
-
"dist"
|
|
10
|
+
"dist",
|
|
11
|
+
"bin"
|
|
13
12
|
],
|
|
14
13
|
"scripts": {
|
|
15
14
|
"build": "tsdown",
|
|
16
15
|
"typecheck": "tsc --noEmit",
|
|
17
|
-
"dev": "
|
|
18
|
-
"start": "
|
|
16
|
+
"dev": "./bin/dev.js",
|
|
17
|
+
"start": "./bin/run.js",
|
|
19
18
|
"clean": "rm -rf dist",
|
|
20
19
|
"lint": "eslint src",
|
|
21
20
|
"test": "vitest run",
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|