mirror of
https://github.com/nix-community/dream2nix.git
synced 2024-11-13 08:06:18 +03:00
replace transl. package-lock with package-lock2
This commit is contained in:
parent
a0fd6b565e
commit
d8d0856c96
@ -6,9 +6,33 @@
|
||||
let
|
||||
b = builtins;
|
||||
l = lib // builtins;
|
||||
in
|
||||
|
||||
rec {
|
||||
# One translator call can process a whole workspace containing all
|
||||
# sub-packages of that workspace.
|
||||
# Therefore we can filter out projects which are children of a workspace.
|
||||
filterProjects = projects:
|
||||
let
|
||||
workspaceRoots =
|
||||
l.filter
|
||||
(proj: proj.subsystemInfo.workspaces or [] != [])
|
||||
projects;
|
||||
|
||||
allWorkspaceChildren =
|
||||
l.flatten
|
||||
(l.map
|
||||
(root: root.subsystemInfo.workspaces)
|
||||
workspaceRoots);
|
||||
|
||||
childrenRemoved =
|
||||
l.filter
|
||||
(proj:
|
||||
(! b.elem proj.relPath allWorkspaceChildren))
|
||||
projects;
|
||||
|
||||
in
|
||||
childrenRemoved;
|
||||
|
||||
|
||||
translate =
|
||||
{
|
||||
translatorName,
|
||||
@ -16,31 +40,107 @@ rec {
|
||||
...
|
||||
}:
|
||||
{
|
||||
projects,
|
||||
source,
|
||||
tree,
|
||||
|
||||
name,
|
||||
noDev,
|
||||
nodejs,
|
||||
...
|
||||
}@args:
|
||||
let
|
||||
getPackageLock = project:
|
||||
let
|
||||
# returns the parsed package-lock.json for a given project
|
||||
fileRelPath =
|
||||
if project ? subsystemInfo.workspaceParent then
|
||||
"${project.subsystemInfo.workspaceParent}/package-lock.json"
|
||||
else
|
||||
"${project.relPath}/package-lock.json";
|
||||
in
|
||||
(tree.getNodeFromPath fileRelPath).jsonContent;
|
||||
|
||||
getPackageJson = project:
|
||||
let
|
||||
node = tree.getNodeFromPath "${project.relPath}/package.json";
|
||||
in
|
||||
node.jsonContent;
|
||||
|
||||
filteredProjects = filterProjects projects;
|
||||
|
||||
allProjectsTranslated =
|
||||
l.map
|
||||
(proj:
|
||||
translateOne {
|
||||
inherit translatorName utils name noDev nodejs;
|
||||
source = "${args.source}/${proj.relPath}";
|
||||
tree = tree.getNodeFromPath proj.relPath;
|
||||
packageLock = getPackageLock proj;
|
||||
packageJson = getPackageJson proj;
|
||||
workspaces = proj.subsystemInfo.workspaces or [];
|
||||
})
|
||||
filteredProjects;
|
||||
|
||||
in
|
||||
allProjectsTranslated;
|
||||
|
||||
|
||||
translateOne =
|
||||
{
|
||||
translatorName,
|
||||
utils,
|
||||
source,
|
||||
tree,
|
||||
|
||||
# subsystem specific
|
||||
packageLock,
|
||||
packageJson,
|
||||
workspaces,
|
||||
|
||||
# translator args
|
||||
name,
|
||||
noDev,
|
||||
nodejs,
|
||||
...
|
||||
}@args:
|
||||
let
|
||||
|
||||
b = builtins;
|
||||
|
||||
dev = ! noDev;
|
||||
|
||||
inputDir = source;
|
||||
parsed = packageLock;
|
||||
|
||||
packageLock = "${inputDir}/package-lock.json";
|
||||
workspacePackageJson =
|
||||
l.genAttrs
|
||||
workspaces
|
||||
(wsRelPath:
|
||||
(tree.getNodeFromPath "${wsRelPath}/package.json").jsonContent);
|
||||
|
||||
parsed = b.fromJSON (b.readFile packageLock);
|
||||
workspacePackages =
|
||||
lib.mapAttrs'
|
||||
(wsRelPath: json:
|
||||
l.nameValuePair
|
||||
json.name
|
||||
json.version)
|
||||
workspacePackageJson;
|
||||
|
||||
parsedDependencies = parsed.dependencies or {};
|
||||
rootDependencies =
|
||||
packageLock.dependencies or {};
|
||||
|
||||
packageJsonDeps =
|
||||
packageJson.dependencies or {} // packageJson.devDependencies or {};
|
||||
|
||||
parsedDependencies =
|
||||
l.filterAttrs
|
||||
(name: dep: packageJsonDeps ? "${name}")
|
||||
parsed.dependencies or {};
|
||||
|
||||
identifyGitSource = dependencyObject:
|
||||
# TODO: when integrity is there, and git url is github then use tarball instead
|
||||
# ! (dependencyObject ? integrity) &&
|
||||
utils.identifyGitUrl dependencyObject.version;
|
||||
dlib.identifyGitUrl dependencyObject.version;
|
||||
|
||||
getVersion = dependencyObject:
|
||||
let
|
||||
@ -51,13 +151,13 @@ rec {
|
||||
if npmMatch != null then
|
||||
b.elemAt npmMatch 0
|
||||
else if identifyGitSource dependencyObject then
|
||||
"0.0.0-rc.${b.substring 0 8 (utils.parseGitUrl dependencyObject.version).rev}"
|
||||
"0.0.0-rc.${b.substring 0 8 (dlib.parseGitUrl dependencyObject.version).rev}"
|
||||
else if lib.hasPrefix "file:" dependencyObject.version then
|
||||
let
|
||||
path = getPath dependencyObject;
|
||||
in
|
||||
(b.fromJSON
|
||||
(b.readFile "${inputDir}/${path}/package.json")
|
||||
(b.readFile "${source}/${path}/package.json")
|
||||
).version
|
||||
else if lib.hasPrefix "https://" dependencyObject.version then
|
||||
"unknown"
|
||||
@ -88,7 +188,8 @@ rec {
|
||||
)
|
||||
dependencies;
|
||||
|
||||
packageLockWithPinnedVersions = pinVersions parsedDependencies parsedDependencies;
|
||||
pinnedRootDeps =
|
||||
pinVersions rootDependencies rootDependencies;
|
||||
|
||||
createMissingSource = name: version:
|
||||
{
|
||||
@ -110,18 +211,20 @@ rec {
|
||||
inherit translatorName;
|
||||
|
||||
# values
|
||||
inputData = packageLockWithPinnedVersions;
|
||||
inputData = pinnedRootDeps;
|
||||
|
||||
defaultPackage =
|
||||
if name != "{automatic}" then
|
||||
name
|
||||
else
|
||||
parsed.name or (throw (
|
||||
packageJson.name or (throw (
|
||||
"Could not identify package name. "
|
||||
+ "Please specify extra argument 'name'"
|
||||
));
|
||||
|
||||
packages."${defaultPackage}" = parsed.version or "unknown";
|
||||
packages =
|
||||
{ "${defaultPackage}" = parsed.version or "unknown"; }
|
||||
// workspacePackages;
|
||||
|
||||
mainPackageDependencies =
|
||||
lib.mapAttrsToList
|
||||
@ -178,7 +281,7 @@ rec {
|
||||
sourceConstructors = {
|
||||
|
||||
git = dependencyObject:
|
||||
utils.parseGitUrl dependencyObject.version;
|
||||
dlib.parseGitUrl dependencyObject.version;
|
||||
|
||||
http = dependencyObject:
|
||||
if lib.hasPrefix "https://" dependencyObject.version then
|
||||
@ -209,6 +312,13 @@ rec {
|
||||
getDependencies = dependencyObject:
|
||||
dependencyObject.depsExact;
|
||||
});
|
||||
in
|
||||
|
||||
rec {
|
||||
|
||||
version = 2;
|
||||
|
||||
inherit translate;
|
||||
|
||||
|
||||
projectName =
|
||||
|
@ -1,379 +0,0 @@
|
||||
{
|
||||
dlib,
|
||||
lib,
|
||||
}:
|
||||
|
||||
let
|
||||
b = builtins;
|
||||
l = lib // builtins;
|
||||
|
||||
# One translator call can process a whole workspace containing all
|
||||
# sub-packages of that workspace.
|
||||
# Therefore we can filter out projects which are children of a workspace.
|
||||
filterProjects = projects:
|
||||
let
|
||||
workspaceRoots =
|
||||
l.filter
|
||||
(proj: proj.subsystemInfo.workspaces or [] != [])
|
||||
projects;
|
||||
|
||||
allWorkspaceChildren =
|
||||
l.flatten
|
||||
(l.map
|
||||
(root: root.subsystemInfo.workspaces)
|
||||
workspaceRoots);
|
||||
|
||||
childrenRemoved =
|
||||
l.filter
|
||||
(proj:
|
||||
(! b.elem proj.relPath allWorkspaceChildren))
|
||||
projects;
|
||||
|
||||
in
|
||||
childrenRemoved;
|
||||
|
||||
|
||||
translate =
|
||||
{
|
||||
translatorName,
|
||||
utils,
|
||||
...
|
||||
}:
|
||||
{
|
||||
projects,
|
||||
source,
|
||||
tree,
|
||||
|
||||
name,
|
||||
noDev,
|
||||
nodejs,
|
||||
...
|
||||
}@args:
|
||||
let
|
||||
getPackageLock = project:
|
||||
let
|
||||
# returns the parsed package-lock.json for a given project
|
||||
fileRelPath =
|
||||
if project ? subsystemInfo.workspaceParent then
|
||||
"${project.subsystemInfo.workspaceParent}/package-lock.json"
|
||||
else
|
||||
"${project.relPath}/package-lock.json";
|
||||
in
|
||||
(tree.getNodeFromPath fileRelPath).jsonContent;
|
||||
|
||||
getPackageJson = project:
|
||||
let
|
||||
node = tree.getNodeFromPath "${project.relPath}/package.json";
|
||||
in
|
||||
node.jsonContent;
|
||||
|
||||
filteredProjects = filterProjects projects;
|
||||
|
||||
allProjectsTranslated =
|
||||
l.map
|
||||
(proj:
|
||||
translateOne {
|
||||
inherit translatorName utils name noDev nodejs;
|
||||
source = "${args.source}/${proj.relPath}";
|
||||
tree = tree.getNodeFromPath proj.relPath;
|
||||
packageLock = getPackageLock proj;
|
||||
packageJson = getPackageJson proj;
|
||||
workspaces = proj.subsystemInfo.workspaces or [];
|
||||
})
|
||||
filteredProjects;
|
||||
|
||||
in
|
||||
allProjectsTranslated;
|
||||
|
||||
|
||||
translateOne =
|
||||
{
|
||||
translatorName,
|
||||
utils,
|
||||
source,
|
||||
tree,
|
||||
|
||||
# subsystem specific
|
||||
packageLock,
|
||||
packageJson,
|
||||
workspaces,
|
||||
|
||||
# translator args
|
||||
name,
|
||||
noDev,
|
||||
nodejs,
|
||||
...
|
||||
}@args:
|
||||
let
|
||||
|
||||
b = builtins;
|
||||
|
||||
dev = ! noDev;
|
||||
|
||||
parsed = packageLock;
|
||||
|
||||
workspacePackageJson =
|
||||
l.genAttrs
|
||||
workspaces
|
||||
(wsRelPath:
|
||||
(tree.getNodeFromPath "${wsRelPath}/package.json").jsonContent);
|
||||
|
||||
workspacePackages =
|
||||
lib.mapAttrs'
|
||||
(wsRelPath: json:
|
||||
l.nameValuePair
|
||||
json.name
|
||||
json.version)
|
||||
workspacePackageJson;
|
||||
|
||||
rootDependencies =
|
||||
packageLock.dependencies or {};
|
||||
|
||||
packageJsonDeps =
|
||||
packageJson.dependencies or {} // packageJson.devDependencies or {};
|
||||
|
||||
parsedDependencies =
|
||||
l.filterAttrs
|
||||
(name: dep: packageJsonDeps ? "${name}")
|
||||
parsed.dependencies or {};
|
||||
|
||||
identifyGitSource = dependencyObject:
|
||||
# TODO: when integrity is there, and git url is github then use tarball instead
|
||||
# ! (dependencyObject ? integrity) &&
|
||||
dlib.identifyGitUrl dependencyObject.version;
|
||||
|
||||
getVersion = dependencyObject:
|
||||
let
|
||||
# example: "version": "npm:@tailwindcss/postcss7-compat@2.2.4",
|
||||
npmMatch = b.match ''^npm:.*@(.*)$'' dependencyObject.version;
|
||||
|
||||
in
|
||||
if npmMatch != null then
|
||||
b.elemAt npmMatch 0
|
||||
else if identifyGitSource dependencyObject then
|
||||
"0.0.0-rc.${b.substring 0 8 (dlib.parseGitUrl dependencyObject.version).rev}"
|
||||
else if lib.hasPrefix "file:" dependencyObject.version then
|
||||
let
|
||||
path = getPath dependencyObject;
|
||||
in
|
||||
(b.fromJSON
|
||||
(b.readFile "${source}/${path}/package.json")
|
||||
).version
|
||||
else if lib.hasPrefix "https://" dependencyObject.version then
|
||||
"unknown"
|
||||
else
|
||||
dependencyObject.version;
|
||||
|
||||
getPath = dependencyObject:
|
||||
lib.removePrefix "file:" dependencyObject.version;
|
||||
|
||||
pinVersions = dependencies: parentScopeDeps:
|
||||
lib.mapAttrs
|
||||
(pname: pdata:
|
||||
let
|
||||
selfScopeDeps = parentScopeDeps // dependencies;
|
||||
requires = pdata.requires or {};
|
||||
dependencies = pdata.dependencies or {};
|
||||
in
|
||||
pdata // {
|
||||
depsExact =
|
||||
lib.forEach
|
||||
(lib.attrNames requires)
|
||||
(reqName: {
|
||||
name = reqName;
|
||||
version = getVersion selfScopeDeps."${reqName}";
|
||||
});
|
||||
dependencies = pinVersions dependencies selfScopeDeps;
|
||||
}
|
||||
)
|
||||
dependencies;
|
||||
|
||||
pinnedRootDeps =
|
||||
pinVersions rootDependencies rootDependencies;
|
||||
|
||||
createMissingSource = name: version:
|
||||
{
|
||||
type = "http";
|
||||
url = "https://registry.npmjs.org/${name}/-/${name}-${version}.tgz";
|
||||
};
|
||||
|
||||
in
|
||||
|
||||
utils.simpleTranslate
|
||||
({
|
||||
getDepByNameVer,
|
||||
dependenciesByOriginalID,
|
||||
...
|
||||
}:
|
||||
|
||||
rec {
|
||||
|
||||
inherit translatorName;
|
||||
|
||||
# values
|
||||
inputData = pinnedRootDeps;
|
||||
|
||||
defaultPackage =
|
||||
if name != "{automatic}" then
|
||||
name
|
||||
else
|
||||
packageJson.name or (throw (
|
||||
"Could not identify package name. "
|
||||
+ "Please specify extra argument 'name'"
|
||||
));
|
||||
|
||||
packages =
|
||||
{ "${defaultPackage}" = parsed.version or "unknown"; }
|
||||
// workspacePackages;
|
||||
|
||||
mainPackageDependencies =
|
||||
lib.mapAttrsToList
|
||||
(pname: pdata:
|
||||
{ name = pname; version = getVersion pdata; })
|
||||
(lib.filterAttrs
|
||||
(pname: pdata: ! (pdata.dev or false) || dev)
|
||||
parsedDependencies);
|
||||
|
||||
subsystemName = "nodejs";
|
||||
|
||||
subsystemAttrs = { nodejsVersion = args.nodejs; };
|
||||
|
||||
# functions
|
||||
serializePackages = inputData:
|
||||
let
|
||||
serialize = inputData:
|
||||
lib.mapAttrsToList # returns list of lists
|
||||
(pname: pdata:
|
||||
[ (pdata // {
|
||||
inherit pname;
|
||||
depsExact =
|
||||
lib.filter
|
||||
(req:
|
||||
(! (pdata.dependencies."${req.name}".bundled or false)))
|
||||
pdata.depsExact or {};
|
||||
}) ]
|
||||
++
|
||||
(lib.optionals (pdata ? dependencies)
|
||||
(lib.flatten
|
||||
(serialize
|
||||
(lib.filterAttrs
|
||||
(pname: data: ! data.bundled or false)
|
||||
pdata.dependencies)))))
|
||||
inputData;
|
||||
in
|
||||
lib.filter
|
||||
(pdata:
|
||||
dev || ! (pdata.dev or false))
|
||||
(lib.flatten (serialize inputData));
|
||||
|
||||
getName = dependencyObject: dependencyObject.pname;
|
||||
|
||||
inherit getVersion;
|
||||
|
||||
getSourceType = dependencyObject:
|
||||
if identifyGitSource dependencyObject then
|
||||
"git"
|
||||
else if lib.hasPrefix "file:" dependencyObject.version then
|
||||
"path"
|
||||
else
|
||||
"http";
|
||||
|
||||
sourceConstructors = {
|
||||
|
||||
git = dependencyObject:
|
||||
dlib.parseGitUrl dependencyObject.version;
|
||||
|
||||
http = dependencyObject:
|
||||
if lib.hasPrefix "https://" dependencyObject.version then
|
||||
rec {
|
||||
version = getVersion dependencyObject;
|
||||
url = dependencyObject.version;
|
||||
hash = dependencyObject.integrity;
|
||||
}
|
||||
else if dependencyObject.resolved == false then
|
||||
(createMissingSource
|
||||
(getName dependencyObject)
|
||||
(getVersion dependencyObject))
|
||||
// {
|
||||
hash = dependencyObject.integrity;
|
||||
}
|
||||
else
|
||||
rec {
|
||||
url = dependencyObject.resolved;
|
||||
hash = dependencyObject.integrity;
|
||||
};
|
||||
|
||||
path = dependencyObject:
|
||||
rec {
|
||||
path = getPath dependencyObject;
|
||||
};
|
||||
};
|
||||
|
||||
getDependencies = dependencyObject:
|
||||
dependencyObject.depsExact;
|
||||
});
|
||||
in
|
||||
|
||||
rec {
|
||||
|
||||
version = 2;
|
||||
|
||||
inherit translate;
|
||||
|
||||
|
||||
projectName =
|
||||
{
|
||||
source,
|
||||
}:
|
||||
let
|
||||
packageJson = "${source}/package.json";
|
||||
parsed = b.fromJSON (b.readFile packageJson);
|
||||
in
|
||||
if b.pathExists packageJson && parsed ? name then
|
||||
parsed.name
|
||||
else
|
||||
null;
|
||||
|
||||
|
||||
compatible =
|
||||
{
|
||||
source,
|
||||
}:
|
||||
dlib.containsMatchingFile
|
||||
[
|
||||
''.*package-lock\.json''
|
||||
''.*package.json''
|
||||
]
|
||||
source;
|
||||
|
||||
extraArgs = {
|
||||
|
||||
name = {
|
||||
description = "The name of the main package";
|
||||
examples = [
|
||||
"react"
|
||||
"@babel/code-frame"
|
||||
];
|
||||
default = "{automatic}";
|
||||
type = "argument";
|
||||
};
|
||||
|
||||
noDev = {
|
||||
description = "Exclude development dependencies";
|
||||
type = "flag";
|
||||
};
|
||||
|
||||
# TODO: this should either be removed or only used to select
|
||||
# the nodejs version for translating, not for building.
|
||||
nodejs = {
|
||||
description = "nodejs version to use for building";
|
||||
default = "14";
|
||||
examples = [
|
||||
"14"
|
||||
"16"
|
||||
];
|
||||
type = "argument";
|
||||
};
|
||||
|
||||
};
|
||||
}
|
Loading…
Reference in New Issue
Block a user