Frontend Enhancements: - Complete React TypeScript frontend with modern UI components - Distributed workflows management interface with real-time updates - Socket.IO integration for live agent status monitoring - Agent management dashboard with cluster visualization - Project management interface with metrics and task tracking - Responsive design with proper error handling and loading states Backend Infrastructure: - Distributed coordinator for multi-agent workflow orchestration - Cluster management API with comprehensive agent operations - Enhanced database models for agents and projects - Project service for filesystem-based project discovery - Performance monitoring and metrics collection - Comprehensive API documentation and error handling Documentation: - Complete distributed development guide (README_DISTRIBUTED.md) - Comprehensive development report with architecture insights - System configuration templates and deployment guides The platform now provides a complete web interface for managing the distributed AI cluster with real-time monitoring, workflow orchestration, and agent coordination capabilities. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
38 lines
1.2 KiB
JavaScript
38 lines
1.2 KiB
JavaScript
function resolveEnd(end, offset, reqSpace, onError) {
|
|
let comment = '';
|
|
if (end) {
|
|
let hasSpace = false;
|
|
let sep = '';
|
|
for (const token of end) {
|
|
const { source, type } = token;
|
|
switch (type) {
|
|
case 'space':
|
|
hasSpace = true;
|
|
break;
|
|
case 'comment': {
|
|
if (reqSpace && !hasSpace)
|
|
onError(token, 'MISSING_CHAR', 'Comments must be separated from other tokens by white space characters');
|
|
const cb = source.substring(1) || ' ';
|
|
if (!comment)
|
|
comment = cb;
|
|
else
|
|
comment += sep + cb;
|
|
sep = '';
|
|
break;
|
|
}
|
|
case 'newline':
|
|
if (comment)
|
|
sep += source;
|
|
hasSpace = true;
|
|
break;
|
|
default:
|
|
onError(token, 'UNEXPECTED_TOKEN', `Unexpected ${type} at node end`);
|
|
}
|
|
offset += source.length;
|
|
}
|
|
}
|
|
return { comment, offset };
|
|
}
|
|
|
|
export { resolveEnd };
|