Add comprehensive development roadmap via GitHub Issues

Created 10 detailed GitHub issues covering:
- Project activation and management UI (#1-2)
- Worker node coordination and visualization (#3-4)
- Automated GitHub repository scanning (#5)
- Intelligent model-to-issue matching (#6)
- Multi-model task execution system (#7)
- N8N workflow integration (#8)
- Hive-Bzzz P2P bridge (#9)
- Peer assistance protocol (#10)

Each issue includes detailed specifications, acceptance criteria,
technical implementation notes, and dependency mapping.

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
anthonyrawlins
2025-07-12 19:41:01 +10:00
parent 9a6a06da89
commit e89f2f4b7b
4980 changed files with 1501266 additions and 57 deletions

View File

@@ -0,0 +1,86 @@
import resolveToValue from './resolveToValue.js';
function isObjectValuesCall(path) {
if (!path.isCallExpression() || path.node.arguments.length !== 1) {
return false;
}
const callee = path.get('callee');
if (!callee.isMemberExpression()) {
return false;
}
const object = callee.get('object');
const property = callee.get('property');
return (object.isIdentifier({ name: 'Object' }) &&
property.isIdentifier({ name: 'values' }));
}
// Resolves an ObjectExpression or an ObjectTypeAnnotation
function resolveObjectToPropMap(object) {
if (object.isObjectExpression()) {
const values = new Map();
let error = false;
object.get('properties').forEach((propPath) => {
if (error || propPath.isObjectMethod())
return;
if (propPath.isObjectProperty()) {
const key = propPath.get('key');
let name;
// Key is either Identifier or Literal
if (key.isIdentifier()) {
name = key.node.name;
}
else if (key.isNumericLiteral() || key.isStringLiteral()) {
name = `${key.node.value}`;
}
else {
error = true;
return;
}
const valuePath = resolveToValue(propPath.get('value'));
const value = valuePath.isStringLiteral()
? `"${valuePath.node.value}"`
: valuePath.isNumericLiteral()
? `${valuePath.node.value}`
: // we return null here because there are a lot of cases and we don't know yet what we need to handle
'null';
values.set(name, value);
}
else if (propPath.isSpreadElement()) {
const spreadObject = resolveToValue(propPath.get('argument'));
const spreadValues = resolveObjectToPropMap(spreadObject);
if (!spreadValues) {
error = true;
return;
}
for (const entry of spreadValues.entries()) {
const [key, value] = entry;
values.set(key, value);
}
}
});
if (!error) {
return values;
}
}
return null;
}
/**
* Returns an ArrayExpression which contains all the values resolved from an object
*
* Ignores setters in objects
*
* Returns null in case of
* unresolvable spreads
* computed identifier values
*/
export default function resolveObjectValuesToArray(path) {
if (isObjectValuesCall(path)) {
const argument = path.get('arguments')[0];
const objectExpression = resolveToValue(
// isObjectValuesCall already asserts that there is at least one argument, hence the non-null-assertion
argument);
const values = resolveObjectToPropMap(objectExpression);
if (values) {
return Array.from(values.values());
}
}
return null;
}