最新消息:

NSJSON是NSIS操作JavaScript对象表示法的语法分析器插件

nsis 永恒心锁 2477浏览 0评论
/*
NSJSON是NSIS操作JavaScript对象表示法的语法分析器插件
NSJSON将格式不规范的文本字符进行语法分析然后生成规范的JSON文本
NSJSON直接将二进制流(nsdata)转化成字典1,字典1的value也是字典,设为字典2. 利用for in 可以遍历输出字典2中所有的value值.
*/
!AddPluginDir "../../Plugins"
!include MUI2.nsh
Name `nsJSON plug-in`
OutFile Example.exe
RequestExecutionLevel user
ShowInstDetails show
!insertmacro MUI_PAGE_COMPONENTS
!insertmacro MUI_PAGE_INSTFILES
!insertmacro MUI_LANGUAGE English
Section
 CreateDirectory $EXEDIROutput
SectionEnd
Section `Parse Example1.json` EXAMPLE1
 ; Input: Example1.json; output: Example1.json.
 nsJSON::Set /file $EXEDIRExample1.json
 nsJSON::Serialize /format /file $EXEDIROutputExample1.json
 DetailPrint `Generate: $EXEDIROutputExample1.json`
SectionEnd
Section `Convert Example1_Unicode.json` EXAMPLE1B
 ; Use the /unicode switch if the input file is Unicode.
 nsJSON::Set /file /unicode $EXEDIRExample1_Unicode.json
 ; Generate an ANSII output file.
 nsJSON::Serialize /format /file $EXEDIROutputExample1_ASCII.json
 DetailPrint `Generate: $EXEDIROutputExample1_ASCII.json`
 ; Generate a Unicode output file.
 nsJSON::Serialize /format /file /unicode $EXEDIROutputExample1_Unicode.json
 DetailPrint `Generate: $EXEDIROutputExample1_Unicode.json`
SectionEnd
Section `Parse Example2.json` EXAMPLE2
 ; Input: Example2.json; output: Example2.json.
 nsJSON::Set /file $EXEDIRExample2.json
 nsJSON::Serialize /format /file $EXEDIROutputExample2.json
 DetailPrint `Generate: $EXEDIROutputExample2.json`
SectionEnd
Section `Parse Example3.json` EXAMPLE3
 ; Input: Example3.json; output: Example3.json.
 nsJSON::Set /file $EXEDIRExample3.json
 nsJSON::Serialize /format /file $EXEDIROutputExample3.json
 DetailPrint `Generate: $EXEDIROutputExample3.json`
SectionEnd
Section `Parse Example4.json` EXAMPLE4
 ; Input: Example4.json; output: Example4.json.
 nsJSON::Set /file $EXEDIRExample4.json
 nsJSON::Serialize /format /file $EXEDIROutputExample4.json
 DetailPrint `Generate: $EXEDIROutputExample4.json`
SectionEnd
Section `Parse Example5.json` EXAMPLE5
 ; Input: Example5.json; output: Example5.json.
 nsJSON::Set /file $EXEDIRExample5.json
 nsJSON::Serialize /format /file $EXEDIROutputExample5.json
 DetailPrint `Generate: $EXEDIROutputExample5.json`
SectionEnd
Section `Generate Example6.json` EXAMPLE6
 nsJSON::Set /value `{}`
 nsJSON::Set `html` `head` `title` /value `"Example6"`
 ; Build an array using individual calls.
 nsJSON::Set `html` `body` `h1` /value `[]`
 nsJSON::Set `html` `body` `h1` /value `"Hello, my name is"`
 nsJSON::Set `html` `body` `h1` `i` /value `"Stuart."`
 nsJSON::Set `html` `body` `h1` /value `"Howdy"`
 nsJSON::Set `html` `body` `h1` /value `"!"`
 ; Build an array using a JSON string.
 nsJSON::Set `html` `body` `h2` /value `[ "I like", { "u": { "i" : "programming" } }, "very much!" ]`
 ; Quotes in node keys are allowed; they are escaped automatically.
 nsJSON::Set `html` `body` `a href="http://www.afrowsoft.co.uk"` /value `"My website!"`
 ; Open the file below in Notepad.
 nsJSON::Serialize /format /file $EXEDIROutputExample6.json
 DetailPrint `Generate: $EXEDIROutputExample6.json`
SectionEnd
Section `Reading from Example1.json` EXAMPLE7
 nsJSON::Set /file $EXEDIRExample1.json
 ; Read quoted string value.
 ClearErrors
 nsJSON::Get `glossary` `GlossDiv` `GlossList` `GlossEntry` `GlossTerm` /end
 ${IfNot} ${Errors}
 Pop $R0
 DetailPrint `glossary->GlossDiv->GlossList->GlossEntry->GlossTerm = $R0`
 ${EndIf}
 ; Read quoted string value with escaping.
 ClearErrors
 nsJSON::Set `glossary` `GlossDiv` `GlossList` `GlossEntry` `GlossDef` `para2` /value `"A meta-markup language, used to create markup languagesrnsuch as DocBook."`
 nsJSON::Get `glossary` `GlossDiv` `GlossList` `GlossEntry` `GlossDef` `para2` /end
 ${IfNot} ${Errors}
 Pop $R0
 DetailPrint `glossary->GlossDiv->GlossList->GlossEntry->GlossDef->para2 = $R0`
 ${EndIf}
 ; Read quoted string value without expanding escape sequences.
 ClearErrors
 nsJSON::Set `glossary` `GlossDiv` `GlossList` `GlossEntry` `GlossDef` `para3` /value `"A meta-markup language, used to create markup languagesrnsuch as DocBook."`
 nsJSON::Get /noexpand `glossary` `GlossDiv` `GlossList` `GlossEntry` `GlossDef` `para3` /end
 ${IfNot} ${Errors}
 Pop $R0
 DetailPrint `glossary->GlossDiv->GlossList->GlossEntry->GlossDef->para3 = $R0`
 ${EndIf}
 ; Read the value of an array (returns a comma delimited list).
 ClearErrors
 nsJSON::Get `glossary` `GlossDiv` `GlossList` `GlossEntry` `GlossDef` `GlossSeeAlso` /end
 ${IfNot} ${Errors}
 Pop $R0
 DetailPrint `glossary->GlossDiv->GlossList->GlossEntry->GlossDef->GlossSeeAlso = $R0`
 ${EndIf}
 ; Try reading a node that does not exist.
 ClearErrors
 nsJSON::Get `glossary` `GlossDiv` `GlossList` `GlossEntry` `GlossDef` `GlossSeeAlso2` /end
 ${IfNot} ${Errors}
 Pop $R0
 DetailPrint `glossary->GlossDiv->GlossList->GlossEntry->GlossDef->GlossSeeAlso2 = $R0`
 ${Else}
 DetailPrint `glossary->GlossDiv->GlossList->GlossEntry->GlossDef->GlossSeeAlso2 = Does not exist!`
 ${EndIf}
 ; Try reading an array element that does not exist.
 ClearErrors
 nsJSON::Get `glossary` `GlossDiv` `GlossList` `GlossEntry` `GlossDef` `GlossSeeAlso` 99 /end
 ${IfNot} ${Errors}
 Pop $R0
 DetailPrint `glossary->GlossDiv->GlossList->GlossEntry->GlossDef->GlossSeeAlso->#99 = $R0`
 ${Else}
 DetailPrint `glossary->GlossDiv->GlossList->GlossEntry->GlossDef->GlossSeeAlso->#99 = Does not exist!`
 ${EndIf}
SectionEnd
Section `Arrays test` EXAMPLE8
 nsJSON::Set /value `{}`
 ; You can add an array this way.
 nsJSON::Set `array1` /value `[ "value 1", "value 2", { "value 3": "node value" }, "value 4", 5 ]`
 ; Inspect array1.
 nsJSON::Get `array1` /end
 Pop $R0
 DetailPrint `array1 = [$R0]`
 ; Or you can build it this way.
 nsJSON::Set `array2` /value `[]`
 nsJSON::Set `array2` /value `"value 1"`
 nsJSON::Set `array2` /value `"value 2"`
 nsJSON::Set `array2` `value 3` /value `"node value"`
 nsJSON::Set `array2` /value `"value 4"`
 nsJSON::Set `array2` /value `5`
 ; You cannot add the same value again.
 nsJSON::Set `array2` /value `5`
 ; Inspect array2.
 nsJSON::Get `array2` /end
 Pop $R0
 DetailPrint `array2 = [$R0]`
 ; Does an array element exist at the given index?
 nsJSON::Get /exists `array2` /index 0 /end
 Pop $R0
 DetailPrint `array2[0] exists? = $R0`
 ; Does an array element exist that matches the value?
 nsJSON::Get /exists `array2` `5` /end
 Pop $R0
 DetailPrint `array2->5 exists? = $R0`
 ; Does an array element exist at the given index?
 nsJSON::Get /exists `array2` /index 6 /end
 Pop $R0
 DetailPrint `array2[6] exists? = $R0`
 ; Open Example8_1.json to see what it now looks like.
 nsJSON::Serialize /format /file $EXEDIROutputExample8_1.json
 DetailPrint `Generate: $EXEDIROutputExample8_1.json`
 ; Now delete the element at the given index.
 nsJSON::Delete `array1` /index 2 `value 3` /end
 DetailPrint `Delete: array1[2]->value 3`
 nsJSON::Delete `array2` /index 5 /end
 DetailPrint `Delete: array2[5]`
 ; Now delete the elements with the given values.
 nsJSON::Delete `array1` `value 1` /end
 DetailPrint `Delete: array1->value 1`
 nsJSON::Delete `array2` `value 2` /end
 DetailPrint `Delete: array2->value 2`
 ; Inspect array1.
 nsJSON::Get `array1` /end
 Pop $R0
 DetailPrint `array1 = [$R0]`
 ; Inspect array2.
 nsJSON::Get `array2` /end
 Pop $R0
 DetailPrint `array2 = [$R0]`
 ; Open Example8_2.json to see what it now looks like.
 nsJSON::Serialize /format /file $EXEDIROutputExample8_2.json
 DetailPrint `Generate: $EXEDIROutputExample8_2.json`
SectionEnd
Section `Node iteration test` EXAMPLE9
 nsJSON::Set /file $EXEDIRExample4.json
 ; Get the node count.
 nsJSON::Get /count `web-app` `servlet` /index 0 `init-param` /end
 Pop $R0
 DetailPrint `Node web-app->servlet[0]->init-param contains $R0 children:`
 ${For} $R1 0 $R0
 nsJSON::Get /key `web-app` `servlet` /index 0 `init-param` /index $R1 /end
 Pop $R2
 nsJSON::Get `web-app` `servlet` /index 0 `init-param` /index $R1 /end
 Pop $R3
 nsJSON::Get /type `web-app` `servlet` /index 0 `init-param` /index $R1 /end
 Pop $R4
 DetailPrint `$R2 = $R3 (type: $R4)`
 ${Next}
SectionEnd
Section `Load Example5.json into Example4.json` EXAMPLE10
 ; Input: Example5.json; output: Example5.json.
 nsJSON::Set /file $EXEDIRExample5.json
 nsJSON::Set `menu` `example4` /file $EXEDIRExample4.json
 nsJSON::Serialize /format /file $EXEDIROutputExample10.json
 DetailPrint `Generate: $EXEDIROutputExample10.json`
SectionEnd
Section `Copies Preferences.json into PreferencesNew.json` EXAMPLE11
 ; Input: Preferences.json; output: PreferencesNew.json.
 nsJSON::Set /file $EXEDIRPreferences.json
 nsJSON::Serialize /format /file $EXEDIROutputPreferencesNew.json
 DetailPrint `Generate: $EXEDIROutputPreferencesNew.json`
SectionEnd
Section `Copies Preferences2.json into Preferences2New.json` EXAMPLE12
 ; Input: PreferencesNew.json; output: Preferences2New.json.
 nsJSON::Set /file $EXEDIRPreferences2.json
 nsJSON::Serialize /format /file $EXEDIROutputPreferences2New.json
 DetailPrint `Generate: $EXEDIROutputPreferences2New.json`
SectionEnd
LangString Example1Desc ${LANG_ENGLISH} `Parses Example1.json and then generates OutputExample1.json`
LangString Example1BDesc ${LANG_ENGLISH} `Parses Example1_Unicode.json and then generates Unicode and ASCII copies`
LangString Example2Desc ${LANG_ENGLISH} `Parses Example2.json and then generates OutputExample2.json`
LangString Example3Desc ${LANG_ENGLISH} `Parses Example3.json and then generates OutputExample3.json`
LangString Example4Desc ${LANG_ENGLISH} `Parses Example4.json and then generates OutputExample4.json`
LangString Example5Desc ${LANG_ENGLISH} `Parses Example5.json and then generates OutputExample5.json`
LangString Example6Desc ${LANG_ENGLISH} `Generates OutputExample6.json using Parse, Set and Serialize`
LangString Example7Desc ${LANG_ENGLISH} `Parses Example1.json and then reads values from the tree using Get`
LangString Example8Desc ${LANG_ENGLISH} `Tests JSON array manipulation while generating OutputExample8.json`
LangString Example9Desc ${LANG_ENGLISH} `Iterates through some nodes in Example4.json by index`
LangString Example10Desc ${LANG_ENGLISH} `Parses Example5.json into Example4.json and then generates OutputExample10.json`
LangString Example11Desc ${LANG_ENGLISH} `Parses Preferences.json and then generates OutputPreferencesNew.json`
LangString Example12Desc ${LANG_ENGLISH} `Parses Preferences2.json and then generates OutputPreferences2New.json`
!insertmacro MUI_FUNCTION_DESCRIPTION_BEGIN
 !insertmacro MUI_DESCRIPTION_TEXT ${EXAMPLE1} $(Example1Desc)
 !insertmacro MUI_DESCRIPTION_TEXT ${EXAMPLE1B} $(Example1BDesc)
 !insertmacro MUI_DESCRIPTION_TEXT ${EXAMPLE2} $(Example2Desc)
 !insertmacro MUI_DESCRIPTION_TEXT ${EXAMPLE3} $(Example3Desc)
 !insertmacro MUI_DESCRIPTION_TEXT ${EXAMPLE4} $(Example4Desc)
 !insertmacro MUI_DESCRIPTION_TEXT ${EXAMPLE5} $(Example5Desc)
 !insertmacro MUI_DESCRIPTION_TEXT ${EXAMPLE6} $(Example6Desc)
 !insertmacro MUI_DESCRIPTION_TEXT ${EXAMPLE7} $(Example7Desc)
 !insertmacro MUI_DESCRIPTION_TEXT ${EXAMPLE8} $(Example8Desc)
 !insertmacro MUI_DESCRIPTION_TEXT ${EXAMPLE9} $(Example9Desc)
 !insertmacro MUI_DESCRIPTION_TEXT ${EXAMPLE10} $(Example10Desc)
 !insertmacro MUI_DESCRIPTION_TEXT ${EXAMPLE11} $(Example11Desc)
 !insertmacro MUI_DESCRIPTION_TEXT ${EXAMPLE12} $(Example12Desc)
!insertmacro MUI_FUNCTION_DESCRIPTION_END
永恒心锁,版权所有丨如未注明,均为转载丨本网站采用BY-NC-SA协议进行授权

转载请注明:永恒心锁-分享互联网 » NSJSON是NSIS操作JavaScript对象表示法的语法分析器插件

您必须 登录 才能发表评论!