update
This commit is contained in:
parent
e0d569cadc
commit
db5a419af8
@ -1,13 +0,0 @@
|
|||||||
import { cloneDeep } from "lodash"
|
|
||||||
import NmakeGlobal from "../interface/NmakeGlobal"
|
|
||||||
import printDebug from "../Tools/DebugPrint"
|
|
||||||
import { popGlobalStack, pushGlobalStack } from "../Tools/GlobalStack"
|
|
||||||
|
|
||||||
const project = (name:string,callback:Function) =>{
|
|
||||||
pushGlobalStack()
|
|
||||||
printDebug("adding project :"+name)
|
|
||||||
callback()
|
|
||||||
popGlobalStack()
|
|
||||||
}
|
|
||||||
|
|
||||||
export default project
|
|
@ -1 +0,0 @@
|
|||||||
export {default as project} from "./project"
|
|
@ -1,4 +1,5 @@
|
|||||||
export default interface Compiler{
|
export default interface Compiler{
|
||||||
compilerPath:string;
|
compilerPath:string;
|
||||||
compilerVersion:string;
|
compilerVersion:string;
|
||||||
|
compilerName:string
|
||||||
}
|
}
|
@ -5,10 +5,22 @@ import Compiler from "./Compiler";
|
|||||||
export default class GppCompiler implements Compiler{
|
export default class GppCompiler implements Compiler{
|
||||||
compilerPath: string;
|
compilerPath: string;
|
||||||
compilerVersion: string;
|
compilerVersion: string;
|
||||||
constructor(){
|
compilerName: string = "g++";
|
||||||
const compilerPaths = getExecutablePathsFromEnv("g++")
|
// staticCompilerName: string = "g++";
|
||||||
if(compilerPaths.length==0)throw Error("cannot find g++ compiler")
|
constructor()
|
||||||
|
constructor(path:string)
|
||||||
|
constructor(path?:string,version?:string){
|
||||||
|
if(path){
|
||||||
|
this.compilerPath = `"${path}"`
|
||||||
|
}else{
|
||||||
|
const compilerPaths = getExecutablePathsFromEnv(this.compilerName)
|
||||||
|
if(compilerPaths.length==0)throw Error(`cannot find ${this.compilerName} compiler`)
|
||||||
this.compilerPath = `"${compilerPaths[0]}"`
|
this.compilerPath = `"${compilerPaths[0]}"`
|
||||||
|
}
|
||||||
|
if(version){
|
||||||
|
this.compilerVersion = version
|
||||||
|
}else{
|
||||||
this.compilerVersion = tryGetCompilerVersion(this.compilerPath,"--version")
|
this.compilerVersion = tryGetCompilerVersion(this.compilerPath,"--version")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
@ -1,4 +1,7 @@
|
|||||||
import GppCompiler from "../Compiler/GppCompiler";
|
import GppCompiler from "../Compiler/GppCompiler";
|
||||||
|
import printDebug from "../Tools/DebugPrint";
|
||||||
|
import { getDefaultCompiler, setDefaultCompiler } from "../Tools/DefaultCompiler";
|
||||||
|
import setGetDefaultCompiler from "../Tools/setGetDefaultCompiler";
|
||||||
import HaveCompiler from "./interface/HaveCompiler";
|
import HaveCompiler from "./interface/HaveCompiler";
|
||||||
import Optimize from "./interface/Optimize";
|
import Optimize from "./interface/Optimize";
|
||||||
import SourceFiles from "./interface/SourceFiles";
|
import SourceFiles from "./interface/SourceFiles";
|
||||||
@ -9,17 +12,18 @@ export default class CppProject implements Project , SourceFiles,HaveCompiler,Op
|
|||||||
compiler: GppCompiler;
|
compiler: GppCompiler;
|
||||||
sourceFiles: string[]=[];
|
sourceFiles: string[]=[];
|
||||||
optimize: "fast" | "fastest" | "normal" = "fast"
|
optimize: "fast" | "fastest" | "normal" = "fast"
|
||||||
|
typeName: string = "cpp";
|
||||||
|
|
||||||
constructor(name:string)
|
constructor(name:string)
|
||||||
constructor(name:string,compiler:GppCompiler)
|
constructor(name:string,compiler:GppCompiler)
|
||||||
|
|
||||||
constructor(name:string,compiler?:GppCompiler){
|
constructor(name:string,compiler?:GppCompiler){
|
||||||
|
printDebug(`adding new ${this.typeName} project`)
|
||||||
if(compiler){
|
if(compiler){
|
||||||
this.compiler = compiler
|
this.compiler = compiler
|
||||||
}else{
|
}else{
|
||||||
this.compiler=new GppCompiler()
|
this.compiler = setGetDefaultCompiler("g++",()=>{return new GppCompiler()})
|
||||||
}
|
}
|
||||||
this.name=name
|
this.name=name
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -1,5 +1,6 @@
|
|||||||
import Compiler from "../Compiler/Compiler"
|
import Compiler from "../Compiler/Compiler"
|
||||||
|
|
||||||
export default interface Project{
|
export default interface Project{
|
||||||
name:string
|
name:string;
|
||||||
|
typeName:string
|
||||||
}
|
}
|
@ -1,9 +0,0 @@
|
|||||||
import NmakeGlobal from "../interface/NmakeGlobal"
|
|
||||||
import { getGlobalNmake, Global } from "./GlobalStack"
|
|
||||||
|
|
||||||
const constructGlobal = ()=>{
|
|
||||||
Global.nmake = {}
|
|
||||||
Global.nmake.projects = {} as NmakeGlobal[]
|
|
||||||
}
|
|
||||||
|
|
||||||
export default constructGlobal
|
|
15
src/Tools/DefaultCompiler.ts
Normal file
15
src/Tools/DefaultCompiler.ts
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
import Compiler from "../Compiler/Compiler"
|
||||||
|
|
||||||
|
const Global = (global as any)
|
||||||
|
|
||||||
|
export const setDefaultCompiler = (name:string,compiler:Compiler)=>{
|
||||||
|
if(!Global.defaultCompiler)Global.defaultCompiler = {};
|
||||||
|
const globalCompilers = Global.defaultCompiler as {[key:string]:Compiler}
|
||||||
|
globalCompilers[name] = compiler
|
||||||
|
}
|
||||||
|
|
||||||
|
export const getDefaultCompiler = (name:string):undefined|Compiler=>{
|
||||||
|
if(!Global.defaultCompiler)Global.defaultCompiler = {};
|
||||||
|
const globalCompilers = Global.defaultCompiler as {[key:string]:Compiler}
|
||||||
|
return globalCompilers[name]
|
||||||
|
}
|
@ -1,24 +0,0 @@
|
|||||||
import { cloneDeep } from "lodash"
|
|
||||||
import NmakeGlobal from "../interface/NmakeGlobal"
|
|
||||||
import printDebug from "./DebugPrint"
|
|
||||||
|
|
||||||
export const Global = global as any
|
|
||||||
let globalNmakeStacks = Global.globalStacks as NmakeGlobal[]
|
|
||||||
|
|
||||||
export const pushGlobalStack = () =>{
|
|
||||||
printDebug("pushing global stack")
|
|
||||||
if(!Global.globalStacks){Global.globalStacks = [];globalNmakeStacks = Global.globalStacks as NmakeGlobal[]}
|
|
||||||
globalNmakeStacks.push(Global.nmake)
|
|
||||||
Global.nmake = cloneDeep(Global.nmake)
|
|
||||||
}
|
|
||||||
|
|
||||||
export const popGlobalStack = ()=>{
|
|
||||||
printDebug("popping global stack")
|
|
||||||
Global.nmake = globalNmakeStacks[globalNmakeStacks.length-1]
|
|
||||||
globalNmakeStacks.pop()
|
|
||||||
}
|
|
||||||
|
|
||||||
export const getGlobalNmake=():NmakeGlobal=>{
|
|
||||||
printDebug("getting global nmake")
|
|
||||||
return Global.nmake
|
|
||||||
}
|
|
21
src/Tools/SetGetDefaultCompiler.ts
Normal file
21
src/Tools/SetGetDefaultCompiler.ts
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
import Compiler from "../Compiler/Compiler"
|
||||||
|
import printDebug from "./DebugPrint"
|
||||||
|
import { getDefaultCompiler, setDefaultCompiler } from "./DefaultCompiler"
|
||||||
|
|
||||||
|
const setGetDefaultCompiler = (name: string, newCompiler: { (): Compiler }) => {
|
||||||
|
let defaultCompiler = getDefaultCompiler("g++")
|
||||||
|
if (defaultCompiler) {
|
||||||
|
return defaultCompiler
|
||||||
|
} else {
|
||||||
|
printDebug(`setting default compiler for g++`)
|
||||||
|
setDefaultCompiler("g++", newCompiler())
|
||||||
|
defaultCompiler = getDefaultCompiler("g++")
|
||||||
|
if (defaultCompiler) {
|
||||||
|
return defaultCompiler
|
||||||
|
} else {
|
||||||
|
throw Error("cannot set compiler")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export default setGetDefaultCompiler
|
@ -1,6 +1,5 @@
|
|||||||
import { exec, execSync } from "child_process"
|
import { exec, execSync } from "child_process"
|
||||||
import printDebug from "./DebugPrint";
|
import printDebug from "./DebugPrint";
|
||||||
import util from "util";
|
|
||||||
|
|
||||||
const tryGetCompilerVersion =(path:string,command:string):string=>{
|
const tryGetCompilerVersion =(path:string,command:string):string=>{
|
||||||
const exec_command = `${path} ${command}`
|
const exec_command = `${path} ${command}`
|
||||||
|
@ -2,7 +2,6 @@ import path from "path";
|
|||||||
import printDebug from "./Tools/DebugPrint";
|
import printDebug from "./Tools/DebugPrint";
|
||||||
import { existsSync } from "fs";
|
import { existsSync } from "fs";
|
||||||
import printErrorOrDebug from "./Tools/PrintErrorOrDebug";
|
import printErrorOrDebug from "./Tools/PrintErrorOrDebug";
|
||||||
import constructGlobal from "./Tools/ConstructGlobal";
|
|
||||||
|
|
||||||
const argv = require('minimist')(process.argv.slice(2))
|
const argv = require('minimist')(process.argv.slice(2))
|
||||||
|
|
||||||
@ -22,7 +21,6 @@ printDebug("adding ts-node")
|
|||||||
require("ts-node").register()
|
require("ts-node").register()
|
||||||
|
|
||||||
printDebug("adding global values")
|
printDebug("adding global values")
|
||||||
constructGlobal();
|
|
||||||
|
|
||||||
printDebug(`running file ${nmakeFilePath}`)
|
printDebug(`running file ${nmakeFilePath}`)
|
||||||
require(nmakeFilePath)
|
require(nmakeFilePath)
|
||||||
|
@ -1,3 +1,10 @@
|
|||||||
|
import GppCompiler from "../../src/Compiler/GppCompiler";
|
||||||
import CppProject from "../../src/Project/CppProject";
|
import CppProject from "../../src/Project/CppProject";
|
||||||
|
|
||||||
|
// const compiler = new GppCompiler()
|
||||||
|
|
||||||
|
new CppProject("hello");
|
||||||
|
|
||||||
|
new CppProject("hello");
|
||||||
|
|
||||||
new CppProject("hello");
|
new CppProject("hello");
|
||||||
|
Loading…
Reference in New Issue
Block a user