Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
erp5
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Levin Zimmermann
erp5
Commits
29224500
Commit
29224500
authored
Jun 15, 2018
by
Romain Courteaud
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[erp5_gadget_interface_validator] Remove not needed defer
parent
598bb3fe
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
68 additions
and
138 deletions
+68
-138
bt5/erp5_gadget_interface_validator/PathTemplateItem/web_page_module/gadget_interface_js.js
...r/PathTemplateItem/web_page_module/gadget_interface_js.js
+68
-138
No files found.
bt5/erp5_gadget_interface_validator/PathTemplateItem/web_page_module/gadget_interface_js.js
View file @
29224500
...
@@ -85,17 +85,12 @@
...
@@ -85,17 +85,12 @@
}
}
function
fetchAppcacheData
(
appcache_url
)
{
function
fetchAppcacheData
(
appcache_url
)
{
var
defer
=
RSVP
.
defer
();
return
new
RSVP
.
Queue
()
return
new
RSVP
.
Queue
()
.
push
(
function
()
{
.
push
(
function
()
{
return
ajax
(
appcache_url
);
return
ajax
(
appcache_url
);
})
})
.
push
(
function
(
xhr
)
{
.
push
(
function
(
xhr
)
{
var
filename_list
=
xhr
.
responseText
.
split
(
'
\n
'
);
return
xhr
.
responseText
.
split
(
'
\n
'
);
return
filename_list
;
},
function
(
error
)
{
defer
.
reject
(
error
);
return
defer
.
promise
;
});
});
}
}
...
@@ -136,7 +131,6 @@
...
@@ -136,7 +131,6 @@
}
}
function
getInterfaceListFromURL
(
gadget_url
)
{
function
getInterfaceListFromURL
(
gadget_url
)
{
var
defer
=
RSVP
.
defer
();
return
new
RSVP
.
Queue
()
return
new
RSVP
.
Queue
()
.
push
(
function
()
{
.
push
(
function
()
{
return
ajax
(
gadget_url
);
return
ajax
(
gadget_url
);
...
@@ -165,16 +159,14 @@
...
@@ -165,16 +159,14 @@
},
function
(
error
)
{
},
function
(
error
)
{
var
message
=
"
Error with loading the gadget data.
\n
"
;
var
message
=
"
Error with loading the gadget data.
\n
"
;
error
.
message
=
message
+
generateErrorMessage
(
error
);
error
.
message
=
message
+
generateErrorMessage
(
error
);
defer
.
reject
(
error
);
throw
error
;
return
defer
.
promise
;
});
});
}
}
function
verifyInterfaceDefinition
(
interface_url
)
{
function
verifyInterfaceDefinition
(
interface_url
)
{
//to verify if interface definition follows the correct template.
//to verify if interface definition follows the correct template.
var
error_message
=
"
Interface definition is incorrect:
"
+
var
error_message
=
"
Interface definition is incorrect:
"
+
"
One or more required tags are missing.
"
,
"
One or more required tags are missing.
"
;
defer
=
RSVP
.
defer
();
return
new
RSVP
.
Queue
()
return
new
RSVP
.
Queue
()
.
push
(
function
()
{
.
push
(
function
()
{
return
ajax
(
interface_url
);
return
ajax
(
interface_url
);
...
@@ -192,66 +184,52 @@
...
@@ -192,66 +184,52 @@
if
(
dl_list
[
0
].
childElementCount
!==
3
*
method_len
)
{
if
(
dl_list
[
0
].
childElementCount
!==
3
*
method_len
)
{
throw
new
Error
(
error_message
);
throw
new
Error
(
error_message
);
}
}
try
{
for
(
i
=
0
;
i
<
method_len
;
i
+=
1
)
{
for
(
i
=
0
;
i
<
method_len
;
i
+=
1
)
{
if
((
next_element
===
null
)
||
if
((
next_element
===
null
)
||
(
next_element
.
localName
.
toLowerCase
()
!==
'
dt
'
))
{
(
next_element
.
localName
.
toLowerCase
()
!==
'
dt
'
))
{
throw
new
Error
(
error_message
);
throw
new
Error
(
error_message
);
}
}
next_element
=
next_element
.
nextElementSibling
;
next_element
=
next_element
.
nextElementSibling
;
if
(
next_element
.
localName
.
toLowerCase
()
!==
'
dd
'
)
{
if
(
next_element
.
localName
.
toLowerCase
()
!==
'
dd
'
)
{
throw
new
Error
(
error_message
);
throw
new
Error
(
error_message
);
}
}
next_element
=
next_element
.
nextElementSibling
;
next_element
=
next_element
.
nextElementSibling
;
if
(
next_element
.
localName
.
toLowerCase
()
!==
'
dl
'
)
{
if
(
next_element
.
localName
.
toLowerCase
()
!==
'
dl
'
)
{
throw
new
Error
(
error_message
);
throw
new
Error
(
error_message
);
}
}
if
(
next_element
.
getElementsByTagName
(
'
dt
'
).
length
!==
if
(
next_element
.
getElementsByTagName
(
'
dt
'
).
length
!==
next_element
.
getElementsByTagName
(
'
dd
'
).
length
)
{
next_element
.
getElementsByTagName
(
'
dd
'
).
length
)
{
throw
new
Error
(
error_message
);
}
argument_len
=
next_element
.
getElementsByTagName
(
'
dt
'
).
length
;
next_child_element
=
next_element
.
firstElementChild
;
for
(
j
=
0
;
j
<
argument_len
;
j
+=
1
)
{
if
((
next_child_element
===
null
)
||
(
next_child_element
.
localName
.
toLowerCase
()
!==
'
dt
'
))
{
throw
new
Error
(
error_message
);
throw
new
Error
(
error_message
);
}
}
argument_len
=
next_element
.
getElementsByTagName
(
'
dt
'
).
length
;
next_child_element
=
next_child_element
.
nextElementSibling
;
next_child_element
=
next_element
.
firstElementChild
;
if
(
next_child_element
.
localName
.
toLowerCase
()
!==
'
dd
'
)
{
for
(
j
=
0
;
j
<
argument_len
;
j
+=
1
)
{
throw
new
Error
(
error_message
);
if
((
next_child_element
===
null
)
||
(
next_child_element
.
localName
.
toLowerCase
()
!==
'
dt
'
))
{
throw
new
Error
(
error_message
);
}
next_child_element
=
next_child_element
.
nextElementSibling
;
if
(
next_child_element
.
localName
.
toLowerCase
()
!==
'
dd
'
)
{
throw
new
Error
(
error_message
);
}
next_child_element
=
next_child_element
.
nextElementSibling
;
}
}
next_
element
=
next
_element
.
nextElementSibling
;
next_
child_element
=
next_child
_element
.
nextElementSibling
;
}
}
defer
.
resolve
(
"
Success
"
);
next_element
=
next_element
.
nextElementSibling
;
}
catch
(
error
)
{
defer
.
reject
(
error
);
}
}
return
defer
.
promise
;
},
function
(
error
)
{
},
function
(
error
)
{
var
message
=
"
Error with loading the interface data.
\n
"
;
var
message
=
"
Error with loading the interface data.
\n
"
;
error
.
message
=
message
+
generateErrorMessage
(
error
);
error
.
message
=
message
+
generateErrorMessage
(
error
);
defer
.
reject
(
error
);
throw
error
;
return
defer
.
promise
;
});
});
}
}
function
verifyInterfaceDeclaration
(
interface_url
,
declared_interface_list
)
{
function
verifyInterfaceDeclaration
(
interface_url
,
declared_interface_list
)
{
//to verify if gadget declares the interface.
//to verify if gadget declares the interface.
var
defer
=
RSVP
.
defer
();
if
(
declared_interface_list
.
indexOf
(
interface_url
)
>
-
1
)
{
try
{
return
"
Success
"
;
if
(
declared_interface_list
.
indexOf
(
interface_url
)
>
-
1
)
{
defer
.
resolve
(
"
Success
"
);
}
else
{
throw
new
Error
(
"
Interface is not declared.
"
);
}
}
catch
(
error
)
{
defer
.
reject
(
error
);
}
}
return
defer
.
promise
;
throw
new
Error
(
"
Interface is not declared.
"
)
;
}
}
/*
/*
...
@@ -320,8 +298,7 @@
...
@@ -320,8 +298,7 @@
function
verifyAllMethodDeclared
(
interface_method_list
,
gadget_method_list
)
{
function
verifyAllMethodDeclared
(
interface_method_list
,
gadget_method_list
)
{
//to verify if all the interface methods are declared by the gadget.
//to verify if all the interface methods are declared by the gadget.
var
defer
=
RSVP
.
defer
(),
var
gadget_method_name_list
=
gadget_method_list
,
gadget_method_name_list
=
gadget_method_list
,
interface_method_name_list
=
[],
interface_method_name_list
=
[],
i
,
i
,
j
,
j
,
...
@@ -331,38 +308,32 @@
...
@@ -331,38 +308,32 @@
for
(
i
=
0
;
i
<
interface_method_list
.
length
;
i
+=
1
)
{
for
(
i
=
0
;
i
<
interface_method_list
.
length
;
i
+=
1
)
{
interface_method_name_list
.
push
(
interface_method_list
[
i
].
name
);
interface_method_name_list
.
push
(
interface_method_list
[
i
].
name
);
}
}
try
{
for
(
j
=
0
;
j
<
interface_method_name_list
.
length
;
j
+=
1
)
{
for
(
j
=
0
;
j
<
interface_method_name_list
.
length
;
j
+=
1
)
{
if
(
gadget_method_name_list
.
indexOf
(
if
(
gadget_method_name_list
.
indexOf
(
interface_method_name_list
[
j
]
interface_method_name_list
[
j
]
)
<
0
)
{
)
<
0
)
{
failed
=
true
;
failed
=
true
;
failed_methods
.
push
(
interface_method_name_list
[
j
]);
failed_methods
.
push
(
interface_method_name_list
[
j
]);
}
}
}
if
(
failed
)
{
}
error_message
=
if
(
failed
)
{
"
Following required methods are not declared in the gadget:
"
;
error_message
=
for
(
i
=
0
;
i
<
failed_methods
.
length
;
i
+=
1
)
{
"
Following required methods are not declared in the gadget:
"
;
error_message
+=
(
"
\n
"
+
failed_methods
[
i
]);
for
(
i
=
0
;
i
<
failed_methods
.
length
;
i
+=
1
)
{
}
error_message
+=
(
"
\n
"
+
failed_methods
[
i
]);
throw
new
Error
(
error_message
);
}
}
defer
.
resolve
(
"
Success
"
);
throw
new
Error
(
error_message
);
}
catch
(
error
)
{
defer
.
reject
(
error
);
}
}
return
defer
.
promise
;
return
"
Success
"
;
}
}
function
verifyAllMethod
(
interface_method_list
,
gadget_method_list
)
{
function
verifyAllMethod
(
interface_method_list
,
gadget_method_list
)
{
//to verify all methods of gadget and interface.
//to verify all methods of gadget and interface.
var
defer
=
RSVP
.
defer
();
return
new
RSVP
.
Queue
()
return
new
RSVP
.
Queue
()
.
push
(
function
()
{
.
push
(
function
()
{
return
verifyAllMethodDeclared
(
interface_method_list
,
return
verifyAllMethodDeclared
(
interface_method_list
,
gadget_method_list
[
0
]);
gadget_method_list
[
0
]);
})
})
;
/* Commented till figure out the way to fetch the argument length of a
/* Commented till figure out the way to fetch the argument length of a
defined function.
defined function.
.push(function() {
.push(function() {
...
@@ -370,54 +341,29 @@
...
@@ -370,54 +341,29 @@
gadget_method_list[1]);
gadget_method_list[1]);
})
})
*/
*/
.
push
(
function
()
{
defer
.
resolve
(
"
Success
"
);
return
defer
.
promise
;
},
function
(
error
)
{
defer
.
reject
(
error
);
return
defer
.
promise
;
});
}
}
rJS
(
window
)
rJS
(
window
)
.
ready
(
function
(
g
)
{
g
.
props
=
{};
})
.
declareMethod
(
"
getVerifyGadget
"
,
function
(
gadget_url
)
{
.
declareMethod
(
"
getVerifyGadget
"
,
function
(
gadget_url
)
{
var
interface_gadget
=
this
,
var
interface_gadget
=
this
;
defer
=
RSVP
.
defer
();
return
interface_gadget
.
declareGadget
(
gadget_url
,
{
return
new
RSVP
.
Queue
()
scope
:
gadget_url
.
push
(
function
()
{
})
return
interface_gadget
.
declareGadget
(
gadget_url
,
{
scope
:
gadget_url
});
})
.
push
(
function
()
{
.
push
(
function
()
{
return
interface_gadget
.
getDeclaredGadget
(
gadget_url
);
return
interface_gadget
.
getDeclaredGadget
(
gadget_url
);
},
function
(
error
)
{
},
function
(
error
)
{
var
message
=
"
Error with loading the gadget.
\n
"
;
var
message
=
"
Error with loading the gadget.
\n
"
;
error
.
message
=
message
+
error
.
message
;
error
.
message
=
message
+
error
.
message
;
defer
.
reject
(
error
);
throw
error
;
return
defer
.
promise
;
});
});
})
})
.
declareMethod
(
"
getDeclaredGadgetInterfaceList
"
,
function
(
gadget_data
)
{
.
declareMethod
(
"
getDeclaredGadgetInterfaceList
"
,
function
(
gadget_data
)
{
var
defer
=
RSVP
.
defer
();
if
(
gadget_data
.
constructor
===
String
)
{
return
new
RSVP
.
Queue
()
return
getInterfaceListFromURL
(
gadget_data
);
.
push
(
function
()
{
}
if
(
gadget_data
.
constructor
===
String
)
{
return
gadget_data
.
getInterfaceList
();
return
getInterfaceListFromURL
(
gadget_data
);
}
return
gadget_data
.
getInterfaceList
();
})
.
push
(
function
(
interface_list
)
{
return
interface_list
;
},
function
(
error
)
{
defer
.
reject
(
error
);
return
defer
.
promise
;
});
})
})
.
declareMethod
(
"
getDeclaredGadgetMethodList
"
,
function
(
gadget
)
{
.
declareMethod
(
"
getDeclaredGadgetMethodList
"
,
function
(
gadget
)
{
...
@@ -443,27 +389,17 @@
...
@@ -443,27 +389,17 @@
})
})
.
declareMethod
(
"
getGadgetListFromAppcache
"
,
function
(
appcache_url
)
{
.
declareMethod
(
"
getGadgetListFromAppcache
"
,
function
(
appcache_url
)
{
var
defer
=
RSVP
.
defer
();
return
new
RSVP
.
Queue
()
return
new
RSVP
.
Queue
()
.
push
(
function
()
{
.
push
(
function
()
{
return
fetchAppcacheData
(
appcache_url
);
return
fetchAppcacheData
(
appcache_url
);
})
})
.
push
(
function
(
filename_list
)
{
.
push
(
function
(
filename_list
)
{
return
filterGadgetList
(
filename_list
);
return
filterGadgetList
(
filename_list
);
})
.
push
(
function
(
filtered_gadget_list
)
{
return
filtered_gadget_list
;
},
function
(
error
)
{
defer
.
reject
(
error
);
return
defer
.
promise
;
});
});
})
})
.
declareMethod
(
"
getAbsoluteURL
"
,
function
(
gadget
,
url
)
{
.
declareMethod
(
"
getAbsoluteURL
"
,
function
(
gadget
,
url
)
{
return
new
RSVP
.
Queue
()
return
gadget
.
getPath
()
.
push
(
function
()
{
return
gadget
.
getPath
();
})
.
push
(
function
(
base_url
)
{
.
push
(
function
(
base_url
)
{
return
rJS
.
getAbsoluteURL
(
url
,
base_url
);
return
rJS
.
getAbsoluteURL
(
url
,
base_url
);
});
});
...
@@ -474,8 +410,7 @@
...
@@ -474,8 +410,7 @@
name
:
""
,
name
:
""
,
description
:
""
,
description
:
""
,
method_list
:
[]
method_list
:
[]
},
};
defer
=
RSVP
.
defer
();
return
new
RSVP
.
Queue
()
return
new
RSVP
.
Queue
()
.
push
(
function
()
{
.
push
(
function
()
{
return
ajax
(
interface_url
);
return
ajax
(
interface_url
);
...
@@ -483,9 +418,9 @@
...
@@ -483,9 +418,9 @@
.
push
(
function
(
xhr
)
{
.
push
(
function
(
xhr
)
{
var
doc
=
(
new
DOMParser
()).
parseFromString
(
xhr
.
responseText
,
var
doc
=
(
new
DOMParser
()).
parseFromString
(
xhr
.
responseText
,
'
text/html
'
).
body
,
'
text/html
'
).
body
,
dl_list
=
doc
.
getElementsByTagName
(
'
dl
'
),
dl_list
=
doc
.
querySelectorAll
(
'
dl
'
),
dt_list
=
doc
.
getElementsByTagName
(
'
dt
'
),
dt_list
=
doc
.
querySelectorAll
(
'
dt
'
),
dd_list
=
doc
.
getElementsByTagName
(
'
dd
'
),
dd_list
=
doc
.
querySelectorAll
(
'
dd
'
),
method_len
=
dl_list
.
length
-
1
,
method_len
=
dl_list
.
length
-
1
,
dt_count
=
0
,
dt_count
=
0
,
dl_count
=
1
,
dl_count
=
1
,
...
@@ -494,16 +429,16 @@
...
@@ -494,16 +429,16 @@
argument_len
,
argument_len
,
j
,
j
,
argument_item
;
argument_item
;
interface_data
.
name
=
doc
.
getElementsByTagName
(
'
h1
'
)[
0
]
.
innerHTML
;
interface_data
.
name
=
doc
.
querySelector
(
'
h1
'
)
.
innerHTML
;
interface_data
.
description
=
interface_data
.
description
=
doc
.
getElementsByTagName
(
'
h3
'
)[
0
]
.
innerHTML
;
doc
.
querySelector
(
'
h3
'
)
.
innerHTML
;
for
(
i
=
0
;
i
<
method_len
;
i
+=
1
)
{
for
(
i
=
0
;
i
<
method_len
;
i
+=
1
)
{
method
=
{
method
=
{
name
:
dt_list
[
dt_count
].
innerHTML
,
name
:
dt_list
[
dt_count
].
innerHTML
,
description
:
dd_list
[
dt_count
].
innerHTML
,
description
:
dd_list
[
dt_count
].
innerHTML
,
argument_list
:
[]
argument_list
:
[]
};
};
argument_len
=
dl_list
[
dl_count
].
getElementsByTagName
(
'
dt
'
)
argument_len
=
dl_list
[
dl_count
].
querySelectorAll
(
'
dt
'
)
.
length
;
.
length
;
dt_count
+=
1
;
dt_count
+=
1
;
dl_count
+=
1
;
dl_count
+=
1
;
...
@@ -524,19 +459,14 @@
...
@@ -524,19 +459,14 @@
},
function
(
error
)
{
},
function
(
error
)
{
var
message
=
"
Error with loading the interface data.
\n
"
;
var
message
=
"
Error with loading the interface data.
\n
"
;
error
.
message
=
message
+
generateErrorMessage
(
error
);
error
.
message
=
message
+
generateErrorMessage
(
error
);
defer
.
reject
(
error
);
throw
error
;
return
defer
.
promise
;
});
});
})
})
.
declareMethod
(
"
getDefinedInterfaceMethodList
"
,
function
(
interface_url
)
{
.
declareMethod
(
"
getDefinedInterfaceMethodList
"
,
function
(
interface_url
)
{
var
defer
=
RSVP
.
defer
();
return
this
.
getInterfaceData
(
interface_url
)
return
this
.
getInterfaceData
(
interface_url
)
.
push
(
function
(
interface_data
)
{
.
push
(
function
(
interface_data
)
{
return
interface_data
.
method_list
;
return
interface_data
.
method_list
;
},
function
(
error
)
{
defer
.
reject
(
error
);
return
defer
.
promise
;
});
});
})
})
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment