forked from ungleich-public/cdist
		
	[type/__uci] Only generate __uci_commit if changes are required
This commit is contained in:
		
					parent
					
						
							
								e30ecdda53
							
						
					
				
			
			
				commit
				
					
						55e7b32449
					
				
			
		
					 1 changed files with 24 additions and 2 deletions
				
			
		| 
						 | 
					@ -18,9 +18,12 @@
 | 
				
			||||||
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
 | 
					# along with cdist. If not, see <http://www.gnu.org/licenses/>.
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					in_list() { printf '%s\n' "$@" | { grep -qxF "$(read -r ndl; echo "${ndl}")"; } }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
os=$(cat "${__global:?}/explorer/os")
 | 
					os=$(cat "${__global:?}/explorer/os")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					state_is=$(cat "${__object:?}/explorer/state")
 | 
				
			||||||
 | 
					state_should=$(cat "${__object:?}/parameter/state")
 | 
				
			||||||
transaction_name=$(cat "${__object:?}/parameter/transaction")
 | 
					transaction_name=$(cat "${__object:?}/parameter/transaction")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
case ${os}
 | 
					case ${os}
 | 
				
			||||||
| 
						 | 
					@ -35,6 +38,25 @@ in
 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
esac
 | 
					esac
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					changes_required=false
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Make sure the changes are being commited
 | 
					case ${state_should}
 | 
				
			||||||
require=${__object_name:?} __uci_commit "${transaction_name}"
 | 
					in
 | 
				
			||||||
 | 
						(present)
 | 
				
			||||||
 | 
							# NOTE: order is ignored so rearranged is also fine.
 | 
				
			||||||
 | 
							in_list "${state_is}" 'present' 'rearranged' || changes_required=true
 | 
				
			||||||
 | 
							;;
 | 
				
			||||||
 | 
						(absent)
 | 
				
			||||||
 | 
							in_list "${state_is}" 'absent' || changes_required=true
 | 
				
			||||||
 | 
							;;
 | 
				
			||||||
 | 
						(*)
 | 
				
			||||||
 | 
							printf 'Invalid --state: %s\n' "${state_should}" >&2
 | 
				
			||||||
 | 
							exit 1
 | 
				
			||||||
 | 
							;;
 | 
				
			||||||
 | 
					esac
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					if ${changes_required}
 | 
				
			||||||
 | 
					then
 | 
				
			||||||
 | 
						# Make sure the changes are being committed
 | 
				
			||||||
 | 
						require=${__object_name:?} __uci_commit "${transaction_name}"
 | 
				
			||||||
 | 
					fi
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue