diff --git a/.github/ISSUE_TEMPLATE/mvp-tasks.md b/.github/ISSUE_TEMPLATE/mvp-tasks.md
new file mode 100644
index 0000000..895508a
--- /dev/null
+++ b/.github/ISSUE_TEMPLATE/mvp-tasks.md
@@ -0,0 +1,101 @@
+---
+name: MVP Final Tasks
+about: Tracking the final tasks needed for MVP release
+title: 'MVP: Final Tasks for Initial Release'
+labels: enhancement, MVP
+assignees: ''
+---
+
+## Description
+This issue tracks the final tasks needed to prepare Dev Session Buddy for its initial MVP release. These tasks focus on ensuring the package is well-tested, documented, and ready for publication on npm.
+
+## Tasks
+
+### 1. Add Comprehensive Test Suite
+- [ ] Unit Tests
+ - [ ] Template manager functionality
+ - [ ] Utility functions
+ - [ ] Configuration management
+ - [ ] Version checking
+- [ ] Integration Tests
+ - [ ] CLI commands (`doctor`, `init`)
+ - [ ] Project creation workflow
+ - [ ] Template application
+ - [ ] Error handling
+- [ ] Shell Tests
+ - [ ] Session start scripts
+ - [ ] Environment setup
+ - [ ] Tool validation
+- [ ] Test Coverage
+ - [ ] Set up coverage reporting
+ - [ ] Achieve >80% coverage
+
+### 2. Add Detailed Documentation
+- [ ] API Documentation
+ - [ ] CLI command reference
+ - [ ] Configuration options
+ - [ ] Template structure
+- [ ] User Guides
+ - [ ] Getting started guide
+ - [ ] Template customization
+ - [ ] Framework integration
+- [ ] Contributing Guidelines
+ - [ ] Development setup
+ - [ ] Code style guide
+ - [ ] Pull request process
+- [ ] Package Documentation
+ - [ ] Update README.md
+ - [ ] Add examples
+ - [ ] Document installation options
+
+### 3. Set up Continuous Integration
+- [ ] GitHub Actions Workflow
+ - [ ] Automated testing
+ - [ ] Code linting
+ - [ ] Coverage reporting
+- [ ] Release Management
+ - [ ] Version bumping
+ - [ ] Changelog generation
+ - [ ] Tag creation
+- [ ] Package Publishing
+ - [ ] npm publish automation
+ - [ ] Package verification
+
+### 4. Prepare for npm Publication
+- [ ] Package Configuration
+ - [ ] Update package.json metadata
+ - [ ] Add keywords
+ - [ ] Set up package scope
+- [ ] Access Control
+ - [ ] Configure package access
+ - [ ] Set up maintainers
+- [ ] Release Planning
+ - [ ] Create release checklist
+ - [ ] Plan version strategy
+ - [ ] Document release process
+
+## Technical Details
+- Test Framework: Jest for unit/integration tests, BATS for shell tests
+- Documentation: Markdown files in `/docs` directory
+- CI/CD: GitHub Actions
+- Package Manager: npm
+
+## Dependencies
+- Node.js >=16.0.0
+- npm >=8.0.0
+- Git for version control
+- GitHub Actions for CI/CD
+
+## Success Criteria
+- All tests passing with >80% coverage
+- Documentation complete and reviewed
+- CI/CD pipeline operational
+- Package successfully published to npm
+- Sample projects working with published package
+
+## Additional Notes
+- Focus on maintainability and extensibility
+- Ensure clear error messages and user feedback
+- Document all breaking changes
+- Consider backward compatibility
+- Plan for future enhancements
diff --git a/.github/ISSUE_TEMPLATE/task.md b/.github/ISSUE_TEMPLATE/task.md
new file mode 100644
index 0000000..d824ac6
--- /dev/null
+++ b/.github/ISSUE_TEMPLATE/task.md
@@ -0,0 +1,26 @@
+---
+name: Task
+about: A development task that needs to be completed
+title: ''
+labels: task
+assignees: ''
+---
+
+## Description
+
+
+## Acceptance Criteria
+
+
+- [ ] Requirement 1
+- [ ] Requirement 2
+- [ ] Requirement 3
+
+## Technical Details
+
+
+## Dependencies
+
+
+## Additional Context
+
diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml
new file mode 100644
index 0000000..01f5e55
--- /dev/null
+++ b/.github/workflows/test.yml
@@ -0,0 +1,54 @@
+name: Tests
+
+on:
+ push:
+ branches: [ main, develop ]
+ pull_request:
+ branches: [ main, develop ]
+
+jobs:
+ test:
+ runs-on: ubuntu-latest
+
+ strategy:
+ matrix:
+ node-version: [16.x, 18.x]
+
+ steps:
+ - uses: actions/checkout@v3
+
+ - name: Use Node.js ${{ matrix.node-version }}
+ uses: actions/setup-node@v3
+ with:
+ node-version: ${{ matrix.node-version }}
+
+ - name: Install dependencies
+ run: npm ci
+
+ - name: Install BATS
+ run: npm install -g bats
+
+ - name: Install shellcheck
+ run: sudo apt-get install -y shellcheck
+
+ - name: Install yq
+ run: |
+ wget https://github.com/mikefarah/yq/releases/latest/download/yq_linux_amd64 -O /usr/local/bin/yq
+ chmod +x /usr/local/bin/yq
+
+ - name: Run shell script linting
+ run: npm run lint:shell
+
+ - name: Run unit tests
+ run: npm run test:unit
+
+ - name: Run shell tests
+ run: npm run test:shell
+
+ - name: Upload coverage reports
+ uses: codecov/codecov-action@v3
+ with:
+ token: ${{ secrets.CODECOV_TOKEN }}
+ files: ./coverage/lcov.info
+ flags: unittests
+ name: codecov-umbrella
diff --git a/.npmignore b/.npmignore
new file mode 100644
index 0000000..3abf512
--- /dev/null
+++ b/.npmignore
@@ -0,0 +1,30 @@
+# Development files
+tests/
+docs/
+scripts/
+.github/
+.git/
+.gitignore
+.eslintrc*
+.prettierrc*
+jest.config.js
+
+# Editor files
+.vscode/
+.idea/
+*.swp
+*.swo
+
+# Build and coverage
+coverage/
+.nyc_output/
+*.log
+
+# Environment
+.env*
+.env.local
+.env.*.local
+
+# Misc
+*.tgz
+.DS_Store
diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md
new file mode 100644
index 0000000..679cccd
--- /dev/null
+++ b/CONTRIBUTING.md
@@ -0,0 +1,182 @@
+# Contributing to Dev Session Buddy ๐ค
+
+Thank you for your interest in contributing to Dev Session Buddy! This document provides guidelines and workflows for contributing to the project.
+
+## Table of Contents
+- [Code of Conduct](#code-of-conduct)
+- [GitFlow Workflow](#gitflow-workflow)
+- [Getting Started](#getting-started)
+- [Development Process](#development-process)
+- [Pull Request Guidelines](#pull-request-guidelines)
+- [Commit Message Guidelines](#commit-message-guidelines)
+- [Code Style Guidelines](#code-style-guidelines)
+
+## Code of Conduct
+
+By participating in this project, you agree to maintain a respectful and inclusive environment for all contributors.
+
+## GitFlow Workflow
+
+We follow the GitFlow branching strategy:
+
+### Main Branches
+- `main`: Production-ready code
+- `develop`: Integration branch for features
+
+### Supporting Branches
+- `feature/*`: New features
+- `fix/*`: Bug fixes
+- `refactor/*`: Code refactoring
+- `docs/*`: Documentation changes
+- `release/*`: Release preparation
+- `hotfix/*`: Urgent production fixes
+
+### Branch Naming Convention
+- Features: `feature/descriptive-name`
+- Bug fixes: `fix/descriptive-name`
+- Refactoring: `refactor/descriptive-name`
+- Documentation: `docs/descriptive-name`
+
+## Getting Started
+
+1. Fork the repository
+2. Clone your fork:
+ ```bash
+ git clone https://github.com/your-username/dev-session-buddy.git
+ ```
+3. Add upstream remote:
+ ```bash
+ git remote add upstream https://github.com/codevalve/dev-session-buddy.git
+ ```
+4. Create a feature branch from `develop`:
+ ```bash
+ git checkout develop
+ git pull upstream develop
+ git checkout -b feature/your-feature-name
+ ```
+
+## Development Process
+
+1. **Start from Develop**
+ ```bash
+ git checkout develop
+ git pull upstream develop
+ ```
+
+2. **Create Feature Branch**
+ ```bash
+ git checkout -b feature/your-feature-name
+ ```
+
+3. **Make Changes**
+ - Write code
+ - Add tests if applicable
+ - Update documentation
+
+4. **Commit Changes**
+ ```bash
+ git add .
+ git commit -m "type(scope): description"
+ ```
+
+5. **Push Changes**
+ ```bash
+ git push origin feature/your-feature-name
+ ```
+
+6. **Create Pull Request**
+ - Target the `develop` branch
+ - Fill out PR template
+ - Link related issues
+
+## Pull Request Guidelines
+
+1. **Title Format**
+ - Use the format: `type: description`
+ - Example: `feat: add new template for React projects`
+
+2. **Description**
+ - Explain the changes made
+ - List any breaking changes
+ - Reference related issues
+
+3. **Checklist**
+ - [ ] Tests added/updated (if applicable)
+ - [ ] Documentation updated
+ - [ ] Follows code style guidelines
+ - [ ] Commit messages follow guidelines
+
+4. **Review Process**
+ - At least one approval required
+ - All discussions resolved
+ - CI checks passing
+
+## Commit Message Guidelines
+
+Follow the Conventional Commits specification:
+
+```
+type(scope): description
+
+[optional body]
+
+[optional footer]
+```
+
+### Types
+- `feat`: New feature
+- `fix`: Bug fix
+- `docs`: Documentation changes
+- `style`: Code style changes (formatting, etc.)
+- `refactor`: Code refactoring
+- `test`: Adding or updating tests
+- `chore`: Maintenance tasks
+
+### Scopes
+- `core`: Core functionality
+- `templates`: Template-related changes
+- `docs`: Documentation
+- `deps`: Dependencies
+- `ci`: CI/CD changes
+
+Example:
+```
+feat(templates): add React project template
+
+- Add basic React template
+- Include React-specific configuration
+- Update documentation
+
+Closes #123
+```
+
+## Code Style Guidelines
+
+1. **Shell Scripts**
+ - Use shellcheck for linting
+ - Add comments for complex logic
+ - Use meaningful variable names
+
+2. **JavaScript/Node.js**
+ - Follow ESLint configuration
+ - Use meaningful variable names
+ - Add JSDoc comments for functions
+
+3. **YAML Configuration**
+ - Use consistent indentation (2 spaces)
+ - Add comments for clarity
+ - Keep files organized by section
+
+4. **Documentation**
+ - Use clear, concise language
+ - Include code examples
+ - Keep formatting consistent
+
+## Questions or Need Help?
+
+Feel free to:
+- Open an issue for questions
+- Join discussions in existing issues
+- Reach out to maintainers
+
+Thank you for contributing to Dev Session Buddy! ๐
diff --git a/README.md b/README.md
index 6c4274c..7c3fdeb 100644
--- a/README.md
+++ b/README.md
@@ -4,6 +4,15 @@
+
+
+[](https://github.com/codevalve/dev-session-buddy/actions/workflows/test.yml)
+[](https://opensource.org/licenses/MIT)
+[](https://nodejs.org)
+[](https://github.com/codevalve/dev-session-buddy/blob/main/CONTRIBUTING.md)
+
+
+
Born from the experience of pair programming with AI assistants, Dev Session Buddy is a smart development session startup script that standardizes how project context, tooling, and development standards are communicated to both human and AI collaborators.
## Origin Story ๐
@@ -31,7 +40,304 @@ Dev Session Buddy aims to:
## Getting Started ๐
-[Coming Soon]
+### Prerequisites
+
+Before using Dev Session Buddy, ensure you have the following installed:
+- Git (for version control)
+- Node.js (v16 or higher)
+- npm (usually comes with Node.js)
+- yq (for YAML processing) - Install with:
+ ```bash
+ # On macOS
+ brew install yq
+
+ # On Linux
+ sudo wget -qO /usr/local/bin/yq https://github.com/mikefarah/yq/releases/latest/download/yq_linux_amd64
+ sudo chmod +x /usr/local/bin/yq
+ ```
+
+### Installation
+
+1. Clone the repository:
+ ```bash
+ git clone https://github.com/codevalve/dev-session-buddy.git
+ ```
+
+2. Install dependencies:
+ ```bash
+ cd dev-session-buddy
+ npm install
+ ```
+
+### Project Setup
+
+1. Copy the template for your framework (currently supporting Vue.js):
+ ```bash
+ cp -r src/templates/vue/* /path/to/your/project
+ ```
+
+2. Create a configuration file in your project:
+ ```bash
+ # Either in project root
+ touch dev-session-buddy.yaml
+
+ # Or in config directory
+ mkdir -p config
+ touch config/default.yaml
+ ```
+
+3. Configure your project settings (example configuration):
+ ```yaml
+ name: "My Project"
+ tools:
+ required:
+ - git
+ - node
+ - npm
+ optional:
+ - gh
+ - docker
+ - aws-cli
+ standards:
+ - "Follow project coding standards"
+ - "Write clear commit messages"
+ - "Document complex logic"
+ ```
+
+### Usage
+
+Start a new development session:
+```bash
+./session-start.sh
+```
+
+This will:
+1. Display project context and standards
+2. Verify required tools are installed
+3. Show git status and recent commits
+4. Present development workflow guidance
+5. Provide framework-specific best practices
+
+### Example Output
+
+```
+=== My Project Development Session Start ===
+
+Current branch: develop
+
+Quick Reference:
+1. Branch naming:
+ - features: feature/descriptive-name
+ - fixes: fix/descriptive-name
+ - refactors: refactor/descriptive-name
+2. Commit format:
+ type(scope): description
+ Scopes: ui|api|docs|deps
+
+Recent commits:
+abc1234 feat: add new feature
+def5678 fix: resolve bug
+ghi9012 docs: update README
+
+Development Environment:
+- Git (required)
+- Node.js (required)
+- npm (required)
+- Docker (optional)
+
+=== Ready to Code! ===
+```
+
+### Project Structure
+```
+dev-session-buddy/
+โโโ src/
+โ โโโ core/ # Core functionality
+โ โโโ templates/ # Framework-specific templates
+โ โโโ utils/ # Utility functions
+โโโ config/ # Default configurations
+โโโ docs/ # Documentation
+```
+
+### Common Configurations
+
+Here are some common configuration examples:
+
+```yaml
+# Basic configuration
+name: "My Project"
+tools:
+ required:
+ - git
+ - node
+ optional:
+ - docker
+
+# Full configuration with all options
+name: "Advanced Project"
+description: "A complex project with multiple tools"
+tools:
+ required:
+ - git
+ - node
+ - npm
+ - python3
+ optional:
+ - docker
+ - aws-cli
+ - terraform
+standards:
+ - "Use TypeScript for new features"
+ - "Write unit tests for all components"
+ - "Follow GitFlow branching strategy"
+git:
+ main_branch: main
+ develop_branch: develop
+ feature_prefix: feature
+ fix_prefix: fix
+frameworks:
+ - vue
+ - typescript
+ci:
+ provider: github-actions
+ node_versions:
+ - 16
+ - 18
+```
+
+### Advanced Usage
+
+#### Custom Templates
+
+Create a custom template for your framework:
+
+1. Create a new directory in `src/templates/`:
+ ```bash
+ mkdir src/templates/my-framework
+ ```
+
+2. Add required files:
+ - `session-start.sh`: Main script
+ - `config-template.yaml`: Default configuration
+ - `README.md`: Template documentation
+
+#### Multiple Projects
+
+Use Dev Session Buddy across multiple projects:
+
+1. Install globally:
+ ```bash
+ npm install -g @devsessionbuddy/cli
+ ```
+
+2. Initialize in any project:
+ ```bash
+ dsb init --framework vue
+ ```
+
+### Troubleshooting
+
+Common issues and solutions:
+
+1. **Script Permission Errors**
+ ```bash
+ chmod +x session-start.sh
+ ```
+
+2. **Missing Dependencies**
+ - Ensure Node.js version is 16 or higher
+ - Run `npm install` in project root
+ - Check PATH for required tools
+
+3. **Configuration Not Found**
+ - Ensure config file is in project root or config/
+ - Check file permissions
+ - Validate YAML syntax
+
+4. **Git Integration Issues**
+ - Ensure you're in a git repository
+ - Check git installation: `git --version`
+ - Verify git remote configuration
+
+5. **Framework Template Issues**
+ - Verify template exists for your framework
+ - Check template files permissions
+ - Ensure all template files were copied
+
+For more complex issues:
+1. Enable debug mode: `DEBUG=true ./session-start.sh`
+2. Check logs in `~/.dev-session-buddy/logs/`
+3. [Open an issue](https://github.com/codevalve/dev-session-buddy/issues) with debug output
+
+## Testing ๐งช
+
+Dev Session Buddy uses a comprehensive testing approach with both JavaScript and shell script testing:
+
+### Test Frameworks
+
+- **Jest**: For JavaScript unit testing
+ - Configuration validation
+ - Project structure verification
+ - Utility function testing
+
+- **BATS** (Bash Automated Testing System): For shell script testing
+ - Script functionality verification
+ - Environment setup testing
+ - Tool availability checks
+
+### Running Tests
+
+```bash
+# Run all tests
+npm test
+
+# Run only JavaScript tests
+npm run test:unit
+
+# Run only shell script tests
+npm run test:shell
+
+# Run shell script linting
+npm run lint:shell
+
+# Run tests in watch mode (during development)
+npm run test:watch
+
+# Generate test coverage report
+npm run test:coverage
+```
+
+### Test Structure
+
+```
+tests/
+โโโ unit/ # JavaScript unit tests
+โ โโโ config.test.js
+โโโ integration/ # Integration tests
+โโโ shell/ # Shell script tests
+โ โโโ session-start.bats
+โโโ test_helper.bash # Test helper functions
+```
+
+### Writing Tests
+
+1. **JavaScript Tests**
+ - Place in `tests/unit/` or `tests/integration/`
+ - Use `.test.js` or `.spec.js` extension
+ - Follow Jest testing patterns
+
+2. **Shell Script Tests**
+ - Place in `tests/shell/`
+ - Use `.bats` extension
+ - Import test helper: `load '../test_helper'`
+
+### Coverage Reports
+
+Test coverage reports are generated in the `coverage/` directory after running `npm run test:coverage`. The project aims for:
+
+- Line coverage: 80%
+- Branch coverage: 80%
+- Function coverage: 90%
## Configuration ๐ง
diff --git a/bin/create-dev-session-buddy.js b/bin/create-dev-session-buddy.js
new file mode 100755
index 0000000..b17ecc5
--- /dev/null
+++ b/bin/create-dev-session-buddy.js
@@ -0,0 +1,64 @@
+#!/usr/bin/env node
+import { Command } from 'commander';
+import inquirer from 'inquirer';
+import chalk from 'chalk';
+import ora from 'ora';
+import { fileURLToPath } from 'url';
+import { dirname, join } from 'path';
+import { TemplateManager } from '../src/template-manager.js';
+
+const __filename = fileURLToPath(import.meta.url);
+const __dirname = dirname(__filename);
+
+const program = new Command();
+
+program
+ .version('0.1.0')
+ .description('Create a new project with Dev Session Buddy')
+ .argument('[name]', 'Project name')
+ .option('-f, --framework ', 'Framework to use (minimal, vue)')
+ .option('-p, --preset ', 'Configuration preset (minimal, full, team)')
+ .action(async (name, options) => {
+ try {
+ // If no name provided, prompt for it
+ if (!name) {
+ const answers = await inquirer.prompt([
+ {
+ type: 'input',
+ name: 'projectName',
+ message: 'What is your project name?',
+ validate: input => input.length > 0 || 'Project name is required'
+ }
+ ]);
+ name = answers.projectName;
+ }
+
+ // Create project directory
+ const projectDir = join(process.cwd(), name);
+ const spinner = ora('Creating new project...').start();
+
+ try {
+ const framework = options.framework || 'minimal';
+ const preset = options.preset || 'full';
+
+ const templateManager = new TemplateManager();
+ await templateManager.applyTemplate(projectDir, framework, preset);
+
+ spinner.succeed('Project created successfully!');
+
+ console.log('\nNext steps:');
+ console.log(`1. cd ${name}`);
+ console.log('2. npm install');
+ console.log('3. npm start');
+ } catch (error) {
+ spinner.fail('Project creation failed');
+ console.error(chalk.red(error.message));
+ process.exit(1);
+ }
+ } catch (error) {
+ console.error(chalk.red(error.message));
+ process.exit(1);
+ }
+ });
+
+program.parse(process.argv);
diff --git a/bin/dev-session-buddy.js b/bin/dev-session-buddy.js
new file mode 100755
index 0000000..5be7aa2
--- /dev/null
+++ b/bin/dev-session-buddy.js
@@ -0,0 +1,147 @@
+#!/usr/bin/env node
+import { Command } from 'commander';
+import inquirer from 'inquirer';
+import chalk from 'chalk';
+import ora from 'ora';
+import { fileURLToPath } from 'url';
+import { dirname, join } from 'path';
+import { TemplateManager } from '../src/template-manager.js';
+import { commandExists, getToolVersion, checkVersion } from '../src/utils.js';
+
+const __filename = fileURLToPath(import.meta.url);
+const __dirname = dirname(__filename);
+
+const program = new Command();
+
+program
+ .version('0.1.0')
+ .description('Dev Session Buddy - Your AI-Powered Development Companion');
+
+program
+ .command('doctor')
+ .description('Check development environment setup')
+ .action(async () => {
+ const spinner = ora('Checking environment').start();
+
+ try {
+ const checks = [
+ {
+ name: 'Node.js',
+ version: process.version,
+ required: '>=16.0.0',
+ command: 'node',
+ versionCommand: 'node --version'
+ },
+ {
+ name: 'npm',
+ required: '>=8.0.0',
+ command: 'npm',
+ versionCommand: 'npm --version'
+ },
+ {
+ name: 'Git',
+ required: '>=2.0.0',
+ command: 'git',
+ versionCommand: 'git --version'
+ },
+ {
+ name: 'yq',
+ required: '>=4.0.0',
+ command: 'yq',
+ versionCommand: 'yq --version'
+ }
+ ];
+
+ const results = [];
+
+ for (const check of checks) {
+ const exists = await commandExists(check.command);
+ if (!exists) {
+ results.push({
+ name: check.name,
+ status: 'missing',
+ message: `${check.name} is not installed`
+ });
+ continue;
+ }
+
+ const version = check.version || await getToolVersion(check.versionCommand);
+ if (!version) {
+ results.push({
+ name: check.name,
+ status: 'error',
+ message: `Could not determine ${check.name} version`
+ });
+ continue;
+ }
+
+ const isValid = checkVersion(version, check.required);
+ results.push({
+ name: check.name,
+ status: isValid ? 'ok' : 'outdated',
+ version,
+ required: check.required,
+ message: isValid ? null : `${check.name} version ${version} does not meet requirement ${check.required}`
+ });
+ }
+
+ spinner.succeed('Environment check complete');
+
+ // Display results
+ console.log('');
+ for (const result of results) {
+ const icon = {
+ ok: chalk.green('โ'),
+ outdated: chalk.yellow('!'),
+ missing: chalk.red('โ'),
+ error: chalk.red('โ')
+ }[result.status];
+
+ const version = result.version ? `: ${result.version}` : '';
+ console.log(`${icon} ${result.name}${version}`);
+
+ if (result.message) {
+ console.log(` ${chalk.dim(result.message)}`);
+ }
+ }
+
+ // Exit with error if any checks failed
+ const hasErrors = results.some(r => ['missing', 'error', 'outdated'].includes(r.status));
+ if (hasErrors) {
+ process.exit(1);
+ }
+ } catch (error) {
+ spinner.fail('Environment check failed');
+ console.error(chalk.red(error.message));
+ process.exit(1);
+ }
+ });
+
+program
+ .command('init')
+ .description('Initialize Dev Session Buddy in an existing project')
+ .option('-f, --framework ', 'Framework to use (minimal, vue)')
+ .option('-p, --preset ', 'Configuration preset (minimal, full, team)')
+ .action(async (options) => {
+ const spinner = ora('Initializing Dev Session Buddy').start();
+
+ try {
+ const framework = options.framework || 'minimal';
+ const preset = options.preset || 'full';
+
+ const templateManager = new TemplateManager();
+ await templateManager.applyTemplate(process.cwd(), framework, preset);
+
+ spinner.succeed('Dev Session Buddy initialized successfully!');
+
+ console.log('\nNext steps:');
+ console.log('1. Review the configuration in dev-session-buddy.yaml');
+ console.log('2. Run ./session-start.sh to begin your development session');
+ } catch (error) {
+ spinner.fail('Initialization failed');
+ console.error(chalk.red(error.message));
+ process.exit(1);
+ }
+ });
+
+program.parse(process.argv);
diff --git a/config.yaml b/config.yaml
new file mode 100644
index 0000000..91e335c
--- /dev/null
+++ b/config.yaml
@@ -0,0 +1,8 @@
+framework: vue
+dependencies:
+ required:
+ - vue
+ - vite
+ dev:
+ - jest
+ - eslint
diff --git a/coverage/lcov-report/base.css b/coverage/lcov-report/base.css
new file mode 100644
index 0000000..f418035
--- /dev/null
+++ b/coverage/lcov-report/base.css
@@ -0,0 +1,224 @@
+body, html {
+ margin:0; padding: 0;
+ height: 100%;
+}
+body {
+ font-family: Helvetica Neue, Helvetica, Arial;
+ font-size: 14px;
+ color:#333;
+}
+.small { font-size: 12px; }
+*, *:after, *:before {
+ -webkit-box-sizing:border-box;
+ -moz-box-sizing:border-box;
+ box-sizing:border-box;
+ }
+h1 { font-size: 20px; margin: 0;}
+h2 { font-size: 14px; }
+pre {
+ font: 12px/1.4 Consolas, "Liberation Mono", Menlo, Courier, monospace;
+ margin: 0;
+ padding: 0;
+ -moz-tab-size: 2;
+ -o-tab-size: 2;
+ tab-size: 2;
+}
+a { color:#0074D9; text-decoration:none; }
+a:hover { text-decoration:underline; }
+.strong { font-weight: bold; }
+.space-top1 { padding: 10px 0 0 0; }
+.pad2y { padding: 20px 0; }
+.pad1y { padding: 10px 0; }
+.pad2x { padding: 0 20px; }
+.pad2 { padding: 20px; }
+.pad1 { padding: 10px; }
+.space-left2 { padding-left:55px; }
+.space-right2 { padding-right:20px; }
+.center { text-align:center; }
+.clearfix { display:block; }
+.clearfix:after {
+ content:'';
+ display:block;
+ height:0;
+ clear:both;
+ visibility:hidden;
+ }
+.fl { float: left; }
+@media only screen and (max-width:640px) {
+ .col3 { width:100%; max-width:100%; }
+ .hide-mobile { display:none!important; }
+}
+
+.quiet {
+ color: #7f7f7f;
+ color: rgba(0,0,0,0.5);
+}
+.quiet a { opacity: 0.7; }
+
+.fraction {
+ font-family: Consolas, 'Liberation Mono', Menlo, Courier, monospace;
+ font-size: 10px;
+ color: #555;
+ background: #E8E8E8;
+ padding: 4px 5px;
+ border-radius: 3px;
+ vertical-align: middle;
+}
+
+div.path a:link, div.path a:visited { color: #333; }
+table.coverage {
+ border-collapse: collapse;
+ margin: 10px 0 0 0;
+ padding: 0;
+}
+
+table.coverage td {
+ margin: 0;
+ padding: 0;
+ vertical-align: top;
+}
+table.coverage td.line-count {
+ text-align: right;
+ padding: 0 5px 0 20px;
+}
+table.coverage td.line-coverage {
+ text-align: right;
+ padding-right: 10px;
+ min-width:20px;
+}
+
+table.coverage td span.cline-any {
+ display: inline-block;
+ padding: 0 5px;
+ width: 100%;
+}
+.missing-if-branch {
+ display: inline-block;
+ margin-right: 5px;
+ border-radius: 3px;
+ position: relative;
+ padding: 0 4px;
+ background: #333;
+ color: yellow;
+}
+
+.skip-if-branch {
+ display: none;
+ margin-right: 10px;
+ position: relative;
+ padding: 0 4px;
+ background: #ccc;
+ color: white;
+}
+.missing-if-branch .typ, .skip-if-branch .typ {
+ color: inherit !important;
+}
+.coverage-summary {
+ border-collapse: collapse;
+ width: 100%;
+}
+.coverage-summary tr { border-bottom: 1px solid #bbb; }
+.keyline-all { border: 1px solid #ddd; }
+.coverage-summary td, .coverage-summary th { padding: 10px; }
+.coverage-summary tbody { border: 1px solid #bbb; }
+.coverage-summary td { border-right: 1px solid #bbb; }
+.coverage-summary td:last-child { border-right: none; }
+.coverage-summary th {
+ text-align: left;
+ font-weight: normal;
+ white-space: nowrap;
+}
+.coverage-summary th.file { border-right: none !important; }
+.coverage-summary th.pct { }
+.coverage-summary th.pic,
+.coverage-summary th.abs,
+.coverage-summary td.pct,
+.coverage-summary td.abs { text-align: right; }
+.coverage-summary td.file { white-space: nowrap; }
+.coverage-summary td.pic { min-width: 120px !important; }
+.coverage-summary tfoot td { }
+
+.coverage-summary .sorter {
+ height: 10px;
+ width: 7px;
+ display: inline-block;
+ margin-left: 0.5em;
+ background: url(sort-arrow-sprite.png) no-repeat scroll 0 0 transparent;
+}
+.coverage-summary .sorted .sorter {
+ background-position: 0 -20px;
+}
+.coverage-summary .sorted-desc .sorter {
+ background-position: 0 -10px;
+}
+.status-line { height: 10px; }
+/* yellow */
+.cbranch-no { background: yellow !important; color: #111; }
+/* dark red */
+.red.solid, .status-line.low, .low .cover-fill { background:#C21F39 }
+.low .chart { border:1px solid #C21F39 }
+.highlighted,
+.highlighted .cstat-no, .highlighted .fstat-no, .highlighted .cbranch-no{
+ background: #C21F39 !important;
+}
+/* medium red */
+.cstat-no, .fstat-no, .cbranch-no, .cbranch-no { background:#F6C6CE }
+/* light red */
+.low, .cline-no { background:#FCE1E5 }
+/* light green */
+.high, .cline-yes { background:rgb(230,245,208) }
+/* medium green */
+.cstat-yes { background:rgb(161,215,106) }
+/* dark green */
+.status-line.high, .high .cover-fill { background:rgb(77,146,33) }
+.high .chart { border:1px solid rgb(77,146,33) }
+/* dark yellow (gold) */
+.status-line.medium, .medium .cover-fill { background: #f9cd0b; }
+.medium .chart { border:1px solid #f9cd0b; }
+/* light yellow */
+.medium { background: #fff4c2; }
+
+.cstat-skip { background: #ddd; color: #111; }
+.fstat-skip { background: #ddd; color: #111 !important; }
+.cbranch-skip { background: #ddd !important; color: #111; }
+
+span.cline-neutral { background: #eaeaea; }
+
+.coverage-summary td.empty {
+ opacity: .5;
+ padding-top: 4px;
+ padding-bottom: 4px;
+ line-height: 1;
+ color: #888;
+}
+
+.cover-fill, .cover-empty {
+ display:inline-block;
+ height: 12px;
+}
+.chart {
+ line-height: 0;
+}
+.cover-empty {
+ background: white;
+}
+.cover-full {
+ border-right: none !important;
+}
+pre.prettyprint {
+ border: none !important;
+ padding: 0 !important;
+ margin: 0 !important;
+}
+.com { color: #999 !important; }
+.ignore-none { color: #999; font-weight: normal; }
+
+.wrapper {
+ min-height: 100%;
+ height: auto !important;
+ height: 100%;
+ margin: 0 auto -48px;
+}
+.footer, .push {
+ height: 48px;
+}
diff --git a/coverage/lcov-report/block-navigation.js b/coverage/lcov-report/block-navigation.js
new file mode 100644
index 0000000..cc12130
--- /dev/null
+++ b/coverage/lcov-report/block-navigation.js
@@ -0,0 +1,87 @@
+/* eslint-disable */
+var jumpToCode = (function init() {
+ // Classes of code we would like to highlight in the file view
+ var missingCoverageClasses = ['.cbranch-no', '.cstat-no', '.fstat-no'];
+
+ // Elements to highlight in the file listing view
+ var fileListingElements = ['td.pct.low'];
+
+ // We don't want to select elements that are direct descendants of another match
+ var notSelector = ':not(' + missingCoverageClasses.join('):not(') + ') > '; // becomes `:not(a):not(b) > `
+
+ // Selecter that finds elements on the page to which we can jump
+ var selector =
+ fileListingElements.join(', ') +
+ ', ' +
+ notSelector +
+ missingCoverageClasses.join(', ' + notSelector); // becomes `:not(a):not(b) > a, :not(a):not(b) > b`
+
+ // The NodeList of matching elements
+ var missingCoverageElements = document.querySelectorAll(selector);
+
+ var currentIndex;
+
+ function toggleClass(index) {
+ missingCoverageElements
+ .item(currentIndex)
+ .classList.remove('highlighted');
+ missingCoverageElements.item(index).classList.add('highlighted');
+ }
+
+ function makeCurrent(index) {
+ toggleClass(index);
+ currentIndex = index;
+ missingCoverageElements.item(index).scrollIntoView({
+ behavior: 'smooth',
+ block: 'center',
+ inline: 'center'
+ });
+ }
+
+ function goToPrevious() {
+ var nextIndex = 0;
+ if (typeof currentIndex !== 'number' || currentIndex === 0) {
+ nextIndex = missingCoverageElements.length - 1;
+ } else if (missingCoverageElements.length > 1) {
+ nextIndex = currentIndex - 1;
+ }
+
+ makeCurrent(nextIndex);
+ }
+
+ function goToNext() {
+ var nextIndex = 0;
+
+ if (
+ typeof currentIndex === 'number' &&
+ currentIndex < missingCoverageElements.length - 1
+ ) {
+ nextIndex = currentIndex + 1;
+ }
+
+ makeCurrent(nextIndex);
+ }
+
+ return function jump(event) {
+ if (
+ document.getElementById('fileSearch') === document.activeElement &&
+ document.activeElement != null
+ ) {
+ // if we're currently focused on the search input, we don't want to navigate
+ return;
+ }
+
+ switch (event.which) {
+ case 78: // n
+ case 74: // j
+ goToNext();
+ break;
+ case 66: // b
+ case 75: // k
+ case 80: // p
+ goToPrevious();
+ break;
+ }
+ };
+})();
+window.addEventListener('keydown', jumpToCode);
diff --git a/coverage/lcov-report/favicon.png b/coverage/lcov-report/favicon.png
new file mode 100644
index 0000000..c1525b8
Binary files /dev/null and b/coverage/lcov-report/favicon.png differ
diff --git a/coverage/lcov-report/index.html b/coverage/lcov-report/index.html
new file mode 100644
index 0000000..7826e0f
--- /dev/null
+++ b/coverage/lcov-report/index.html
@@ -0,0 +1,131 @@
+
+
+
+
+
+ Code coverage report for All files
+
+
+
+
+
+
+
+
+
+
+
+
All files
+
+
+
+ 42.3%
+ Statements
+ 33/78
+
+
+
+
+ 53.57%
+ Branches
+ 15/28
+
+
+
+
+ 50%
+ Functions
+ 6/12
+
+
+
+
+ 41.09%
+ Lines
+ 30/73
+
+
+
+
+
+ Press n or j to go to the next uncovered block, b, p or k for the previous block.
+
+
+
+ Filter:
+
+
+
+
+
+
+
+
+
+ | File |
+ |
+ Statements |
+ |
+ Branches |
+ |
+ Functions |
+ |
+ Lines |
+ |
+
+
+
+ | template-manager.js |
+
+
+ |
+ 10.34% |
+ 3/29 |
+ 0% |
+ 0/6 |
+ 20% |
+ 1/5 |
+ 10.71% |
+ 3/28 |
+
+
+
+ | utils.js |
+
+
+ |
+ 61.22% |
+ 30/49 |
+ 68.18% |
+ 15/22 |
+ 71.42% |
+ 5/7 |
+ 60% |
+ 27/45 |
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/coverage/lcov-report/prettify.css b/coverage/lcov-report/prettify.css
new file mode 100644
index 0000000..b317a7c
--- /dev/null
+++ b/coverage/lcov-report/prettify.css
@@ -0,0 +1 @@
+.pln{color:#000}@media screen{.str{color:#080}.kwd{color:#008}.com{color:#800}.typ{color:#606}.lit{color:#066}.pun,.opn,.clo{color:#660}.tag{color:#008}.atn{color:#606}.atv{color:#080}.dec,.var{color:#606}.fun{color:red}}@media print,projection{.str{color:#060}.kwd{color:#006;font-weight:bold}.com{color:#600;font-style:italic}.typ{color:#404;font-weight:bold}.lit{color:#044}.pun,.opn,.clo{color:#440}.tag{color:#006;font-weight:bold}.atn{color:#404}.atv{color:#060}}pre.prettyprint{padding:2px;border:1px solid #888}ol.linenums{margin-top:0;margin-bottom:0}li.L0,li.L1,li.L2,li.L3,li.L5,li.L6,li.L7,li.L8{list-style-type:none}li.L1,li.L3,li.L5,li.L7,li.L9{background:#eee}
diff --git a/coverage/lcov-report/prettify.js b/coverage/lcov-report/prettify.js
new file mode 100644
index 0000000..b322523
--- /dev/null
+++ b/coverage/lcov-report/prettify.js
@@ -0,0 +1,2 @@
+/* eslint-disable */
+window.PR_SHOULD_USE_CONTINUATION=true;(function(){var h=["break,continue,do,else,for,if,return,while"];var u=[h,"auto,case,char,const,default,double,enum,extern,float,goto,int,long,register,short,signed,sizeof,static,struct,switch,typedef,union,unsigned,void,volatile"];var p=[u,"catch,class,delete,false,import,new,operator,private,protected,public,this,throw,true,try,typeof"];var l=[p,"alignof,align_union,asm,axiom,bool,concept,concept_map,const_cast,constexpr,decltype,dynamic_cast,explicit,export,friend,inline,late_check,mutable,namespace,nullptr,reinterpret_cast,static_assert,static_cast,template,typeid,typename,using,virtual,where"];var x=[p,"abstract,boolean,byte,extends,final,finally,implements,import,instanceof,null,native,package,strictfp,super,synchronized,throws,transient"];var R=[x,"as,base,by,checked,decimal,delegate,descending,dynamic,event,fixed,foreach,from,group,implicit,in,interface,internal,into,is,lock,object,out,override,orderby,params,partial,readonly,ref,sbyte,sealed,stackalloc,string,select,uint,ulong,unchecked,unsafe,ushort,var"];var r="all,and,by,catch,class,else,extends,false,finally,for,if,in,is,isnt,loop,new,no,not,null,of,off,on,or,return,super,then,true,try,unless,until,when,while,yes";var w=[p,"debugger,eval,export,function,get,null,set,undefined,var,with,Infinity,NaN"];var s="caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END";var I=[h,"and,as,assert,class,def,del,elif,except,exec,finally,from,global,import,in,is,lambda,nonlocal,not,or,pass,print,raise,try,with,yield,False,True,None"];var f=[h,"alias,and,begin,case,class,def,defined,elsif,end,ensure,false,in,module,next,nil,not,or,redo,rescue,retry,self,super,then,true,undef,unless,until,when,yield,BEGIN,END"];var H=[h,"case,done,elif,esac,eval,fi,function,in,local,set,then,until"];var A=[l,R,w,s+I,f,H];var e=/^(DIR|FILE|vector|(de|priority_)?queue|list|stack|(const_)?iterator|(multi)?(set|map)|bitset|u?(int|float)\d*)/;var C="str";var z="kwd";var j="com";var O="typ";var G="lit";var L="pun";var F="pln";var m="tag";var E="dec";var J="src";var P="atn";var n="atv";var N="nocode";var M="(?:^^\\.?|[+-]|\\!|\\!=|\\!==|\\#|\\%|\\%=|&|&&|&&=|&=|\\(|\\*|\\*=|\\+=|\\,|\\-=|\\->|\\/|\\/=|:|::|\\;|<|<<|<<=|<=|=|==|===|>|>=|>>|>>=|>>>|>>>=|\\?|\\@|\\[|\\^|\\^=|\\^\\^|\\^\\^=|\\{|\\||\\|=|\\|\\||\\|\\|=|\\~|break|case|continue|delete|do|else|finally|instanceof|return|throw|try|typeof)\\s*";function k(Z){var ad=0;var S=false;var ac=false;for(var V=0,U=Z.length;V122)){if(!(al<65||ag>90)){af.push([Math.max(65,ag)|32,Math.min(al,90)|32])}if(!(al<97||ag>122)){af.push([Math.max(97,ag)&~32,Math.min(al,122)&~32])}}}}af.sort(function(av,au){return(av[0]-au[0])||(au[1]-av[1])});var ai=[];var ap=[NaN,NaN];for(var ar=0;arat[0]){if(at[1]+1>at[0]){an.push("-")}an.push(T(at[1]))}}an.push("]");return an.join("")}function W(al){var aj=al.source.match(new RegExp("(?:\\[(?:[^\\x5C\\x5D]|\\\\[\\s\\S])*\\]|\\\\u[A-Fa-f0-9]{4}|\\\\x[A-Fa-f0-9]{2}|\\\\[0-9]+|\\\\[^ux0-9]|\\(\\?[:!=]|[\\(\\)\\^]|[^\\x5B\\x5C\\(\\)\\^]+)","g"));var ah=aj.length;var an=[];for(var ak=0,am=0;ak=2&&ai==="["){aj[ak]=X(ag)}else{if(ai!=="\\"){aj[ak]=ag.replace(/[a-zA-Z]/g,function(ao){var ap=ao.charCodeAt(0);return"["+String.fromCharCode(ap&~32,ap|32)+"]"})}}}}return aj.join("")}var aa=[];for(var V=0,U=Z.length;V=0;){S[ac.charAt(ae)]=Y}}var af=Y[1];var aa=""+af;if(!ag.hasOwnProperty(aa)){ah.push(af);ag[aa]=null}}ah.push(/[\0-\uffff]/);V=k(ah)})();var X=T.length;var W=function(ah){var Z=ah.sourceCode,Y=ah.basePos;var ad=[Y,F];var af=0;var an=Z.match(V)||[];var aj={};for(var ae=0,aq=an.length;ae=5&&"lang-"===ap.substring(0,5);if(am&&!(ai&&typeof ai[1]==="string")){am=false;ap=J}if(!am){aj[ag]=ap}}var ab=af;af+=ag.length;if(!am){ad.push(Y+ab,ap)}else{var al=ai[1];var ak=ag.indexOf(al);var ac=ak+al.length;if(ai[2]){ac=ag.length-ai[2].length;ak=ac-al.length}var ar=ap.substring(5);B(Y+ab,ag.substring(0,ak),W,ad);B(Y+ab+ak,al,q(ar,al),ad);B(Y+ab+ac,ag.substring(ac),W,ad)}}ah.decorations=ad};return W}function i(T){var W=[],S=[];if(T.tripleQuotedStrings){W.push([C,/^(?:\'\'\'(?:[^\'\\]|\\[\s\S]|\'{1,2}(?=[^\']))*(?:\'\'\'|$)|\"\"\"(?:[^\"\\]|\\[\s\S]|\"{1,2}(?=[^\"]))*(?:\"\"\"|$)|\'(?:[^\\\']|\\[\s\S])*(?:\'|$)|\"(?:[^\\\"]|\\[\s\S])*(?:\"|$))/,null,"'\""])}else{if(T.multiLineStrings){W.push([C,/^(?:\'(?:[^\\\']|\\[\s\S])*(?:\'|$)|\"(?:[^\\\"]|\\[\s\S])*(?:\"|$)|\`(?:[^\\\`]|\\[\s\S])*(?:\`|$))/,null,"'\"`"])}else{W.push([C,/^(?:\'(?:[^\\\'\r\n]|\\.)*(?:\'|$)|\"(?:[^\\\"\r\n]|\\.)*(?:\"|$))/,null,"\"'"])}}if(T.verbatimStrings){S.push([C,/^@\"(?:[^\"]|\"\")*(?:\"|$)/,null])}var Y=T.hashComments;if(Y){if(T.cStyleComments){if(Y>1){W.push([j,/^#(?:##(?:[^#]|#(?!##))*(?:###|$)|.*)/,null,"#"])}else{W.push([j,/^#(?:(?:define|elif|else|endif|error|ifdef|include|ifndef|line|pragma|undef|warning)\b|[^\r\n]*)/,null,"#"])}S.push([C,/^<(?:(?:(?:\.\.\/)*|\/?)(?:[\w-]+(?:\/[\w-]+)+)?[\w-]+\.h|[a-z]\w*)>/,null])}else{W.push([j,/^#[^\r\n]*/,null,"#"])}}if(T.cStyleComments){S.push([j,/^\/\/[^\r\n]*/,null]);S.push([j,/^\/\*[\s\S]*?(?:\*\/|$)/,null])}if(T.regexLiterals){var X=("/(?=[^/*])(?:[^/\\x5B\\x5C]|\\x5C[\\s\\S]|\\x5B(?:[^\\x5C\\x5D]|\\x5C[\\s\\S])*(?:\\x5D|$))+/");S.push(["lang-regex",new RegExp("^"+M+"("+X+")")])}var V=T.types;if(V){S.push([O,V])}var U=(""+T.keywords).replace(/^ | $/g,"");if(U.length){S.push([z,new RegExp("^(?:"+U.replace(/[\s,]+/g,"|")+")\\b"),null])}W.push([F,/^\s+/,null," \r\n\t\xA0"]);S.push([G,/^@[a-z_$][a-z_$@0-9]*/i,null],[O,/^(?:[@_]?[A-Z]+[a-z][A-Za-z_$@0-9]*|\w+_t\b)/,null],[F,/^[a-z_$][a-z_$@0-9]*/i,null],[G,new RegExp("^(?:0x[a-f0-9]+|(?:\\d(?:_\\d+)*\\d*(?:\\.\\d*)?|\\.\\d\\+)(?:e[+\\-]?\\d+)?)[a-z]*","i"),null,"0123456789"],[F,/^\\[\s\S]?/,null],[L,/^.[^\s\w\.$@\'\"\`\/\#\\]*/,null]);return g(W,S)}var K=i({keywords:A,hashComments:true,cStyleComments:true,multiLineStrings:true,regexLiterals:true});function Q(V,ag){var U=/(?:^|\s)nocode(?:\s|$)/;var ab=/\r\n?|\n/;var ac=V.ownerDocument;var S;if(V.currentStyle){S=V.currentStyle.whiteSpace}else{if(window.getComputedStyle){S=ac.defaultView.getComputedStyle(V,null).getPropertyValue("white-space")}}var Z=S&&"pre"===S.substring(0,3);var af=ac.createElement("LI");while(V.firstChild){af.appendChild(V.firstChild)}var W=[af];function ae(al){switch(al.nodeType){case 1:if(U.test(al.className)){break}if("BR"===al.nodeName){ad(al);if(al.parentNode){al.parentNode.removeChild(al)}}else{for(var an=al.firstChild;an;an=an.nextSibling){ae(an)}}break;case 3:case 4:if(Z){var am=al.nodeValue;var aj=am.match(ab);if(aj){var ai=am.substring(0,aj.index);al.nodeValue=ai;var ah=am.substring(aj.index+aj[0].length);if(ah){var ak=al.parentNode;ak.insertBefore(ac.createTextNode(ah),al.nextSibling)}ad(al);if(!ai){al.parentNode.removeChild(al)}}}break}}function ad(ak){while(!ak.nextSibling){ak=ak.parentNode;if(!ak){return}}function ai(al,ar){var aq=ar?al.cloneNode(false):al;var ao=al.parentNode;if(ao){var ap=ai(ao,1);var an=al.nextSibling;ap.appendChild(aq);for(var am=an;am;am=an){an=am.nextSibling;ap.appendChild(am)}}return aq}var ah=ai(ak.nextSibling,0);for(var aj;(aj=ah.parentNode)&&aj.nodeType===1;){ah=aj}W.push(ah)}for(var Y=0;Y=S){ah+=2}if(V>=ap){Z+=2}}}var t={};function c(U,V){for(var S=V.length;--S>=0;){var T=V[S];if(!t.hasOwnProperty(T)){t[T]=U}else{if(window.console){console.warn("cannot override language handler %s",T)}}}}function q(T,S){if(!(T&&t.hasOwnProperty(T))){T=/^\s*]*(?:>|$)/],[j,/^<\!--[\s\S]*?(?:-\->|$)/],["lang-",/^<\?([\s\S]+?)(?:\?>|$)/],["lang-",/^<%([\s\S]+?)(?:%>|$)/],[L,/^(?:<[%?]|[%?]>)/],["lang-",/^]*>([\s\S]+?)<\/xmp\b[^>]*>/i],["lang-js",/^
+
+
+
+